]> git.evergreen-ils.org Git - working/Evergreen.git/blob - Open-ILS/xul/staff_client/chrome/content/OpenILS/data.js
Merge branch 'master' of git.evergreen-ils.org:Evergreen into template-toolkit-opac
[working/Evergreen.git] / Open-ILS / xul / staff_client / chrome / content / OpenILS / data.js
1 dump('entering OpenILS/data.js\n');
2
3 if (typeof OpenILS == 'undefined') OpenILS = {};
4 OpenILS.data = function () {
5
6     try {
7         /* We're going to turn this guy into a singleton, at least for a given window, and look for it in xulG */
8         if (! window.xulG) { window.xulG = {}; }
9         if (window.xulG._data) { return window.xulG._data; }
10
11         JSAN.use('util.error'); this.error = new util.error();
12         JSAN.use('util.network'); this.network = new util.network();
13     } catch(E) {
14         alert(location.href + '\nError in OpenILS.data constructor: ' + E);
15         throw(E);
16     }
17
18     window.xulG._data = this;
19     return this;
20 }
21
22 OpenILS.data.prototype = {
23
24     'list' : {},
25     'hash' : {},
26     'tree' : {},
27
28     'temp' : '',
29
30     'data_progress' : function(msg) {
31         try {
32             var x = document.getElementById('data_progress');
33             if (x) {
34                 x.appendChild( document.createTextNode( msg ) );
35             }
36         } catch(E) {
37             this.error.sdump('D_ERROR',msg + '\n' + E);
38         }
39     },
40
41     'init' : function (params) {
42
43         try {
44             if (params && params.via == 'stash') {    
45                 this.stash_retrieve();
46             } else {
47                 this.network_retrieve();
48             }
49         
50         } catch(E) {
51             this.error.sdump('D_ERROR','Error in OpenILS.data.init('
52                 +js2JSON(params)+'): ' + js2JSON(E) );
53         }
54
55
56     },
57
58     // This should be invoked only once per application, in a persistant window
59     'init_observer_functions' : function() {
60         try {
61             var obj = this;                // OpenILS.data
62             obj.observers = {};            //
63             obj.observers.id = 1;        // Unique id for each observer function added
64             obj.observers.id2path = {}; // Lookup for full_path via observer id
65             obj.observers.cache = {};    // Observer funcs go in here
66
67             // For a given path, this executes all the registered observer funcs
68             obj.observers.dispatch = function(full_path, old_value, new_value) {
69                 obj.error.sdump('D_OBSERVERS', 'entering observers.dispatch\nfull_path = ' + full_path + '\nold_value = ' + js2JSON(old_value) + '\nnew_value = ' + js2JSON(new_value) + '\n');
70                 try {
71                     var path = full_path.split(/\./).pop();
72                     for (var i in obj.observers.cache[full_path]) {
73                         try {
74                             var o = obj.observers.cache[full_path][i];
75                             if (typeof o.func == 'function') o.func(path, old_value, new_value);
76                         } catch(E) {
77                             obj.error.sdump('D_ERROR','Error in OpenILS.data.observers.dispatch(): ' + js2JSON(E) );
78                         }
79                     }
80                 } catch(E) {
81                     obj.error.sdump('D_ERROR','Error in OpenILS.data.observers.dispatch(): ' + js2JSON(E) );
82                 }
83             }
84
85             // This registers an observer function for a given path
86             obj.observers.add = function(full_path, func) {
87                 try {
88                     obj.error.sdump('D_OBSERVERS', 'entering observers.add\nfull_path = ' + full_path + '\nfunc = ' + func + '\n');
89                     netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
90                     const OpenILS=new Components.Constructor("@mozilla.org/openils_data_cache;1", "nsIOpenILS");
91                     var data_cache=new OpenILS( );
92                     var stash = data_cache.wrappedJSObject.OpenILS.prototype.data;
93
94                     var id = obj.observers.id++;
95                     if (typeof obj.observers.cache[ full_path ] == 'undefined') obj.observers.cache[ full_path ] = {};
96                     obj.observers.cache[ full_path ][ id ] = { 'func' : func, 'time_added' : new Date() };
97                     obj.observers.id2path[ id ] = [ full_path ];
98
99                     var path_list = full_path.split(/\./);
100                     var observed_prop = path_list.pop();
101
102                     // Convert soft path to object reference.  Error if any but the last node is undefined
103                     for (var i in path_list) stash = stash[ path_list[i] ];
104
105                     /*
106
107                     // experiment with storing only json in cache to avoid the [ ] -> { '0' : .., '1' : .. } bug
108
109                     if (stash[observed_prop] && getKeys( obj.observers.cache[ full_path ] ).length == 0) {
110                         stash['_' + observed_prop] = js2JSON(stash[observed_prop]);
111                     }
112
113                     stash.__defineSetter__(observed_prop, function(x) { this['_'+observed_prop] = js2JSON(x); });
114                     stash.__defineGetter__(observed_prop, function() { return JSON2js(this['_'+observed_prop]); });
115                     */
116
117                     stash.watch(
118                         observed_prop,
119                         function(p,old_value,new_value) {
120                             obj.observers.dispatch(full_path,old_value,new_value);
121                             return new_value;
122                         }
123                     );
124
125                     return id;
126                 } catch(E) {
127                     obj.error.sdump('D_ERROR','Error in OpenILS.data.observers.add(): ' + js2JSON(E) );
128                 }
129             }
130
131             // This unregisters an observer function for a given observer id
132             obj.observers.remove = function(id) {
133                 try {
134                     obj.error.sdump('D_OBSERVERS', 'entering observers.remove\nid = ' + id + '\n');
135                     var path = obj.observers.id2path[ id ];
136                     delete obj.observers.cache[ path ][ id ];
137                     delete obj.observers.id2path[ id ];
138                 } catch(E) {
139                     obj.error.sdump('D_ERROR','Error in OpenILS.data.observers.remove(): ' + js2JSON(E) );
140                 }
141             }
142
143             // This purges observer functions for a given path
144             obj.observers.purge = function(full_path) {
145                 obj.error.sdump('D_OBSERVERS', 'entering observers.purge\nfull_path = ' + full_path + '\n');
146                 try {
147                     var remove_these = [];
148                     for (var id in obj.observers.cache[ full_path ]) remove_these.push( id );
149                     for (var id in remove_these) delete obj.observers.id2path[ id ];
150                     delete obj.observers.cache[ full_path ];
151                 } catch(E) {
152                     obj.error.sdump('D_ERROR','Error in OpenILS.data.observers.purge(): ' + js2JSON(E) );
153                 }
154             }
155
156             obj.stash('observers'); // make this accessible globally
157
158         } catch(E) {
159             this.error.sdump('D_ERROR','Error in OpenILS.data.init_observer_functions(): ' + js2JSON(E) );
160         }
161     },
162
163     'stash' : function () {
164         try {
165             netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
166             const OpenILS=new Components.Constructor("@mozilla.org/openils_data_cache;1", "nsIOpenILS");
167             var data_cache=new OpenILS( );
168             for (var i = 0; i < arguments.length; i++) {
169                 try {
170                     if (arguments[i] != 'hash' && arguments[i] != 'list') this.error.sdump('D_DATA_STASH','stashing ' + arguments[i] + ' : ' + this[arguments[i]] + (typeof this[arguments[i]] == 'object' ? ' = ' + (this[arguments[i]]) : '') + '\n');
171                 } catch(F) { alert(F); }
172                 data_cache.wrappedJSObject.OpenILS.prototype.data[arguments[i]] = this[arguments[i]];
173             }
174         } catch(E) {
175             this.error.sdump('D_ERROR','Error in OpenILS.data.stash(): ' + js2JSON(E) );
176         }
177     },
178
179     'lookup' : function(key,value) {
180         try {
181             var obj = this; var found;
182             if (obj.hash[key] && obj.hash[key][value]) return obj.hash[key][value];
183             switch(key) {
184                 case 'acnp':
185                     found = obj.network.simple_request('FM_ACNP_RETRIEVE_VIA_PCRUD',[ ses(), { 'id' : { '=' : value } }]);
186                     if (typeof found.ilsevent != 'undefined') throw(js2JSON(found));
187                     found = found[0];
188                 break;
189                 case 'acns':
190                     found = obj.network.simple_request('FM_ACNS_RETRIEVE_VIA_PCRUD',[ ses(), { 'id' : { '=' : value } }]);
191                     if (typeof found.ilsevent != 'undefined') throw(js2JSON(found));
192                     found = found[0];
193                 break;
194                 case 'acpl': 
195                     found = obj.network.simple_request('FM_ACPL_RETRIEVE_VIA_ID.authoritative',[ value ]);
196                 break;
197                 case 'actsc':
198                     found = obj.network.simple_request('FM_ACTSC_RETRIEVE_VIA_PCRUD',[ ses(), { 'id' : { '=' : value } }]);
199                     if (typeof found.ilsevent != 'undefined') throw(js2JSON(found));
200                     found = found[0];
201                 break;
202                 default: return undefined; break;
203             }
204             if (typeof found.ilsevent != 'undefined') throw(found);
205             if (!obj.hash[key]) obj.hash[key] = {};
206             obj.hash[key][value] = found;
207             if (!obj.list[key]) obj.list[key] = [];
208             obj.list[key].push( found );
209             obj.stash('hash','list');
210             return found;
211         } catch(E) {
212             alert('Error in OpenILS.data.lookup('+key+','+value+'): ' + E );
213             return undefined;
214         }
215     },
216
217     '_debug_stash' : function() {
218         try {
219             netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
220             const OpenILS=new Components.Constructor("@mozilla.org/openils_data_cache;1", "nsIOpenILS");
221             var data_cache=new OpenILS( );
222             for (var i in data_cache.wrappedJSObject.OpenILS.prototype.data) {
223                 dump('_debug_stash ' + i + '\n');
224             }
225         } catch(E) {
226             this.error.sdump('D_ERROR','Error in OpenILS.data._debug_stash(): ' + js2JSON(E) );
227         }
228     },
229
230     '_fm_objects' : {
231
232         'pgt' : [ api.FM_PGT_RETRIEVE.app, api.FM_PGT_RETRIEVE.method, [], true ],
233         'cit' : [ api.FM_CIT_RETRIEVE.app, api.FM_CIT_RETRIEVE.method, [], true ],
234         'citm' : [ api.FM_CITM_RETRIEVE.app, api.FM_CITM_RETRIEVE.method, [{'query':{'ctype' : 'item_type'}}], true ],
235         /*
236         'cst' : [ api.FM_CST_RETRIEVE.app, api.FM_CST_RETRIEVE.method, [], true ],
237         */
238         /*
239         'acpl' : [ api.FM_ACPL_RETRIEVE.app, api.FM_ACPL_RETRIEVE.method, [], true ],
240         */
241         'ccs' : [ api.FM_CCS_RETRIEVE.app, api.FM_CCS_RETRIEVE.method, [], true ],
242         'aou' : [ api.FM_AOU_RETRIEVE.app, api.FM_AOU_RETRIEVE.method, [], true ],
243         'aout' : [ api.FM_AOUT_RETRIEVE.app, api.FM_AOUT_RETRIEVE.method, [], true ],
244         'crahp' : [ api.FM_CRAHP_RETRIEVE.app, api.FM_CRAHP_RETRIEVE.method, [], true ]
245     },
246
247     'stash_retrieve' : function() {
248         try {
249             netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
250             const OpenILS=new Components.Constructor("@mozilla.org/openils_data_cache;1", "nsIOpenILS");
251             var data_cache=new OpenILS( );
252             var dc = data_cache.wrappedJSObject.OpenILS.prototype.data;
253             for (var i in dc) {
254                 this.error.sdump('D_DATA_RETRIEVE','Retrieving ' + i + ' : ' + dc[i] + '\n');
255                 this[i] = dc[i];
256             }
257         } catch(E) {
258             this.error.sdump('D_ERROR','Error in OpenILS.data._debug_stash(): ' + js2JSON(E) );
259         }
260     },
261
262     'load_saved_print_templates' : function() {
263         var obj = this;
264         try {
265             JSAN.use('util.file'); var file = new util.file('print_list_templates');
266             if (file._file.exists()) {
267                 try {
268                     var x = file.get_object();
269                     if (x) {
270                         for (var i in x) {
271                             obj.print_list_templates[i] = x[i];
272                         }
273                         obj.stash('print_list_templates');
274                         obj.data_progress('Saved print templates retrieved from file. ');
275                     }
276                 } catch(E) {
277                     alert(E);
278                 }
279             }
280             file.close();
281         } catch(E) {
282             alert("Error in OpenILS.data, load_saved_print_templates(): " + E);
283         }
284     },
285
286     'fetch_print_strategy' : function() {
287         var obj = this;
288         try {
289             obj.print_strategy = {};
290             var print_contexts = [ 'default', 'receipt', 'label', 'mail', 'offline' ];
291             for (var i in print_contexts) {
292                 JSAN.use('util.file'); var file = new util.file('print_strategy.' + print_contexts[i]);
293                 if (file._file.exists()) {
294                     try {
295                         var x = file.get_content();
296                         if (x) {
297                             obj.print_strategy[ print_contexts[i] ] = x;
298                             obj.data_progress('Print strategy ' + print_contexts[i] + ' retrieved from file. ');
299                         }
300                     } catch(E) {
301                         alert(E);
302                     }
303                 }
304                 file.close();
305             }
306             obj.stash('print_strategy');
307         } catch(E) {
308             alert('Error in OpenILS.data, fetch_print_strategy(): ' + E);
309         }
310     },
311
312     'print_list_defaults' : function() {
313         var obj = this;
314         //if (typeof obj.print_list_templates == 'undefined') {
315         {
316             obj.print_list_types = [ 
317                 'offline_checkout', 
318                 'offline_checkin', 
319                 'offline_renew', 
320                 'offline_inhouse_use', 
321                 'items', 
322                 'bills', 
323                 'payment', 
324                 'holds', 
325                 /* 'patrons' */
326             ];
327             obj.print_list_templates = { 
328                 'item_status' : {
329                     'type' : 'items',
330                     'header' : 'The following items have been examined:<hr/><ol>',
331                     'line_item' : '<li>%title%<br/>\r\nBarcode: %barcode%\r\n',
332                     'footer' : '</ol><hr />%SHORTNAME% %TODAY_TRIM%<br/>\r\n<br/>\r\n'
333                 }, 
334                 'transit_list' : {
335                     'type' : 'transits',
336                     'header' : 'Transits:<hr/><ol>',
337                     'line_item' : '<li>From: %transit_source% To: %transit_dest_lib%<br/>\r\nWhen: %transit_source_send_time%<br />\r\nBarcode: %transit_item_barcode% Title: %transit_item_title%<br/>\r\n',
338                     'footer' : '</ol><hr />%SHORTNAME% %TODAY_TRIM%<br/>\r\n<br/>\r\n'
339                 }, 
340                 'items_out' : {
341                     'type' : 'items',
342                     'header' : 'Welcome to %LIBRARY%!<br/>\r\nYou have the following items:<hr/><ol>',
343                     'line_item' : '<li>%title%<br/>\r\nBarcode: %barcode% Due: %due_date%\r\n',
344                     'footer' : '</ol><hr />%SHORTNAME% %TODAY_TRIM%<br/>\r\nYou were helped by %STAFF_FIRSTNAME%<br/>\r\n<br/>\r\n'
345                 }, 
346                 'renew' : {
347                     'type' : 'items',
348                     'header' : 'Welcome to %LIBRARY%!<br/>\r\nYou have renewed the following items:<hr/><ol>',
349                     'line_item' : '<li>%title%<br/>\r\nBarcode: %barcode% Due: %due_date%\r\n',
350                     'footer' : '</ol><hr />%SHORTNAME% %TODAY_TRIM%<br/>\r\nYou were helped by %STAFF_FIRSTNAME%<br/>\r\n<br/>\r\n'
351                 }, 
352                 'checkout' : {
353                     'type' : 'items',
354                     'header' : 'Welcome to %LIBRARY%!<br/>\r\nYou checked out the following items:<hr/><ol>',
355                     'line_item' : '<li>%title%<br/>\r\nBarcode: %barcode% Due: %due_date%\r\n',
356                     'footer' : '</ol><hr />%SHORTNAME% %TODAY_TRIM%<br/>\r\nYou were helped by %STAFF_FIRSTNAME%<br/>\r\n<br/>\r\n'
357                 }, 
358                 'offline_checkout' : {
359                     'type' : 'offline_checkout',
360                     'header' : 'Patron %patron_barcode%<br/>\r\nYou checked out the following items:<hr/><ol>',
361                     'line_item' : '<li>Barcode: %barcode%<br/>\r\nDue: %due_date%\r\n',
362                     'footer' : '</ol><hr />%TODAY_TRIM%<br/>\r\n<br/>\r\n'
363                 },
364                 'checkin' : {
365                     'type' : 'items',
366                     'header' : 'You checked in the following items:<hr/><ol>',
367                     'line_item' : '<li>%title%<br/>\r\nBarcode: %barcode%  Call Number: %call_number%\r\n',
368                     'footer' : '</ol><hr />%SHORTNAME% %TODAY_TRIM%<br/>\r\n<br/>\r\n'
369                 }, 
370                 'bill_payment' : {
371                     'type' : 'payment',
372                     'header' : 'Welcome to %LIBRARY%!<br/>A receipt of your  transaction:<hr/> <table width="100%"> <tr> <td>Original Balance:</td> <td align="right">$%original_balance%</td> </tr> <tr> <td>Payment Method:</td> <td align="right">%payment_type%</td> </tr> <tr> <td>Payment Received:</td> <td align="right">$%payment_received%</td> </tr> <tr> <td>Payment Applied:</td> <td align="right">$%payment_applied%</td> </tr> <tr> <td>Billings Voided:</td> <td align="right">%voided_balance%</td> </tr> <tr> <td>Change Given:</td> <td align="right">$%change_given%</td> </tr> <tr> <td>New Balance:</td> <td align="right">$%new_balance%</td> </tr> </table> <p> Note: %note% </p> <p> Specific bills: <blockquote>',
373                     'line_item' : 'Bill #%bill_id%  %last_billing_type% Received: $%payment%<br />%barcode% %title%<br /><br />',
374                     'footer' : '</blockquote> </p> <hr />%SHORTNAME% %TODAY_TRIM%<br/> <br/> '
375                 },
376                 'bills_historical' : {
377                     'type' : 'bills',
378                     'header' : 'Welcome to %LIBRARY%!<br/>You had the following bills:<hr/><ol>',
379                     'line_item' : '<dt><b>Bill #%mbts_id%</b> %title% </dt> <dd> <table> <tr valign="top"><td>Date:</td><td>%xact_start%</td></tr> <tr valign="top"><td>Type:</td><td>%xact_type%</td></tr> <tr valign="top"><td>Last Billing:</td><td>%last_billing_type%<br/>%last_billing_note%</td></tr> <tr valign="top"><td>Total Billed:</td><td>$%total_owed%</td></tr> <tr valign="top"><td>Last Payment:</td><td>%last_payment_type%<br/>%last_payment_note%</td></tr> <tr valign="top"><td>Total Paid:</td><td>$%total_paid%</td></tr> <tr valign="top"><td><b>Balance:</b></td><td><b>$%balance_owed%</b></td></tr> </table><br/>',
380                     'footer' : '</ol><hr />%SHORTNAME% %TODAY_TRIM%<br/>\r\n<br/>\r\n'
381                 }, 
382                 'bills_current' : {
383                     'type' : 'bills',
384                     'header' : 'Welcome to %LIBRARY%!<br/>You have the following bills:<hr/><ol>',
385                     'line_item' : '<dt><b>Bill #%id%</b></dt> <dd> <table> <tr valign="top"><td>Date:</td><td>%xact_start%</td></tr> <tr valign="top"><td>Type:</td><td>%xact_type%</td></tr> <tr valign="top"><td>Last Billing:</td><td>%last_billing_type%<br/>%last_billing_note%</td></tr> <tr valign="top"><td>Total Billed:</td><td>$%total_owed%</td></tr> <tr valign="top"><td>Last Payment:</td><td>%last_payment_type%<br/>%last_payment_note%</td></tr> <tr valign="top"><td>Total Paid:</td><td>$%total_paid%</td></tr> <tr valign="top"><td><b>Balance:</b></td><td><b>$%balance_owed%</b></td></tr> </table><br/>',
386                     'footer' : '</ol><hr />%SHORTNAME% %TODAY_TRIM%<br/>\r\n<br/>\r\n'
387                 },
388                 'bills_main_view' : {
389                     'type' : 'bills',
390                     'header' : 'Welcome to %LIBRARY%!<br/>You have the following bills:<hr/><ol>',
391                     'line_item' : '<dt><b>Bill #%id%</b> %title%</dt> <dd> <table width="100%"> <tr valign="top"><td>Date:</td><td>%xact_start%</td></tr> <tr valign="top"><td>Type:</td><td>%xact_type%</td></tr> <tr valign="top"><td>Last Billing:</td><td>%last_billing_type%<br/>%last_billing_note%</td></tr> <tr valign="top"><td>Total Billed:</td><td>$%total_owed%</td></tr> <tr valign="top"><td>Last Payment:</td><td>%last_payment_type%<br/>%last_payment_note%</td></tr> <tr valign="top"><td>Total Paid:</td><td>$%total_paid%</td></tr> <tr valign="top"><td><b>Balance:</b></td><td><b>$%balance_owed%</b></td></tr> </table><br/>',
392                     'footer' : '</ol><hr />%SHORTNAME% %TODAY_TRIM%<br/>\r\n<br/>\r\n'
393                 },
394                 'offline_checkin' : {
395                     'type' : 'offline_checkin',
396                     'header' : 'You checked in the following items:<hr/><ol>',
397                     'line_item' : '<li>Barcode: %barcode%\r\n',
398                     'footer' : '</ol><hr />%TODAY_TRIM%<br/>\r\n<br/>\r\n'
399                 },
400                 'offline_renew' : {
401                     'type' : 'offline_renew',
402                     'header' : 'You renewed the following items:<hr/><ol>',
403                     'line_item' : '<li>Barcode: %barcode%\r\n',
404                     'footer' : '</ol><hr />%TODAY_TRIM%<br/>\r\n<br/>\r\n'
405                 },
406                 'offline_inhouse_use' : {
407                     'type' : 'offline_inhouse_use',
408                     'header' : 'You marked the following in-house items used:<hr/><ol>',
409                     'line_item' : '<li>Barcode: %barcode%\r\nUses: %count%',
410                     'footer' : '</ol><hr />%TODAY_TRIM%<br/>\r\n<br/>\r\n'
411                 },
412                 'in_house_use' : {
413                     'type' : 'items',
414                     'header' : 'You marked the following in-house items used:<hr/><ol>',
415                     'line_item' : '<li>Barcode: %barcode%\r\nUses: %uses%\r\n<br />%alert_message%',
416                     'footer' : '</ol><hr />%TODAY_TRIM%<br/>\r\n<br/>\r\n'
417                 },
418                 'holds' : {
419                     'type' : 'holds',
420                     'header' : 'Welcome to %LIBRARY%!<br/>\r\nYou have the following titles on hold:<hr/><ol>',
421                     'line_item' : '<li>%title%\r\n',
422                     'footer' : '</ol><hr />%SHORTNAME% %TODAY_TRIM%<br/>\r\nYou were helped by %STAFF_FIRSTNAME%<br/>\r\n<br/>\r\n'
423                 },
424                 'hold_slip' : {
425                     'type' : 'holds',
426                     'header' : 'This item needs to be routed to <b>%route_to%</b>:<br/>\r\nBarcode: %item_barcode%<br/>\r\nTitle: %item_title%<br/>\r\n<br/>\r\n%hold_for_msg%<br/>\r\nBarcode: %PATRON_BARCODE%<br/>\r\nNotify by phone: %notify_by_phone%<br/>\r\nNotify by email: %notify_by_email%<br/>\r\n',
427                     'line_item' : '%formatted_note%<br/>\r\n',
428                     'footer' : '<br/>\r\nRequest date: %request_date%<br/>\r\nSlip Date: %TODAY_TRIM%<br/>\r\nPrinted by %STAFF_FIRSTNAME% at %SHORTNAME%<br/>\r\n<br/>\r\n'
429                 },
430                 'transit_slip' : {
431                     'type' : 'transits',
432                     'header' : 'This item needs to be routed to <b>%route_to%</b>:<br/>\r\n%route_to_org_fullname%<br/>\r\n%street1%<br/>\r\n%street2%<br/>\r\n%city_state_zip%<br/>\r\n<br/>\r\nBarcode: %item_barcode%<br/>\r\nTitle: %item_title%<br/>\r\nAuthor: %item_author%<br>\r\n<br/>\r\n',
433                     'line_item' : '',
434                     'footer' : 'Slip Date: %TODAY_TRIM%<br/>\r\nPrinted by %STAFF_FIRSTNAME% at %SHORTNAME%<br/>\r\n<br/>\r\n'
435                 },
436                 'hold_transit_slip' : {
437                     'type' : 'transits',
438                     'header' : 'This item needs to be routed to <b>%route_to%</b>:<br/>\r\n%route_to_org_fullname%<br/>\r\n%street1%<br/>\r\n%street2%<br/>\r\n%city_state_zip%<br/>\r\n<br/>\r\nBarcode: %item_barcode%<br/>\r\nTitle: %item_title%<br/>\r\nAuthor: %item_author%<br>\r\n<br/>\r\n%hold_for_msg%<br/>\r\nBarcode: %PATRON_BARCODE%<br/>\r\nNotify by phone: %notify_by_phone%<br/>\r\nNotify by email: %notify_by_email%<br/>\r\n',
439                     'line_item' : '%formatted_note%<br/>\r\n',
440                     'footer' : '<br/>\r\nRequest date: %request_date%<br/>\r\nSlip Date: %TODAY_TRIM%<br/>\r\nPrinted by %STAFF_FIRSTNAME% at %SHORTNAME%<br/>\r\n<br/>\r\n'
441                 },
442                 'holdings_maintenance' : {
443                     'type' : 'items',
444                     'header' : 'Title: %title%<br/>\r\nAuthor: %author%<br/>\r\nISBN: %isbn% Edition: %edition% PubDate: %pubdate%<br/>\r\nTCN: %tcn_value% Record ID: %mvr_doc_id%<br/>\r\nCreator: %creator% Create Date: %create_date%<br/>\r\nEditor: %editor% Edit Date: %edit_date%<hr/>\r\n',
445                     'line_item' : '%prefix% %tree_location% %suffix% %parts% %acp_status%<br/>\r\n',
446                     'footer' : '<hr />%SHORTNAME% %TODAY_TRIM%<br/>\r\n<br/>\r\n'
447                 }
448             }; 
449
450             obj.stash( 'print_list_templates', 'print_list_types' );
451         }
452     },
453
454     'network_retrieve' : function() {
455         netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
456         var obj = this;
457
458         JSAN.use('util.file'); var file = new util.file('global_font_adjust');
459         if (file._file.exists()) {
460             try {
461                 var x = file.get_object();
462                 if (x) {
463                     obj.global_font_adjust = x;
464                     obj.stash('global_font_adjust');
465                     obj.data_progress('Saved font settings retrieved from file. ');
466                 }
467             } catch(E) {
468                 alert(E);
469             }
470         }
471         file.close();
472
473         JSAN.use('util.file'); var file = new util.file('no_sound');
474         if (file._file.exists()) {
475             try {
476                 var x = file.get_content();
477                 if (x) {
478                     obj.no_sound = x;
479                     obj.stash('no_sound');
480                     obj.data_progress('Saved sound settings retrieved from file. ');
481                 }
482             } catch(E) {
483                 alert(E);
484             }
485         }
486         file.close();
487
488         obj.print_list_defaults();
489         obj.data_progress('Default print templates set. ');
490         obj.load_saved_print_templates();
491         obj.fetch_print_strategy();
492         JSAN.use('util.print'); (new util.print()).GetPrintSettings();
493         obj.data_progress('Printer settings retrieved. ');
494
495         JSAN.use('util.functional');
496         JSAN.use('util.fm_utils');
497
498         function gen_fm_retrieval_func(classname,data) {
499             var app = data[0]; var method = data[1]; var params = data[2]; var cacheable = data[3];
500             return function () {
501                 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
502
503                 function convert() {
504                     netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
505                     try {
506                         if (obj.list[classname].constructor.name == 'Array') {
507                             obj.hash[classname] = 
508                                 util.functional.convert_object_list_to_hash(
509                                     obj.list[classname],
510                                     classname == 'citm' ? 'code' : null
511                                 );
512                         }
513                     } catch(E) {
514
515                         obj.error.sdump('D_ERROR',E + '\n');
516                     }
517
518                 }
519
520                 try {
521                     var level = obj.error.sdump_levels.D_SES_RESULT;
522                     if (classname == 'aou' || classname == 'my_aou')
523                         obj.error.sdump_levels.D_SES_RESULT = false;
524                     var robj = obj.network.request( app, method, params);
525                     if (robj != null && typeof robj.ilsevent != 'undefined') {
526                         obj.error.standard_unexpected_error_alert('The staff client failed to retrieve expected data from this call, "' + method + '"',robj);
527                         throw(robj);
528                     }
529                     obj.list[classname] = robj == null ? [] : robj;
530                     obj.error.sdump_levels.D_SES_RESULT = level;
531                     convert();
532                     obj.data_progress('Retrieved list for ' + classname + ' objects. ');
533
534                 } catch(E) {
535                     // if cacheable, try offline
536                     if (cacheable) {
537                         /* FIXME -- we're going to revisit caching and do it differently
538                         try {
539                             var file = new util.file( classname );
540                             obj.list[classname] = file.get_object(); file.close();
541                             convert();
542                         } catch(E) {
543                             throw(E);
544                         }
545                         */
546                         throw(E); // for now
547                     } else {
548                         throw(E); // for now
549                     }
550                 }
551             }
552         }
553
554         // If we don't clear these, then things like obj.list['acnp_for_lib_1'] may stick around
555         obj.hash = {}; obj.list = {};
556
557         this.chain = [];
558
559         this.chain.push(
560             function() {
561                 try {
562                     var robj = obj.network.simple_request('CIRC_MODIFIER_LIST',[{'full':true}]);
563                     if (typeof robj.ilsevent != 'undefined') throw(robj);
564                     obj.list.ccm = robj == null ? [] : robj;
565                     obj.hash.ccm = util.functional.convert_object_list_to_hash( obj.list.ccm );
566                     obj.list.circ_modifier = util.functional.map_list( obj.list.ccm, function(o) { return o.code(); } );
567                     obj.data_progress('Retrieved circ modifier list. ');
568                 } catch(E) {
569                     var error = 'Error: ' + js2JSON(E);
570                     obj.error.sdump('D_ERROR',error);
571                     throw(E);
572                 }
573             }
574         );
575
576         this.chain.push(
577             function() {
578                 var f = gen_fm_retrieval_func(
579                     'cnal',
580                     [
581                         api.FM_CNAL_RETRIEVE.app,
582                         api.FM_CNAL_RETRIEVE.method,
583                         [ obj.session.key ],
584                         false
585                     ]
586                 );
587                 try {
588                     f();
589                 } catch(E) {
590                     var error = 'Error: ' + js2JSON(E);
591                     obj.error.sdump('D_ERROR',error);
592                     throw(E);
593                 }
594             }
595         );
596
597         this.chain.push(
598             function() {
599                 var f = gen_fm_retrieval_func(
600                     'bpt',
601                     [
602                         api.FM_BPT_PCRUD_SEARCH.app,
603                         api.FM_BPT_PCRUD_SEARCH.method,
604                         [ obj.session.key, {"id":{"!=":null}}, {"order_by":{"bpt":"id"}} ],
605                         false
606                     ]
607                 );
608                 try {
609                     f();
610                 } catch(E) {
611                     var error = 'Error: ' + js2JSON(E);
612                     obj.error.sdump('D_ERROR',error);
613                     throw(E);
614                 }
615             }
616         );
617
618         this.chain.push(
619             function() {
620                 var f = gen_fm_retrieval_func(
621                     'csp',
622                     [
623                         api.FM_CSP_PCRUD_SEARCH.app,
624                         api.FM_CSP_PCRUD_SEARCH.method,
625                         [ obj.session.key, {"id":{"!=":null}}, {"order_by":{"csp":"id"}} ],
626                         false
627                     ]
628                 );
629                 try {
630                     f();
631                 } catch(E) {
632                     var error = 'Error: ' + js2JSON(E);
633                     obj.error.sdump('D_ERROR',error);
634                     throw(E);
635                 }
636             }
637         );
638
639         this.chain.push(
640             function() {
641                 var f = gen_fm_retrieval_func(
642                     'acnc',
643                     [
644                         api.FM_ACNC_RETRIEVE_VIA_PCRUD.app,
645                         api.FM_ACNC_RETRIEVE_VIA_PCRUD.method,
646                         [ obj.session.key, {"id":{"!=":null}}, {"order_by":{"acnc":"name"}} ],
647                         false
648                     ]
649                 );
650                 try {
651                     f();
652                 } catch(E) {
653                     var error = 'Error: ' + js2JSON(E);
654                     obj.error.sdump('D_ERROR',error);
655                     throw(E);
656                 }
657             }
658         );
659
660         this.chain.push(
661             function() {
662                 var f = gen_fm_retrieval_func(
663                     'ahrcc',
664                     [
665                         api.FM_AHRCC_PCRUD_SEARCH.app,
666                         api.FM_AHRCC_PCRUD_SEARCH.method,
667                         [ obj.session.key, {"id":{"!=":null}}, {"order_by":{"ahrcc":"label"}} ],
668                         false
669                     ]
670                 );
671                 try {
672                     f();
673                 } catch(E) {
674                     var error = 'Error: ' + js2JSON(E);
675                     obj.error.sdump('D_ERROR',error);
676                     throw(E);
677                 }
678             }
679         );
680
681
682         this.chain.push(
683             function() {
684                 var f = gen_fm_retrieval_func(
685                     'au',
686                     [
687                         api.FM_AU_RETRIEVE_VIA_SESSION.app,
688                         api.FM_AU_RETRIEVE_VIA_SESSION.method,
689                         [ obj.session.key ],
690                         false
691                     ]
692                 );
693                 try {
694                     f();
695                 } catch(E) {
696                     var error = 'Error: ' + js2JSON(E);
697                     obj.error.sdump('D_ERROR',error);
698                     throw(E);
699                 }
700                 obj.list.au = [ obj.list.au ];
701             }
702         );
703
704         this.chain.push(
705             function() {
706                 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
707                 var f = gen_fm_retrieval_func(
708                     'my_asv',
709                     [
710                         api.FM_ASV_RETRIEVE_REQUIRED.app,
711                         api.FM_ASV_RETRIEVE_REQUIRED.method,
712                         [ obj.session.key ],
713                         true
714                     ]
715                 );
716                 try {
717                     netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
718                     f();
719                 } catch(E) {
720                     var error = 'Error: ' + js2JSON(E);
721                     obj.error.sdump('D_ERROR',error);
722                     throw(E);
723                 }
724             }
725         );
726
727         this.chain.push(
728             function() {
729                 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
730                 var f = gen_fm_retrieval_func(
731                     'asv',
732                     [
733                         api.FM_ASV_RETRIEVE.app,
734                         api.FM_ASV_RETRIEVE.method,
735                         [ obj.session.key ],
736                         true
737                     ]
738                 );
739                 try {
740                     netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
741                     f();
742                 } catch(E) {
743                     var error = 'Error: ' + js2JSON(E);
744                     obj.error.sdump('D_ERROR',error);
745                     throw(E);
746                 }
747             }
748         );
749
750         obj.error.sdump('D_DEBUG','_fm_objects = ' + js2JSON(this._fm_objects) + '\n');
751
752         for (var i in this._fm_objects) {
753             this.chain.push( gen_fm_retrieval_func(i,this._fm_objects[i]) );
754         }
755
756         // The previous org_tree call returned a tree, not a list or hash.
757         this.chain.push(
758             function () {
759                 obj.tree.aou = obj.list.aou;
760                 obj.list.aou = util.fm_utils.flatten_ou_branch( obj.tree.aou );
761                 for (var i = 0; i < obj.list.aou.length; i++) {
762                     var c = obj.list.aou[i].children();
763                     if (!c) c = [];
764                     c = c.sort(
765                         function( a, b ) {
766                             if (a.shortname() < b.shortname()) return -1;
767                             if (a.shortname() > b.shortname()) return 1;
768                             return 0;
769                         }
770                     );
771                     obj.list.aou[i].children( c );
772                 }
773                 obj.list.aou = util.fm_utils.flatten_ou_branch( obj.tree.aou );
774                 obj.hash.aou = util.functional.convert_object_list_to_hash( obj.list.aou );
775             }
776         );
777
778         // The previous pgt call returned a tree, not a list or hash.
779         this.chain.push(
780             function () {
781                 obj.tree.pgt = obj.list.pgt;
782                 obj.list.pgt = util.fm_utils.flatten_ou_branch( obj.tree.pgt );
783                 obj.hash.pgt = util.functional.convert_object_list_to_hash( obj.list.pgt );
784             }
785         );
786
787         // Do these after we get the user object
788
789         this.chain.push(
790             function() {
791                 try {
792                     var robj = obj.network.simple_request('FM_AOUS_RETRIEVE',[ obj.session.key, obj.list.au[0].ws_ou() ]);
793                     if (typeof robj.ilsevent != 'undefined') throw(robj);
794                     obj.hash.aous = robj;
795                     obj.data_progress('Retrieved org unit settings. ');
796                 } catch(E) {
797                     var error = 'Error: ' + js2JSON(E);
798                     obj.error.sdump('D_ERROR',error);
799                     throw(E);
800                 }
801             }
802         );
803
804         this.chain.push(
805
806             function() {
807
808                 gen_fm_retrieval_func('my_aou', 
809                     [ 
810                         api.FM_AOU_RETRIEVE_RELATED_VIA_SESSION.app,
811                         api.FM_AOU_RETRIEVE_RELATED_VIA_SESSION.method,
812                         [ obj.session.key, obj.list.au[0].ws_ou() ], /* use ws_ou and not home_ou */
813                         true
814                     ]
815                 )();
816             }
817         );
818
819         this.chain.push(
820
821             function () {
822
823                 gen_fm_retrieval_func( 'my_actsc', 
824                     [ 
825                         api.FM_ACTSC_RETRIEVE_VIA_AOU.app,
826                         api.FM_ACTSC_RETRIEVE_VIA_AOU.method,
827                         [ obj.session.key, obj.list.au[0].ws_ou() ],
828                         true
829                     ]
830                 )();
831             }
832         );
833
834         this.chain.push(
835
836             function () {
837
838                 gen_fm_retrieval_func( 'my_asc', 
839                     [ 
840                         api.FM_ASC_RETRIEVE_VIA_AOU.app,
841                         api.FM_ASC_RETRIEVE_VIA_AOU.method,
842                         [ obj.session.key, obj.list.au[0].ws_ou() ],
843                         true
844                     ]
845                 )();
846             }
847         );
848
849
850         this.chain.push(
851             function() {
852                 var f = gen_fm_retrieval_func(
853                     'cnct',
854                     [
855                         api.FM_CNCT_RETRIEVE.app,
856                         api.FM_CNCT_RETRIEVE.method,
857                         [ obj.list.au[0].ws_ou() ], 
858                         false
859                     ]
860                 );
861                 try {
862                     f();
863                 } catch(E) {
864                     var error = 'Error: ' + js2JSON(E);
865                     obj.error.sdump('D_ERROR',error);
866                     throw(E);
867                 }
868             }
869         );
870
871         this.chain.push(
872             function() {
873                 var f = gen_fm_retrieval_func(
874                     'my_cnct',
875                     [
876                         api.FM_CNCT_RETRIEVE.app,
877                         api.FM_CNCT_RETRIEVE.method,
878                         [ obj.list.au[0].ws_ou() ], 
879                         false
880                     ]
881                 );
882                 try {
883                     f();
884                 } catch(E) {
885                     var error = 'Error: ' + js2JSON(E);
886                     obj.error.sdump('D_ERROR',error);
887                     throw(E);
888                 }
889             }
890         );
891
892         this.chain.push(
893             function() {
894                 var f = gen_fm_retrieval_func(
895                     'acpl',
896                     [
897                         api.FM_ACPL_RETRIEVE.app,
898                         api.FM_ACPL_RETRIEVE.method,
899                         [ obj.list.au[0].ws_ou() ],
900                         false
901                     ]
902                 );
903                 try {
904                     f();
905                 } catch(E) {
906                     var error = 'Error: ' + js2JSON(E);
907                     obj.error.sdump('D_ERROR',error);
908                     throw(E);
909                 }
910             }
911         );
912
913         this.chain.push(
914             function() {
915                 var f = gen_fm_retrieval_func(
916                     'acnp',
917                     [
918                         api.FM_ACNP_RETRIEVE_VIA_PCRUD.app,
919                         api.FM_ACNP_RETRIEVE_VIA_PCRUD.method,
920                         [ obj.session.key, {"owning_lib":{"=":obj.list.au[0].ws_ou()}}, {"order_by":{"acnp":"label_sortkey"}} ],
921                         false
922                     ]
923                 );
924                 try {
925                     f();
926                     obj.list['acnp_for_lib_'+obj.list.au[0].ws_ou()] = obj.list.acnp;
927                 } catch(E) {
928                     var error = 'Error: ' + js2JSON(E);
929                     obj.error.sdump('D_ERROR',error);
930                     throw(E);
931                 }
932             }
933         );
934
935         this.chain.push(
936             function() {
937                 var f = gen_fm_retrieval_func(
938                     'acns',
939                     [
940                         api.FM_ACNS_RETRIEVE_VIA_PCRUD.app,
941                         api.FM_ACNS_RETRIEVE_VIA_PCRUD.method,
942                         [ obj.session.key, {"owning_lib":{"=":obj.list.au[0].ws_ou()}}, {"order_by":{"acns":"label_sortkey"}} ],
943                         false
944                     ]
945                 );
946                 try {
947                     f();
948                     obj.list['acns_for_lib_'+obj.list.au[0].ws_ou()] = obj.list.acns;
949                 } catch(E) {
950                     var error = 'Error: ' + js2JSON(E);
951                     obj.error.sdump('D_ERROR',error);
952                     throw(E);
953                 }
954             }
955         );
956
957         this.chain.push(
958             function() {
959                 var f = gen_fm_retrieval_func(
960                     'cbt',
961                     [
962                         api.FM_CBT_RETRIEVE.app,
963                         api.FM_CBT_RETRIEVE.method,
964                         [ obj.session.key, obj.list.au[0].ws_ou() ],
965                         false
966                     ]
967                 );
968                 try {
969                     f();
970                 } catch(E) {
971                     var error = 'Error: ' + js2JSON(E);
972                     obj.error.sdump('D_ERROR',error);
973                     throw(E);
974                 }
975             }
976         );
977
978         if (typeof this.on_complete == 'function') {
979
980             this.chain.push( this.on_complete );
981         }
982         JSAN.use('util.exec'); this.exec = new util.exec();
983         this.exec.on_error = function(E) { 
984         
985             if (typeof obj.on_error == 'function') {
986                 return obj.on_error(E); /* false breaks chain */
987             } else {
988                 alert('oops: ' + E ); 
989                 return false; /* break chain */
990             }
991
992         }
993
994         this.exec.chain( this.chain );
995
996     }
997 }
998
999 dump('exiting OpenILS/data.js\n');