epson-fiscal-printer
v1.1.23
Published
A typescript module for fiscal printers support.
Downloads
307
Maintainers
Readme
Fiscal Printer
In order to easily interface with different brands of fiscal printers and use their same functions, this module defines a unified interactive data structure and interfaces. By implementing these interfaces to interact with a certain certain brand of fiscal printer.
Interactive data structure
Fiscal.Receipt
| Name | Desc | | --- | --- | | operator | to identify the operator | | sales | sale items or cancel sale items | | lottery | national lottery unique customer code | | personalTaxCode | | refunds | refund items or cancel refunds | | subtotals | | | payments | | | barCode | | | qrCode | | | graphicCoupon | | | openDrawer | |
Fiscal.Report
| Name | Desc | | --- | --- | | type | report type: daily financial report or daily fiscal closure or both | | operator | | | timeout | | | openDrawer | |
Fiscal.Cancel
| Name | Desc | | --- | --- | | type | void or redund | | zRepNum | daily fiscal closure report number | | docNum | document number | | date | | | fiscalNum | fiscal serial number of the printer | | operator | |
Fiscal.Command
| Name | Desc | | --- | --- | | code | command type | | data | data required by the command |
Commands
| Command | Desc | Support | --- | --- | --- | | OPEN_DRAWER | value: 0, open drawer | Epson / Custom | | QUERY_PRINTER_STATUS | value 1, query printer status | Epson / Custom | | RESET_PRINTER | value 2, reset printer | Epson / Custom | | GET_NATIVE_CODE_FUNCTION | value 3, use printer native code command | Epson / Custom | | GET_INFO | value 4, get printer device info | Custom Only |
Interfaces
| Epson | Custom | RCH |
| --- | --- | --- |
| printFiscalReceipt(receipt: Fiscal.Receipt)
| printFiscalReceipt(receipt: FPrinterCustom.Receipt)
|
| printFiscalReport(report: Fiscal.Report)
| printFiscalReport(report: FPrinterCustom.Report)
|
| printCancel(cancel: Fiscal.Cancel)
| printCancel(cancel: FPrinterCustom.Cancel)
|
| executeCommand(...commands: Fiscal.Command[])
| executeCommand(...commands: FPrinterCustom.Command[])
|executeCommand(commands: RCHProtocol.Commands)
|
Usage
- Epson Fiscal ePOS-Print XML Examples
// Create a client
const fprinter: FPrinter.Client = new EpsonXmlHttpClient({
host: '192.168.1.1',
deviceId: 'local_printer',
timeout: 10000
});
// Fiscal receipt
await client.printFiscalReceipt({
sales: [
{
type: Fiscal.ItemType.HOLD,
description: 'A',
quantity: 1,
unitPrice: 5
},
{
type: Fiscal.ItemType.HOLD,
description: 'B',
quantity: 2,
unitPrice: 2.5
},
{
type: Fiscal.ItemType.HOLD,
description: 'C',
quantity: 3,
unitPrice: 3
},
],
payments: [
{
description: 'Payment in cash',
payment: 19
}
]
});
// Fiscal Report
await client.printFiscalReport({
type: Fiscal.ReportType.DAILY_FISCAL_CLOUSE,
});
- Custom Protocol Examples
Note: unit quantity multiplied by 1000, unit price multiplied by 1000, include the discount, payment
// Create a client
const fprinter: FPrinterCustom.Client = new CustomXmlHttpClient({
host: '192.168.1.1',
fiscalId: 'STMTE500432', // 11 digits
});
// Fiscal receipt
await fprinter.printFiscalReceipt({
sales: [
{
type: Fiscal.ItemType.HOLD,
description: 'A',
quantity: 1 * 1000,
unitPrice: 5 * 100
},
{
type: Fiscal.ItemType.HOLD,
description: 'B',
quantity: 2 * 1000,
unitPrice: 2.5 * 100
},
{
type: Fiscal.ItemType.HOLD,
description: 'C',
quantity: 3 * 1000,
unitPrice: 3 * 100
},
],
payments: [
{
description: 'Payment in cash',
payment: 19 * 100,
paymentType: 1
}
]
});
// Fiscal Refund
// step 1 request to make sure the annulment is possible, if responseBuf === 1 then execute step 2
await fprinter.printCancel({
docRefZ: '0021',
docRefNumber: '0034',
docDate: '011022', // DDMMYY
printPreview: CustomProtocol.EnableType.DISABLE,
fiscalSerial: 'STMTE500432',
checkOnly: CustomProtocol.EnableType.ABLE,
codLottery: 'ASDSFES7',
});
// step 2 to proceed with the actual void request
await fprinter.printCancel({
docRefZ: '0021',
docRefNumber: '0034',
docDate: '011022', // DDMMYY,
printPreview: CustomProtocol.EnableType.DISABLE,
fiscalSerial: 'STMTE500432',
checkOnly: CustomProtocol.EnableType.DISABLE,
codLottery: 'ASDSFES7',
});
// Fiscal Report
await fprinter.printFiscalReport({
type: CustomProtocol.ReportType.DAILY_FISCAL_CLOUSE,
});
// Fiscal Command
await fprinter.executeCommand({
code: CustomProtocol.CommandCode.OPEN_DRAWER
});
- RCH Protocol Examples
// init instance
const rchInstance = new RCHXmlHttpClient({
host: '192.168.1.99',
});
// exec sale item command
const response = await rchInstance.executeCommand([
'=R1/$200/(DOLCE)',
'=R2/$100/*2/(CAFFE)',
'=T1'
]);
// get fiscal status command
const getStatus = await rchInstance.executeCommand([
'</?i/*4',
]);
/**
* refund
* 180923: DDMMYY
* 27: lastZ + 1
* 16: lastDocF
*/
const getStatus = await rchInstance.executeCommand([
`=k/&180923/[27/]16`
]);
Implemented
| Epson | Custom | RCH | --- | --- | --- | | Fiscal ePOS-Print XML | | |