var ScholarLocalizedStrings; var myTreeView; var dynamicBox; Scholar.TreeView = function() { this._treebox = null; this._dataObjects = new Array(); this.rowCount = 0; } Scholar.TreeView.prototype.setTree = function(treebox) { if(this._treebox) return; this._treebox = treebox; var newRows = Scholar.Items.getTreeRows(); for(var i = 0; i < newRows.length; i++) this._insertItem(newRows[i], 0, i+1); //object ref, isContainerOpen, level this.rowCount = this._dataObjects.length; } Scholar.TreeView.prototype.getCellText = function(row, column) { var obj = this._getObjectAtRow(row); if(obj.isFolder()) { if(column.id == "title_column") return obj.getName(); else return ""; } else { if(column.id == "title_column") return obj.getField("title"); else if(column.id == "creator_column") return obj.getField("firstCreator"); else return obj.getField("source"); } } Scholar.TreeView.prototype.isContainer = function(row) { return this._getObjectAtRow(row).isFolder(); } Scholar.TreeView.prototype.isContainerOpen = function(row) { return this._dataObjects[row][1]; } Scholar.TreeView.prototype.isContainerEmpty = function(row) { return (this.isContainer(row) && this._getObjectAtRow(row).isEmpty()); } Scholar.TreeView.prototype.getLevel = function(row) { return this._dataObjects[row][2]; } Scholar.TreeView.prototype.getParentIndex = function(row) { var thisLevel = this.getLevel(row); if(thisLevel == 0) return -1; for(var i = row - 1; i >= 0; i--) if(this.getLevel(i) < thisLevel) return i; return -1; } Scholar.TreeView.prototype.hasNextSibling = function(row, afterIndex) { var thisLevel = this.getLevel(row); for(var i = afterIndex + 1; i < this.rowCount; i++) { var nextLevel = this.getLevel(i); if(nextLevel == thisLevel) return true; else if(nextLevel < thisLevel) return false; } } Scholar.TreeView.prototype.toggleOpenState = function(row) { var count = 0; //used to tell the tree how many rows were added/removed var thisLevel = this.getLevel(row); if(this.isContainerOpen(row)) { while((row + 1 < this._dataObjects.length) && (this.getLevel(row + 1) > thisLevel)) { this._deleteItem(row+1); count--; //count is negative when closing a container because we are removing rows } } else { var newRows = Scholar.Items.getTreeRows(this._getObjectAtRow(row).getID()); //Get children for(var i = 0; i < newRows.length; i++) { count++; this._insertItem(newRows[i], thisLevel+1, row+i+1); //insert new row } } this._dataObjects[row][1] = !this._dataObjects[row][1]; //toggle container open value this.rowCount = this._dataObjects.length; this._treebox.rowCountChanged(row, count); //tell treebox to repaint these } Scholar.TreeView.prototype.selectionChanged = function() { if(this.selection.count == 1 && !this.isContainer(this.selection.currentIndex)) { populateObjectPane(this._getObjectAtRow(this.selection.currentIndex)); document.getElementById('scholar-sidebar-object-pane').hidden = false; } else { document.getElementById('scholar-sidebar-object-pane').hidden = true; } } Scholar.TreeView.prototype._insertItem = function(item, level, beforeRow) { this._dataObjects.splice(beforeRow, 0, [item, false, level]); } Scholar.TreeView.prototype._deleteItem = function(row) { this._dataObjects.splice(row,1);; } Scholar.TreeView.prototype._getObjectAtRow = function(row) { return this._dataObjects[row][0]; } Scholar.TreeView.prototype.isSorted = function() { return false; } Scholar.TreeView.prototype.isSeparator = function(row) { return false; } Scholar.TreeView.prototype.isEditable = function(row, idx) { return false; } Scholar.TreeView.prototype.getRowProperties = function(row, prop) { } Scholar.TreeView.prototype.getColumnProperties = function(col, prop) { } Scholar.TreeView.prototype.getCellProperties = function(row, col, prop) { } Scholar.TreeView.prototype.getImageSrc = function(row, col) { } Scholar.TreeView.prototype.performAction = function(action) { } Scholar.TreeView.prototype.performActionOnCell = function(action, row, col) { } Scholar.TreeView.prototype.getProgressMode = function(row, col) { } /* DRAG AND DROP (IMPLEMENT LATER) Scholar.TreeView.prototype.canDrop = function(row, orient) { return !orient; } Scholar.TreeView.prototype.drop = function(row, orient) { } */ function populateObjectPane(thisRow) { removeDynamicRows(); var fieldNames = getFullFieldList(thisRow); for(var i = 0; i