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;
318 var export_button = document.getElementById('export_btn');
319 if (export_button) export_button.addEventListener(
323 obj.error_list.on_all_fleshed =
326 dump( obj.error_list.dump_csv() + '\n' );
327 copy_to_clipboard(obj.error_list.dump_csv());
328 setTimeout(function(){ obj.error_list.on_all_fleshed = null; },0);
330 obj.error.standard_unexpected_error_alert('export',E);
333 obj.error_list.full_retrieve();
335 obj.error.standard_unexpected_error_alert('export',E);
342 'check_perm' : function(perms) {
344 var robj = obj.network.simple_request('PERM_CHECK',[ses(),obj.data.list.au[0].id(),obj.data.list.au[0].ws_ou(),perms]);
345 if (typeof robj.ilsevent != 'undefined') {
346 obj.error.standard_unexpected_error_alert('check permission',E);
349 return robj.length == 0 ? true : false;
352 'execute_ses' : function() {
356 obj.data.stash_retrieve();
358 for (var i = 0; i < obj.sel_list.length; i++) {
360 var url = xulG.url_prefix(urls.XUL_OFFLINE_MANAGE_XACTS_CGI)
361 + "?ses=" + window.escape(ses())
363 + "&seskey=" + window.escape(obj.seslist[obj.sel_list[i]].key)
364 + "&ws=" + window.escape(obj.data.ws_name);
365 var x = new XMLHttpRequest();
366 x.open("GET",url,false);
369 dump(url + ' = ' + x.responseText + '\n' );
370 var robj = JSON2js(x.responseText);
372 if (robj.ilsevent != 0) { alert('Execute error: ' + x.responseText); }
374 obj.retrieve_seslist(); obj.render_seslist();
378 'ses_errors' : function() {
382 obj.data.stash_retrieve();
384 var url = xulG.url_prefix(urls.XUL_OFFLINE_MANAGE_XACTS_CGI)
385 + "?ses=" + window.escape(ses())
387 + "&seskey=" + window.escape(obj.seslist[ obj.sel_list[0] ].key)
388 + "&ws=" + window.escape(obj.data.ws_name)
389 + '&status_type=exceptions';
390 var x = new XMLHttpRequest();
391 x.open("GET",url,false);
394 dump(url + ' = ' + x.responseText + '\n' );
395 var robj = JSON2js(x.responseText);
397 return { 'errors' : robj, 'description' : obj.seslist[ obj.sel_list[0] ].description };
401 'rename_file' : function() {
402 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
404 JSAN.use('util.file');
405 var pending = new util.file('pending_xacts');
406 if ( !pending._file.exists() ) { throw("Can't rename a non-existent file"); }
407 obj.transition_filename = 'pending_xacts_' + new Date().getTime();
409 var file = new util.file(obj.transition_filename);
410 while (file._file.exists()) {
411 obj.transition_filename = 'pending_xacts_' + new Date().getTime();
412 file = new util.file(obj.transition_filename);
413 if (count++>100) throw("Taking too long to find a unique filename.");
415 pending._file.moveTo(null,obj.transition_filename);
418 'revert_file' : function() {
419 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
421 JSAN.use('util.file');
422 var pending = new util.file('pending_xacts');
423 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; }
424 var file = new util.file(obj.transition_filename);
425 file._file.moveTo(null,'pending_xacts');
428 'archive_file' : function() {
429 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
431 JSAN.use('util.file');
432 var file = new util.file(obj.transition_filename);
433 if (file._file.exists()) file._file.moveTo(null,obj.transition_filename + '.complete')
436 'upload' : function() {
437 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
439 if (obj.sel_list.length == 0) { alert('Please select a session to upload to.'); return; }
440 if (obj.sel_list.length > 1) { alert('Please select a single session to upload to.'); return; }
442 JSAN.use('util.file');
444 var file = new util.file('pending_xacts');
445 if (!file._file.exists()) { alert('No pending transactions to upload.'); return; }
449 obj.data.stash_retrieve();
450 var seskey = obj.seslist[ obj.sel_list[0] ].key;
451 JSAN.use('util.widgets');
452 var xx = document.getElementById('iframe_placeholder'); util.widgets.remove_children(xx);
453 var x = document.createElement('iframe'); xx.appendChild(x); x.flex = 1;
456 window.xulG.url_prefix( urls.XUL_REMOTE_BROWSER )
457 + '?url=' + window.escape(
458 urls.XUL_OFFLINE_UPLOAD_XACTS
459 + '?ses=' + window.escape(ses())
460 + '&seskey=' + window.escape(seskey)
461 + '&ws=' + window.escape(obj.data.ws_name)
462 + '&delta=' + window.escape('0')
463 + '&filename=' + window.escape( obj.transition_filename )
467 'url_prefix' : window.xulG.url_prefix,
468 'passthru_content_params' : {
469 'url_prefix' : window.xulG.url_prefix,
470 'handle_event' : function(robj){
471 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
473 dump('robj = ' + js2JSON(robj) + '\n');
474 if ( robj.ilsevent != 0 ) {
476 alert('There was an error:\n' + js2JSON(robj));
480 obj.retrieve_seslist(); obj.render_seslist();
483 JSAN.use('util.widgets');
484 util.widgets.remove_children('iframe_placeholder');
488 alert('handle_event error: ' + E);
493 x.contentWindow.xulG = newG;
496 'ses_status' : function() {
500 obj.data.stash_retrieve();
502 var url = xulG.url_prefix(urls.XUL_OFFLINE_MANAGE_XACTS_CGI)
503 + "?ses=" + window.escape(ses())
505 + "&seskey=" + window.escape(obj.seslist[obj.sel_list[0]].key)
506 + "&ws=" + window.escape(obj.data.ws_name)
507 + "&status_type=scripts";
508 var x = new XMLHttpRequest();
509 x.open("GET",url,false);
512 dump(url + ' = ' + x.responseText + '\n' );
513 var robj = JSON2js(x.responseText);
518 'create_ses' : function() {
522 var desc = window.prompt('Please enter a description:','','Create an Offline Transaction Session');
523 if (desc=='' || desc==null) { return; }
526 obj.data.stash_retrieve();
528 var url = xulG.url_prefix(urls.XUL_OFFLINE_MANAGE_XACTS_CGI)
529 + "?ses=" + window.escape(ses())
531 + "&desc=" + window.escape(desc)
532 + "&ws=" + window.escape(obj.data.ws_name);
533 var x = new XMLHttpRequest();
534 x.open("GET",url,false);
537 dump(url + ' = ' + x.responseText + '\n' );
538 var robj = JSON2js(x.responseText);
539 if (robj.ilsevent == 0) {
540 obj.retrieve_seslist(); obj.render_seslist();
542 alert('Error: ' + x.responseText);
546 'retrieve_seslist' : function() {
553 obj.data.stash_retrieve();
555 var url = xulG.url_prefix(urls.XUL_OFFLINE_MANAGE_XACTS_CGI)
556 + "?ses=" + window.escape(ses())
558 + "&org=" + window.escape(obj.data.list.au[0].ws_ou())
559 + "&status_type=sessions";
560 var x = new XMLHttpRequest();
561 x.open("GET",url,false);
564 dump(url + ' = ' + x.responseText + '\n' );
566 var robj = JSON2js( x.responseText );
567 if (typeof robj.ilsevent != 'undefined') throw(robj);
569 obj.seslist = robj.sort(
571 return b.create_time - a.create_time;
576 obj.error.standard_unexpected_error_alert('Error retrieving offline sessions.',E);
580 'render_seslist' : function() {
584 var old_idx = obj.list.node.currentIndex;
585 if (old_idx < 0) old_idx = 0;
590 for (var i = 0; i < obj.seslist.length; i++) {
594 obj.list.append( { 'retrieve_id' : idx, 'row' : row } );
595 if (idx == old_idx) obj.list.node.view.selection.select(idx);
597 }(i,{ 'my' : obj.seslist[i] })
601 JSAN.use('util.exec'); var exec = new util.exec();
604 document.getElementById('execute').disabled = true;
605 document.getElementById('upload').disabled = true;
609 'render_scriptlist' : function() {
611 dump('render_scriptlist\n');
613 document.getElementById('deck').selectedIndex = 1;
617 obj.script_list.clear();
619 var status = obj.ses_status();
620 document.getElementById('status_caption').setAttribute('label','Uploaded Transactions for ' + status.description);
622 var scripts = status.scripts;
625 for (var i = 0; i < scripts.length; i++) {
629 obj.script_list.append( { 'row' : row } );
631 }({ 'my' : scripts[i] })
634 JSAN.use('util.exec'); var exec = new util.exec();
638 'render_errorlist' : function() {
640 dump('render_errorlist\n');
642 document.getElementById('deck').selectedIndex = 2;
646 obj.error_list.clear();
648 var error_meta = obj.ses_errors();
649 document.getElementById('errors_caption').setAttribute('label','Exceptions for ' + error_meta.description);
651 obj.errors = error_meta.errors;
654 for (var i = 0; i < obj.errors.length; i++) {
658 obj.error_list.append( { 'retrieve_id' : idx, 'row' : row } );
660 }(i,{ 'my' : obj.errors[i] })
663 JSAN.use('util.exec'); var exec = new util.exec();
667 'render_status' : function() {
669 dump('render_status\n');
671 document.getElementById('deck').selectedIndex = 3;
675 'retrieve_item' : function() {
679 for (var i = 0; i < obj.sel_errors.length; i++) {
680 var error = obj.errors[ obj.sel_errors[i] ];
681 if ( ! error.command.barcode ) continue;
682 if ( [ '', ' ', '???' ].indexOf( error.command.barcode ) != -1 ) continue;
683 barcodes.push( error.command.barcode );
685 if (typeof window.xulG == 'object' && typeof window.xulG.new_tab == 'function') {
687 var url = urls.XUL_COPY_STATUS
688 + '?barcodes=' + window.escape( js2JSON(barcodes) );
701 'retrieve_patron' : function() {
704 for (var i = 0; i < obj.sel_errors.length; i++) {
705 var error = obj.errors[ obj.sel_errors[i] ];
706 if ( ! error.command.patron_barcode ) continue;
707 if ( [ '', ' ', '???' ].indexOf( error.command.patron_barcode ) != -1 ) continue;
708 if (typeof window.xulG == 'object' && typeof window.xulG.new_tab == 'function') {
710 var url = urls.XUL_PATRON_DISPLAY
711 + '?barcode=' + window.escape( error.command.patron_barcode );
725 'retrieve_details' : function() {
727 JSAN.use('util.window'); var win = new util.window();
729 for (var i = 0; i < obj.sel_errors.length; i++) {
730 var error = obj.errors[ obj.sel_errors[i] ];
732 'data:text/plain,' + window.escape(
733 'Details:\n' + obj.error.pretty_print(js2JSON(error))
735 'offline_error_details',
736 'height=240,width=320,scrollbars=yes,chrome,resizable,modal'
746 dump('exiting admin/offline_manage_xacts.js\n');