update
This commit is contained in:
59
ts/formats/ubl/ubl.encoder.ts
Normal file
59
ts/formats/ubl/ubl.encoder.ts
Normal file
@ -0,0 +1,59 @@
|
||||
import { BaseEncoder } from '../base/base.encoder.js';
|
||||
import type { TInvoice, TCreditNote, TDebitNote } from '../../interfaces/common.js';
|
||||
import { UBLDocumentType, UBL_NAMESPACES } from './ubl.types.js';
|
||||
|
||||
/**
|
||||
* Base encoder for UBL-based invoice formats
|
||||
*/
|
||||
export abstract class UBLBaseEncoder extends BaseEncoder {
|
||||
/**
|
||||
* Encodes a TInvoice object into UBL XML
|
||||
* @param invoice TInvoice object to encode
|
||||
* @returns UBL XML string
|
||||
*/
|
||||
public async encode(invoice: TInvoice): Promise<string> {
|
||||
// Determine if it's a credit note or debit note
|
||||
if (invoice.invoiceType === 'creditnote') {
|
||||
return this.encodeCreditNote(invoice as TCreditNote);
|
||||
} else {
|
||||
return this.encodeDebitNote(invoice as TDebitNote);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Encodes a TCreditNote object into UBL XML
|
||||
* @param creditNote TCreditNote object to encode
|
||||
* @returns UBL XML string
|
||||
*/
|
||||
protected abstract encodeCreditNote(creditNote: TCreditNote): Promise<string>;
|
||||
|
||||
/**
|
||||
* Encodes a TDebitNote object into UBL XML
|
||||
* @param debitNote TDebitNote object to encode
|
||||
* @returns UBL XML string
|
||||
*/
|
||||
protected abstract encodeDebitNote(debitNote: TDebitNote): Promise<string>;
|
||||
|
||||
/**
|
||||
* Creates the XML declaration and root element
|
||||
* @param documentType UBL document type
|
||||
* @returns XML string with declaration and root element
|
||||
*/
|
||||
protected createXmlRoot(documentType: UBLDocumentType): string {
|
||||
return `<?xml version="1.0" encoding="UTF-8"?>
|
||||
<${documentType} xmlns="urn:oasis:names:specification:ubl:schema:xsd:${documentType}-2"
|
||||
xmlns:cac="${UBL_NAMESPACES.CAC}"
|
||||
xmlns:cbc="${UBL_NAMESPACES.CBC}">
|
||||
</${documentType}>`;
|
||||
}
|
||||
|
||||
/**
|
||||
* Formats a date as an ISO string (YYYY-MM-DD)
|
||||
* @param timestamp Timestamp to format
|
||||
* @returns Formatted date string
|
||||
*/
|
||||
protected formatDate(timestamp: number): string {
|
||||
const date = new Date(timestamp);
|
||||
return date.toISOString().split('T')[0];
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user