How to generate and print raw ESC/POS commands from Javascript
Product JSPrintManager Published 09/15/2020 Updated 08/01/2022 Author Neodynamic
Overview
In this article, you'll learn how to generate and print raw ESC/POS commands from Javascript directly to the client printer without displaying a print dialog at all. You'll be able to print ESC/POS commands to the Default client printer as well as to any other installed printer at the client machine. This solution works with any popular browser like Chrome, Firefox, IE/Edge & Safari on Windows, Linux, Raspberry Pi and Mac systems!
If you don't know how to write ESC/POS commands, then you can take advantage of our JSESCPOSBuilder project to generate the ESC/POS commands by writing simple and dev-friendly Javascript code to finally print it from any Web Platform/Framework you use (ASP.NET, PHP, Django, Ruby On Rails (RoR), Express.js, AngularJS/SPA, etc.) right to the client printer through JSPrintManager solution.
The ESC/POS commands that we'll use in this article will print out a simple label that will look like this:
Follow up these steps
-
JSPrintManager Client App
Be sure you install in your dev machine JSPrintManager (JSPM) (Available for Windows, Linux, Raspberry Pi & Mac)
IMPORTANT: This small app must be installed on each client! -
HTML & Script References
- Download JSPrintManager.js
- Download cptable.js & cputils.js
- Copy all of these *.js files to the same folder where the next
index.html
page sample will be located in. - By using your favorite Web Development IDE or Text Editor, create a new HTML file naming it
index.html
Copy/paste the following code inside that html file:
<!DOCTYPE html> <html> <head> <title>Advanced ESC/POS Printing from Javascript</title> <meta charset="utf-8" /> </head> <body> <div style="text-align:center"> <h1>Advanced ESC/POS Printing from Javascript</h1> <hr /> <label class="checkbox"> <input type="checkbox" id="useDefaultPrinter" /> <strong>Print to Default printer</strong> </label> <p>or...</p> <div id="installedPrinters"> <label for="printerName">Select an installed Printer:</label> <select name="printerName" id="printerName"></select> </div> <br /><br /> <button type="button" onclick="doPrinting();">Print Now...</button> </div> <script src="https://cdnjs.cloudflare.com/ajax/libs/bluebird/3.3.5/bluebird.min.js"></script> <script src="https://code.jquery.com/jquery-3.2.1.slim.min.js"></script> <!--IMPORTANT: BE SURE YOU HONOR THIS JS LOAD ORDER--> <script src="scripts/cptable.js"></script> <script src="scripts/cputils.js"></script> <script src="scripts/JSESCPOSBuilder.js"></script> <script src="scripts/JSPrintManager.js"></script> <script> var clientPrinters = null; var _this = this; //WebSocket settings JSPM.JSPrintManager.auto_reconnect = true; JSPM.JSPrintManager.start(); JSPM.JSPrintManager.WS.onStatusChanged = function () { if (jspmWSStatus()) { //get client installed printers JSPM.JSPrintManager.getPrinters().then(function (printersList) { clientPrinters = printersList; var options = ''; for (var i = 0; i < clientPrinters.length; i++) { options += '<option>' + clientPrinters[i] + '</option>'; } $('#printerName').html(options); }); } }; //Check JSPM WebSocket status function jspmWSStatus() { if (JSPM.JSPrintManager.websocket_status == JSPM.WSStatus.Open) return true; else if (JSPM.JSPrintManager.websocket_status == JSPM.WSStatus.Closed) { console.warn('JSPrintManager (JSPM) is not installed or not running! Download JSPM Client App from https://neodynamic.com/downloads/jspm'); return false; } else if (JSPM.JSPrintManager.websocket_status == JSPM.WSStatus.Blocked) { alert('JSPM has blocked this website!'); return false; } } //Do printing... function doPrinting() { if (jspmWSStatus()) { // Gen sample label featuring logo/image, barcode, QRCode, text, etc by using JSESCPOSBuilder.js var escpos = Neodynamic.JSESCPOSBuilder; var doc = new escpos.Document(); escpos.ESCPOSImage.load('') .then(logo => { // logo image loaded, create ESC/POS commands var escposCommands = doc .image(logo, escpos.BitmapDensity.D24) .font(escpos.FontFamily.A) .align(escpos.TextAlignment.Center) .style([escpos.FontStyle.Bold]) .size(1, 1) .text("This is a BIG text") .font(escpos.FontFamily.B) .size(0, 0) .text("Normal-small text") .linearBarcode('1234567', escpos.Barcode1DType.EAN8, new escpos.Barcode1DOptions(2, 100, true, escpos.BarcodeTextPosition.Below, escpos.BarcodeFont.A)) .qrCode('https://mycompany.com', new escpos.BarcodeQROptions(escpos.QRLevel.L, 6)) .pdf417('PDF417 data to be encoded here', new escpos.BarcodePDF417Options(3, 3, 0, 0.1, false)) .feed(5) .cut() .generateUInt8Array(); // create ClientPrintJob var cpj = new JSPM.ClientPrintJob(); // Set Printer info var myPrinter = new JSPM.InstalledPrinter($('#printerName').val()); cpj.clientPrinter = myPrinter; // Set the ESC/POS commands cpj.binaryPrinterCommands = escposCommands; // Send print job to printer! cpj.sendToClient(); }); } } </script> </body> </html>
- That's it! Run your website and test it.