allocate-credit-note-to-invoice.ts•1.85 kB
import { Property, createAction } from '@activepieces/pieces-framework';
import {
  AuthenticationType,
  HttpMethod,
  HttpRequest,
  httpClient,
} from '@activepieces/pieces-common';
import { xeroAuth } from '../..';
import { props } from '../common/props';
export const xeroAllocateCreditNoteToInvoice = createAction({
  auth: xeroAuth,
  name: 'xero_allocate_credit_note_to_invoice',
  displayName: 'Allocate Credit Note to Invoice',
  description: 'Allocates a credit note to a specific invoice.',
  props: {
    tenant_id: props.tenant_id,
    credit_note_id: props.credit_note_id(true),
    invoice_id: props.invoice_id(true),
    amount: Property.Number({
      displayName: 'Amount',
      description: 'The amount of the credit to allocate.',
      required: true,
    }),
    date: Property.ShortText({
      displayName: 'Allocation Date',
      description: 'Date of allocation. Format: YYYY-MM-DD. Optional.',
      required: false,
    }),
  },
  async run(context) {
    const { tenant_id, credit_note_id, invoice_id, amount, date } =
      context.propsValue;
    const url = `https://api.xero.com/api.xro/2.0/CreditNotes/${credit_note_id}/Allocations`;
    const body: Record<string, unknown> = {
      Allocations: [
        {
          Invoice: {
            InvoiceID: invoice_id,
          },
          Amount: amount,
          ...(date ? { Date: date } : {}),
        },
      ],
    };
    const request: HttpRequest = {
      method: HttpMethod.POST,
      url,
      body,
      authentication: {
        type: AuthenticationType.BEARER_TOKEN,
        token: context.auth.access_token,
      },
      headers: {
        'Xero-Tenant-Id': tenant_id,
      },
    };
    const result = await httpClient.sendRequest(request);
    if (result.status === 200) {
      return result.body;
    }
    return result;
  },
});