All files / src/Batch MYOBGetEmployeeBatch.ts

93.33% Statements 14/15
50% Branches 2/4
100% Functions 2/2
93.33% Lines 14/15

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 1051x 1x     1x 1x   1x     1x       1x 1x 1x           1x 1x   1x 1x       1x                                                                                                                                                    
import ABatchNode from '@orchesty/nodejs-sdk/dist/lib/Batch/ABatchNode';
import { HttpMethods } from '@orchesty/nodejs-sdk/dist/lib/Transport/HttpMethods';
import BatchProcessDto from '@orchesty/nodejs-sdk/dist/lib/Utils/BatchProcessDto';
 
export const NAME = 'myob-get-employee-batch';
const limit = 100;
 
export default class MYOBGetEmployeeBatch extends ABatchNode {
 
    public getName(): string {
        return NAME;
    }
 
    public async processAction(dto: BatchProcessDto): Promise<BatchProcessDto> {
        const skip = dto.getBatchCursor('0');
        const appInstall = await this.getApplicationInstallFromProcess(dto);
        const req = await this.getApplication().getRequestDto(
            dto,
            appInstall,
            HttpMethods.GET,
            `/Contact/Employee?$top=${limit}&$skip=${skip}`,
        );
        const resp = await this.getSender().send<IOutput[]>(req, [200]);
        const response = resp.getJsonBody();
 
        dto.setItemList(response ?? []);
        Iif (response.length >= limit) {
            dto.setBatchCursor((Number(skip) + limit).toString());
        }
 
        return dto;
    }
 
}
 
/* eslint-disable @typescript-eslint/naming-convention */
 
interface IOutput {
    UID: string;
    LastName: string;
    FirstName: string;
    IsIndividual: boolean;
    DisplayID: string;
    IsActive: boolean;
    Addresses: {
        Location: number;
        Street: string;
        City: string;
        State: string;
        PostCode: string;
        Country: string;
        Phone1: string;
        Phone2: string;
        Phone3: string;
        Fax: string;
        Email: string;
        Website: string;
        ContactName: string;
        Salutation: string;
    }[];
    Notes: string;
    Identifiers: {
        Label: string;
        Value: string;
    }[];
    CustomList1: null;
    CustomList2: null;
    CustomList3: null;
    CustomField1: {
        Label: string;
        Value: string;
    };
    CustomField2: {
        Label: string;
        Value: string;
    };
    CustomField3: {
        Label: string;
        Value: string;
    };
    CurrentBalance: number;
    EmployeePayrollDetails: {
        UID: string;
        URI: string;
    };
    EmployeePaymentDetails: {
        UID: string;
        URI: string;
    };
    EmployeeStandardPay: {
        UID: string;
        URI: string;
    };
    TimeBillingDetails: {
        EmployeeBillingRateExcludingTax: number;
        CostPerHour: number;
    };
    LastModified: string;
    PhotoURI: string;
    URI: string;
    RowVersion: string;
}
 
/* eslint-enable @typescript-eslint/naming-convention */