1 dump('entering util/print.js\n');
3 if (typeof util == 'undefined') util = {};
4 util.print = function () {
6 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
8 JSAN.use('util.error'); this.error = new util.error();
9 JSAN.use('OpenILS.data'); this.data = new OpenILS.data(); this.data.init( { 'via':'stash' } );
10 JSAN.use('util.window'); this.win = new util.window();
11 JSAN.use('util.functional');
12 JSAN.use('util.file');
17 util.print.prototype = {
19 'reprint_last' : function() {
21 var obj = this; obj.data.init({'via':'stash'});
22 if (!obj.data.last_print) {
23 alert('Nothing to re-print');
26 var msg = obj.data.last_print.msg;
27 var params = obj.data.last_print.params; params.no_prompt = false;
28 obj.simple( msg, params );
30 this.error.standard_unexpected_error_alert('util.print.reprint_last',E);
34 'simple' : function(msg,params) {
36 if (!params) params = {};
40 obj.data.last_print = { 'msg' : msg, 'params' : params}; obj.data.stash('last_print');
43 if ( params && params.no_prompt && (params.no_prompt == true || params.no_prompt == 'true') ) {
48 if (params && params.content_type) {
49 content_type = params.content_type;
51 content_type = 'text/html';
56 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
57 obj.data.init({'via':'stash'});
59 if (params.print_strategy || obj.data.print_strategy) {
61 switch(params.print_strategy || obj.data.print_strategy) {
63 /* FIXME - this it a kludge.. we're going to sidestep window-based html rendering for printing */
64 /* I'm using regexps to mangle the html receipt templates; it'd be nice to use xsl but the */
65 /* templates aren't guaranteed to be valid xml */
66 if (content_type=='text/html') {
67 w = msg.replace(/<br.*?>/gi,'\r\n').replace(/<table.*?>/gi,'\r\n').replace(/<tr.*?>/gi,'\r\n').replace(/<hr.*?>/gi,'\r\n').replace(/<p.*?>/gi,'\r\n').replace(/<block.*?>/gi,'\r\n').replace(/<li.*?>/gi,'\r\n * ').replace(/<.+?>/gi,'');
71 if (! params.no_form_feed) { w = w + '\r\n\r\n\r\n\r\n\r\n\r\n\f'; }
72 obj.NSPrint(w, silent, params);
78 switch(content_type) {
80 var jsrc = 'data:text/javascript,' + window.escape('var params = { "data" : ' + js2JSON(params.data) + ', "list" : ' + js2JSON(params.list) + '}; function my_init() { if (typeof go_print == "function") { go_print(); } else { setTimeout( function() { if (typeof go_print == "function") { alert("Please tell the developers that the 2-second go_print workaround executed, and let them know whether this job printed successfully. Thanks!"); go_print(); } else { alert("Please tell the developers that the 2-second go_print workaround did not work. We will try to print one more time; there have been reports of wasted receipt paper at this point. Please check the settings in the print dialog and/or prepare to power off your printer. Thanks!"); window.print(); } }, 2000 ); } /* FIXME - mozilla bug#301560 - xpcom kills it too */ }');
81 w = obj.win.open('data:text/html,<html id="top"><head><script src="/xul/server/main/JSAN.js"></script><script src="' + window.escape(jsrc) + '"></script></head><body onload="try{my_init();}catch(E){alert(E);}">' + window.escape(msg) + '</body></html>','receipt_temp','chrome,resizable');
83 w.go_print = function() {
85 obj.NSPrint(w, silent, params);
87 obj.error.standard_unexpected_error_alert("Print Error in util.print.simple. After this dialog we'll try a second print attempt. content_type = " + content_type,E);
90 w.minimize(); w.close();
94 w = obj.win.open('data:' + content_type + ',' + window.escape(msg),'receipt_temp','chrome,resizable');
99 obj.NSPrint(w, silent, params);
101 obj.error.standard_unexpected_error_alert("Print Error in util.print.simple. After this dialog we'll try a second print attempt. content_type = " + content_type,E);
104 w.minimize(); w.close();
111 this.error.standard_unexpected_error_alert('util.print.simple',E);
115 'tree_list' : function (params) {
117 dump('print.tree_list.params.list = \n' + this.error.pretty_print(js2JSON(params.list)) + '\n');
118 dump('print.tree_list.params.data = \n' + this.error.pretty_print(js2JSON(params.data)) + '\n');
124 if (params.header) s += this.template_sub( params.header, cols, params );
126 for (var i = 0; i < params.list.length; i++) {
127 params.row = params.list[i];
129 s += this.template_sub( params.line_item, cols, params );
132 if (params.footer) s += this.template_sub( params.footer, cols, params );
134 if (params.sample_frame) {
135 var jsrc = 'data:text/javascript,' + window.escape('var params = { "data" : ' + js2JSON(params.data) + ', "list" : ' + js2JSON(params.list) + '};');
136 params.sample_frame.setAttribute('src','data:text/html,<html id="top"><head><script src="' + window.escape(jsrc) + '"></script></head><body>' + window.escape(s) + '</body></html>');
138 this.simple(s,params);
142 'template_sub' : function( msg, cols, params ) {
145 if (!msg) { dump('template sub called with empty string\n'); return; }
146 JSAN.use('util.date');
149 try{b = s; s = s.replace(/%LINE_NO%/,Number(params.row_idx)+1);}
150 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
152 try{b = s; s = s.replace(/%patron_barcode%/,params.patron_barcode);}
153 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
155 try{b = s; s = s.replace(/%LIBRARY%/,params.lib.name());}
156 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
157 try{b = s; s = s.replace(/%PINES_CODE%/,params.lib.shortname());}
158 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
159 try{b = s; s = s.replace(/%SHORTNAME%/,params.lib.shortname());}
160 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
161 try{b = s; s = s.replace(/%STAFF_FIRSTNAME%/,params.staff.first_given_name());}
162 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
163 try{b = s; s = s.replace(/%STAFF_LASTNAME%/,params.staff.family_name());}
164 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
165 try{b = s; s = s.replace(/%STAFF_BARCODE%/,params.staff.barcode); }
166 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
167 try{b = s; s = s.replace(/%STAFF_PROFILE%/,obj.data.hash.pgt[ params.staff.profile() ].name() ); }
168 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
169 try{b = s; s = s.replace(/%PATRON_ALIAS_OR_FIRSTNAME%/,(params.patron.alias() == '' || params.patron.alias() == null) ? params.patron.first_given_name() : params.patron.alias());}
170 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
171 try{b = s; s = s.replace(/%PATRON_ALIAS%/,(params.patron.alias() == '' || params.patron.alias() == null) ? '' : params.patron.alias());}
172 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
173 try{b = s; s = s.replace(/%PATRON_FIRSTNAME%/,params.patron.first_given_name());}
174 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
175 try{b = s; s = s.replace(/%PATRON_LASTNAME%/,params.patron.family_name());}
176 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
177 try{b = s; s = s.replace(/%PATRON_BARCODE%/,typeof params.patron.card() == 'object' ? params.patron.card().barcode() : util.functional.find_id_object_in_list( params.patron.cards(), params.patron.card() ).barcode() ) ;}
178 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
180 try{b = s; s=s.replace(/%TODAY%/g,(new Date()));}
181 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
182 try{b = s; s=s.replace(/%TODAY_m%/g,(util.date.formatted_date(new Date(),'%m')));}
183 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
184 try{b = s; s=s.replace(/%TODAY_TRIM%/g,(util.date.formatted_date(new Date(),'')));}
185 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
186 try{b = s; s=s.replace(/%TODAY_d%/g,(util.date.formatted_date(new Date(),'%d')));}
187 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
188 try{b = s; s=s.replace(/%TODAY_Y%/g,(util.date.formatted_date(new Date(),'%Y')));}
189 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
190 try{b = s; s=s.replace(/%TODAY_H%/g,(util.date.formatted_date(new Date(),'%H')));}
191 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
192 try{b = s; s=s.replace(/%TODAY_I%/g,(util.date.formatted_date(new Date(),'%I')));}
193 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
194 try{b = s; s=s.replace(/%TODAY_M%/g,(util.date.formatted_date(new Date(),'%M')));}
195 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
196 try{b = s; s=s.replace(/%TODAY_D%/g,(util.date.formatted_date(new Date(),'%D')));}
197 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
198 try{b = s; s=s.replace(/%TODAY_F%/g,(util.date.formatted_date(new Date(),'%F')));}
199 catch(E){s = b; this.error.sdump('D_WARN','string = <' + s + '> error = ' + js2JSON(E)+'\n');}
202 if (typeof params.row != 'undefined') {
203 if (params.row.length >= 0) {
204 alert('debug - please tell the developers that deprecated template code tried to execute');
205 for (var i = 0; i < cols.length; i++) {
206 var re = new RegExp(cols[i],"g");
207 try{b = s; s=s.replace(re, params.row[i]);}
208 catch(E){s = b; this.error.standard_unexpected_error_alert('print.js, template_sub(): 1 string = <' + s + '>',E);}
211 /* for dump_with_keys */
212 for (var i in params.row) {
213 var re = new RegExp('%'+i+'%',"g");
214 try{b = s; s=s.replace(re, params.row[i]);}
215 catch(E){s = b; this.error.standard_unexpected_error_alert('print.js, template_sub(): 2 string = <' + s + '>',E);}
220 if (typeof params.data != 'undefined') {
221 for (var i in params.data) {
222 var re = new RegExp('%'+i+'%',"g");
223 if (typeof params.data[i] == 'string') {
224 try{b = s; s=s.replace(re, params.data[i]);}
225 catch(E){s = b; this.error.standard_unexpected_error_alert('print.js, template_sub(): 3 string = <' + s + '>',E);}
229 } catch(E) { dump(E+'\n'); }
233 alert('Error in print.js, template_sub(): ' + E);
238 'NSPrint' : function(w,silent,params) {
242 if (!params) params = {};
244 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
245 obj.data.init({'via':'stash'});
247 if (params.print_strategy || obj.data.print_strategy) {
249 switch(params.print_strategy || obj.data.print_strategy) {
251 if (typeof w != 'string') {
252 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
253 w.getSelection().selectAllChildren(w.document.firstChild);
254 w = w.getSelection().toString();
256 obj._NSPrint_dos_print(w,silent,params);
261 case 'webBrowserPrint':
262 obj._NSPrint_webBrowserPrint(w,silent,params);
266 obj._NSPrint_webBrowserPrint(w,silent,params);
272 obj._NSPrint_webBrowserPrint(w,silent,params);
276 alert('Probably not printing: ' + e);
277 this.error.sdump('D_ERROR','PRINT EXCEPTION: ' + js2JSON(e) + '\n');
282 '_NSPrint_dos_print' : function(w,silent,params) {
286 /* OLD way: This is a kludge/workaround. webBrowserPrint doesn't always work. So we're going to let
287 the html window handle our receipt template rendering, and then force a selection of all
288 the text nodes and dump that to a file, for printing through a dos utility */
290 /* NEW way: we just pass in the text */
294 var file = new util.file('receipt.txt');
295 file.write_content('truncate',text);
296 var path = file._file.path;
299 file = new util.file('receipt.bat');
300 file.write_content('truncate+exec','#!/bin/sh\ncopy "' + path + '" lpt1 /b\nlpr ' + path + '\n');
302 file = new util.file('receipt.bat');
304 var process = Components.classes["@mozilla.org/process/util;1"].createInstance(Components.interfaces.nsIProcess);
305 process.init(file._file);
309 dump('process.run = ' + process.run(true, args, args.length) + '\n');
314 //alert('Probably not printing: ' + e);
315 this.error.sdump('D_ERROR','_NSPrint_dos_print PRINT EXCEPTION: ' + js2JSON(e) + '\n');
319 '_NSPrint_webBrowserPrint' : function(w,silent,params) {
322 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
323 var webBrowserPrint = w
324 .QueryInterface(Components.interfaces.nsIInterfaceRequestor)
325 .getInterface(Components.interfaces.nsIWebBrowserPrint);
326 this.error.sdump('D_PRINT','webBrowserPrint = ' + webBrowserPrint);
327 if (webBrowserPrint) {
328 var gPrintSettings = obj.GetPrintSettings();
329 if (silent) gPrintSettings.printSilent = true;
330 else gPrintSettings.printSilent = false;
332 if (params.marginLeft) gPrintSettings.marginLeft = params.marginLeft;
334 webBrowserPrint.print(gPrintSettings, null);
335 this.error.sdump('D_PRINT','Should be printing\n');
337 this.error.sdump('D_ERROR','Should not be printing\n');
340 //alert('Probably not printing: ' + e);
341 // Pressing cancel is expressed as an NS_ERROR_ABORT return value,
342 // causing an exception to be thrown which we catch here.
343 // Unfortunately this will also consume helpful failures
344 this.error.sdump('D_ERROR','_NSPrint_webBrowserPrint PRINT EXCEPTION: ' + js2JSON(e) + '\n');
348 'GetPrintSettings' : function() {
350 //alert('entering GetPrintSettings');
351 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
352 var pref = Components.classes["@mozilla.org/preferences-service;1"]
353 .getService(Components.interfaces.nsIPrefBranch);
354 //alert('pref = ' + pref);
356 this.gPrintSettingsAreGlobal = pref.getBoolPref("print.use_global_printsettings", false);
357 this.gSavePrintSettings = pref.getBoolPref("print.save_print_settings", false);
358 //alert('gPrintSettingsAreGlobal = ' + this.gPrintSettingsAreGlobal + ' gSavePrintSettings = ' + this.gSavePrintSettings);
361 var printService = Components.classes["@mozilla.org/gfx/printsettings-service;1"]
362 .getService(Components.interfaces.nsIPrintSettingsService);
363 if (this.gPrintSettingsAreGlobal) {
364 this.gPrintSettings = printService.globalPrintSettings;
365 //alert('called setPrinterDefaultsForSelectedPrinter');
366 this.setPrinterDefaultsForSelectedPrinter(printService);
368 this.gPrintSettings = printService.newPrintSettings;
369 //alert('used printService.newPrintSettings');
372 this.error.sdump('D_ERROR',"GetPrintSettings() "+e+"\n");
373 //alert("GetPrintSettings() "+e+"\n");
376 return this.gPrintSettings;
379 'setPrinterDefaultsForSelectedPrinter' : function (aPrintService) {
381 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
382 if (this.gPrintSettings.printerName == "") {
383 this.gPrintSettings.printerName = aPrintService.defaultPrinterName;
384 //alert('used .defaultPrinterName');
386 //alert('printerName = ' + this.gPrintSettings.printerName);
388 // First get any defaults from the printer
389 aPrintService.initPrintSettingsFromPrinter(this.gPrintSettings.printerName, this.gPrintSettings);
391 // now augment them with any values from last time
392 aPrintService.initPrintSettingsFromPrefs(this.gPrintSettings, true, this.gPrintSettings.kInitSaveAll);
394 // now augment from our own saved settings if they exist
395 this.load_settings();
398 this.error.sdump('D_ERROR',"setPrinterDefaultsForSelectedPrinter() "+E+"\n");
402 'page_settings' : function() {
404 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
405 this.GetPrintSettings();
406 var PO = Components.classes["@mozilla.org/gfx/printsettings-service;1"].getService(Components.interfaces.nsIPrintOptions);
407 PO.ShowPrintSetupDialog(this.gPrintSettings);
409 this.error.standard_unexpected_error_alert("page_settings()",E);
413 'load_settings' : function() {
416 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
417 var file = new util.file('gPrintSettings');
418 if (file._file.exists()) {
419 temp = file.get_object(); file.close();
420 for (var i in temp) {
421 try { this.gPrintSettings[i] = temp[i]; } catch(E) { error_msg += 'Error trying to set gPrintSettings.'+i+'='+temp[i]+' : ' + js2JSON(E) + '\n'; }
424 this.gPrintSettings.marginTop = 0;
425 this.gPrintSettings.marginLeft = 0;
426 this.gPrintSettings.marginBottom = 0;
427 this.gPrintSettings.marginRight = 0;
428 this.gPrintSettings.headerStrLeft = '';
429 this.gPrintSettings.headerStrCenter = '';
430 this.gPrintSettings.headerStrRight = '';
431 this.gPrintSettings.footerStrLeft = '';
432 this.gPrintSettings.footerStrCenter = '';
433 this.gPrintSettings.footerStrRight = '';
436 this.error.sdump('D_PRINT',error_msg);
437 this.error.yns_alert(
438 document.getElementById('offlineStrings').getString('load_printer_settings_error_description'),
439 document.getElementById('offlineStrings').getString('load_printer_settings_error_title'),
440 document.getElementById('offlineStrings').getString('common.ok'),
447 this.error.standard_unexpected_error_alert("load_settings()",E);
451 'save_settings' : function() {
454 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
455 var file = new util.file('gPrintSettings');
456 if (typeof obj.gPrintSettings == 'undefined') obj.GetPrintSettings();
457 if (obj.gPrintSettings) file.set_object(obj.gPrintSettings);
460 this.error.standard_unexpected_error_alert("save_settings()",E);
465 dump('exiting util/print.js\n');