]> git.evergreen-ils.org Git - Evergreen.git/blob - Open-ILS/xul/staff_client/server/admin/offline_manage_xacts.js
session browse for exceptions, status
[Evergreen.git] / Open-ILS / xul / staff_client / server / admin / offline_manage_xacts.js
1 dump('entering admin/offline_manage_xacts.js\n');
2
3 if (typeof admin == 'undefined') admin = {};
4 admin.offline_manage_xacts = function (params) {
5
6         JSAN.use('util.error'); this.error = new util.error();
7         JSAN.use('util.network'); this.network = new util.network();
8 }
9
10 admin.offline_manage_xacts.prototype = {
11
12         'sel_list' : [],
13         'seslist' : [],
14
15         'init' : function( params ) {
16
17                 var obj = this;
18
19                 JSAN.use('OpenILS.data'); obj.data = new OpenILS.data(); obj.data.init({'via':'stash'});
20
21                 obj.init_list(); obj.init_script_list(); obj.init_error_list();
22
23                 obj.retrieve_seslist(); obj.render_seslist();
24
25                 var x = document.getElementById('create');
26                 if (obj.check_perm(obj.session,'OFFLINE_CREATE_SESSION')) {
27                         x.disabled = false;
28                         x.addEventListener('command',function() { try{obj.create_ses();}catch(E){alert(E);} },false);
29                 }
30
31                 x = document.getElementById('upload');
32                 x.addEventListener('command',function() { try{obj.upload();}catch(E){alert(E);} },false);
33
34                 x = document.getElementById('refresh');
35                 x.addEventListener('command',function() { try{obj.retrieve_seslist();obj.render_seslist();}catch(E){alert(E);} },false);
36
37                 x = document.getElementById('execute');
38                 x.addEventListener('command',function() { try{obj.execute_ses();}catch(E){alert(E);} },false);
39
40                 document.getElementById('deck').selectedIndex = 2;
41         },
42
43         'init_list' : function() {
44                 var obj = this; JSAN.use('util.list'); 
45                 obj.list = new util.list('session_tree');
46                 obj.list.init( {
47                         'columns' : [
48                                 {
49                                         'id' : 'org', 'hidden' : 'true', 'flex' : '1',
50                                         'label' : 'Organization',
51                                         'render' : 'data.hash.aou[ my.org ].shortname()',
52                                 },
53                                 { 
54                                         'id' : 'description', 'flex' : '2',
55                                         'label' : 'Description', 
56                                         'render' : "my.description", 
57                                 },
58                                 {
59                                         'id' : 'create_time', 'flex' : '1',
60                                         'label' : 'Date Created',
61                                         'render' : 'if (my.create_time) { var x = new Date(); x.setTime(my.create_time+"000"); util.date.formatted_date(x,"%F %H:%M"); } else { ""; }',
62                                 },
63                                 {
64                                         'id' : 'creator', 'flex' : '1', 'hidden' : 'true',
65                                         'label' : 'Created By',
66                                         'render' : 'my.creator',
67                                 },
68                                 { 
69                                         'id' : 'count', 'flex' : '1',
70                                         'label' : 'Upload Count', 
71                                         'render' : "my.scripts.length", 
72                                 },
73                                 { 
74                                         'id' : 'num_complete', 'flex' : '1', 
75                                         'label' : 'Transactions Processed', 
76                                         'render' : "my.num_complete", 
77                                 },
78                                 { 
79                                         'id' : 'in_process', 'flex' : '1',
80                                         'label' : 'Processing?', 
81                                         'render' : "if (my.end_time) { 'Completed' } else {my.in_process == 0 ? 'No' : 'Yes'}", 
82                                 },
83                                 {
84                                         'id' : 'start_time', 'flex' : '1', 'hidden' : 'true',
85                                         'label' : 'Date Started',
86                                         'render' : 'if (my.start_time) {var x = new Date(); x.setTime(my.start_time+"000"); util.date.formatted_date(x,"%F %H:%M");} else { ""; }',
87                                 },
88                                 {
89                                         'id' : 'end_time', 'flex' : '1',
90                                         'label' : 'Date Completed',
91                                         'render' : 'if (my.end_time) {var x = new Date(); x.setTime(my.end_time+"000"); util.date.formatted_date(x,"%F %H:%M");} else { ""; }',
92                                 },
93                                 { 
94                                         'id' : 'key', 'hidden' : 'true', 'flex' : '1', 
95                                         'label' : 'Session', 
96                                         'render' : "my.key", 
97                                 },
98                         ],
99                         'map_row_to_column' : function(row,col) {
100                                 JSAN.use('util.date');
101                                 JSAN.use('OpenILS.data'); var data = new OpenILS.data(); data.init({'via':'stash'});
102                                 var my = row; var value;
103                                 try { value = eval( col.render ); } catch(E) { obj.error.sdump('D_ERROR',E); value = '???'; }
104                                 return value;
105                         },
106                         'on_select' : function(ev) {
107                                 try {
108                                         JSAN.use('util.functional');
109                                         var sel = obj.list.retrieve_selection();
110                                         obj.sel_list = util.functional.map_list(
111                                                 sel,
112                                                 function(o) { return o.getAttribute('retrieve_id'); }
113                                         );
114                                         if (obj.check_perm(obj.session,'OFFLINE_EXECUTE_SESSION')) {
115                                                 document.getElementById('execute').disabled = false;    
116                                         }
117                                         if (obj.check_perm(obj.session,'OFFLINE_UPLOAD_XACTS')) {
118                                                 document.getElementById('upload').disabled = false;     
119                                         }
120                                         var complete = false;
121                                         for (var i = 0; i < obj.sel_list.length; i++) { 
122                                                 if (obj.seslist[ obj.sel_list[i] ].end_time) { complete = true; }
123                                         }
124                                         if (complete) {
125                                                 obj.render_errorlist();
126                                         } else {
127                                                 obj.render_scriptlist();
128                                         }
129                                 } catch(E) {
130                                         alert('on_select: ' + E);
131                                 }
132                         },
133                 } );
134
135
136         },
137
138         'init_script_list' : function() {
139                 var obj = this; JSAN.use('util.list'); 
140                 obj.script_list = new util.list('script_tree');
141                 obj.script_list.init( {
142                         'columns' : [
143                                 {
144                                         'id' : 'create_time', 'flex' : '1',
145                                         'label' : 'Date Uploaded',
146                                         'render' : 'if (my.create_time) { var x = new Date(); x.setTime(my.create_time+"000"); util.date.formatted_date(x,"%F %H:%M"); } else { ""; }',
147                                 },
148                                 {
149                                         'id' : 'requestor', 'flex' : '1', 'hidden' : 'true',
150                                         'label' : 'Uploaded By',
151                                         'render' : 'my.requestor',
152                                 },
153                                 { 
154                                         'id' : 'time_delta', 'hidden' : 'true', 'flex' : '1', 
155                                         'label' : 'Server/Local Time Delta', 
156                                         'render' : "my.time_delta", 
157                                 },
158                                 { 
159                                         'id' : 'workstation', 'flex' : '1', 
160                                         'label' : 'Workstation', 
161                                         'render' : "my.workstation", 
162                                 },
163                         ],
164                         'map_row_to_column' : function(row,col) {
165                                 JSAN.use('util.date');
166                                 JSAN.use('OpenILS.data'); var data = new OpenILS.data(); data.init({'via':'stash'});
167                                 var my = row; var value;
168                                 try { value = eval( col.render ); } catch(E) { obj.error.sdump('D_ERROR',E); value = '???'; }
169                                 return value;
170                         },
171                 } );
172
173
174         },
175
176         'init_error_list' : function() {
177                 var obj = this; JSAN.use('util.list'); 
178                 obj.error_list = new util.list('error_tree');
179                 obj.error_list.init( {
180                         'columns' : [
181                                 {
182                                         'id' : 'workstation', 'flex' : '1',
183                                         'label' : 'Workstation',
184                                         'render' : 'my.command._workstation ? my.command._workstation : my.command._worksation',
185                                 },
186                                 {
187                                         'id' : 'timestamp', 'flex' : '1',
188                                         'label' : 'Timestamp',
189                                         'render' : 'if (my.command.timestamp) { var x = new Date(); x.setTime(my.command.timestamp+"000"); util.date.formatted_date(x,"%F %H:%M"); } else { my.command._realtime; }',
190                                 },
191                                 {
192                                         'id' : 'type', 'flex' : '1',
193                                         'label' : 'Type',
194                                         'render' : 'my.command.type',
195                                 },
196                                 { 
197                                         'id' : 'ilsevent', 'hidden' : 'true', 'flex' : '1', 
198                                         'label' : 'Event Code', 
199                                         'render' : "my.event.ilsevent", 
200                                 },
201                                 { 
202                                         'id' : 'textcode', 'flex' : '1', 
203                                         'label' : 'Event Name', 
204                                         'render' : "my.event.textcode", 
205                                 },
206                                 {
207                                         'id' : 'i_barcode', 'flex' : '1',
208                                         'label' : 'Item Barcode',
209                                         'render' : 'my.command.barcode ? my.command.barcode : ""',
210                                 },
211                                 {
212                                         'id' : 'p_barcode', 'flex' : '1',
213                                         'label' : 'Patron Barcode',
214                                         'render' : 'if (my.command.patron_barcode) { my.command.patron_barcode; } else { if (my.command.user.card.barcode) { my.command.user.card.barcode; } else { ""; } }',
215                                 },
216                                 {
217                                         'id' : 'duedate', 'flex' : '1', 'hidden' : 'true',
218                                         'label' : 'Due Date',
219                                         'render' : 'my.command.due_date || ""',
220                                 },
221                                 {
222                                         'id' : 'backdate', 'flex' : '1', 'hidden' : 'true',
223                                         'label' : 'Check In Backdate',
224                                         'render' : 'my.command.backdate || ""',
225                                 },
226                                 {
227                                         'id' : 'count', 'flex' : '1', 'hidden' : 'true',
228                                         'label' : 'In House Use Count',
229                                         'render' : 'my.command.count || ""',
230                                 },
231                                 {
232                                         'id' : 'noncat', 'flex' : '1', 'hidden' : 'true',
233                                         'label' : 'Non-Cataloged?',
234                                         'render' : 'my.command.noncat == 1 ? "Yes" : "No"',
235                                 },
236                                 {
237                                         'id' : 'noncat_type', 'flex' : '1', 'hidden' : 'true',
238                                         'label' : 'Non-Cataloged Type',
239                                         'render' : 'data.hash.cnct[ my.command.noncat_type ] ? data.hash.cnct[ my.command.noncat_type ].name() : ""',
240                                 },
241                                 {
242                                         'id' : 'noncat_count', 'flex' : '1', 'hidden' : 'true',
243                                         'label' : 'Non-Cataloged Count',
244                                         'render' : 'my.command.noncat_count || ""',
245                                 },
246                         ],
247                         'map_row_to_column' : function(row,col) {
248                                 JSAN.use('util.date');
249                                 JSAN.use('OpenILS.data'); var data = new OpenILS.data(); data.init({'via':'stash'});
250                                 var my = row; var value;
251                                 try { value = eval( col.render ); } catch(E) { obj.error.sdump('D_ERROR',E); value = '???'; }
252                                 return value;
253                         },
254                 } );
255
256
257         },
258
259         'check_perm' : function(ses,perms) {
260                 return true; /* FIXME */
261         },
262
263         'execute_ses' : function() {
264                 var obj = this;
265
266                 obj.data.stash_retrieve();
267
268                 for (var i = 0; i < obj.sel_list.length; i++) {
269
270                         var url  = xulG.url_prefix(urls.XUL_OFFLINE_MANAGE_XACTS_CGI)
271                                 + "?ses=" + window.escape(obj.data.session)
272                                 + "&action=execute" 
273                                 + "&seskey=" + window.escape(obj.seslist[obj.sel_list[i]].key)
274                                 + "&ws=" + window.escape(obj.data.ws_name);
275                         var x = new XMLHttpRequest();
276                         x.open("GET",url,false);
277                         x.send(null);
278
279                         dump(url + ' = ' + x.responseText + '\n' );
280                         var robj = JSON2js(x.responseText);
281
282                         if (robj.ilsevent != 0) { alert('Execute error: ' + x.responseText); }
283
284                         obj.retrieve_seslist(); obj.render_seslist();
285                 }
286         },
287
288         'ses_errors' : function() {
289                 var obj = this;
290
291                 obj.data.stash_retrieve();
292
293                 var url  = xulG.url_prefix(urls.XUL_OFFLINE_MANAGE_XACTS_CGI)
294                         + "?ses=" + window.escape(obj.data.session)
295                         + "&action=status" 
296                         + "&seskey=" + window.escape(obj.seslist[ obj.sel_list[0] ].key)
297                         + "&ws=" + window.escape(obj.data.ws_name)
298                         + '&status_type=exceptions';
299                 var x = new XMLHttpRequest();
300                 x.open("GET",url,false);
301                 x.send(null);
302
303                 dump(url + ' = ' + x.responseText + '\n' );
304                 var robj = JSON2js(x.responseText);
305
306                 return { 'errors' : robj, 'description' : obj.seslist[ obj.sel_list[0] ].description };
307
308         },
309
310         'rename_file' : function() {
311                 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
312                 var obj = this;
313                 JSAN.use('util.file'); 
314                 var pending = new util.file('pending_xacts');
315                 if ( !pending._file.exists() ) { throw("Can't rename a non-existent file"); }
316                 obj.transition_filename = 'pending_xacts_' + new Date().getTime();
317                 var count = 0;
318                 var file = new util.file(obj.transition_filename);
319                 while (file._file.exists()) {
320                         obj.transition_filename = 'pending_xacts_' + new Date().getTime();
321                         file = new util.file(obj.transition_filename);
322                         if (count++>100) throw("Taking too long to find a unique filename.");
323                 }
324                 pending._file.moveTo(null,obj.transition_filename);
325         },
326
327         'revert_file' : function() {
328                 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
329                 var obj = this;
330                 JSAN.use('util.file');
331                 var pending = new util.file('pending_xacts');
332                 if (pending._file.exists()) { alert('Something bad happened.  New offline transactions were accumulated during our attempted upload.  Tell your system admin that the file involved is ' + obj.transition_filename); return; }
333                 var file = new util.file(obj.transition_filename);
334                 file._file.moveTo(null,'pending_xacts');
335         },
336
337         'archive_file' : function() {
338                 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
339                 var obj = this;
340                 JSAN.use('util.file');
341                 var file = new util.file(obj.transition_filename);
342                 if (file._file.exists()) file._file.moveTo(null,obj.transition_filename + '.complete')
343         },
344
345         'upload' : function() {
346                 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
347                 var obj = this;
348                 if (obj.sel_list.length == 0) { alert('Please select a session to upload to.'); return; }
349                 if (obj.sel_list.length > 1) { alert('Please select a single session to upload to.'); return; }
350
351                 JSAN.use('util.file');
352
353                 var file = new util.file('pending_xacts');
354                 if (!file._file.exists()) { alert('No pending transactions to upload.'); return; }
355
356                 obj.rename_file();
357
358                 obj.data.stash_retrieve();
359                 var seskey = obj.seslist[ obj.sel_list[0] ].key;
360                 JSAN.use('util.widgets');
361                 var xx = document.getElementById('iframe_placeholder'); util.widgets.remove_children(xx);
362                 var x = document.createElement('iframe'); xx.appendChild(x); x.flex = 1;
363                 x.setAttribute(
364                         'src',
365                         window.xulG.url_prefix( urls.XUL_REMOTE_BROWSER )
366                         + '?url=' + window.escape(
367                                 urls.XUL_OFFLINE_UPLOAD_XACTS
368                                 + '?ses=' + window.escape(obj.data.session)
369                                 + '&seskey=' + window.escape(seskey)
370                                 + '&ws=' + window.escape(obj.data.ws_name)
371                                 + '&delta=' + window.escape('0')
372                                 + '&filename=' + window.escape( obj.transition_filename )
373                         )
374                 );
375                 var newG = { 
376                         'url_prefix' : window.xulG.url_prefix, 
377                         'passthru_content_params' : {
378                                 'url_prefix' : window.xulG.url_prefix,
379                                 'handle_event' : function(robj){
380                                         netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
381                                         try {
382                                                 dump('robj = ' + js2JSON(robj) + '\n');
383                                                 if ( robj.ilsevent != 0 ) {
384                                                         obj.revert_file();
385                                                 } else {
386                                                         obj.archive_file();
387                                                 }
388                                                 obj.retrieve_seslist(); obj.render_seslist();
389                                                 setTimeout(
390                                                         function() {
391                                                                 JSAN.use('util.widgets');
392                                                                 util.widgets.remove_children('iframe_placeholder');
393                                                         },0
394                                                 );
395                                         } catch(E) {
396                                                 alert('handle_event error: ' + E);
397                                         }
398                                 } 
399                         }
400                 };
401                 x.contentWindow.xulG = newG;
402         },
403
404         'ses_status' : function() {
405                 var obj = this;
406
407                 obj.data.stash_retrieve();
408
409                 var url  = xulG.url_prefix(urls.XUL_OFFLINE_MANAGE_XACTS_CGI)
410                         + "?ses=" + window.escape(obj.data.session)
411                         + "&action=status" 
412                         + "&seskey=" + window.escape(obj.seslist[obj.sel_list[0]].key)
413                         + "&ws=" + window.escape(obj.data.ws_name)
414                         + "&status_type=scripts";
415                 var x = new XMLHttpRequest();
416                 x.open("GET",url,false);
417                 x.send(null);
418
419                 dump(url + ' = ' + x.responseText + '\n' );
420                 var robj = JSON2js(x.responseText);
421
422                 return robj;
423         },
424
425         'create_ses' : function() {
426
427                 var obj = this;
428
429                 var desc = window.prompt('Please enter a description:','','Create an Offline Transaction Session');
430                 if (desc=='' || desc==null) { return; }
431
432                 obj.data.stash_retrieve();
433
434                 var url  = xulG.url_prefix(urls.XUL_OFFLINE_MANAGE_XACTS_CGI)
435                         + "?ses=" + window.escape(obj.data.session)
436                         + "&action=create" 
437                         + "&desc=" + window.escape(desc)
438                         + "&ws=" + window.escape(obj.data.ws_name);
439                 var x = new XMLHttpRequest();
440                 x.open("GET",url,false);
441                 x.send(null);
442
443                 dump(url + ' = ' + x.responseText + '\n' );
444                 var robj = JSON2js(x.responseText);
445                 if (robj.ilsevent == 0) {
446                         obj.retrieve_seslist(); obj.render_seslist();
447                 } else {
448                         alert('Error: ' + x.responseText);
449                 }
450         },
451
452         'retrieve_seslist' : function() {
453
454                 var obj = this;
455
456                 obj.data.stash_retrieve();
457
458                 var url = xulG.url_prefix(urls.XUL_OFFLINE_MANAGE_XACTS_CGI) 
459                         + "?ses=" + window.escape(obj.data.session)
460                         + "&action=status"
461                         + "&org=" + window.escape(obj.data.list.au[0].ws_ou())
462                         + "&status_type=sessions";
463                 var x = new XMLHttpRequest();
464                 x.open("GET",url,false);
465                 x.send(null);
466
467                 dump(url + ' = ' + x.responseText + '\n' );
468                 obj.seslist = JSON2js( x.responseText );
469         },
470
471         'render_seslist' : function() {
472
473                 var obj = this;
474
475                 obj.list.clear();
476
477                 var funcs = [];
478                 for (var i = 0; i < obj.seslist.length; i++) {
479                         funcs.push( 
480                                 function(idx,row){ 
481                                         return function(){
482                                                 obj.list.append( { 'retrieve_id' : idx, 'row' : row } );
483                                         };
484                                 }(i,obj.seslist[i]) 
485                         );
486                 }
487                 JSAN.use('util.exec'); var exec = new util.exec();
488                 exec.chain( funcs );
489
490                 document.getElementById('execute').disabled = true;
491                 document.getElementById('upload').disabled = true;
492
493         },
494
495         'render_scriptlist' : function() {
496
497                 dump('render_scriptlist\n');
498
499                 document.getElementById('deck').selectedIndex = 0;
500
501                 var obj = this;
502
503                 obj.script_list.clear();
504
505                 var status = obj.ses_status();
506                 document.getElementById('status_caption').setAttribute('label','Uploaded Transactions for ' + status.description);
507
508                 var scripts = status.scripts;
509
510                 var funcs = [];
511                 for (var i = 0; i < scripts.length; i++) {
512                         funcs.push( 
513                                 function(row){ 
514                                         return function(){
515                                                 obj.script_list.append( { 'row' : row } );
516                                         };
517                                 }(scripts[i]) 
518                         );
519                 }
520                 JSAN.use('util.exec'); var exec = new util.exec();
521                 exec.chain( funcs );
522         },
523         
524         'render_errorlist' : function() {
525
526                 dump('render_errorlist\n');
527
528                 document.getElementById('deck').selectedIndex = 1;
529
530                 var obj = this;
531
532                 obj.error_list.clear();
533
534                 var error_meta = obj.ses_errors();
535                 document.getElementById('errors_caption').setAttribute('label','Exceptions for ' + error_meta.description);
536
537                 obj.errors = error_meta.errors;
538
539                 var funcs = [];
540                 for (var i = 0; i < obj.errors.length; i++) {
541                         funcs.push( 
542                                 function(idx,row){ 
543                                         return function(){
544                                                 obj.error_list.append( { 'retrieve_id' : idx, 'row' : row } );
545                                         };
546                                 }(i,obj.errors[i]) 
547                         );
548                 }
549                 JSAN.use('util.exec'); var exec = new util.exec();
550                 exec.chain( funcs );
551         },
552
553 }
554
555 dump('exiting admin/offline_manage_xacts.js\n');