const ordersApi = client.ordersApi;
OrdersApi
- Create Order
- Batch Retrieve Orders
- Calculate Order
- Clone Order
- Search Orders
- Retrieve Order
- Update Order
- Pay Order
Creates a new order that can include information about products for purchase and settings to apply to the purchase.
To pay for a created order, see Pay for Orders.
You can modify open orders using the UpdateOrder endpoint.
async createOrder(
body: CreateOrderRequest,
requestOptions?: RequestOptions
): Promise<ApiResponse<CreateOrderResponse>>
Parameter | Type | Tags | Description |
---|---|---|---|
body |
CreateOrderRequest |
Body, Required | An object containing the fields to POST for the request. See the corresponding object definition for field details. |
requestOptions |
RequestOptions | undefined |
Optional | Pass additional request options. |
const contentType = null;
const bodyOrderLineItems: OrderLineItem[] = [];
const bodyOrderlineItems0BasePriceMoney: Money = {};
bodyOrderlineItems0BasePriceMoney.amount = BigInt(1599);
bodyOrderlineItems0BasePriceMoney.currency = 'USD';
const bodyOrderlineItems0: OrderLineItem = {
quantity: '1',
};
bodyOrderlineItems0.name = 'New York Strip Steak';
bodyOrderlineItems0.basePriceMoney = bodyOrderlineItems0BasePriceMoney;
bodyOrderLineItems[0] = bodyOrderlineItems0;
const bodyOrderlineItems1Modifiers: OrderLineItemModifier[] = [];
const bodyOrderlineItems1modifiers0: OrderLineItemModifier = {};
bodyOrderlineItems1modifiers0.catalogObjectId = 'CHQX7Y4KY6N5KINJKZCFURPZ';
bodyOrderlineItems1Modifiers[0] = bodyOrderlineItems1modifiers0;
const bodyOrderlineItems1AppliedDiscounts: OrderLineItemAppliedDiscount[] = [];
const bodyOrderlineItems1appliedDiscounts0: OrderLineItemAppliedDiscount = {
discountUid: 'one-dollar-off',
};
bodyOrderlineItems1AppliedDiscounts[0] = bodyOrderlineItems1appliedDiscounts0;
const bodyOrderlineItems1: OrderLineItem = {
quantity: '2',
};
bodyOrderlineItems1.catalogObjectId = 'BEMYCSMIJL46OCDV4KYIKXIB';
bodyOrderlineItems1.modifiers = bodyOrderlineItems1Modifiers;
bodyOrderlineItems1.appliedDiscounts = bodyOrderlineItems1AppliedDiscounts;
bodyOrderLineItems[1] = bodyOrderlineItems1;
const bodyOrderTaxes: OrderLineItemTax[] = [];
const bodyOrdertaxes0: OrderLineItemTax = {};
bodyOrdertaxes0.uid = 'state-sales-tax';
bodyOrdertaxes0.name = 'State Sales Tax';
bodyOrdertaxes0.percentage = '9';
bodyOrdertaxes0.scope = 'ORDER';
bodyOrderTaxes[0] = bodyOrdertaxes0;
const bodyOrderDiscounts: OrderLineItemDiscount[] = [];
const bodyOrderdiscounts0: OrderLineItemDiscount = {};
bodyOrderdiscounts0.uid = 'labor-day-sale';
bodyOrderdiscounts0.name = 'Labor Day Sale';
bodyOrderdiscounts0.percentage = '5';
bodyOrderdiscounts0.scope = 'ORDER';
bodyOrderDiscounts[0] = bodyOrderdiscounts0;
const bodyOrderdiscounts1: OrderLineItemDiscount = {};
bodyOrderdiscounts1.uid = 'membership-discount';
bodyOrderdiscounts1.catalogObjectId = 'DB7L55ZH2BGWI4H23ULIWOQ7';
bodyOrderdiscounts1.scope = 'ORDER';
bodyOrderDiscounts[1] = bodyOrderdiscounts1;
const bodyOrderdiscounts2AmountMoney: Money = {};
bodyOrderdiscounts2AmountMoney.amount = BigInt(100);
bodyOrderdiscounts2AmountMoney.currency = 'USD';
const bodyOrderdiscounts2: OrderLineItemDiscount = {};
bodyOrderdiscounts2.uid = 'one-dollar-off';
bodyOrderdiscounts2.name = 'Sale - $1.00 off';
bodyOrderdiscounts2.amountMoney = bodyOrderdiscounts2AmountMoney;
bodyOrderdiscounts2.scope = 'LINE_ITEM';
bodyOrderDiscounts[2] = bodyOrderdiscounts2;
const bodyOrder: Order = {
locationId: '057P5VYJ4A5X1',
};
bodyOrder.referenceId = 'my-order-001';
bodyOrder.lineItems = bodyOrderLineItems;
bodyOrder.taxes = bodyOrderTaxes;
bodyOrder.discounts = bodyOrderDiscounts;
const body: CreateOrderRequest = {};
body.order = bodyOrder;
body.idempotencyKey = '8193148c-9586-11e6-99f9-28cfe92138cf';
try {
const { result, ...httpResponse } = await ordersApi.createOrder(body);
// Get more response info...
// const { statusCode, headers } = httpResponse;
} catch(error) {
if (error instanceof ApiError) {
const errors = error.result;
// const { statusCode, headers } = error;
}
}
Retrieves a set of orders by their IDs.
If a given order ID does not exist, the ID is ignored instead of generating an error.
async batchRetrieveOrders(
body: BatchRetrieveOrdersRequest,
requestOptions?: RequestOptions
): Promise<ApiResponse<BatchRetrieveOrdersResponse>>
Parameter | Type | Tags | Description |
---|---|---|---|
body |
BatchRetrieveOrdersRequest |
Body, Required | An object containing the fields to POST for the request. See the corresponding object definition for field details. |
requestOptions |
RequestOptions | undefined |
Optional | Pass additional request options. |
const contentType = null;
const bodyOrderIds: string[] = ['CAISEM82RcpmcFBM0TfOyiHV3es', 'CAISENgvlJ6jLWAzERDzjyHVybY'];
const body: BatchRetrieveOrdersRequest = {
orderIds: bodyOrderIds,
};
body.locationId = '057P5VYJ4A5X1';
try {
const { result, ...httpResponse } = await ordersApi.batchRetrieveOrders(body);
// Get more response info...
// const { statusCode, headers } = httpResponse;
} catch(error) {
if (error instanceof ApiError) {
const errors = error.result;
// const { statusCode, headers } = error;
}
}
Enables applications to preview order pricing without creating an order.
async calculateOrder(
body: CalculateOrderRequest,
requestOptions?: RequestOptions
): Promise<ApiResponse<CalculateOrderResponse>>
Parameter | Type | Tags | Description |
---|---|---|---|
body |
CalculateOrderRequest |
Body, Required | An object containing the fields to POST for the request. See the corresponding object definition for field details. |
requestOptions |
RequestOptions | undefined |
Optional | Pass additional request options. |
const contentType = null;
const bodyOrderLineItems: OrderLineItem[] = [];
const bodyOrderlineItems0BasePriceMoney: Money = {};
bodyOrderlineItems0BasePriceMoney.amount = BigInt(500);
bodyOrderlineItems0BasePriceMoney.currency = 'USD';
const bodyOrderlineItems0: OrderLineItem = {
quantity: '1',
};
bodyOrderlineItems0.name = 'Item 1';
bodyOrderlineItems0.basePriceMoney = bodyOrderlineItems0BasePriceMoney;
bodyOrderLineItems[0] = bodyOrderlineItems0;
const bodyOrderlineItems1BasePriceMoney: Money = {};
bodyOrderlineItems1BasePriceMoney.amount = BigInt(300);
bodyOrderlineItems1BasePriceMoney.currency = 'USD';
const bodyOrderlineItems1: OrderLineItem = {
quantity: '2',
};
bodyOrderlineItems1.name = 'Item 2';
bodyOrderlineItems1.basePriceMoney = bodyOrderlineItems1BasePriceMoney;
bodyOrderLineItems[1] = bodyOrderlineItems1;
const bodyOrderDiscounts: OrderLineItemDiscount[] = [];
const bodyOrderdiscounts0: OrderLineItemDiscount = {};
bodyOrderdiscounts0.name = '50% Off';
bodyOrderdiscounts0.percentage = '50';
bodyOrderdiscounts0.scope = 'ORDER';
bodyOrderDiscounts[0] = bodyOrderdiscounts0;
const bodyOrder: Order = {
locationId: 'D7AVYMEAPJ3A3',
};
bodyOrder.lineItems = bodyOrderLineItems;
bodyOrder.discounts = bodyOrderDiscounts;
const body: CalculateOrderRequest = {
order: bodyOrder,
};
try {
const { result, ...httpResponse } = await ordersApi.calculateOrder(body);
// Get more response info...
// const { statusCode, headers } = httpResponse;
} catch(error) {
if (error instanceof ApiError) {
const errors = error.result;
// const { statusCode, headers } = error;
}
}
Creates a new order, in the DRAFT
state, by duplicating an existing order. The newly created order has
only the core fields (such as line items, taxes, and discounts) copied from the original order.
async cloneOrder(
body: CloneOrderRequest,
requestOptions?: RequestOptions
): Promise<ApiResponse<CloneOrderResponse>>
Parameter | Type | Tags | Description |
---|---|---|---|
body |
CloneOrderRequest |
Body, Required | An object containing the fields to POST for the request. See the corresponding object definition for field details. |
requestOptions |
RequestOptions | undefined |
Optional | Pass additional request options. |
const contentType = null;
const body: CloneOrderRequest = {
orderId: 'ZAISEM52YcpmcWAzERDOyiWS123',
};
body.version = 3;
body.idempotencyKey = 'UNIQUE_STRING';
try {
const { result, ...httpResponse } = await ordersApi.cloneOrder(body);
// Get more response info...
// const { statusCode, headers } = httpResponse;
} catch(error) {
if (error instanceof ApiError) {
const errors = error.result;
// const { statusCode, headers } = error;
}
}
Search all orders for one or more locations. Orders include all sales, returns, and exchanges regardless of how or when they entered the Square ecosystem (such as Point of Sale, Invoices, and Connect APIs).
SearchOrders
requests need to specify which locations to search and define a
SearchOrdersQuery object that controls
how to sort or filter the results. Your SearchOrdersQuery
can:
Set filter criteria.
Set the sort order.
Determine whether to return results as complete Order
objects or as
OrderEntry objects.
Note that details for orders processed with Square Point of Sale while in
offline mode might not be transmitted to Square for up to 72 hours. Offline
orders have a created_at
value that reflects the time the order was created,
not the time it was subsequently transmitted to Square.
async searchOrders(
body: SearchOrdersRequest,
requestOptions?: RequestOptions
): Promise<ApiResponse<SearchOrdersResponse>>
Parameter | Type | Tags | Description |
---|---|---|---|
body |
SearchOrdersRequest |
Body, Required | An object containing the fields to POST for the request. See the corresponding object definition for field details. |
requestOptions |
RequestOptions | undefined |
Optional | Pass additional request options. |
const contentType = null;
const bodyLocationIds: string[] = ['057P5VYJ4A5X1', '18YC4JDH91E1H'];
const bodyQueryFilterStateFilterStates: string[] = ['COMPLETED'];
const bodyQueryFilterStateFilter: SearchOrdersStateFilter = {
states: bodyQueryFilterStateFilterStates,
};
const bodyQueryFilterDateTimeFilterClosedAt: TimeRange = {};
bodyQueryFilterDateTimeFilterClosedAt.startAt = '2018-03-03T20:00:00+00:00';
bodyQueryFilterDateTimeFilterClosedAt.endAt = '2019-03-04T21:54:45+00:00';
const bodyQueryFilterDateTimeFilter: SearchOrdersDateTimeFilter = {};
bodyQueryFilterDateTimeFilter.closedAt = bodyQueryFilterDateTimeFilterClosedAt;
const bodyQueryFilter: SearchOrdersFilter = {};
bodyQueryFilter.stateFilter = bodyQueryFilterStateFilter;
bodyQueryFilter.dateTimeFilter = bodyQueryFilterDateTimeFilter;
const bodyQuerySort: SearchOrdersSort = {
sortField: 'CLOSED_AT',
};
bodyQuerySort.sortOrder = 'DESC';
const bodyQuery: SearchOrdersQuery = {};
bodyQuery.filter = bodyQueryFilter;
bodyQuery.sort = bodyQuerySort;
const body: SearchOrdersRequest = {};
body.locationIds = bodyLocationIds;
body.query = bodyQuery;
body.limit = 3;
body.returnEntries = true;
try {
const { result, ...httpResponse } = await ordersApi.searchOrders(body);
// Get more response info...
// const { statusCode, headers } = httpResponse;
} catch(error) {
if (error instanceof ApiError) {
const errors = error.result;
// const { statusCode, headers } = error;
}
}
Retrieves an Order by ID.
async retrieveOrder(
orderId: string,
requestOptions?: RequestOptions
): Promise<ApiResponse<RetrieveOrderResponse>>
Parameter | Type | Tags | Description |
---|---|---|---|
orderId |
string |
Template, Required | The ID of the order to retrieve. |
requestOptions |
RequestOptions | undefined |
Optional | Pass additional request options. |
const orderId = 'order_id6';
try {
const { result, ...httpResponse } = await ordersApi.retrieveOrder(orderId);
// Get more response info...
// const { statusCode, headers } = httpResponse;
} catch(error) {
if (error instanceof ApiError) {
const errors = error.result;
// const { statusCode, headers } = error;
}
}
Updates an open order by adding, replacing, or deleting
fields. Orders with a COMPLETED
or CANCELED
state cannot be updated.
An UpdateOrder
request requires the following:
- The
order_id
in the endpoint path, identifying the order to update. - The latest
version
of the order to update. - The sparse order containing only the fields to update and the version to which the update is being applied.
- If deleting fields, the dot notation paths identifying the fields to clear.
To pay for an order, see Pay for Orders.
async updateOrder(
orderId: string,
body: UpdateOrderRequest,
requestOptions?: RequestOptions
): Promise<ApiResponse<UpdateOrderResponse>>
Parameter | Type | Tags | Description |
---|---|---|---|
orderId |
string |
Template, Required | The ID of the order to update. |
body |
UpdateOrderRequest |
Body, Required | An object containing the fields to POST for the request. See the corresponding object definition for field details. |
requestOptions |
RequestOptions | undefined |
Optional | Pass additional request options. |
const orderId = 'order_id6';
const contentType = null;
const body: UpdateOrderRequest = {};
try {
const { result, ...httpResponse } = await ordersApi.updateOrder(orderId, body);
// Get more response info...
// const { statusCode, headers } = httpResponse;
} catch(error) {
if (error instanceof ApiError) {
const errors = error.result;
// const { statusCode, headers } = error;
}
}
Pay for an order using one or more approved payments
or settle an order with a total of 0
.
The total of the payment_ids
listed in the request must be equal to the order
total. Orders with a total amount of 0
can be marked as paid by specifying an empty
array of payment_ids
in the request.
To be used with PayOrder
, a payment must:
- Reference the order by specifying the
order_id
when creating the payment. Any approved payments that reference the sameorder_id
not specified in thepayment_ids
is canceled. - Be approved with delayed capture.
Using a delayed capture payment with
PayOrder
completes the approved payment.
async payOrder(
orderId: string,
body: PayOrderRequest,
requestOptions?: RequestOptions
): Promise<ApiResponse<PayOrderResponse>>
Parameter | Type | Tags | Description |
---|---|---|---|
orderId |
string |
Template, Required | The ID of the order being paid. |
body |
PayOrderRequest |
Body, Required | An object containing the fields to POST for the request. See the corresponding object definition for field details. |
requestOptions |
RequestOptions | undefined |
Optional | Pass additional request options. |
const orderId = 'order_id6';
const contentType = null;
const bodyPaymentIds: string[] = ['EnZdNAlWCmfh6Mt5FMNST1o7taB', '0LRiVlbXVwe8ozu4KbZxd12mvaB'];
const body: PayOrderRequest = {
idempotencyKey: 'c043a359-7ad9-4136-82a9-c3f1d66dcbff',
};
body.paymentIds = bodyPaymentIds;
try {
const { result, ...httpResponse } = await ordersApi.payOrder(orderId, body);
// Get more response info...
// const { statusCode, headers } = httpResponse;
} catch(error) {
if (error instanceof ApiError) {
const errors = error.result;
// const { statusCode, headers } = error;
}
}