RetroZilla/extensions/inspector/resources/content/search/inSearchTreeBuilder.js
2015-10-20 23:03:22 -04:00

142 lines
4.3 KiB
JavaScript

/* ***** BEGIN LICENSE BLOCK *****
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*
* The Original Code is mozilla.org code.
*
* The Initial Developer of the Original Code is
* Netscape Communications Corporation.
* Portions created by the Initial Developer are Copyright (C) 2001
* the Initial Developer. All Rights Reserved.
*
* Contributor(s):
* Joe Hewitt <hewitt@netscape.com> (original author)
*
* Alternatively, the contents of this file may be used under the terms of
* either the GNU General Public License Version 2 or later (the "GPL"), or
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
* in which case the provisions of the GPL or the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of either the GPL or the LGPL, and not to allow others to
* use your version of this file under the terms of the MPL, indicate your
* decision by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL or the LGPL. If you do not delete
* the provisions above, a recipient may use your version of this file under
* the terms of any one of the MPL, the GPL or the LGPL.
*
* ***** END LICENSE BLOCK ***** */
/***************************************************************
* inSearchTreeBuilder ------------------------------------------
* Utility for automatically building an rdf template and xul
* tree structure from a tabular data set.
* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
* REQUIRED IMPORTS:
* chrome://inspector/content/jsutil/inTreeBuilder.js
****************************************************************/
//////////// global variables /////////////////////
//////////// global constants ////////////////////
////////////////////////////////////////////////////////////////////////////
//// class inSearchTreeBuilder
function inSearchTreeBuilder(aTree, aNameSpace, aArcName)
{
this.mBuilder = new inTreeTableBuilder(aTree, aNameSpace, aArcName);
aTree.setAttribute("ref", "inspector:searchResults");
this.mBuilder.initialize();
}
inSearchTreeBuilder.prototype =
{
mCommited: false,
mBuilder: null,
mModule: null,
mCommitted: false,
get tree() { return this.mBuilder.tree },
set tree(aVal) { this.mBuilder.tree = aVal },
get isIconic() { return this.mBuilder.isIconic },
set isIconic(aVal) { this.mBuilder.isIconic = aVal },
get module() { return this.mModule },
set module(aModule)
{
if (aModule != this.mModule) {
if (this.mModule) {
if (this.mCommitted)
this.mBuilder.tree.database.RemoveDataSource(this.mModule.datasource);
this.mCommitted = false;
this.mModule.removeSearchObserver(this);
this.mBuilder.reset();
}
this.mModule = aModule;
if (aModule) {
aModule.addSearchObserver(this);
this.isIconic = aModule.defaultIconURL ? true : false;
for (var i = 0; i < aModule.columnCount; i++)
this.mBuilder.addColumn(aModule.getColumn(i));
this.mBuilder.build();
}
}
},
getSelectedSearchIndex: function()
{
var tItem = this.mSearchTree.selectedItems[0];
return this.mSearchTree.getIndexOfItem(tItem);
},
onSearchStart: function(aProcess)
{
if (this.mCommitted)
this.mBuilder.tree.database.RemoveDataSource(this.mModule.datasource);
},
onSearchResult: function(aProcess)
{
},
onSearchEnd: function(aProcess, aResult)
{
this.mBuilder.tree.database.AddDataSource(this.mModule.datasource);
this.mBuilder.buildContent();
this.mCommitted = true;
},
onSearchError: function(aProcess, aMessage)
{
},
reset: function()
{
this.mBuilder.reset();
},
buildContent: function()
{
this.mBuilder.buildContent();
}
};