# yarn
yarn add ecpay-invoice-sdk
# npm
npm install --save ecpay-invoice-sdk
# pnpm
pnpm add ecpay-invoice-sdk
const EcpayInvoiceClient = require("ecpay-invoice-sdk");
const client = new EcpayInvoiceClient({
merchantId: "ECPay Invoice Merchant ID",
hashKey: "ECPay Invoice Hash Key",
hashIV: "ECPay Invoice Hash IV",
env: "production", // 'sandbox' | 'production'
});
import EcpayInvoiceClient from "ecpay-invoice-sdk";
const client = new EcpayInvoiceClient({
merchantId: "ECPay Invoice Merchant ID",
hashKey: "ECPay Invoice Hash Key",
hashIV: "ECPay Invoice Hash IV",
env: "production", // 'sandbox' | 'production'
});
詳情請見官方文件:文件網址
await client.issueB2CInvoice({
RelateNumber: "ORDERID12345",
Print: "0", // 0:不列印 1:要列印
Donation: "0", // 0:不捐贈 1:要捐贈
CarrierType: "1", // 空字串:無載具 1:綠界電子發票載具 2:自然人憑證號碼 3:手機條碼載具
SpecialTaxType: 0, // 特種稅額類別
CustomerEmail: "test@example.com",
Items: [
{ ItemName: "測試商品", ItemCount: 1, ItemWord: "個", ItemPrice: 1000 },
],
});
詳情請見官方文件:文件網址
await client.revokeB2CInvoice(
"AA123456", // 發票號碼
"YYYY-MM-DD", // 發票開立日期
"invoke reason" // 作廢原因
);
詳情請見官方文件:文件網址
await client.issueB2CAllowance({
InvoiceNo: "AA123456", // 發票號碼
InvoiceDate: "2023-01-01", // 發票開立日期
AllowanceNotify: "E", // S:簡訊 E:電子郵件 A:皆通知時 N:皆不通知
CustomerEmail: "test@example.com",
Items: [
{ ItemName: "測試商品", ItemCount: 1, ItemWord: "個", ItemPrice: 1000 },
],
});
詳情請見官方文件:文件網址
await client.revokeB2CAllowance(
"AA123456", // 發票號碼
"2016022615195209", // 折讓號碼
"invoke reason" // 作廢原因
);