A node module to natively print your files
- Supports edge-js
- Supports electron-edge-js
-
- edge or electron-edge (depending on your environment). Both of them need to be installed before this module. During installation it will be detected which one is installed
Due to important differences in enviroments and ecosystems between Microsoft and Unix-based systems, this module has been written in C++ for Unix and C# for Windows. This can result in different behaviours during the execution of the methods (such as different execution time, returning values, allowed options for printer, etc.).
npm install node-native-printer --save
First of all you need to require the module inside your app this way:
const printer = require('node-native-printer');
Then you can set a printer to work on, calling setPrinter(printerName)
. In this way you don't need to pass else the printer name on each method it's required.
return an array with all installed printers
return the default printer name
set the printer to work on
get current printer you are working on
return general info about current working printer such jobs and options:
- printer: printer of which get informations
- returning value:
- Windows: return only jobs in printer queue
- Unix: return jobs in printer queue and CUPS options. Theese last depends on printer
return printer-specific options:
-
printer: name of the printer to print on. If not specified it will print on previously setted printer. If printer is not set it will print on default printer.
-
Returning value:
- Windows: return an object containing main options for printer:
{ "Collate": "array containing collation options", "Duplexing": "array containing collation options", "MaxCopy": "max number of copies you can send to printer", "SupportsColor": "boolean indicating whether a print can print with colors", "PaperSheets": "available paper formats supported from printer. If custom is present it can be submitted custom width and height", "Resolutions": "printer resolutions (i.e.: High, Medium)" }
- Unix: return an object containing printer-specific options and from PPD file.
- filename: file to print
- options: a JSON object containing options for printer:
-
Windows: default options:
{ "collate": true, "color": true, "copies": 1, "duplex": "Default", "landscape": false, "paperSize": "", "fromPage": 0, "toPage": 0 }
List of supported extensions can be found here
Notes: duplex is case sensitive, so be careful to write correctly.
"paperSize"
refers to size of sheet to print on; if you want to print on a paper with custom dimensions, pass"Custom.WidthxHeight"
where Width and Height are integer dimensions in hundredths of inch."fromPage": 0
means document will be printed from first page;"toPage": 0
means document will be printed from"fromPage"
to last page. -
Unix: you can use command-line options in JSON-style and/or printer-specific options retrieved from
printerOptions()
; i.e.:{ "landscape": true, "n": 2, "sides": "two-sided-long-edge" }
For options that doesn't have a value (like
landscape
orfit-to-page
) you can assign a boolean (see above)It will be generated and executed a command like
lp -d printerName /path/to/filename -o landscape -n 2 -o sides=two-sided-long-edge
-
- Returning value (only for Unix): job id of work sent to printer
Same as print()
but you can pass directly a string of text on the first parameter.