]> git.evergreen-ils.org Git - working/Evergreen.git/blob - Open-ILS/xul/staff_client/chrome/content/OpenILS/data.js
transit printing
[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         JSAN.use('util.error'); this.error = new util.error();
7         JSAN.use('util.network'); this.network = new util.network();
8
9         return this;
10 }
11
12 OpenILS.data.prototype = {
13
14         'list' : {},
15         'hash' : {},
16         'tree' : {},
17
18         'temp' : '',
19
20         'init' : function (params) {
21
22                 try {
23                         if (params && params.via == 'stash') {  
24                                 this.stash_retrieve();
25                         } else {
26                                 this.network_retrieve();
27                         }
28                 
29                 } catch(E) {
30                         this.error.sdump('D_ERROR','Error in OpenILS.data.init('
31                                 +js2JSON(params)+'): ' + js2JSON(E) );
32                 }
33
34
35         },
36
37         'stash' : function () {
38                 try {
39                         netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
40                         const OpenILS=new Components.Constructor("@mozilla.org/openils_data_cache;1", "nsIOpenILS");
41                         var data_cache=new OpenILS( );
42                         for (var i = 0; i < arguments.length; i++) {
43                                 try {
44                                         if (arguments[i] != 'hash' && arguments[i] != 'list') this.error.sdump('D_DATA_STASH','stashing ' + arguments[i] + ' : ' + this[arguments[i]] + (typeof this[arguments[i]] == 'object' ? ' = ' + js2JSON(this[arguments[i]]) : '') + '\n');
45                                 } catch(F) { alert(F); }
46                                 data_cache.wrappedJSObject.OpenILS.prototype.data[arguments[i]] = this[arguments[i]];
47                         }
48                 } catch(E) {
49                         this.error.sdump('D_ERROR','Error in OpenILS.data.stash(): ' + js2JSON(E) );
50                 }
51         },
52
53         'lookup' : function(key,value) {
54                 try {
55                         var obj = this; var found;
56                         if (obj.hash[key] && obj.hash[key][value]) return obj.hash[key][value];
57                         switch(key) {
58                                 case 'acpl': 
59                                         found = obj.network.simple_request('FM_ACPL_RETRIEVE_VIA_ID',[ value ]);
60                                 break;
61                                 default: return undefined; break;
62                         }
63                         if (typeof found.ilsevent != 'undefined') throw(found);
64                         if (!obj.hash[key]) obj.hash[key] = {};
65                         obj.hash[key][value] = found; obj.list[key].push( found ); obj.stash('hash','list');
66                         return found;
67                 } catch(E) {
68                         this.error.sdump('D_ERROR','Error in OpenILS.data.lookup('+key+','+value+'): ' + js2JSON(E) );
69                         return undefined;
70                 }
71         },
72
73         '_debug_stash' : function() {
74                 try {
75                         netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
76                         const OpenILS=new Components.Constructor("@mozilla.org/openils_data_cache;1", "nsIOpenILS");
77                         var data_cache=new OpenILS( );
78                         for (var i in data_cache.wrappedJSObject.OpenILS.prototype.data) {
79                                 dump('_debug_stash ' + i + '\n');
80                         }
81                 } catch(E) {
82                         this.error.sdump('D_ERROR','Error in OpenILS.data._debug_stash(): ' + js2JSON(E) );
83                 }
84         },
85
86         '_fm_objects' : {
87
88                 'pgt' : [ api.FM_PGT_RETRIEVE.app, api.FM_PGT_RETRIEVE.method, [], true ],
89                 'cit' : [ api.FM_CIT_RETRIEVE.app, api.FM_CIT_RETRIEVE.method, [], true ],
90                 'citm' : [ api.FM_CITM_RETRIEVE.app, api.FM_CITM_RETRIEVE.method, [], true ],
91                 /*
92                 'cst' : [ api.FM_CST_RETRIEVE.app, api.FM_CST_RETRIEVE.method, [], true ],
93                 */
94                 /*
95                 'acpl' : [ api.FM_ACPL_RETRIEVE.app, api.FM_ACPL_RETRIEVE.method, [], true ],
96                 */
97                 'ccs' : [ api.FM_CCS_RETRIEVE.app, api.FM_CCS_RETRIEVE.method, [], true ],
98                 'aou' : [ api.FM_AOU_RETRIEVE.app, api.FM_AOU_RETRIEVE.method, [], true ],
99                 'aout' : [ api.FM_AOUT_RETRIEVE.app, api.FM_AOUT_RETRIEVE.method, [], true ],
100                 'crahp' : [ api.FM_CRAHP_RETRIEVE.app, api.FM_CRAHP_RETRIEVE.method, [], true ],
101         },
102
103         'stash_retrieve' : function() {
104                 try {
105                         netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
106                         const OpenILS=new Components.Constructor("@mozilla.org/openils_data_cache;1", "nsIOpenILS");
107                         var data_cache=new OpenILS( );
108                         var dc = data_cache.wrappedJSObject.OpenILS.prototype.data;
109                         for (var i in dc) {
110                                 this.error.sdump('D_DATA_RETRIEVE','Retrieving ' + i + ' : ' + dc[i] + '\n');
111                                 this[i] = dc[i];
112                         }
113                         if (typeof this.on_complete == 'function') {
114
115                                 this.on_complete();
116                         }
117                 } catch(E) {
118                         this.error.sdump('D_ERROR','Error in OpenILS.data._debug_stash(): ' + js2JSON(E) );
119                 }
120         },
121
122         'print_list_defaults' : function() {
123                 var obj = this;
124                 //if (typeof obj.print_list_templates == 'undefined') {
125                 {
126                         obj.print_list_types = [ 
127                                 'offline_checkout', 
128                                 'offline_checkin', 
129                                 'offline_renew', 
130                                 'offline_inhouse_use', 
131                                 'items', 
132                                 'bills', 
133                                 'payment', 
134                                 'holds', 
135                                 /* 'patrons' */
136                         ];
137                         obj.print_list_templates = { 
138                                 'item_status' : {
139                                         'type' : 'items',
140                                         'header' : 'The following items have been examined:<hr/><ol>',
141                                         'line_item' : '<li>%title%<br/>\r\nBarcode: %barcode%\r\n',
142                                         'footer' : '</ol><hr />%PINES_CODE% %TODAY_TRIM%<br/>\r\n<br/>\r\n',
143                                 }, 
144                                 'transit_list' : {
145                                         'type' : 'transits',
146                                         'header' : 'Transits:<hr/><ol>',
147                                         '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',
148                                         'footer' : '</ol><hr />%PINES_CODE% %TODAY_TRIM%<br/>\r\n<br/>\r\n',
149                                 }, 
150                                 'items_out' : {
151                                         'type' : 'items',
152                                         'header' : 'Welcome to %LIBRARY%!<br/>\r\nYou have the following items:<hr/><ol>',
153                                         'line_item' : '<li>%title%<br/>\r\nBarcode: %barcode% Due: %due_date%\r\n',
154                                         'footer' : '</ol><hr />%PINES_CODE% %TODAY_TRIM%<br/>\r\nYou were helped by %STAFF_FIRSTNAME%<br/>\r\n<br/>\r\n',
155                                 }, 
156                                 'checkout' : {
157                                         'type' : 'items',
158                                         'header' : 'Welcome to %LIBRARY%!<br/>\r\nYou checked out the following items:<hr/><ol>',
159                                         'line_item' : '<li>%title%<br/>\r\nBarcode: %barcode% Due: %due_date%\r\n',
160                                         'footer' : '</ol><hr />%PINES_CODE% %TODAY_TRIM%<br/>\r\nYou were helped by %STAFF_FIRSTNAME%<br/>\r\n<br/>\r\n',
161                                 }, 
162                                 'offline_checkout' : {
163                                         'type' : 'offline_checkout',
164                                         'header' : 'Patron %patron_barcode%<br/>\r\nYou checked out the following items:<hr/><ol>',
165                                         'line_item' : '<li>Barcode: %barcode%<br/>\r\nDue: %due_date%\r\n',
166                                         'footer' : '</ol><hr />%TODAY_TRIM%<br/>\r\n<br/>\r\n',
167                                 },
168                                 'checkin' : {
169                                         'type' : 'items',
170                                         'header' : 'You checked in the following items:<hr/><ol>',
171                                         'line_item' : '<li>%title%<br/>\r\nBarcode: %barcode%  Call Number: %call_number%\r\n',
172                                         'footer' : '</ol><hr />%PINES_CODE% %TODAY_TRIM%<br/>\r\n<br/>\r\n',
173                                 }, 
174                                 'bill_payment' : {
175                                         'type' : 'payment',
176                                         '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>',
177                                         'line_item' : 'Bill #%bill_id%  %last_billing_type% Received: $%payment%<br />%barcode% %title%<br /><br />',
178                                         'footer' : '</blockquote> </p> <hr />%PINES_CODE% %TODAY_TRIM%<br/> <br/> ',
179                                 },
180                                 'bills_historical' : {
181                                         'type' : 'bills',
182                                         'header' : 'Welcome to %LIBRARY%!<br/>You had the following bills:<hr/><ol>',
183                                         '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/>',
184                                         'footer' : '</ol><hr />%PINES_CODE% %TODAY_TRIM%<br/>\r\n<br/>\r\n',
185                                 }, 
186                                 'bills_current' : {
187                                         'type' : 'bills',
188                                         'header' : 'Welcome to %LIBRARY%!<br/>You have the following bills:<hr/><ol>',
189                                         '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/>',
190                                         'footer' : '</ol><hr />%PINES_CODE% %TODAY_TRIM%<br/>\r\n<br/>\r\n',
191                                 }, 
192                                 'offline_checkin' : {
193                                         'type' : 'offline_checkin',
194                                         'header' : 'You checked in the following items:<hr/><ol>',
195                                         'line_item' : '<li>Barcode: %barcode%\r\n',
196                                         'footer' : '</ol><hr />%TODAY_TRIM%<br/>\r\n<br/>\r\n',
197                                 },
198                                 'offline_renew' : {
199                                         'type' : 'offline_renew',
200                                         'header' : 'You renewed the following items:<hr/><ol>',
201                                         'line_item' : '<li>Barcode: %barcode%\r\n',
202                                         'footer' : '</ol><hr />%TODAY_TRIM%<br/>\r\n<br/>\r\n',
203                                 },
204                                 'offline_inhouse_use' : {
205                                         'type' : 'offline_inhouse_use',
206                                         'header' : 'You marked the following in-house items used:<hr/><ol>',
207                                         'line_item' : '<li>Barcode: %barcode%\r\nUses: %count%',
208                                         'footer' : '</ol><hr />%TODAY_TRIM%<br/>\r\n<br/>\r\n',
209                                 },
210                                 'in_house_use' : {
211                                         'type' : 'items',
212                                         'header' : 'You marked the following in-house items used:<hr/><ol>',
213                                         'line_item' : '<li>Barcode: %barcode%\r\nUses: %uses%\r\n<br />%alert_message%',
214                                         'footer' : '</ol><hr />%TODAY_TRIM%<br/>\r\n<br/>\r\n',
215                                 },
216                                 'holds' : {
217                                         'type' : 'holds',
218                                         'header' : 'Welcome to %LIBRARY%!<br/>\r\nYou have the following titles on hold:<hr/><ol>',
219                                         'line_item' : '<li>%title%\r\n',
220                                         'footer' : '</ol><hr />%PINES_CODE% %TODAY_TRIM%<br/>\r\nYou were helped by %STAFF_FIRSTNAME%<br/>\r\n<br/>\r\n',
221                                 } 
222                         }; 
223
224                         obj.stash( 'print_list_templates', 'print_list_types' );
225                 }
226         },
227
228         'network_retrieve' : function() {
229                 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
230                 var obj = this;
231
232
233                 JSAN.use('util.file'); var file = new util.file('print_list_templates');
234                 obj.print_list_defaults();
235                 if (file._file.exists()) {
236                         try {
237                                 var x = file.get_object();
238                                 if (x) {
239                                         for (var i in x) {
240                                                 obj.print_list_templates[i] = x[i];
241                                         }
242                                         obj.stash('print_list_templates');
243                                 }
244                         } catch(E) {
245                                 alert(E);
246                         }
247                 }
248                 file.close();
249
250                 JSAN.use('util.file'); var file = new util.file('global_font_adjust');
251                 if (file._file.exists()) {
252                         try {
253                                 var x = file.get_object();
254                                 if (x) {
255                                         obj.global_font_adjust = x;
256                                         obj.stash('global_font_adjust');
257                                 }
258                         } catch(E) {
259                                 alert(E);
260                         }
261                 }
262                 file.close();
263
264                 JSAN.use('util.functional');
265                 JSAN.use('util.fm_utils');
266
267                 function gen_fm_retrieval_func(classname,data) {
268                         var app = data[0]; var method = data[1]; var params = data[2]; var cacheable = data[3];
269                         return function () {
270                                 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
271
272                                 function convert() {
273                                         netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
274                                         try {
275                                                 if (obj.list[classname].constructor.name == 'Array') {
276                                                         obj.hash[classname] = 
277                                                                 util.functional.convert_object_list_to_hash(
278                                                                         obj.list[classname]
279                                                                 );
280                                                 }
281                                         } catch(E) {
282
283                                                 obj.error.sdump('D_ERROR',E + '\n');
284                                         }
285
286                                 }
287
288                                 try {
289                                         var level = obj.error.sdump_levels.D_SES_RESULT;
290                                         if (classname == 'aou' || classname == 'my_aou')
291                                                 obj.error.sdump_levels.D_SES_RESULT = false;
292                                         var robj = obj.network.request( app, method, params);
293                                         if (!robj || robj.ilsevent) {
294                                                 obj.error.standard_unexpected_error_alert('The staff client failed to retrieve expected data from this call, "' + method + '"',robj);
295                                                 throw(robj);
296                                         }
297                                         obj.list[classname] = robj;
298                                         obj.error.sdump_levels.D_SES_RESULT = level;
299                                         convert();
300                                         // if cacheable, store an offline copy
301                                         /* FIXME -- we're going to revisit caching and do it differently
302                                         if (cacheable) {
303                                                 var file = new util.file( classname );
304                                                 file.set_object( obj.list[classname] );
305                                         }
306                                         */
307
308                                 } catch(E) {
309                                         // if cacheable, try offline
310                                         if (cacheable) {
311                                                 /* FIXME -- we're going to revisit caching and do it differently
312                                                 try {
313                                                         var file = new util.file( classname );
314                                                         obj.list[classname] = file.get_object(); file.close();
315                                                         convert();
316                                                 } catch(E) {
317                                                         throw(E);
318                                                 }
319                                                 */
320                                                 throw(E); // for now
321                                         } else {
322                                                 throw(E); // for now
323                                         }
324                                 }
325                         }
326                 }
327
328                 this.chain = [];
329
330                 this.chain.push(
331                         function() {
332                                 try {
333                                         var robj = obj.network.simple_request('CIRC_MODIFIER_LIST',[]);
334                                         if (typeof robj.ilsevent != 'undefined') throw(robj);
335                                         obj.list.circ_modifier = robj;
336                                 } catch(E) {
337                                         var error = 'Error: ' + js2JSON(E);
338                                         obj.error.sdump('D_ERROR',error);
339                                         throw(E);
340                                 }
341                         }
342                 );
343
344                 this.chain.push(
345                         function() {
346                                 try {
347                                         var robj = obj.network.simple_request('BILLING_TYPE_LIST',[]);
348                                         if (typeof robj.ilsevent != 'undefined') throw(robj);
349                                         obj.list.billing_type = robj;
350                                 } catch(E) {
351                                         var error = 'Error: ' + js2JSON(E);
352                                         obj.error.sdump('D_ERROR',error);
353                                         throw(E);
354                                 }
355                         }
356                 );
357
358
359                 this.chain.push(
360                         function() {
361                                 var f = gen_fm_retrieval_func(
362                                         'cnal',
363                                         [
364                                                 api.FM_CNAL_RETRIEVE.app,
365                                                 api.FM_CNAL_RETRIEVE.method,
366                                                 [ obj.session.key ],
367                                                 false
368                                         ]
369                                 );
370                                 try {
371                                         f();
372                                 } catch(E) {
373                                         var error = 'Error: ' + js2JSON(E);
374                                         obj.error.sdump('D_ERROR',error);
375                                         throw(E);
376                                 }
377                         }
378                 );
379
380                 this.chain.push(
381                         function() {
382                                 var f = gen_fm_retrieval_func(
383                                         'au',
384                                         [
385                                                 api.FM_AU_RETRIEVE_VIA_SESSION.app,
386                                                 api.FM_AU_RETRIEVE_VIA_SESSION.method,
387                                                 [ obj.session.key ],
388                                                 false
389                                         ]
390                                 );
391                                 try {
392                                         f();
393                                 } catch(E) {
394                                         var error = 'Error: ' + js2JSON(E);
395                                         obj.error.sdump('D_ERROR',error);
396                                         throw(E);
397                                 }
398                                 obj.list.au = [ obj.list.au ];
399                         }
400                 );
401
402                 this.chain.push(
403                         function() {
404                                 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
405                                 var f = gen_fm_retrieval_func(
406                                         'my_asv',
407                                         [
408                                                 api.FM_ASV_RETRIEVE_REQUIRED.app,
409                                                 api.FM_ASV_RETRIEVE_REQUIRED.method,
410                                                 [ obj.session.key ],
411                                                 true
412                                         ]
413                                 );
414                                 try {
415                                         netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
416                                         f();
417                                 } catch(E) {
418                                         var error = 'Error: ' + js2JSON(E);
419                                         obj.error.sdump('D_ERROR',error);
420                                         throw(E);
421                                 }
422                         }
423                 );
424
425                 this.chain.push(
426                         function() {
427                                 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
428                                 var f = gen_fm_retrieval_func(
429                                         'asv',
430                                         [
431                                                 api.FM_ASV_RETRIEVE.app,
432                                                 api.FM_ASV_RETRIEVE.method,
433                                                 [ obj.session.key ],
434                                                 true
435                                         ]
436                                 );
437                                 try {
438                                         netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
439                                         f();
440                                 } catch(E) {
441                                         var error = 'Error: ' + js2JSON(E);
442                                         obj.error.sdump('D_ERROR',error);
443                                         throw(E);
444                                 }
445                         }
446                 );
447
448                 obj.error.sdump('D_DEBUG','_fm_objects = ' + js2JSON(this._fm_objects) + '\n');
449
450                 for (var i in this._fm_objects) {
451                         this.chain.push( gen_fm_retrieval_func(i,this._fm_objects[i]) );
452                 }
453
454                 // The previous org_tree call returned a tree, not a list or hash.
455                 this.chain.push(
456                         function () {
457                                 obj.tree.aou = obj.list.aou;
458                                 obj.list.aou = util.fm_utils.flatten_ou_branch( obj.tree.aou );
459                                 obj.hash.aou = util.functional.convert_object_list_to_hash( obj.list.aou );
460                         }
461                 );
462
463                 // The previous pgt call returned a tree, not a list or hash.
464                 this.chain.push(
465                         function () {
466                                 obj.tree.pgt = obj.list.pgt;
467                                 obj.list.pgt = util.fm_utils.flatten_ou_branch( obj.tree.pgt );
468                                 obj.hash.pgt = util.functional.convert_object_list_to_hash( obj.list.pgt );
469                         }
470                 );
471
472                 // Do this after we get the user object
473                 this.chain.push(
474
475                         function() {
476
477                                 gen_fm_retrieval_func('my_aou', 
478                                         [ 
479                                                 api.FM_AOU_RETRIEVE_RELATED_VIA_SESSION.app,
480                                                 api.FM_AOU_RETRIEVE_RELATED_VIA_SESSION.method,
481                                                 [ obj.session.key, obj.list.au[0].ws_ou() ], /* use ws_ou and not home_ou */
482                                                 true
483                                         ]
484                                 )();
485                         }
486                 );
487
488                 this.chain.push(
489
490                         function () {
491
492                                 gen_fm_retrieval_func( 'my_actsc', 
493                                         [ 
494                                                 api.FM_ACTSC_RETRIEVE_VIA_AOU.app,
495                                                 api.FM_ACTSC_RETRIEVE_VIA_AOU.method,
496                                                 [ obj.session.key, obj.list.au[0].ws_ou() ],
497                                                 true
498                                         ]
499                                 )();
500                         }
501                 );
502
503                 this.chain.push(
504
505                         function () {
506
507                                 gen_fm_retrieval_func( 'my_asc', 
508                                         [ 
509                                                 api.FM_ASC_RETRIEVE_VIA_AOU.app,
510                                                 api.FM_ASC_RETRIEVE_VIA_AOU.method,
511                                                 [ obj.session.key, obj.list.au[0].ws_ou() ],
512                                                 true
513                                         ]
514                                 )();
515                         }
516                 );
517
518
519                 this.chain.push(
520                         function() {
521                                 var f = gen_fm_retrieval_func(
522                                         'cnct',
523                                         [
524                                                 api.FM_CNCT_RETRIEVE.app,
525                                                 api.FM_CNCT_RETRIEVE.method,
526                                                 [ obj.list.au[0].ws_ou() ], 
527                                                 false
528                                         ]
529                                 );
530                                 try {
531                                         f();
532                                 } catch(E) {
533                                         var error = 'Error: ' + js2JSON(E);
534                                         obj.error.sdump('D_ERROR',error);
535                                         throw(E);
536                                 }
537                         }
538                 );
539
540                 this.chain.push(
541                         function() {
542                                 var f = gen_fm_retrieval_func(
543                                         'acpl',
544                                         [
545                                                 api.FM_ACPL_RETRIEVE.app,
546                                                 api.FM_ACPL_RETRIEVE.method,
547                                                 [ obj.list.au[0].ws_ou() ],
548                                                 false
549                                         ]
550                                 );
551                                 try {
552                                         f();
553                                 } catch(E) {
554                                         var error = 'Error: ' + js2JSON(E);
555                                         obj.error.sdump('D_ERROR',error);
556                                         throw(E);
557                                 }
558                         }
559                 );
560
561
562
563                 if (typeof this.on_complete == 'function') {
564
565                         this.chain.push( this.on_complete );
566                 }
567                 JSAN.use('util.exec'); this.exec = new util.exec();
568                 this.exec.on_error = function(E) { 
569                 
570                         if (typeof obj.on_error == 'function') {
571                                 obj.on_error();
572                         } else {
573                                 alert('oops: ' + E ); 
574                         }
575
576                         return false; /* break chain */
577                 }
578
579                 this.exec.chain( this.chain );
580
581         }
582 }
583
584 dump('exiting OpenILS/data.js\n');