Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 | 8x 8x 8x 8x 8x 1x 1x 1x | import AConnector from '@orchesty/nodejs-sdk/dist/lib/Connector/AConnector';
import { HttpMethods } from '@orchesty/nodejs-sdk/dist/lib/Transport/HttpMethods';
import ProcessDto from '@orchesty/nodejs-sdk/dist/lib/Utils/ProcessDto';
export const NAME = 'quick-books-create-invoice-connector';
export default class QuickBooksCreateInvoiceConnector extends AConnector {
public getName(): string {
return NAME;
}
public async processAction(dto: ProcessDto<IInput>): Promise<ProcessDto<IOutput>> {
const req = await this.getApplication().getRequestDto(
dto,
await this.getApplicationInstallFromProcess(dto),
HttpMethods.POST,
'/invoice',
dto.getJsonData(),
);
const resp = await this.getSender().send<IOutput>(req, [200]);
return dto.setNewJsonData(resp.getJsonBody());
}
}
/* eslint-disable @typescript-eslint/naming-convention */
export interface IOutput {
Invoice: {
DocNumber: string;
SyncToken: string;
domain: string;
Balance: number;
BillAddr: {
City: string;
Line1: string;
PostalCode: string;
Lat: string;
Long: string;
CountrySubDivisionCode: string;
Id: string;
};
TxnDate: string;
TotalAmt: number;
CustomerRef: {
name: string;
value: string;
};
ShipAddr: {
City: string;
Line1: string;
PostalCode: string;
Lat: string;
Long: string;
CountrySubDivisionCode: string;
Id: string;
};
LinkedTxn: unknown[];
DueDate: string;
PrintStatus: string;
Deposit: number;
sparse: boolean;
EmailStatus: string;
Line: {
LineNum: number;
Amount: number;
SalesItemLineDetail: {
TaxCodeRef: {
name: string;
value: string;
};
ItemRef: {
name: string;
value: string;
};
};
Id: string;
DetailType: string;
}[];
ApplyTaxAfterDiscount: boolean;
CustomField: {
DefinitionId: string;
Type: string;
Name: string;
}[];
Id: string;
TxnTaxDetail: {
TotalTax: number;
};
MetaData: {
CreateTime: string;
LastUpdatedTime: string;
};
};
time?: string;
}
export interface IInput {
Line: {
DetailType: string;
Amount: number;
SalesItemLineDetail: {
ItemRef?: {
value: string;
name?: string;
};
};
}[];
CustomerRef: {
value: string;
name?: string;
};
}
/* eslint-enable @typescript-eslint/naming-convention */
|