]> git.evergreen-ils.org Git - working/Evergreen.git/blob - Open-ILS/xul/staff_client/server/patron/bill_history.js
Fix: Current Bills thinks it is Bill History
[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         'map_row_to_columns' : patron.util.std_map_row_to_columns(' '),
132         'on_select' : function(ev) {
133             JSAN.use('util.functional');
134             g.bill_list_selection = util.functional.map_list(
135                 g.bill_list.retrieve_selection(),
136                 function(o) { return o.getAttribute('retrieve_id'); }
137             );
138             tally_selected();
139             $('details').disabled = g.bill_list_selection.length == 0;
140             $('copy_details').disabled = g.bill_list_selection.length == 0;
141             $('add').disabled = g.bill_list_selection.length == 0;
142             $('summary').hidden = g.bill_list_selection.length == 0;
143             $('copy_summary').hidden = g.bill_list_selection.length == 0;
144         },
145         'retrieve_row' : function(params) {
146             var id = params.retrieve_id;
147             var row = params.row;
148             if (id) {
149                 if (typeof row.my == 'undefined') row.my = {};
150                 if (typeof row.my.mbts == 'undefined' ) {
151                     g.network.simple_request('BLOB_MBTS_DETAILS_RETRIEVE',[ses(),id], function(req) {
152                         var blob = req.getResultObject();
153                         row.my.mbts = blob.transaction;
154                         row.my.circ = blob.circ;
155                         row.my.acp = blob.copy;
156                         row.my.mvr = blob.record;
157                         g.bill_map[ id ] = blob;
158                         if (typeof params.on_retrieve == 'function') {
159                             params.on_retrieve(row);
160                         };
161                         tally_selected();
162                     } );
163                 }
164             }
165             return row;
166         },
167     } );
168
169     $('bill_list_actions').appendChild( g.bill_list.render_list_actions() );
170     g.bill_list.set_list_actions();
171 }
172
173 function init_payments_list() {
174     g.payments_list_selection = [];
175
176     g.payments_list = new util.list('payments_tree');
177
178     g.payments_list.init( {
179         'columns' : g.payments_list.fm_columns('mp').concat( [
180             {
181                 'id' : 'payments_blob_xact_type', 'flex' : 0,
182                 'label' : $('patronStrings').getString('staff.patron.bill_history.column.xact_type.label'),
183                 'render' : function(my) { return my.xact_type; }
184             },
185             {
186                 'id' : 'payments_blob_last_billing_type', 'flex' : 0,
187                 'label' : $('patronStrings').getString('staff.patron.bill_history.column.last_billing_type.label'),
188                 'render' : function(my) { return my.last_billing_type; }
189             },
190             {
191                 'id' : 'payments_blob_title', 'flex' : 1,
192                 'label' : $('patronStrings').getString('staff.patron.bill_history.column.title.label'),
193                 'render' : function(my) { return my.title; }
194             }
195         ] ),
196         'on_select' : function(ev) {
197             JSAN.use('util.functional');
198             g.payments_list_selection = util.functional.map_list(
199                 g.payments_list.retrieve_selection(),
200                 function(o) { return JSON2js( o.getAttribute('retrieve_id') ); }
201             );
202             payments_tally_selected();
203             $('payments_details').disabled = g.payments_list_selection.length == 0;
204             $('copy_details_from_payments').disabled = g.payments_list_selection.length == 0;
205         },
206         'retrieve_row' : function(params) {
207             var id = params.retrieve_id;
208             var row = params.row;
209             if (typeof params.on_retrieve == 'function') {
210                 params.on_retrieve(row);
211             };
212             return row;
213         },
214     } );
215
216     $('payments_list_actions').appendChild( g.payments_list.render_list_actions() );
217     g.payments_list.set_list_actions();
218 }
219
220 function my_init() {
221     try {
222         netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
223         if (typeof JSAN == 'undefined') { throw( $("commonStrings").getString('common.jsan.missing') ); }
224         JSAN.errorLevel = "die"; // none, warn, or die
225         JSAN.addRepository('/xul/server/');
226
227         JSAN.use('util.error'); g.error = new util.error();
228         JSAN.use('util.network'); g.network = new util.network();
229         JSAN.use('util.date');
230         JSAN.use('util.money');
231         JSAN.use('patron.util');
232         JSAN.use('OpenILS.data'); g.data = new OpenILS.data(); g.data.init({'via':'stash'});
233         //g.data.temp = ''; g.data.stash('temp');
234
235         g.error.sdump('D_TRACE','my_init() for bill_history.xul');
236
237         document.title = $("patronStrings").getString('staff.patron.bill_history.my_init.bill_history');
238
239         g.funcs = []; g.bill_map = {}; g.payments_map = {};
240
241         g.patron_id = xul_param('patron_id');
242
243         init_lists();
244
245         $('bills_date1').year = $('bills_date1').year - 1;
246
247         retrieve_mbts_for_list();
248
249         $('details').addEventListener(
250             'command',
251             gen_handle_details('bills'),
252             false
253         );
254
255         $('payments_details').addEventListener(
256             'command',
257             gen_handle_details('payments'),
258             false
259         );
260
261         $('copy_details').addEventListener(
262             'command',
263             gen_handle_copy_details('bills'),
264             false
265         );
266
267         $('copy_details_from_payments').addEventListener(
268             'command',
269             gen_handle_copy_details('payments'),
270             false
271         );
272
273         $('add').addEventListener(
274             'command',
275             handle_add,
276             false
277         );
278
279         JSAN.use('util.exec'); var exec = new util.exec(20); 
280         exec.on_error = function(E) { alert(E); return true; }
281         exec.timer(g.funcs,100);
282     } catch(E) {
283         var err_msg = $("commonStrings").getFormattedString('common.exception', ['patron/bill_history.xul', E]);
284         try { g.error.sdump('D_ERROR',err_msg); } catch(E) { dump(err_msg); }
285         alert(err_msg);
286     }
287 }
288
289 function handle_add() {
290     if(g.bill_list_selection.length > 1)
291         var msg = $("patronStrings").getFormattedString('staff.patron.bill_history.handle_add.message_plural', [g.bill_list_selection]);
292     else
293         var msg = $("patronStrings").getFormattedString('staff.patron.bill_history.handle_add.message_singular', [g.bill_list_selection]);
294         
295     var r = g.error.yns_alert(msg,
296         $("patronStrings").getString('staff.patron.bill_history.handle_add.title'),
297         $("patronStrings").getString('staff.patron.bill_history.handle_add.btn_yes'),
298         $("patronStrings").getString('staff.patron.bill_history.handle_add.btn_no'),null,
299         $("patronStrings").getString('staff.patron.bill_history.handle_add.confirm_message'));
300     if (r == 0) {
301         JSAN.use('util.window');
302         var win = new util.window();
303         for (var i = 0; i < g.bill_list_selection.length; i++) {
304             var w = win.open(
305                 urls.XUL_PATRON_BILL_WIZARD,
306                 'billwizard',
307                 'chrome,resizable,modal',
308                 { 'patron_id' : g.patron_id, 'xact_id' : g.bill_list_selection[i] }
309             );
310         }
311         g.bill_list.clear();
312         retrieve_mbts_for_list();
313         if (typeof window.refresh == 'function') window.refresh();
314         if (typeof window.xulG == 'object' && typeof window.xulG.refresh == 'function') window.xulG.refresh();
315     }
316 }
317
318 function gen_handle_details(which_list) {
319     return function() {
320         JSAN.use('util.functional');
321         var selection;
322         switch(which_list) {
323             case 'payments': selection = util.functional.map_list( g.payments_list_selection, function(o) { return o.xact; } ); break;
324             default: selection = g.bill_list_selection; break;
325         }
326         JSAN.use('util.window'); var win = new util.window();
327         for (var i = 0; i < selection.length; i++) {
328             var my_xulG = win.open(
329                 urls.XUL_PATRON_BILL_DETAILS,
330                 'test_billdetails_' + selection[i],
331                 'chrome,resizable',
332                 {
333                     'patron_id' : g.patron_id,
334                     'mbts_id' : selection[i],
335                     'refresh' : function() { 
336                         if (typeof window.refresh == 'function') window.refresh();
337                         if (typeof window.xulG == 'object' && typeof window.xulG.refresh == 'function') window.xulG.refresh();
338                     }, 
339                 }
340             );
341         }
342     };
343 }
344
345 function gen_handle_copy_details(which_list) {
346     return function() {
347         try {
348             JSAN.use('util.functional');
349             var selection;
350             switch(which_list) {
351                 case 'payments': selection = util.functional.map_list( g.payments_list_selection, function(o) { return o.xact; } ); break;
352                 default: selection = g.bill_list_selection; break;
353             }
354             var ids = [];
355             for (var i = 0; i < selection.length; i++) {
356                 var blob = g.network.simple_request('BLOB_MBTS_DETAILS_RETRIEVE',[ses(),selection[i]]);
357                 if (blob.copy) { ids.push( blob.copy.barcode() ) }
358             }
359             JSAN.use('circ.util');
360             circ.util.item_details_new(ids);
361         } catch(E) {
362             alert('Error in bill_history.js, handle_copy_details(): ' + E);
363         }
364     };
365 }
366
367 function print_bills() {
368     try {
369         var template = 'bills_historical';
370         JSAN.use('patron.util');
371         var params = { 
372             'patron' : patron.util.retrieve_fleshed_au_via_id(ses(),g.patron_id,null), 
373             'template' : template
374         };
375         g.bill_list.print(params);
376     } catch(E) {
377         g.error.standard_unexpected_error_alert($("patronStrings").getString('staff.patron.bill_history.print_bills.print_error'), E);
378     }
379 }
380
381 function payment_history_init() {
382     try {
383         if (payment_history_fetched) { return; } else { payment_history_fetched = true; }
384
385         $('payments_date1').year = $('payments_date1').year - 1;
386
387         retrieve_payments();
388
389     } catch(E) {
390         alert('Error in bill_history.js, payment_history_init(): ' + E);
391     }
392 }
393
394 function retrieve_payments() {
395     try {
396
397         g.payments_list.clear();
398
399         $('payments_meter').hidden = false;
400
401         var date2 = $('payments_date2').dateValue;
402         date2.setDate( date2.getDate() + 1 ); // Javascript will wrap into subsequent months
403         var filters = {
404             'where' : {
405                 'payment_ts' : {
406                     'between' : [
407                         $('payments_date1').value,
408                         $('payments_date2').value == util.date.formatted_date(new Date(),'%F') ? 
409                             'now' : util.date.formatted_date( date2 ,'%F')
410                     ]
411                 }
412             }
413         };
414
415         fieldmapper.standardRequest(
416             [ api.FM_MP_RETRIEVE_VIA_USER.app, api.FM_MP_RETRIEVE_VIA_USER.method ],
417             {   async: true,
418                 params: [ses(), g.patron_id, filters],
419                 onresponse: function(r) {
420                     try {
421                         var result = r.recv().content();
422
423                         if (result && typeof result.ilsevent == 'undefined') {
424                             g.payments_list.append( 
425                                 { 
426                                     'retrieve_id' : js2JSON( { 'id' : result.mp.id(), 'xact' : result.mp.xact() } ),
427                                     'row' : { 
428                                         'my' : { 
429                                             'mp' : result.mp,
430                                             'xact_type' : result.xact_type,
431                                             'last_billing_type' : result.last_billing_type,
432                                             'title' : result.title
433                                         } 
434                                     } 
435                                 } 
436                             );
437                             g.payments_map[ result.mp.id() ] = result.mp;
438                         } else {
439                             throw( js2JSON(result) );
440                         }
441                     } catch(E) {
442                         alert('Error retrieving payment in bill_history.js, onresponse: ' + E);                        
443                     }
444                 },
445                 oncomplete: function() {
446                     $('payments_meter').hidden = true;
447                 },
448                 onerror: function(r) {
449                     var result = r.recv().content();
450                     alert('Error retrieving payment in bill_history.js, onerror: ' + js2JSON(result));                        
451                 }
452             }
453         );
454
455     } catch(E) {
456         alert('Error in bill_history.js, retrieve_payments(): ' + E);
457     }
458 }