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