1 dump('entering admin/offline_manage_xacts.js\n');
3 if (typeof admin == 'undefined') admin = {};
4 admin.offline_manage_xacts = function (params) {
6 JSAN.use('util.error'); this.error = new util.error();
7 JSAN.use('util.network'); this.network = new util.network();
10 admin.offline_manage_xacts.prototype = {
16 'init' : function( params ) {
20 JSAN.use('OpenILS.data'); obj.data = new OpenILS.data(); obj.data.init({'via':'stash'});
22 obj.init_list(); obj.init_script_list(); obj.init_error_list();
24 obj.retrieve_seslist(); obj.render_seslist();
26 var x = document.getElementById('create');
27 if (obj.check_perm(['OFFLINE_UPLOAD'])) {
29 x.addEventListener('command',function() { try{obj.create_ses();}catch(E){alert(E);} },false);
33 x.addEventListener('command',function() { try{obj.upload();}catch(E){alert(E);} },false);
36 x.addEventListener('command',function() { try{$('deck').selectedIndex=0;obj.retrieve_seslist();obj.render_seslist();}catch(E){alert(E);} },false);
39 x.addEventListener('command',function() { try{obj.execute_ses();}catch(E){alert(E);} },false);
41 x = obj.$('retrieve_item');
42 x.addEventListener('command',function() { try{obj.retrieve_item();}catch(E){alert(E);} },false);
44 x = obj.$('retrieve_patron');
45 x.addEventListener('command',function() { try{obj.retrieve_patron();}catch(E){alert(E);} },false);
47 x = obj.$('retrieve_details');
48 x.addEventListener('command',function() { try{obj.retrieve_details();}catch(E){alert(E);} },false);
50 obj.$('deck').selectedIndex = 0;
53 '$' : function(id) { return document.getElementById(id); },
55 'init_list' : function() {
56 var obj = this; JSAN.use('util.list'); JSAN.use('util.date'); JSAN.use('patron.util');
57 obj.list = new util.list('session_tree');
61 'id' : 'org', 'hidden' : 'true', 'flex' : '1',
62 'label' : 'Organization',
63 'render' : function(my) { return obj.data.hash.aou[ my.org ].shortname(); },
66 'id' : 'description', 'flex' : '2',
67 'label' : 'Description',
68 'render' : function(my) { return my.description; },
71 'id' : 'create_time', 'flex' : '1',
72 'label' : 'Date Created',
73 'render' : function(my) { if (my.create_time) { var x = new Date(); x.setTime(my.create_time+"000"); return util.date.formatted_date(x,"%F %H:%M"); } else { return ""; }; },
76 'id' : 'creator', 'flex' : '1', 'hidden' : 'true',
77 'label' : 'Created By',
78 'render' : function(my) { var staff_obj = patron.util.retrieve_name_via_id( ses(), my.creator ); return staff_obj[0] + " @ " + obj.data.hash.aou[ staff_obj[3] ].shortname(); },
81 'id' : 'count', 'flex' : '1',
82 'label' : 'Upload Count',
83 'render' : function(my) { return my.scripts.length; },
86 'id' : 'num_complete', 'flex' : '1',
87 'label' : 'Transactions Processed',
88 'render' : function(my) { return my.num_complete; },
91 'id' : 'in_process', 'flex' : '1',
92 'label' : 'Processing?',
93 'render' : function(my) { if (my.end_time) { return 'Completed' } else { return get_bool(my.in_process) ? 'Yes' : 'No'}; },
96 'id' : 'start_time', 'flex' : '1', 'hidden' : 'true',
97 'label' : 'Date Started',
98 'render' : function(my) { if (my.start_time) {var x = new Date(); x.setTime(my.start_time+"000"); return util.date.formatted_date(x,"%F %H:%M");} else { return ""; }; },
101 'id' : 'end_time', 'flex' : '1',
102 'label' : 'Date Completed',
103 'render' : function(my) { if (my.end_time) {var x = new Date(); x.setTime(my.end_time+"000"); return util.date.formatted_date(x,"%F %H:%M");} else { return ""; }; },
106 'id' : 'key', 'hidden' : 'true', 'flex' : '1',
108 'render' : function(my) { return my.key; },
111 'map_row_to_columns' : patron.util.std_map_row_to_columns(),
112 'on_select' : function(ev) {
114 $('deck').selectedIndex = 0;
115 $('execute').disabled = true;
116 $('upload').disabled = true;
120 JSAN.use('util.functional');
121 var sel = obj.list.retrieve_selection();
122 obj.sel_list = util.functional.map_list(
124 function(o) { return o.getAttribute('retrieve_id'); }
126 if (obj.sel_list.length == 0) return;
128 var upload = true; var process = true;
130 if (obj.sel_list.length > 1) upload = false;
132 if (obj.seslist[ obj.sel_list[0] ].end_time) {
133 upload = false; process = false;
135 if (obj.seslist[ obj.sel_list[0] ].in_process == 1) {
136 upload = false; process = false;
139 /* should we really have this next restriction? */
140 for (var i = 0; i < obj.seslist[ obj.sel_list[0] ].scripts.length; i++) {
141 if (obj.seslist[ obj.sel_list[0] ].scripts[i].workstation ==
142 obj.data.ws_name ) upload = false;
146 if (obj.check_perm(['OFFLINE_UPLOAD'])) {
147 document.getElementById('upload').disabled = false;
150 document.getElementById('upload').disabled = true;
153 if (obj.check_perm(['OFFLINE_EXECUTE'])) {
154 document.getElementById('execute').disabled = false;
157 document.getElementById('execute').disabled = true;
160 var complete = false;
161 for (var i = 0; i < obj.sel_list.length; i++) {
162 if (obj.seslist[ obj.sel_list[i] ].end_time) { complete = true; }
165 obj.render_errorlist();
167 if (obj.seslist[ obj.sel_list[0] ].in_process == 1) {
170 obj.render_scriptlist();
174 alert('on_select: ' + E);
179 alert('on_select:\nobj.seslist.length = ' + obj.seslist.length + ' obj.sel_list.length = ' + obj.sel_list.length + '\nerror: ' + E);
187 'init_script_list' : function() {
188 var obj = this; JSAN.use('util.list'); JSAN.use('util.date'); JSAN.use('patron.util');
189 obj.script_list = new util.list('script_tree');
190 obj.script_list.init( {
193 'id' : 'create_time', 'flex' : '1',
194 'label' : 'Date Uploaded',
195 'render' : function(my) { if (my.create_time) { var x = new Date(); x.setTime(my.create_time+"000"); return util.date.formatted_date(x,"%F %H:%M"); } else { return ""; }; },
198 'id' : 'requestor', 'flex' : '1', 'hidden' : 'true',
199 'label' : 'Uploaded By',
200 'render' : function(my) { var staff_obj = patron.util.retrieve_name_via_id( ses(), my.requestor ); return staff_obj[0] + " @ " + obj.data.hash.aou[ staff_obj[3] ].shortname(); },
203 'id' : 'time_delta', 'hidden' : 'true', 'flex' : '1',
204 'label' : 'Server/Local Time Delta',
205 'render' : function(my) { return my.time_delta; },
208 'id' : 'workstation', 'flex' : '1',
209 'label' : 'Workstation',
210 'render' : function(my) { return my.workstation; },
213 'map_row_to_columns' : patron.util.std_map_row_to_columns(),
219 'init_error_list' : function() {
220 var obj = this; JSAN.use('util.list'); JSAN.use('util.date'); JSAN.use('patron.util'); JSAN.use('util.functional');
221 obj.error_list = new util.list('error_tree');
222 obj.error_list.init( {
225 'id' : 'workstation', 'flex' : '1',
226 'label' : 'Workstation',
227 'render' : function(my) { return my.command._workstation ? my.command._workstation : my.command._worksation; },
230 'id' : 'timestamp', 'flex' : '1',
231 'label' : 'Timestamp',
232 'render' : function(my) { if (my.command.timestamp) { var x = new Date(); x.setTime(my.command.timestamp+"000"); return util.date.formatted_date(x,"%F %H:%M"); } else { return my.command._realtime; }; },
235 'id' : 'type', 'flex' : '1',
237 'render' : function(my) { return my.command.type; },
240 'id' : 'ilsevent', 'hidden' : 'true', 'flex' : '1',
241 'label' : 'Event Code',
242 'render' : function(my) { return my.event.ilsevent; },
245 'id' : 'textcode', 'flex' : '1',
246 'label' : 'Event Name',
247 'render' : function(my) { return typeof my.event.textcode != 'undefined' ? my.event.textcode : util.functional.map_list( my.event, function(o) { return o.textcode; }).join('/'); },
250 'id' : 'desc', 'flex' : '1', 'hidden' : 'true',
251 'label' : 'Event Description',
252 'render' : function(my) { return my.event.desc; },
255 'id' : 'i_barcode', 'flex' : '1',
256 'label' : 'Item Barcode',
257 'render' : function(my) { return my.command.barcode ? my.command.barcode : ""; },
260 'id' : 'p_barcode', 'flex' : '1',
261 'label' : 'Patron Barcode',
262 'render' : function(my) { if (my.command.patron_barcode) { return my.command.patron_barcode; } else { if (my.command.user.card.barcode) { return my.command.user.card.barcode; } else { return ""; } }; },
265 'id' : 'duedate', 'flex' : '1', 'hidden' : 'true',
266 'label' : 'Due Date',
267 'render' : function(my) { return my.command.due_date || ""; },
270 'id' : 'backdate', 'flex' : '1', 'hidden' : 'true',
271 'label' : 'Check In Backdate',
272 'render' : function(my) { return my.command.backdate || ""; },
275 'id' : 'count', 'flex' : '1', 'hidden' : 'true',
276 'label' : 'In House Use Count',
277 'render' : function(my) { return my.command.count || ""; },
280 'id' : 'noncat', 'flex' : '1', 'hidden' : 'true',
281 'label' : 'Non-Cataloged?',
282 'render' : function(my) { return get_bool(my.command.noncat) ? "Yes" : "No"; },
285 'id' : 'noncat_type', 'flex' : '1', 'hidden' : 'true',
286 'label' : 'Non-Cataloged Type',
287 'render' : function(my) { return data.hash.cnct[ my.command.noncat_type ] ? obj.data.hash.cnct[ my.command.noncat_type ].name() : ""; },
290 'id' : 'noncat_count', 'flex' : '1', 'hidden' : 'true',
291 'label' : 'Non-Cataloged Count',
292 'render' : function(my) { return my.command.noncat_count || ""; },
295 'map_row_to_columns' : patron.util.std_map_row_to_columns(),
296 'on_select' : function(ev) {
298 var sel = obj.error_list.retrieve_selection();
299 obj.sel_errors = util.functional.map_list(
301 function(o) { return o.getAttribute('retrieve_id'); }
303 if (obj.sel_errors.length > 0) {
304 obj.$('retrieve_item').disabled = false;
305 obj.$('retrieve_patron').disabled = false;
306 obj.$('retrieve_details').disabled = false;
308 obj.$('retrieve_item').disabled = true;
309 obj.$('retrieve_patron').disabled = true;
310 obj.$('retrieve_details').disabled = true;
321 'check_perm' : function(perms) {
323 var robj = obj.network.simple_request('PERM_CHECK',[ses(),obj.data.list.au[0].id(),obj.data.list.au[0].ws_ou(),perms]);
324 if (typeof robj.ilsevent != 'undefined') {
325 obj.error.standard_unexpected_error_alert('check permission',E);
328 return robj.length == 0 ? true : false;
331 'execute_ses' : function() {
335 obj.data.stash_retrieve();
337 for (var i = 0; i < obj.sel_list.length; i++) {
339 var url = xulG.url_prefix(urls.XUL_OFFLINE_MANAGE_XACTS_CGI)
340 + "?ses=" + window.escape(ses())
342 + "&seskey=" + window.escape(obj.seslist[obj.sel_list[i]].key)
343 + "&ws=" + window.escape(obj.data.ws_name);
344 var x = new XMLHttpRequest();
345 x.open("GET",url,false);
348 dump(url + ' = ' + x.responseText + '\n' );
349 var robj = JSON2js(x.responseText);
351 if (robj.ilsevent != 0) { alert('Execute error: ' + x.responseText); }
353 obj.retrieve_seslist(); obj.render_seslist();
357 'ses_errors' : function() {
361 obj.data.stash_retrieve();
363 var url = xulG.url_prefix(urls.XUL_OFFLINE_MANAGE_XACTS_CGI)
364 + "?ses=" + window.escape(ses())
366 + "&seskey=" + window.escape(obj.seslist[ obj.sel_list[0] ].key)
367 + "&ws=" + window.escape(obj.data.ws_name)
368 + '&status_type=exceptions';
369 var x = new XMLHttpRequest();
370 x.open("GET",url,false);
373 dump(url + ' = ' + x.responseText + '\n' );
374 var robj = JSON2js(x.responseText);
376 return { 'errors' : robj, 'description' : obj.seslist[ obj.sel_list[0] ].description };
380 'rename_file' : function() {
381 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
383 JSAN.use('util.file');
384 var pending = new util.file('pending_xacts');
385 if ( !pending._file.exists() ) { throw("Can't rename a non-existent file"); }
386 obj.transition_filename = 'pending_xacts_' + new Date().getTime();
388 var file = new util.file(obj.transition_filename);
389 while (file._file.exists()) {
390 obj.transition_filename = 'pending_xacts_' + new Date().getTime();
391 file = new util.file(obj.transition_filename);
392 if (count++>100) throw("Taking too long to find a unique filename.");
394 pending._file.moveTo(null,obj.transition_filename);
397 'revert_file' : function() {
398 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
400 JSAN.use('util.file');
401 var pending = new util.file('pending_xacts');
402 if (pending._file.exists()) { obj.error.yns_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,'Scary Error','Ok',null,null,'Check here to confirm this message'); return; }
403 var file = new util.file(obj.transition_filename);
404 file._file.moveTo(null,'pending_xacts');
407 'archive_file' : function() {
408 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
410 JSAN.use('util.file');
411 var file = new util.file(obj.transition_filename);
412 if (file._file.exists()) file._file.moveTo(null,obj.transition_filename + '.complete')
415 'upload' : function() {
416 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
418 if (obj.sel_list.length == 0) { alert('Please select a session to upload to.'); return; }
419 if (obj.sel_list.length > 1) { alert('Please select a single session to upload to.'); return; }
421 JSAN.use('util.file');
423 var file = new util.file('pending_xacts');
424 if (!file._file.exists()) { alert('No pending transactions to upload.'); return; }
428 obj.data.stash_retrieve();
429 var seskey = obj.seslist[ obj.sel_list[0] ].key;
430 JSAN.use('util.widgets');
431 var xx = document.getElementById('iframe_placeholder'); util.widgets.remove_children(xx);
432 var x = document.createElement('iframe'); xx.appendChild(x); x.flex = 1;
435 window.xulG.url_prefix( urls.XUL_REMOTE_BROWSER )
436 + '?url=' + window.escape(
437 urls.XUL_OFFLINE_UPLOAD_XACTS
438 + '?ses=' + window.escape(ses())
439 + '&seskey=' + window.escape(seskey)
440 + '&ws=' + window.escape(obj.data.ws_name)
441 + '&delta=' + window.escape('0')
442 + '&filename=' + window.escape( obj.transition_filename )
446 'url_prefix' : window.xulG.url_prefix,
447 'passthru_content_params' : {
448 'url_prefix' : window.xulG.url_prefix,
449 'handle_event' : function(robj){
450 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
452 dump('robj = ' + js2JSON(robj) + '\n');
453 if ( robj.ilsevent != 0 ) {
455 alert('There was an error:\n' + js2JSON(robj));
459 obj.retrieve_seslist(); obj.render_seslist();
462 JSAN.use('util.widgets');
463 util.widgets.remove_children('iframe_placeholder');
467 alert('handle_event error: ' + E);
472 x.contentWindow.xulG = newG;
475 'ses_status' : function() {
479 obj.data.stash_retrieve();
481 var url = xulG.url_prefix(urls.XUL_OFFLINE_MANAGE_XACTS_CGI)
482 + "?ses=" + window.escape(ses())
484 + "&seskey=" + window.escape(obj.seslist[obj.sel_list[0]].key)
485 + "&ws=" + window.escape(obj.data.ws_name)
486 + "&status_type=scripts";
487 var x = new XMLHttpRequest();
488 x.open("GET",url,false);
491 dump(url + ' = ' + x.responseText + '\n' );
492 var robj = JSON2js(x.responseText);
497 'create_ses' : function() {
501 var desc = window.prompt('Please enter a description:','','Create an Offline Transaction Session');
502 if (desc=='' || desc==null) { return; }
505 obj.data.stash_retrieve();
507 var url = xulG.url_prefix(urls.XUL_OFFLINE_MANAGE_XACTS_CGI)
508 + "?ses=" + window.escape(ses())
510 + "&desc=" + window.escape(desc)
511 + "&ws=" + window.escape(obj.data.ws_name);
512 var x = new XMLHttpRequest();
513 x.open("GET",url,false);
516 dump(url + ' = ' + x.responseText + '\n' );
517 var robj = JSON2js(x.responseText);
518 if (robj.ilsevent == 0) {
519 obj.retrieve_seslist(); obj.render_seslist();
521 alert('Error: ' + x.responseText);
525 'retrieve_seslist' : function() {
532 obj.data.stash_retrieve();
534 var url = xulG.url_prefix(urls.XUL_OFFLINE_MANAGE_XACTS_CGI)
535 + "?ses=" + window.escape(ses())
537 + "&org=" + window.escape(obj.data.list.au[0].ws_ou())
538 + "&status_type=sessions";
539 var x = new XMLHttpRequest();
540 x.open("GET",url,false);
543 dump(url + ' = ' + x.responseText + '\n' );
545 var robj = JSON2js( x.responseText );
546 if (typeof robj.ilsevent != 'undefined') throw(robj);
548 obj.seslist = robj.sort(
550 return b.create_time - a.create_time;
555 obj.error.standard_unexpected_error_alert('Error retrieving offline sessions.',E);
559 'render_seslist' : function() {
563 var old_idx = obj.list.node.currentIndex;
564 if (old_idx < 0) old_idx = 0;
569 for (var i = 0; i < obj.seslist.length; i++) {
573 obj.list.append( { 'retrieve_id' : idx, 'row' : row } );
574 if (idx == old_idx) obj.list.node.view.selection.select(idx);
576 }(i,{ 'my' : obj.seslist[i] })
580 JSAN.use('util.exec'); var exec = new util.exec();
583 document.getElementById('execute').disabled = true;
584 document.getElementById('upload').disabled = true;
588 'render_scriptlist' : function() {
590 dump('render_scriptlist\n');
592 document.getElementById('deck').selectedIndex = 1;
596 obj.script_list.clear();
598 var status = obj.ses_status();
599 document.getElementById('status_caption').setAttribute('label','Uploaded Transactions for ' + status.description);
601 var scripts = status.scripts;
604 for (var i = 0; i < scripts.length; i++) {
608 obj.script_list.append( { 'row' : row } );
610 }({ 'my' : scripts[i] })
613 JSAN.use('util.exec'); var exec = new util.exec();
617 'render_errorlist' : function() {
619 dump('render_errorlist\n');
621 document.getElementById('deck').selectedIndex = 2;
625 obj.error_list.clear();
627 var error_meta = obj.ses_errors();
628 document.getElementById('errors_caption').setAttribute('label','Exceptions for ' + error_meta.description);
630 obj.errors = error_meta.errors;
633 for (var i = 0; i < obj.errors.length; i++) {
637 obj.error_list.append( { 'retrieve_id' : idx, 'row' : row } );
639 }(i,{ 'my' : obj.errors[i] })
642 JSAN.use('util.exec'); var exec = new util.exec();
646 'render_status' : function() {
648 dump('render_status\n');
650 document.getElementById('deck').selectedIndex = 3;
654 'retrieve_item' : function() {
658 for (var i = 0; i < obj.sel_errors.length; i++) {
659 var error = obj.errors[ obj.sel_errors[i] ];
660 if ( ! error.command.barcode ) continue;
661 if ( [ '', ' ', '???' ].indexOf( error.command.barcode ) != -1 ) continue;
662 barcodes.push( error.command.barcode );
664 if (typeof window.xulG == 'object' && typeof window.xulG.new_tab == 'function') {
666 var url = urls.XUL_COPY_STATUS
667 + '?barcodes=' + window.escape( js2JSON(barcodes) );
680 'retrieve_patron' : function() {
683 for (var i = 0; i < obj.sel_errors.length; i++) {
684 var error = obj.errors[ obj.sel_errors[i] ];
685 if ( ! error.command.patron_barcode ) continue;
686 if ( [ '', ' ', '???' ].indexOf( error.command.patron_barcode ) != -1 ) continue;
687 if (typeof window.xulG == 'object' && typeof window.xulG.new_tab == 'function') {
689 var url = urls.XUL_PATRON_DISPLAY
690 + '?barcode=' + window.escape( error.command.patron_barcode );
704 'retrieve_details' : function() {
706 JSAN.use('util.window'); var win = new util.window();
708 for (var i = 0; i < obj.sel_errors.length; i++) {
709 var error = obj.errors[ obj.sel_errors[i] ];
711 'data:text/plain,' + window.escape(
712 'Details:\n' + obj.error.pretty_print(js2JSON(error))
714 'offline_error_details',
715 'height=240,width=320,scrollbars=yes,chrome,resizable,modal'
725 dump('exiting admin/offline_manage_xacts.js\n');