Fix saving of new items

Added Scholar.Folders.reloadAll(), used after saving a new item or moving one to refresh isEmpty

Fixed bug where items without creators wouldn't show
This commit is contained in:
Dan Stillman 2006-05-18 21:55:43 +00:00
parent d398339997
commit 7800f7a39b

View file

@ -76,7 +76,8 @@ Scholar.Item.prototype.loadFromID = function(id){
+ 'LEFT JOIN treeStructure TS ON (I.itemID=TS.id AND isFolder=0) ' + 'LEFT JOIN treeStructure TS ON (I.itemID=TS.id AND isFolder=0) '
+ 'LEFT JOIN itemCreators IC ON (I.itemID=IC.itemID) ' + 'LEFT JOIN itemCreators IC ON (I.itemID=IC.itemID) '
+ 'LEFT JOIN creators C ON (IC.creatorID=C.creatorID) ' + 'LEFT JOIN creators C ON (IC.creatorID=C.creatorID) '
+ 'WHERE itemID=' + id + ' AND IC.orderIndex=0'; + 'WHERE itemID=' + id
+ ' AND (IC.orderIndex=0 OR IC.orderIndex IS NULL)';
var row = Scholar.DB.rowQuery(sql); var row = Scholar.DB.rowQuery(sql);
this.loadFromRow(row); this.loadFromRow(row);
} }
@ -323,9 +324,8 @@ Scholar.Item.prototype.setPosition = function(newFolder, newPos, isNew){
var oldFolder = this.getField('parentFolderID'); var oldFolder = this.getField('parentFolderID');
var oldPos = this.getField('orderIndex'); var oldPos = this.getField('orderIndex');
if (this.getID()){ if (this.getID()){
if (newFolder==oldFolder && newPos==oldPos){ if (!isNew && newFolder==oldFolder && newPos==oldPos){
return true; return true;
} }
@ -363,13 +363,13 @@ Scholar.Item.prototype.setPosition = function(newFolder, newPos, isNew){
// If a new item, insert // If a new item, insert
if (isNew){ if (isNew){
sql = 'INSERT INTO treeStructure SET id=' + this.getID() + ', ' + var sql = 'INSERT INTO treeStructure '
'isFolder=0, orderIndex=' + newPos + ', ' + + '(id, isFolder, orderIndex, parentFolderID) VALUES ('
'parentFolderID=' + newFolder; + this.getID() + ', 0, ' + newPos + ', ' + newFolder + ')';
} }
// Otherwise update // Otherwise update
else { else {
sql = 'UPDATE treeStructure SET parentFolderID=' + newFolder + var sql = 'UPDATE treeStructure SET parentFolderID=' + newFolder +
', orderIndex=' + newPos + ' WHERE id=' + this.getID() + ', orderIndex=' + newPos + ' WHERE id=' + this.getID() +
" AND isFolder=0;\n"; " AND isFolder=0;\n";
} }
@ -385,6 +385,7 @@ Scholar.Item.prototype.setPosition = function(newFolder, newPos, isNew){
if (this.getID() && !isNew){ if (this.getID() && !isNew){
Scholar.Items.reloadAll(); Scholar.Items.reloadAll();
Scholar.Folders.reloadAll(); // needed to recheck isEmpty
} }
return true; return true;
} }
@ -550,7 +551,7 @@ Scholar.Item.prototype.save = function(){
} }
catch (e){ catch (e){
Scholar.DB.rollbackTransaction(); Scholar.DB.rollbackTransaction();
throw (e); throw(e);
} }
} }
@ -633,11 +634,18 @@ Scholar.Item.prototype.save = function(){
} }
sql = sql.substring(0,sql.length-1) + ");\n"; sql = sql.substring(0,sql.length-1) + ");\n";
// Save basic data to items table and get new ID
var itemID = Scholar.DB.query(sql,sqlValues); var itemID = Scholar.DB.query(sql,sqlValues);
this._data['itemID'] = itemID;
// Set itemData
if (this._changedItemData.length){ if (this._changedItemData.length){
sql = ''; sql = '';
for (fieldID in this._changedItemData.items){ for (fieldID in this._changedItemData.items){
if (!this.getField(fieldID)){
continue;
}
sql += 'INSERT INTO itemData VALUES (' + sql += 'INSERT INTO itemData VALUES (' +
itemID + ',' + fieldID + ','; itemID + ',' + fieldID + ',';
if (Scholar.ItemFields.isInteger(fieldID)){ if (Scholar.ItemFields.isInteger(fieldID)){
@ -648,12 +656,11 @@ Scholar.Item.prototype.save = function(){
} }
sql += ");\n"; sql += ");\n";
} }
}
if (sql){
Scholar.DB.query(sql); Scholar.DB.query(sql);
}
}
// Set the position of the new item // Set the position of the new item
var newFolder = this.getField('parentFolderID') var newFolder = this.getField('parentFolderID')
@ -664,14 +671,15 @@ Scholar.Item.prototype.save = function(){
this.setPosition(newFolder, newPos, true); this.setPosition(newFolder, newPos, true);
// TODO: reload Folder or set the empty flag to false manually
// in case this was the first item in a folder
Scholar.DB.commitTransaction(); Scholar.DB.commitTransaction();
// Reload folders to update isEmpty,
// in case this was the first item in a folder
Scholar.Folders.reloadAll();
} }
catch (e){ catch (e){
Scholar.DB.rollbackTransaction(); Scholar.DB.rollbackTransaction();
throw (e); throw(e);
} }
} }
@ -951,7 +959,7 @@ Scholar.Items = new function(){
+ 'LEFT JOIN treeStructure TS ON (I.itemID=TS.id AND isFolder=0) ' + 'LEFT JOIN treeStructure TS ON (I.itemID=TS.id AND isFolder=0) '
+ 'LEFT JOIN itemCreators IC ON (I.itemID=IC.itemID) ' + 'LEFT JOIN itemCreators IC ON (I.itemID=IC.itemID) '
+ 'LEFT JOIN creators C ON (IC.creatorID=C.creatorID) ' + 'LEFT JOIN creators C ON (IC.creatorID=C.creatorID) '
+ 'WHERE IC.orderIndex=0'; + 'WHERE IC.orderIndex=0 OR IC.orderIndex IS NULL';
if (arguments[0]!='all'){ if (arguments[0]!='all'){
sql += ' AND I.itemID IN (' + Scholar.join(arguments,',') + ')'; sql += ' AND I.itemID IN (' + Scholar.join(arguments,',') + ')';
@ -1041,6 +1049,7 @@ Scholar.Folders = new function(){
var _foldersLoaded = false; var _foldersLoaded = false;
this.get = get; this.get = get;
this.reloadAll = reloadAll;
/* /*
* Returns a Scholar.Folder object for a folderID * Returns a Scholar.Folder object for a folderID
@ -1053,6 +1062,11 @@ Scholar.Folders = new function(){
} }
function reloadAll(){
_folders = new Array();
_load();
}
function _load(){ function _load(){
var sql = "SELECT folderID, folderName, parentFolderID, " var sql = "SELECT folderID, folderName, parentFolderID, "
+ "(SELECT COUNT(*) FROM treeStructure WHERE " + "(SELECT COUNT(*) FROM treeStructure WHERE "