1 dump('entering util.list.js\n');
3 if (typeof main == 'undefined') main = {};
4 util.list = function (id) {
6 this.node = document.getElementById(id);
8 if (!this.node) throw('Could not find element ' + id);
9 switch(this.node.nodeName) {
13 throw(this.node.nodeName + ' not yet supported'); break;
14 default: throw(this.node.nodeName + ' not supported'); break;
17 JSAN.use('util.error'); this.error = new util.error();
22 util.list.prototype = {
24 'init' : function (params) {
26 JSAN.use('util.widgets');
28 if (typeof params.map_row_to_column == 'function') this.map_row_to_column = params.map_row_to_column;
29 if (typeof params.retrieve_row == 'function') this.retrieve_row = params.retrieve_row;
31 this.prebuilt = false;
32 if (typeof params.prebuilt != 'undefined') this.prebuilt = params.prebuilt;
34 if (typeof params.columns == 'undefined') throw('util.list.init: No columns');
35 this.columns = params.columns;
37 switch(this.node.nodeName) {
38 case 'tree' : this._init_tree(params); break;
39 case 'listbox' : this._init_listbox(params); break;
40 default: throw('NYI: Need ._init() for ' + this.node.nodeName); break;
44 '_init_tree' : function (params) {
48 this.treechildren = this.node.lastChild;
51 var treecols = document.createElement('treecols');
52 this.node.appendChild(treecols);
54 for (var i = 0; i < this.columns.length; i++) {
55 var treecol = document.createElement('treecol');
56 for (var j in this.columns[i]) {
57 treecol.setAttribute(j,this.columns[i][j]);
59 treecols.appendChild(treecol);
60 var splitter = document.createElement('splitter');
61 splitter.setAttribute('class','tree-splitter');
62 treecols.appendChild(splitter);
65 var treechildren = document.createElement('treechildren');
66 this.node.appendChild(treechildren);
67 this.treechildren = treechildren;
69 if (typeof params.on_select == 'function') {
70 this.node.addEventListener(
76 if (typeof params.on_click == 'function') {
77 this.node.addEventListener(
84 this.node.addEventListener(
86 function(ev) { obj.detect_visible(); },
90 this.node.addEventListener(
92 function(ev) { obj.auto_retrieve(); },
95 this.node.addEventListener(
97 function(ev) { obj.auto_retrieve(); },
100 window.addEventListener(
102 function(ev) { obj.auto_retrieve(); },
105 /* FIXME -- find events on scrollbar to trigger this */
106 //obj.detect_visible_polling();
108 var scrollbar = document.getAnonymousNodes( document.getAnonymousNodes(this.node)[1] )[1];
109 var slider = document.getAnonymousNodes( scrollbar )[2];
110 alert('scrollbar = ' + scrollbar.nodeName + ' grippy = ' + slider.nodeName);
111 scrollbar.addEventListener('click',function(){alert('sb click');},false);
112 scrollbar.addEventListener('command',function(){alert('sb command');},false);
113 scrollbar.addEventListener('scroll',function(){alert('sb scroll');},false);
114 slider.addEventListener('click',function(){alert('slider click');},false);
115 slider.addEventListener('command',function(){alert('slider command');},false);
116 slider.addEventListener('scroll',function(){alert('slider scroll');},false);
118 this.node.addEventListener('scroll',function(){ obj.auto_retrieve(); },false);
121 '_init_listbox' : function (params) {
124 var listhead = document.createElement('listhead');
125 this.node.appendChild(listhead);
127 var listcols = document.createElement('listcols');
128 this.node.appendChild(listcols);
130 for (var i = 0; i < this.columns.length; i++) {
131 var listheader = document.createElement('listheader');
132 listhead.appendChild(listheader);
133 var listcol = document.createElement('listcol');
134 listcols.appendChild(listcol);
135 for (var j in this.columns[i]) {
136 listheader.setAttribute(j,this.columns[i][j]);
137 listcol.setAttribute(j,this.columns[i][j]);
143 'clear' : function (params) {
144 switch (this.node.nodeName) {
145 case 'tree' : this._clear_tree(params); break;
146 case 'listbox' : this._clear_listbox(params); break;
147 default: throw('NYI: Need .clear() for ' + this.node.nodeName); break;
149 this.error.sdump('D_LIST','Clearing list ' + this.node.getAttribute('id') + '\n');
152 '_clear_tree' : function(params) {
154 if (obj.error.sdump_levels.D_LIST_DUMP_ON_CLEAR) {
155 obj.error.sdump('D_LIST_DUMP_ON_CLEAR',obj.dump());
157 if (obj.error.sdump_levels.D_LIST_DUMP_WITH_KEYS_ON_CLEAR) {
158 obj.error.sdump('D_LIST_DUMP_WITH_KEYS_ON_CLEAR',obj.dump_with_keys());
160 while (obj.treechildren.lastChild) obj.treechildren.removeChild( obj.treechildren.lastChild );
163 '_clear_listbox' : function(params) {
165 var nl = this.node.getElementsByTagName('listitem');
166 for (var i = 0; i < nl.length; i++) {
169 for (var i = 0; i < items.length; i++) {
170 this.node.removeChild(items[i]);
174 'append' : function (params) {
176 switch (this.node.nodeName) {
177 case 'tree' : rnode = this._append_to_tree(params); break;
178 case 'listbox' : rnode = this._append_to_listbox(params); break;
179 default: throw('NYI: Need .append() for ' + this.node.nodeName); break;
181 if (rnode && params.attributes) {
182 for (var i in params.attributes) {
183 rnode.setAttribute(i,params.attributes[i]);
189 '_append_to_tree' : function (params) {
193 if (typeof params.row == 'undefined') throw('util.list.append: Object must contain a row');
195 var s = ('util.list.append: params = ' + (params) + '\n');
197 var treechildren_node = this.treechildren;
199 if (params.node && params.node.nodeName == 'treeitem') {
200 params.node.setAttribute('container','true'); /* params.node.setAttribute('open','true'); */
201 if (params.node.lastChild.nodeName == 'treechildren') {
202 treechildren_node = params.node.lastChild;
204 treechildren_node = document.createElement('treechildren');
205 params.node.appendChild(treechildren_node);
209 var treeitem = document.createElement('treeitem');
210 treeitem.setAttribute('retrieve_id',params.retrieve_id);
211 treechildren_node.appendChild( treeitem );
212 var treerow = document.createElement('treerow');
213 treeitem.appendChild( treerow );
215 s += ('tree = ' + this.node + ' treechildren = ' + treechildren_node + '\n');
216 s += ('treeitem = ' + treeitem + ' treerow = ' + treerow + '\n');
218 if (typeof params.retrieve_row == 'function' || typeof this.retrieve_row == 'function') {
220 treerow.setAttribute('retrieve_id',params.retrieve_id);
221 obj.put_retrieving_label(treerow);
222 treerow.addEventListener(
225 //dump('fleshing = ' + params.retrieve_id + '\n');
227 params.row_node = treeitem;
228 params.on_retrieve = function(p) {
231 obj._map_row_to_treecell(p,treerow);
233 alert('fixme2: ' + E);
237 if (typeof params.retrieve_row == 'function') {
239 params.retrieve_row( params );
243 if (typeof obj.retrieve_row == 'function') {
245 obj.retrieve_row( params );
250 treerow.setAttribute('retrieved','true');
257 util.widgets.dispatch('flesh',treerow);
262 obj.put_retrieving_label(treerow);
263 treerow.addEventListener(
266 //dump('fleshing anon\n');
267 obj._map_row_to_treecell(params,treerow);
268 treerow.setAttribute('retrieved','true');
275 util.widgets.dispatch('flesh',treerow);
280 this.error.sdump('D_LIST',s);
282 setTimeout( function() { obj.auto_retrieve(); }, 0 );
287 'put_retrieving_label' : function(treerow) {
292 dump('put_retrieving_label. columns = ' + js2JSON(obj.columns) + '\n');
293 while( obj.columns[cols_idx] && obj.columns[cols_idx].hidden && obj.columns[cols_idx].hidden == 'true') {
294 dump('\t' + cols_idx);
295 var treecell = document.createElement('treecell');
296 treerow.appendChild(treecell);
300 for (var i = 0; i < obj.columns.length; i++) {
301 var treecell = document.createElement('treecell'); treecell.setAttribute('label','Retrieving...');
302 treerow.appendChild(treecell);
305 dump('\t' + cols_idx + '\n');
312 'detect_visible' : function() {
315 //dump('detect_visible obj.node = ' + obj.node + '\n');
316 /* FIXME - this is a hack.. if the implementation of tree changes, this could break */
317 var scrollbar = document.getAnonymousNodes( document.getAnonymousNodes(obj.node)[1] )[1];
318 var curpos = scrollbar.getAttribute('curpos');
319 var maxpos = scrollbar.getAttribute('maxpos');
320 //alert('curpos = ' + curpos + ' maxpos = ' + maxpos + ' obj.curpos = ' + obj.curpos + ' obj.maxpos = ' + obj.maxpos + '\n');
321 if ((curpos != obj.curpos) || (maxpos != obj.maxpos)) {
322 if ( obj.auto_retrieve() > 0 ) {
323 obj.curpos = curpos; obj.maxpos = maxpos;
326 } catch(E) { alert(E); }
329 'detect_visible_polling' : function() {
331 //alert('detect_visible_polling');
333 obj.detect_visible();
334 setTimeout(function() { try { obj.detect_visible_polling(); } catch(E) { alert(E); } },2000);
340 'auto_retrieve' : function () {
342 if (!obj.auto_retrieve_in_progress) {
343 obj.auto_retrieve_in_progress = true;
347 //alert('auto_retrieve\n');
349 var startpos = obj.node.treeBoxObject.getFirstVisibleRow();
350 var endpos = obj.node.treeBoxObject.getLastVisibleRow();
351 if (startpos > endpos) endpos = obj.node.treeBoxObject.getPageLength();
352 //dump('startpos = ' + startpos + ' endpos = ' + endpos + '\n');
353 for (var i = startpos; i < endpos + 2; i++) {
355 //dump('trying index ' + i + '\n');
356 var item = obj.node.contentView.getItemAtIndex(i).firstChild;
357 if (item && item.getAttribute('retrieved') != 'true' ) {
358 //dump('\tgot an unfleshed item = ' + item + ' = ' + item.nodeName + '\n');
359 util.widgets.dispatch('flesh',item); count++;
362 //dump(i + ' : ' + E + '\n');
365 obj.auto_retrieve_in_progress = false;
367 } catch(E) { alert(E); }
373 '_append_to_listbox' : function (params) {
377 if (typeof params.row == 'undefined') throw('util.list.append: Object must contain a row');
379 var s = ('util.list.append: params = ' + (params) + '\n');
381 var listitem = document.createElement('listitem');
383 s += ('listbox = ' + this.node + ' listitem = ' + listitem + '\n');
385 if (typeof params.retrieve_row == 'function' || typeof this.retrieve_row == 'function') {
389 listitem.setAttribute('retrieve_id',params.retrieve_id);
390 //FIXME//Make async and fire when row is visible in list
393 params.row_node = listitem;
394 params.on_retrieve = function(row) {
396 obj._map_row_to_listcell(params,listitem);
397 obj.node.appendChild( listitem );
400 if (typeof params.retrieve_row == 'function') {
402 row = params.retrieve_row( params );
406 if (typeof obj.retrieve_row == 'function') {
408 row = obj.retrieve_row( params );
415 this._map_row_to_listcell(params,listitem);
416 this.node.appendChild( listitem );
419 this.error.sdump('D_LIST',s);
424 '_map_row_to_treecell' : function(params,treerow) {
426 util.widgets.remove_children(treerow);
427 for (var i = 0; i < this.columns.length; i++) {
428 var treecell = document.createElement('treecell');
430 if (params.skip_columns && (params.skip_columns.indexOf(i) != -1)) {
431 treecell.setAttribute('label',label);
432 treerow.appendChild( treecell );
433 s += ('treecell = ' + treecell + ' with label = ' + label + '\n');
436 if (params.skip_all_columns_except && (params.skip_all_columns_except.indexOf(i) == -1)) {
437 treecell.setAttribute('label',label);
438 treerow.appendChild( treecell );
439 s += ('treecell = ' + treecell + ' with label = ' + label + '\n');
442 if (typeof params.map_row_to_column == 'function') {
444 label = params.map_row_to_column(params.row,this.columns[i]);
448 if (typeof this.map_row_to_column == 'function') {
450 label = this.map_row_to_column(params.row,this.columns[i]);
454 throw('No map_row_to_column function');
458 treecell.setAttribute('label',label);
459 treerow.appendChild( treecell );
460 s += ('treecell = ' + treecell + ' with label = ' + label + '\n');
462 this.error.sdump('D_LIST',s);
465 '_map_row_to_listcell' : function(params,listitem) {
467 for (var i = 0; i < this.columns.length; i++) {
469 if (typeof params.map_row_to_column == 'function') {
471 value = params.map_row_to_column(params.row,this.columns[i]);
475 if (typeof this.map_row_to_column == 'function') {
477 value = this.map_row_to_column(params.row,this.columns[i]);
480 if (typeof value == 'string' || typeof value == 'number') {
481 var listcell = document.createElement('listcell');
482 listcell.setAttribute('label',value);
483 listitem.appendChild(listcell);
484 s += ('listcell = ' + listcell + ' with label = ' + value + '\n');
486 listitem.appendChild(value);
487 s += ('listcell = ' + value + ' is really a ' + value.nodeName + '\n');
490 this.error.sdump('D_LIST',s);
493 'retrieve_selection' : function(params) {
494 switch(this.node.nodeName) {
495 case 'tree' : return this._retrieve_selection_from_tree(params); break;
496 default: throw('NYI: Need ._retrieve_selection_from_() for ' + this.node.nodeName); break;
500 '_retrieve_selection_from_tree' : function(params) {
502 var start = new Object();
503 var end = new Object();
504 var numRanges = this.node.view.selection.getRangeCount();
505 for (var t=0; t<numRanges; t++){
506 this.node.view.selection.getRangeAt(t,start,end);
507 for (var v=start.value; v<=end.value; v++){
508 var i = this.node.contentView.getItemAtIndex(v);
515 'dump' : function(params) {
516 switch(this.node.nodeName) {
517 case 'tree' : return this._dump_tree(params); break;
518 default: throw('NYI: Need .dump() for ' + this.node.nodeName); break;
522 '_dump_tree' : function(params) {
524 for (var i = 0; i < this.treechildren.childNodes.length; i++) {
526 var treeitem = this.treechildren.childNodes[i];
527 var treerow = treeitem.firstChild;
528 for (var j = 0; j < treerow.childNodes.length; j++) {
529 row.push( treerow.childNodes[j].getAttribute('label') );
536 'dump_with_keys' : function(params) {
537 switch(this.node.nodeName) {
538 case 'tree' : return this._dump_tree_with_keys(params); break;
539 default: throw('NYI: Need .dump_with_keys() for ' + this.node.nodeName); break;
544 '_dump_tree_with_keys' : function(params) {
547 for (var i = 0; i < this.treechildren.childNodes.length; i++) {
549 var treeitem = this.treechildren.childNodes[i];
550 var treerow = treeitem.firstChild;
551 for (var j = 0; j < treerow.childNodes.length; j++) {
552 row[ obj.columns[j].id ] = treerow.childNodes[j].getAttribute('label');
559 'dump_retrieve_ids' : function(params) {
560 switch(this.node.nodeName) {
561 case 'tree' : return this._dump_retrieve_ids_tree(params); break;
562 default: throw('NYI: Need .dump_retrieve_ids() for ' + this.node.nodeName); break;
566 '_dump_retrieve_ids_tree' : function(params) {
568 for (var i = 0; i < this.treechildren.childNodes.length; i++) {
569 var treeitem = this.treechildren.childNodes[i];
570 dump.push( treeitem.getAttribute('retrieve_id') );
576 dump('exiting util.list.js\n');