]> git.evergreen-ils.org Git - working/Evergreen.git/blob - Open-ILS/xul/staff_client/server/patron/bill_history.js
Address date sorting in Item Status and Copy Buckets interfaces, too
[working/Evergreen.git] / Open-ILS / xul / staff_client / server / patron / bill_history.js
1 function $(id) { return document.getElementById(id); }
2 var payment_history_fetched = false;
3
4 function tally_selected() {
5     try {
6         JSAN.use('util.money');
7         var selected_billed = 0;
8         var selected_paid = 0;
9
10         for (var i = 0; i < g.bill_list_selection.length; i++) {
11             var bill = g.bill_map[g.bill_list_selection[i]];
12             if (!bill) {
13                 $('billed_tally').setAttribute('value', '???');
14                 $('paid_tally').setAttribute('value', '???');
15                 return;
16             }
17             var to = util.money.dollars_float_to_cents_integer( bill.transaction.total_owed() );
18             var tp = util.money.dollars_float_to_cents_integer( bill.transaction.total_paid() );
19             selected_billed += to;
20             selected_paid += tp;
21         }
22         $('billed_tally').setAttribute('value', util.money.cents_as_dollars( selected_billed ) );
23         $('paid_tally').setAttribute('value', util.money.cents_as_dollars( selected_paid ) );
24     } catch(E) {
25         alert('Error in bill_history.js, tally_selected(): ' + E);
26     }
27 }
28
29 function payments_tally_selected() {
30     try {
31         JSAN.use('util.money');
32         var selected_paid = 0;
33
34         for (var i = 0; i < g.payments_list_selection.length; i++) {
35             var payment = g.payments_map[g.payments_list_selection[i].id];
36             if (!payment) {
37                 $('payments_paid_tally').setAttribute('value', '???');
38                 return;
39             }
40             var amount = util.money.dollars_float_to_cents_integer( payment.amount() );
41             selected_paid += amount;
42         }
43         $('payments_paid_tally').setAttribute('value', util.money.cents_as_dollars( selected_paid ) );
44     } catch(E) {
45         alert('Error in bill_history.js, payments_tally_selected(): ' + E);
46     }
47 }
48
49
50 function retrieve_mbts_for_list() {
51     //var method = 'FM_MBTS_IDS_RETRIEVE_ALL_HAVING_CHARGE';
52     var method = 'FM_MBTS_IDS_RETRIEVE_FOR_HISTORY.authoritative';
53     var date2 = $('bills_date2').dateValue;
54     date2.setDate( date2.getDate() + 1 ); // Javascript will wrap into subsequent months
55     var filter = {
56         'xact_start' : {
57             'between' : [
58                 $('bills_date1').value,
59                 $('bills_date2').value == util.date.formatted_date(new Date(),'%F') ?
60                     'now' : util.date.formatted_date( date2 ,'%F')
61             ]
62         }
63     }
64     g.mbts_ids = g.network.simple_request(method,[ses(),g.patron_id, null, filter]);
65     if (g.mbts_ids.ilsevent) {
66         switch(Number(g.mbts_ids.ilsevent)) {
67             case -1: g.error.standard_network_error_alert($("patronStrings").getString('staff.patron.bill_history.retrieve_mbts_for_list.close_win_try_again')); break;
68             default: g.error.standard_unexpected_error_alert($("patronStrings").getString('staff.patron.bill_history.retrieve_mbts_for_list.close_win_try_again'),g.mbts_ids); break;
69         }
70     } else if (g.mbts_ids == null) {
71         g.error.standard_unexpected_error_alert($("patronStrings").getString('staff.patron.bill_history.retrieve_mbts_for_list.close_win_try_again'),null);
72     } else {
73         //g.mbts_ids.reverse();
74     
75         function gen_func(r) {
76             return function() {
77                 if (typeof r == 'object') {
78                     g.bill_list.append( 
79                         { 
80                             'retrieve_id' : r.id(), 
81                             'row' : { 
82                                 'my' : { 
83                                     'mbts' : r 
84                                 } 
85                             } 
86                         } 
87                     );
88                 } else {
89                     g.bill_list.append( 
90                         { 
91                             'retrieve_id' : r, 
92                             'row' : { 
93                                 'my' : {} 
94                             } 
95                         } 
96                     );
97                 }
98             }
99         }
100
101         g.bill_list.clear(); $('bills_meter').hidden = false;
102         for (var i = 0; i < g.mbts_ids.length; i++) {
103             dump('i = ' + i + ' g.mbts_ids[i] = ' + g.mbts_ids[i] + '\n');
104             g.funcs.push( gen_func(g.mbts_ids[i]) );
105         }
106         g.funcs.push( function() { $('bills_meter').hidden = true; } );
107     }
108 }
109
110 function init_lists() {
111     JSAN.use('util.list'); JSAN.use('circ.util'); 
112
113     init_main_list();
114     init_payments_list();
115 }
116
117 function init_main_list() {
118     g.bill_list_selection = [];
119
120     g.bill_list = new util.list('bill_tree');
121
122     g.bill_list.init( {
123         'columns' : 
124             patron.util.mbts_columns({
125                 'xact_finish' : { 'hidden' : false }
126             }).concat( 
127             circ.util.columns({ 
128                 'title' : { 'hidden' : false, 'flex' : '3' }
129             }) 
130         ),
131         'on_select' : function(ev) {
132             JSAN.use('util.functional');
133             g.bill_list_selection = util.functional.map_list(
134                 g.bill_list.retrieve_selection(),
135                 function(o) { return o.getAttribute('retrieve_id'); }
136             );
137             tally_selected();
138             $('details').disabled = g.bill_list_selection.length == 0;
139             $('copy_details').disabled = g.bill_list_selection.length == 0;
140             $('add').disabled = g.bill_list_selection.length == 0;
141             $('summary').hidden = g.bill_list_selection.length == 0;
142             $('copy_summary').hidden = g.bill_list_selection.length == 0;
143         },
144         'retrieve_row' : function(params) {
145             var id = params.retrieve_id;
146             var row = params.row;
147             if (id) {
148                 if (typeof row.my == 'undefined') row.my = {};
149                 if (typeof row.my.mbts == 'undefined' ) {
150                     g.network.simple_request('BLOB_MBTS_DETAILS_RETRIEVE',[ses(),id], function(req) {
151                         var blob = req.getResultObject();
152                         row.my.mbts = blob.transaction;
153                         row.my.circ = blob.circ;
154                         row.my.acp = blob.copy;
155                         row.my.mvr = blob.record;
156                         g.bill_map[ id ] = blob;
157                         if (typeof params.on_retrieve == 'function') {
158                             params.on_retrieve(row);
159                         };
160                         tally_selected();
161                     } );
162                 }
163             }
164             return row;
165         },
166     } );
167
168     $('bill_list_actions').appendChild( g.bill_list.render_list_actions() );
169     g.bill_list.set_list_actions();
170 }
171
172 function init_payments_list() {
173     g.payments_list_selection = [];
174
175     g.payments_list = new util.list('payments_tree');
176
177     g.payments_list.init( {
178         'columns' : g.payments_list.fm_columns('mp').concat( [
179             {
180                 'id' : 'payments_blob_xact_type', 'flex' : 0,
181                 'label' : $('patronStrings').getString('staff.patron.bill_history.column.xact_type.label'),
182                 'render' : function(my) { return my.xact_type; }
183             },
184             {
185                 'id' : 'payments_blob_last_billing_type', 'flex' : 0,
186                 'label' : $('patronStrings').getString('staff.patron.bill_history.column.last_billing_type.label'),
187                 'render' : function(my) { return my.last_billing_type; }
188             },
189             {
190                 'id' : 'payments_blob_title', 'flex' : 1,
191                 'label' : $('patronStrings').getString('staff.patron.bill_history.column.title.label'),
192                 'render' : function(my) { return my.title; }
193             }
194         ] ),
195         'on_select' : function(ev) {
196             JSAN.use('util.functional');
197             g.payments_list_selection = util.functional.map_list(
198                 g.payments_list.retrieve_selection(),
199                 function(o) { return JSON2js( o.getAttribute('retrieve_id') ); }
200             );
201             payments_tally_selected();
202             $('payments_details').disabled = g.payments_list_selection.length == 0;
203             $('copy_details_from_payments').disabled = g.payments_list_selection.length == 0;
204         },
205         'retrieve_row' : function(params) {
206             var id = params.retrieve_id;
207             var row = params.row;
208             if (typeof params.on_retrieve == 'function') {
209                 params.on_retrieve(row);
210             };
211             return row;
212         },
213     } );
214
215     $('payments_list_actions').appendChild( g.payments_list.render_list_actions() );
216     g.payments_list.set_list_actions();
217 }
218
219 function my_init() {
220     try {
221         netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
222         if (typeof JSAN == 'undefined') { throw( $("commonStrings").getString('common.jsan.missing') ); }
223         JSAN.errorLevel = "die"; // none, warn, or die
224         JSAN.addRepository('/xul/server/');
225
226         JSAN.use('util.error'); g.error = new util.error();
227         JSAN.use('util.network'); g.network = new util.network();
228         JSAN.use('util.date');
229         JSAN.use('util.money');
230         JSAN.use('patron.util');
231         JSAN.use('OpenILS.data'); g.data = new OpenILS.data(); g.data.init({'via':'stash'});
232         //g.data.temp = ''; g.data.stash('temp');
233
234         g.error.sdump('D_TRACE','my_init() for bill_history.xul');
235
236         document.title = $("patronStrings").getString('staff.patron.bill_history.my_init.bill_history');
237
238         g.funcs = []; g.bill_map = {}; g.payments_map = {};
239
240         g.patron_id = xul_param('patron_id');
241
242         init_lists();
243
244         $('bills_date1').year = $('bills_date1').year - 1;
245
246         retrieve_mbts_for_list();
247
248         $('details').addEventListener(
249             'command',
250             gen_handle_details('bills'),
251             false
252         );
253
254         $('payments_details').addEventListener(
255             'command',
256             gen_handle_details('payments'),
257             false
258         );
259
260         $('copy_details').addEventListener(
261             'command',
262             gen_handle_copy_details('bills'),
263             false
264         );
265
266         $('copy_details_from_payments').addEventListener(
267             'command',
268             gen_handle_copy_details('payments'),
269             false
270         );
271
272         $('add').addEventListener(
273             'command',
274             handle_add,
275             false
276         );
277
278         JSAN.use('util.exec'); var exec = new util.exec(20); 
279         exec.on_error = function(E) { alert(E); return true; }
280         exec.timer(g.funcs,100);
281     } catch(E) {
282         var err_msg = $("commonStrings").getFormattedString('common.exception', ['patron/bill_history.xul', E]);
283         try { g.error.sdump('D_ERROR',err_msg); } catch(E) { dump(err_msg); }
284         alert(err_msg);
285     }
286 }
287
288 function handle_add() {
289     if(g.bill_list_selection.length > 1)
290         var msg = $("patronStrings").getFormattedString('staff.patron.bill_history.handle_add.message_plural', [g.bill_list_selection]);
291     else
292         var msg = $("patronStrings").getFormattedString('staff.patron.bill_history.handle_add.message_singular', [g.bill_list_selection]);
293         
294     var r = g.error.yns_alert(msg,
295         $("patronStrings").getString('staff.patron.bill_history.handle_add.title'),
296         $("patronStrings").getString('staff.patron.bill_history.handle_add.btn_yes'),
297         $("patronStrings").getString('staff.patron.bill_history.handle_add.btn_no'),null,
298         $("patronStrings").getString('staff.patron.bill_history.handle_add.confirm_message'));
299     if (r == 0) {
300         JSAN.use('util.window');
301         var win = new util.window();
302         for (var i = 0; i < g.bill_list_selection.length; i++) {
303             var w = win.open(
304                 urls.XUL_PATRON_BILL_WIZARD,
305                 'billwizard',
306                 'chrome,resizable,modal',
307                 { 'patron_id' : g.patron_id, 'xact_id' : g.bill_list_selection[i] }
308             );
309         }
310         g.bill_list.clear();
311         retrieve_mbts_for_list();
312         if (typeof window.refresh == 'function') window.refresh();
313         if (typeof window.xulG == 'object' && typeof window.xulG.refresh == 'function') window.xulG.refresh();
314     }
315 }
316
317 function gen_handle_details(which_list) {
318     return function() {
319         JSAN.use('util.functional');
320         var selection;
321         switch(which_list) {
322             case 'payments': selection = util.functional.map_list( g.payments_list_selection, function(o) { return o.xact; } ); break;
323             default: selection = g.bill_list_selection; break;
324         }
325         JSAN.use('util.window'); var win = new util.window();
326         for (var i = 0; i < selection.length; i++) {
327             var my_xulG = win.open(
328                 urls.XUL_PATRON_BILL_DETAILS,
329                 'test_billdetails_' + selection[i],
330                 'chrome,resizable',
331                 {
332                     'patron_id' : g.patron_id,
333                     'mbts_id' : selection[i],
334                     'refresh' : function() { 
335                         if (typeof window.refresh == 'function') window.refresh();
336                         if (typeof window.xulG == 'object' && typeof window.xulG.refresh == 'function') window.xulG.refresh();
337                     }, 
338                 }
339             );
340         }
341     };
342 }
343
344 function gen_handle_copy_details(which_list) {
345     return function() {
346         try {
347             JSAN.use('util.functional');
348             var selection;
349             switch(which_list) {
350                 case 'payments': selection = util.functional.map_list( g.payments_list_selection, function(o) { return o.xact; } ); break;
351                 default: selection = g.bill_list_selection; break;
352             }
353             var ids = [];
354             for (var i = 0; i < selection.length; i++) {
355                 var blob = g.network.simple_request('BLOB_MBTS_DETAILS_RETRIEVE',[ses(),selection[i]]);
356                 if (blob.copy) { ids.push( blob.copy.barcode() ) }
357             }
358             JSAN.use('circ.util');
359             circ.util.item_details_new(ids);
360         } catch(E) {
361             alert('Error in bill_history.js, handle_copy_details(): ' + E);
362         }
363     };
364 }
365
366 function print_bills() {
367     try {
368         var template = 'bills_historical';
369         JSAN.use('patron.util');
370         var params = { 
371             'patron' : patron.util.retrieve_fleshed_au_via_id(ses(),g.patron_id,null), 
372             'template' : template
373         };
374         g.bill_list.print(params);
375     } catch(E) {
376         g.error.standard_unexpected_error_alert($("patronStrings").getString('staff.patron.bill_history.print_bills.print_error'), E);
377     }
378 }
379
380 function payment_history_init() {
381     try {
382         if (payment_history_fetched) { return; } else { payment_history_fetched = true; }
383
384         $('payments_date1').year = $('payments_date1').year - 1;
385
386         retrieve_payments();
387
388     } catch(E) {
389         alert('Error in bill_history.js, payment_history_init(): ' + E);
390     }
391 }
392
393 function retrieve_payments() {
394     try {
395
396         g.payments_list.clear();
397
398         $('payments_meter').hidden = false;
399
400         var date2 = $('payments_date2').dateValue;
401         date2.setDate( date2.getDate() + 1 ); // Javascript will wrap into subsequent months
402         var filters = {
403             'where' : {
404                 'payment_ts' : {
405                     'between' : [
406                         $('payments_date1').value,
407                         $('payments_date2').value == util.date.formatted_date(new Date(),'%F') ? 
408                             'now' : util.date.formatted_date( date2 ,'%F')
409                     ]
410                 }
411             }
412         };
413
414         fieldmapper.standardRequest(
415             [ api.FM_MP_RETRIEVE_VIA_USER.app, api.FM_MP_RETRIEVE_VIA_USER.method ],
416             {   async: true,
417                 params: [ses(), g.patron_id, filters],
418                 onresponse: function(r) {
419                     try {
420                         var result = r.recv().content();
421
422                         if (result && typeof result.ilsevent == 'undefined') {
423                             g.payments_list.append( 
424                                 { 
425                                     'retrieve_id' : js2JSON( { 'id' : result.mp.id(), 'xact' : result.mp.xact() } ),
426                                     'row' : { 
427                                         'my' : { 
428                                             'mp' : result.mp,
429                                             'xact_type' : result.xact_type,
430                                             'last_billing_type' : result.last_billing_type,
431                                             'title' : result.title
432                                         } 
433                                     } 
434                                 } 
435                             );
436                             g.payments_map[ result.mp.id() ] = result.mp;
437                         } else {
438                             throw( js2JSON(result) );
439                         }
440                     } catch(E) {
441                         alert('Error retrieving payment in bill_history.js, onresponse: ' + E);                        
442                     }
443                 },
444                 oncomplete: function() {
445                     $('payments_meter').hidden = true;
446                 },
447                 onerror: function(r) {
448                     var result = r.recv().content();
449                     alert('Error retrieving payment in bill_history.js, onerror: ' + js2JSON(result));                        
450                 }
451             }
452         );
453
454     } catch(E) {
455         alert('Error in bill_history.js, retrieve_payments(): ' + E);
456     }
457 }