postgrid-node 0.1.0-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (291) hide show
  1. package/CHANGELOG.md +19 -0
  2. package/LICENSE +201 -0
  3. package/README.md +346 -0
  4. package/_shims/MultipartBody.d.ts +9 -0
  5. package/_shims/MultipartBody.d.ts.map +1 -0
  6. package/_shims/MultipartBody.js +16 -0
  7. package/_shims/MultipartBody.js.map +1 -0
  8. package/_shims/MultipartBody.mjs +12 -0
  9. package/_shims/MultipartBody.mjs.map +1 -0
  10. package/_shims/README.md +46 -0
  11. package/_shims/auto/runtime-bun.d.ts +5 -0
  12. package/_shims/auto/runtime-bun.d.ts.map +1 -0
  13. package/_shims/auto/runtime-bun.js +21 -0
  14. package/_shims/auto/runtime-bun.js.map +1 -0
  15. package/_shims/auto/runtime-bun.mjs +2 -0
  16. package/_shims/auto/runtime-bun.mjs.map +1 -0
  17. package/_shims/auto/runtime-node.d.ts +5 -0
  18. package/_shims/auto/runtime-node.d.ts.map +1 -0
  19. package/_shims/auto/runtime-node.js +21 -0
  20. package/_shims/auto/runtime-node.js.map +1 -0
  21. package/_shims/auto/runtime-node.mjs +2 -0
  22. package/_shims/auto/runtime-node.mjs.map +1 -0
  23. package/_shims/auto/runtime.d.ts +5 -0
  24. package/_shims/auto/runtime.d.ts.map +1 -0
  25. package/_shims/auto/runtime.js +21 -0
  26. package/_shims/auto/runtime.js.map +1 -0
  27. package/_shims/auto/runtime.mjs +2 -0
  28. package/_shims/auto/runtime.mjs.map +1 -0
  29. package/_shims/auto/types-node.d.ts +5 -0
  30. package/_shims/auto/types-node.d.ts.map +1 -0
  31. package/_shims/auto/types-node.js +21 -0
  32. package/_shims/auto/types-node.js.map +1 -0
  33. package/_shims/auto/types-node.mjs +2 -0
  34. package/_shims/auto/types-node.mjs.map +1 -0
  35. package/_shims/auto/types.d.ts +101 -0
  36. package/_shims/auto/types.js +3 -0
  37. package/_shims/auto/types.mjs +3 -0
  38. package/_shims/bun-runtime.d.ts +6 -0
  39. package/_shims/bun-runtime.d.ts.map +1 -0
  40. package/_shims/bun-runtime.js +14 -0
  41. package/_shims/bun-runtime.js.map +1 -0
  42. package/_shims/bun-runtime.mjs +10 -0
  43. package/_shims/bun-runtime.mjs.map +1 -0
  44. package/_shims/index.d.ts +81 -0
  45. package/_shims/index.js +13 -0
  46. package/_shims/index.mjs +7 -0
  47. package/_shims/manual-types.d.ts +12 -0
  48. package/_shims/manual-types.js +3 -0
  49. package/_shims/manual-types.mjs +3 -0
  50. package/_shims/node-runtime.d.ts +3 -0
  51. package/_shims/node-runtime.d.ts.map +1 -0
  52. package/_shims/node-runtime.js +89 -0
  53. package/_shims/node-runtime.js.map +1 -0
  54. package/_shims/node-runtime.mjs +56 -0
  55. package/_shims/node-runtime.mjs.map +1 -0
  56. package/_shims/node-types.d.ts +42 -0
  57. package/_shims/node-types.js +3 -0
  58. package/_shims/node-types.mjs +3 -0
  59. package/_shims/registry.d.ts +37 -0
  60. package/_shims/registry.d.ts.map +1 -0
  61. package/_shims/registry.js +41 -0
  62. package/_shims/registry.js.map +1 -0
  63. package/_shims/registry.mjs +37 -0
  64. package/_shims/registry.mjs.map +1 -0
  65. package/_shims/web-runtime.d.ts +5 -0
  66. package/_shims/web-runtime.d.ts.map +1 -0
  67. package/_shims/web-runtime.js +78 -0
  68. package/_shims/web-runtime.js.map +1 -0
  69. package/_shims/web-runtime.mjs +71 -0
  70. package/_shims/web-runtime.mjs.map +1 -0
  71. package/_shims/web-types.d.ts +83 -0
  72. package/_shims/web-types.js +3 -0
  73. package/_shims/web-types.mjs +3 -0
  74. package/core.d.ts +241 -0
  75. package/core.d.ts.map +1 -0
  76. package/core.js +914 -0
  77. package/core.js.map +1 -0
  78. package/core.mjs +882 -0
  79. package/core.mjs.map +1 -0
  80. package/error.d.ts +47 -0
  81. package/error.d.ts.map +1 -0
  82. package/error.js +113 -0
  83. package/error.js.map +1 -0
  84. package/error.mjs +97 -0
  85. package/error.mjs.map +1 -0
  86. package/index.d.mts +144 -0
  87. package/index.d.ts +144 -0
  88. package/index.d.ts.map +1 -0
  89. package/index.js +161 -0
  90. package/index.js.map +1 -0
  91. package/index.mjs +118 -0
  92. package/index.mjs.map +1 -0
  93. package/package.json +124 -0
  94. package/pagination.d.ts +24 -0
  95. package/pagination.d.ts.map +1 -0
  96. package/pagination.js +45 -0
  97. package/pagination.js.map +1 -0
  98. package/pagination.mjs +41 -0
  99. package/pagination.mjs.map +1 -0
  100. package/resource.d.ts +6 -0
  101. package/resource.d.ts.map +1 -0
  102. package/resource.js +11 -0
  103. package/resource.js.map +1 -0
  104. package/resource.mjs +7 -0
  105. package/resource.mjs.map +1 -0
  106. package/resources/bank-accounts.d.ts +285 -0
  107. package/resources/bank-accounts.d.ts.map +1 -0
  108. package/resources/bank-accounts.js +45 -0
  109. package/resources/bank-accounts.js.map +1 -0
  110. package/resources/bank-accounts.mjs +40 -0
  111. package/resources/bank-accounts.mjs.map +1 -0
  112. package/resources/boxes.d.ts +683 -0
  113. package/resources/boxes.d.ts.map +1 -0
  114. package/resources/boxes.js +54 -0
  115. package/resources/boxes.js.map +1 -0
  116. package/resources/boxes.mjs +49 -0
  117. package/resources/boxes.mjs.map +1 -0
  118. package/resources/campaigns.d.ts +644 -0
  119. package/resources/campaigns.d.ts.map +1 -0
  120. package/resources/campaigns.js +67 -0
  121. package/resources/campaigns.js.map +1 -0
  122. package/resources/campaigns.mjs +62 -0
  123. package/resources/campaigns.mjs.map +1 -0
  124. package/resources/cheques/cheques.d.ts +349 -0
  125. package/resources/cheques/cheques.d.ts.map +1 -0
  126. package/resources/cheques/cheques.js +95 -0
  127. package/resources/cheques/cheques.js.map +1 -0
  128. package/resources/cheques/cheques.mjs +67 -0
  129. package/resources/cheques/cheques.mjs.map +1 -0
  130. package/resources/cheques/index.d.ts +4 -0
  131. package/resources/cheques/index.d.ts.map +1 -0
  132. package/resources/cheques/index.js +12 -0
  133. package/resources/cheques/index.js.map +1 -0
  134. package/resources/cheques/index.mjs +5 -0
  135. package/resources/cheques/index.mjs.map +1 -0
  136. package/resources/cheques/url.d.ts +29 -0
  137. package/resources/cheques/url.d.ts.map +1 -0
  138. package/resources/cheques/url.js +20 -0
  139. package/resources/cheques/url.js.map +1 -0
  140. package/resources/cheques/url.mjs +16 -0
  141. package/resources/cheques/url.mjs.map +1 -0
  142. package/resources/cheques/with-deposit-ready-pdf.d.ts +13 -0
  143. package/resources/cheques/with-deposit-ready-pdf.d.ts.map +1 -0
  144. package/resources/cheques/with-deposit-ready-pdf.js +18 -0
  145. package/resources/cheques/with-deposit-ready-pdf.js.map +1 -0
  146. package/resources/cheques/with-deposit-ready-pdf.mjs +14 -0
  147. package/resources/cheques/with-deposit-ready-pdf.mjs.map +1 -0
  148. package/resources/contacts.d.ts +295 -0
  149. package/resources/contacts.d.ts.map +1 -0
  150. package/resources/contacts.js +52 -0
  151. package/resources/contacts.js.map +1 -0
  152. package/resources/contacts.mjs +47 -0
  153. package/resources/contacts.mjs.map +1 -0
  154. package/resources/index.d.ts +12 -0
  155. package/resources/index.d.ts.map +1 -0
  156. package/resources/index.js +50 -0
  157. package/resources/index.js.map +1 -0
  158. package/resources/index.mjs +13 -0
  159. package/resources/index.mjs.map +1 -0
  160. package/resources/letters.d.ts +639 -0
  161. package/resources/letters.d.ts.map +1 -0
  162. package/resources/letters.js +55 -0
  163. package/resources/letters.js.map +1 -0
  164. package/resources/letters.mjs +50 -0
  165. package/resources/letters.mjs.map +1 -0
  166. package/resources/postcards.d.ts +346 -0
  167. package/resources/postcards.d.ts.map +1 -0
  168. package/resources/postcards.js +56 -0
  169. package/resources/postcards.js.map +1 -0
  170. package/resources/postcards.mjs +51 -0
  171. package/resources/postcards.mjs.map +1 -0
  172. package/resources/reports/exports.d.ts +207 -0
  173. package/resources/reports/exports.d.ts.map +1 -0
  174. package/resources/reports/exports.js +33 -0
  175. package/resources/reports/exports.js.map +1 -0
  176. package/resources/reports/exports.mjs +29 -0
  177. package/resources/reports/exports.mjs.map +1 -0
  178. package/resources/reports/index.d.ts +4 -0
  179. package/resources/reports/index.d.ts.map +1 -0
  180. package/resources/reports/index.js +12 -0
  181. package/resources/reports/index.js.map +1 -0
  182. package/resources/reports/index.mjs +5 -0
  183. package/resources/reports/index.mjs.map +1 -0
  184. package/resources/reports/reports.d.ts +245 -0
  185. package/resources/reports/reports.d.ts.map +1 -0
  186. package/resources/reports/reports.js +85 -0
  187. package/resources/reports/reports.js.map +1 -0
  188. package/resources/reports/reports.mjs +57 -0
  189. package/resources/reports/reports.mjs.map +1 -0
  190. package/resources/reports/samples.d.ts +81 -0
  191. package/resources/reports/samples.d.ts.map +1 -0
  192. package/resources/reports/samples.js +26 -0
  193. package/resources/reports/samples.js.map +1 -0
  194. package/resources/reports/samples.mjs +22 -0
  195. package/resources/reports/samples.mjs.map +1 -0
  196. package/resources/self-mailers.d.ts +622 -0
  197. package/resources/self-mailers.d.ts.map +1 -0
  198. package/resources/self-mailers.js +45 -0
  199. package/resources/self-mailers.js.map +1 -0
  200. package/resources/self-mailers.mjs +40 -0
  201. package/resources/self-mailers.mjs.map +1 -0
  202. package/resources/shared.d.ts +147 -0
  203. package/resources/shared.d.ts.map +1 -0
  204. package/resources/shared.js +4 -0
  205. package/resources/shared.js.map +1 -0
  206. package/resources/shared.mjs +3 -0
  207. package/resources/shared.mjs.map +1 -0
  208. package/resources/templates.d.ts +126 -0
  209. package/resources/templates.d.ts.map +1 -0
  210. package/resources/templates.js +46 -0
  211. package/resources/templates.js.map +1 -0
  212. package/resources/templates.mjs +41 -0
  213. package/resources/templates.mjs.map +1 -0
  214. package/shims/node.d.ts +30 -0
  215. package/shims/node.d.ts.map +1 -0
  216. package/shims/node.js +31 -0
  217. package/shims/node.js.map +1 -0
  218. package/shims/node.mjs +5 -0
  219. package/shims/node.mjs.map +1 -0
  220. package/shims/web.d.ts +26 -0
  221. package/shims/web.d.ts.map +1 -0
  222. package/shims/web.js +31 -0
  223. package/shims/web.js.map +1 -0
  224. package/shims/web.mjs +5 -0
  225. package/shims/web.mjs.map +1 -0
  226. package/src/_shims/MultipartBody.ts +9 -0
  227. package/src/_shims/README.md +46 -0
  228. package/src/_shims/auto/runtime-bun.ts +4 -0
  229. package/src/_shims/auto/runtime-node.ts +4 -0
  230. package/src/_shims/auto/runtime.ts +4 -0
  231. package/src/_shims/auto/types-node.ts +4 -0
  232. package/src/_shims/auto/types.d.ts +101 -0
  233. package/src/_shims/auto/types.js +3 -0
  234. package/src/_shims/auto/types.mjs +3 -0
  235. package/src/_shims/bun-runtime.ts +14 -0
  236. package/src/_shims/index.d.ts +81 -0
  237. package/src/_shims/index.js +13 -0
  238. package/src/_shims/index.mjs +7 -0
  239. package/src/_shims/manual-types.d.ts +12 -0
  240. package/src/_shims/manual-types.js +3 -0
  241. package/src/_shims/manual-types.mjs +3 -0
  242. package/src/_shims/node-runtime.ts +81 -0
  243. package/src/_shims/node-types.d.ts +42 -0
  244. package/src/_shims/node-types.js +3 -0
  245. package/src/_shims/node-types.mjs +3 -0
  246. package/src/_shims/registry.ts +67 -0
  247. package/src/_shims/web-runtime.ts +103 -0
  248. package/src/_shims/web-types.d.ts +83 -0
  249. package/src/_shims/web-types.js +3 -0
  250. package/src/_shims/web-types.mjs +3 -0
  251. package/src/core.ts +1208 -0
  252. package/src/error.ts +130 -0
  253. package/src/index.ts +428 -0
  254. package/src/lib/.keep +4 -0
  255. package/src/pagination.ts +69 -0
  256. package/src/resource.ts +11 -0
  257. package/src/resources/bank-accounts.ts +382 -0
  258. package/src/resources/boxes.ts +982 -0
  259. package/src/resources/campaigns.ts +853 -0
  260. package/src/resources/cheques/cheques.ts +493 -0
  261. package/src/resources/cheques/index.ts +12 -0
  262. package/src/resources/cheques/url.ts +37 -0
  263. package/src/resources/cheques/with-deposit-ready-pdf.ts +17 -0
  264. package/src/resources/contacts.ts +387 -0
  265. package/src/resources/index.ts +102 -0
  266. package/src/resources/letters.ts +870 -0
  267. package/src/resources/postcards.ts +548 -0
  268. package/src/resources/reports/exports.ts +272 -0
  269. package/src/resources/reports/index.ts +28 -0
  270. package/src/resources/reports/reports.ts +359 -0
  271. package/src/resources/reports/samples.ts +109 -0
  272. package/src/resources/self-mailers.ts +958 -0
  273. package/src/resources/shared.ts +182 -0
  274. package/src/resources/templates.ts +184 -0
  275. package/src/shims/node.ts +50 -0
  276. package/src/shims/web.ts +50 -0
  277. package/src/tsconfig.json +11 -0
  278. package/src/uploads.ts +255 -0
  279. package/src/version.ts +1 -0
  280. package/uploads.d.ts +75 -0
  281. package/uploads.d.ts.map +1 -0
  282. package/uploads.js +171 -0
  283. package/uploads.js.map +1 -0
  284. package/uploads.mjs +158 -0
  285. package/uploads.mjs.map +1 -0
  286. package/version.d.ts +2 -0
  287. package/version.d.ts.map +1 -0
  288. package/version.js +5 -0
  289. package/version.js.map +1 -0
  290. package/version.mjs +2 -0
  291. package/version.mjs.map +1 -0
@@ -0,0 +1,493 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ import { APIResource } from '../../resource';
4
+ import { isRequestOptions } from '../../core';
5
+ import * as Core from '../../core';
6
+ import * as ContactsAPI from '../contacts';
7
+ import * as Shared from '../shared';
8
+ import * as URLAPI from './url';
9
+ import { URL, URLRetrieveResponse } from './url';
10
+ import * as WithDepositReadyPdfAPI from './with-deposit-ready-pdf';
11
+ import { WithDepositReadyPdf } from './with-deposit-ready-pdf';
12
+ import { List, type ListParams } from '../../pagination';
13
+
14
+ export class Cheques extends APIResource {
15
+ url: URLAPI.URL = new URLAPI.URL(this._client);
16
+ withDepositReadyPdf: WithDepositReadyPdfAPI.WithDepositReadyPdf =
17
+ new WithDepositReadyPdfAPI.WithDepositReadyPdf(this._client);
18
+
19
+ /**
20
+ * Create a cheque.
21
+ *
22
+ * This endpoint allows you to create a new cheque with the specified details.
23
+ *
24
+ * If you would like to create a digitalOnly cheque, the digitalOnly object with
25
+ * the watermark will need to be passed in. Feature is available on request, e-mail
26
+ * support@postgrid.com for access.
27
+ *
28
+ * Example request body:
29
+ *
30
+ * ```json
31
+ * {
32
+ * "from": "contact_123",
33
+ * "bankAccount": "bank_123",
34
+ * "amount": 1000,
35
+ * "currencyCode": "USD",
36
+ * "number": 123456,
37
+ * "size": "us_letter",
38
+ * "digitalOnly": {
39
+ * "watermark": "VOID"
40
+ * }
41
+ * }
42
+ * ```
43
+ */
44
+ create(body: ChequeCreateParams, options?: Core.RequestOptions): Core.APIPromise<Cheque> {
45
+ return this._client.post('/cheques', { body, ...options });
46
+ }
47
+
48
+ /**
49
+ * Retrieve a cheque by ID.
50
+ */
51
+ retrieve(id: string, options?: Core.RequestOptions): Core.APIPromise<Cheque> {
52
+ return this._client.get(`/cheques/${id}`, options);
53
+ }
54
+
55
+ /**
56
+ * Get a list of cheques.
57
+ */
58
+ list(query?: ChequeListParams, options?: Core.RequestOptions): Core.PagePromise<ChequesList, Cheque>;
59
+ list(options?: Core.RequestOptions): Core.PagePromise<ChequesList, Cheque>;
60
+ list(
61
+ query: ChequeListParams | Core.RequestOptions = {},
62
+ options?: Core.RequestOptions,
63
+ ): Core.PagePromise<ChequesList, Cheque> {
64
+ if (isRequestOptions(query)) {
65
+ return this.list({}, query);
66
+ }
67
+ return this._client.getAPIList('/cheques', ChequesList, { query, ...options });
68
+ }
69
+
70
+ /**
71
+ * Cancel a cheque by ID. Note that this operation cannot be undone.
72
+ */
73
+ cancel(id: string, options?: Core.RequestOptions): Core.APIPromise<Cheque> {
74
+ return this._client.delete(`/cheques/${id}`, options);
75
+ }
76
+ }
77
+
78
+ export class ChequesList extends List<Cheque> {}
79
+
80
+ export interface Cheque {
81
+ /**
82
+ * A unique ID prefixed with cheque\_
83
+ */
84
+ id: string;
85
+
86
+ /**
87
+ * The amount of the cheque in cents.
88
+ */
89
+ amount: number;
90
+
91
+ /**
92
+ * The bank account (ID) associated with the cheque.
93
+ */
94
+ bankAccount: string;
95
+
96
+ /**
97
+ * The UTC time at which this resource was created.
98
+ */
99
+ createdAt: string;
100
+
101
+ /**
102
+ * The currency code of the cheque. This can be `USD` even if drawing from a
103
+ * Canadian bank account and vice versa. Defaults to the currency of the bank
104
+ * account country if not otherwise specified.
105
+ */
106
+ currencyCode: 'USD' | 'CAD';
107
+
108
+ /**
109
+ * The contact information of the sender.
110
+ */
111
+ from: ContactsAPI.Contact;
112
+
113
+ /**
114
+ * `true` if this is a live mode resource else `false`.
115
+ */
116
+ live: boolean;
117
+
118
+ /**
119
+ * The mailing class of this order. This determines the speed and cost of delivery.
120
+ * See `OrderMailingClass` for more details.
121
+ */
122
+ mailingClass:
123
+ | 'first_class'
124
+ | 'standard_class'
125
+ | 'express'
126
+ | 'certified'
127
+ | 'certified_return_receipt'
128
+ | 'registered'
129
+ | 'usps_first_class'
130
+ | 'usps_standard_class'
131
+ | 'usps_eddm'
132
+ | 'usps_express_2_day'
133
+ | 'usps_express_3_day'
134
+ | 'usps_first_class_certified'
135
+ | 'usps_first_class_certified_return_receipt'
136
+ | 'usps_first_class_registered'
137
+ | 'usps_express_3_day_signature_confirmation'
138
+ | 'usps_express_3_day_certified'
139
+ | 'usps_express_3_day_certified_return_receipt'
140
+ | 'ca_post_lettermail'
141
+ | 'ca_post_personalized'
142
+ | 'ca_post_neighbourhood_mail'
143
+ | 'ups_express_overnight'
144
+ | 'ups_express_2_day'
145
+ | 'ups_express_3_day'
146
+ | 'royal_mail_first_class'
147
+ | 'royal_mail_second_class'
148
+ | 'au_post_second_class';
149
+
150
+ /**
151
+ * Always `cheque`.
152
+ */
153
+ object: 'cheque';
154
+
155
+ /**
156
+ * This order will transition from `ready` to `printing` on the day after this
157
+ * date. For example, if this is a date on Tuesday, the order will transition to
158
+ * `printing` on Wednesday at midnight eastern time.
159
+ */
160
+ sendDate: string;
161
+
162
+ /**
163
+ * Enum representing the supported cheque sizes.
164
+ */
165
+ size: 'us_letter' | 'us_legal';
166
+
167
+ /**
168
+ * See `OrderStatus` for more details on the status of this order.
169
+ */
170
+ status: 'ready' | 'printing' | 'processed_for_delivery' | 'completed' | 'cancelled';
171
+
172
+ /**
173
+ * The recipient of this order. This will be provided even if you delete the
174
+ * underlying contact.
175
+ */
176
+ to: ContactsAPI.Contact;
177
+
178
+ /**
179
+ * The UTC time at which this resource was last updated.
180
+ */
181
+ updatedAt: string;
182
+
183
+ /**
184
+ * The cancellation details of this order. Populated if the order has been
185
+ * cancelled.
186
+ */
187
+ cancellation?: Shared.Cancellation;
188
+
189
+ /**
190
+ * A link to the deposit-ready PDF for a digital-only cheque, returned if requested
191
+ * and available.
192
+ */
193
+ depositReadyPDFURL?: string;
194
+
195
+ /**
196
+ * An optional string describing this resource. Will be visible in the API and the
197
+ * dashboard.
198
+ */
199
+ description?: string;
200
+
201
+ /**
202
+ * The digitalOnly object contains data for digital-only cheques. A watermark must
203
+ * be provided.
204
+ */
205
+ digitalOnly?: Cheque.DigitalOnly;
206
+
207
+ /**
208
+ * The envelope of the cheque. If a custom envelope ID is not specified, defaults
209
+ * to `standard`.
210
+ */
211
+ envelope?: 'standard' | (string & {});
212
+
213
+ /**
214
+ * The last date that the IMB status was updated. See `imbStatus` for more details.
215
+ */
216
+ imbDate?: string;
217
+
218
+ /**
219
+ * The Intelligent Mail Barcode (IMB) status of this order. Only populated for
220
+ * US-printed and US-destined orders. This is the most detailed way to track
221
+ * non-express/certified orders.
222
+ */
223
+ imbStatus?: 'entered_mail_stream' | 'out_for_delivery' | 'returned_to_sender';
224
+
225
+ /**
226
+ * The most recent ZIP code of the USPS facility that the order has been processed
227
+ * through. Only populated when an `imbStatus` is present.
228
+ */
229
+ imbZIPCode?: string;
230
+
231
+ /**
232
+ * An optional logo URL for the cheque. This will be placed next to the recipient
233
+ * address at the top left corner of the cheque. This needs to be a public link to
234
+ * an image file (e.g. a PNG or JPEG file).
235
+ */
236
+ logoURL?: string;
237
+
238
+ /**
239
+ * The memo of the cheque.
240
+ */
241
+ memo?: string;
242
+
243
+ /**
244
+ * These will be merged with the variables in the template or HTML you create this
245
+ * order with. The keys in this object should match the variable names in the
246
+ * template _exactly_ as they are case-sensitive. Note that these _do not_ apply to
247
+ * PDFs uploaded with the order.
248
+ */
249
+ mergeVariables?: Record<string, unknown>;
250
+
251
+ /**
252
+ * The message of the cheque.
253
+ */
254
+ message?: string;
255
+
256
+ /**
257
+ * See the section on Metadata.
258
+ */
259
+ metadata?: Record<string, unknown>;
260
+
261
+ /**
262
+ * The number of the cheque. If you don't provide this, it will automatically be
263
+ * set to an incrementing number starting from 1 across your entire account,
264
+ * ensuring that every cheque has a unique number.
265
+ */
266
+ number?: number;
267
+
268
+ /**
269
+ * The tracking number of this order. Populated after an express/certified order
270
+ * has been processed for delivery.
271
+ */
272
+ trackingNumber?: string;
273
+
274
+ /**
275
+ * PostGrid renders a PDF preview for all orders. This should be inspected to
276
+ * ensure that the order is correct before it is sent out because it shows what
277
+ * will be printed and mailed to the recipient. Once the PDF preview is generated,
278
+ * this field will be returned by all `GET` endpoints which produce this order.
279
+ *
280
+ * This URL is a signed link to the PDF preview. It will expire after a short
281
+ * period of time. If you need to access this URL after it has expired, you can
282
+ * regenerate it by calling the `GET` endpoint again.
283
+ */
284
+ url?: string;
285
+ }
286
+
287
+ export namespace Cheque {
288
+ /**
289
+ * The digitalOnly object contains data for digital-only cheques. A watermark must
290
+ * be provided.
291
+ */
292
+ export interface DigitalOnly {
293
+ /**
294
+ * Text to be displayed as a watermark on the digital cheque.
295
+ */
296
+ watermark: string;
297
+ }
298
+ }
299
+
300
+ export interface ChequeList {
301
+ data: Array<Cheque>;
302
+
303
+ limit: number;
304
+
305
+ object: 'list';
306
+
307
+ skip: number;
308
+
309
+ totalCount: number;
310
+ }
311
+
312
+ export interface ChequeCreateParams {
313
+ /**
314
+ * The amount of the cheque in cents.
315
+ */
316
+ amount: number;
317
+
318
+ /**
319
+ * The bank account (ID) associated with the cheque.
320
+ */
321
+ bankAccount: string;
322
+
323
+ /**
324
+ * The contact information of the sender. You can pass contact information inline
325
+ * here just like you can for the `to`.
326
+ */
327
+ from: Shared.ContactCreateWithFirstName | Shared.ContactCreateWithCompanyName | string;
328
+
329
+ /**
330
+ * The recipient of this order. You can either supply the contact information
331
+ * inline here or provide a contact ID. PostGrid will automatically deduplicate
332
+ * contacts regardless of whether you provide the information inline here or call
333
+ * the contact creation endpoint.
334
+ */
335
+ to: Shared.ContactCreateWithFirstName | Shared.ContactCreateWithCompanyName | string;
336
+
337
+ /**
338
+ * The currency code of the cheque. This will be set to the default currency of the
339
+ * bank account (`USD` for US bank accounts and `CAD` for Canadian bank accounts)
340
+ * if not provided. You can set this value to `USD` if you want to draw USD from a
341
+ * Canadian bank account or vice versa.
342
+ */
343
+ currencyCode?: 'USD' | 'CAD';
344
+
345
+ /**
346
+ * An optional string describing this resource. Will be visible in the API and the
347
+ * dashboard.
348
+ */
349
+ description?: string;
350
+
351
+ /**
352
+ * The digitalOnly object contains data for digital-only cheques. A watermark must
353
+ * be provided.
354
+ */
355
+ digitalOnly?: ChequeCreateParams.DigitalOnly;
356
+
357
+ /**
358
+ * The envelope of the cheque. If a custom envelope ID is not specified, defaults
359
+ * to `standard`.
360
+ */
361
+ envelope?: 'standard' | (string & {});
362
+
363
+ /**
364
+ * An optional logo URL for the cheque. This will be placed next to the recipient
365
+ * address at the top left corner of the cheque. This needs to be a public link to
366
+ * an image file (e.g. a PNG or JPEG file).
367
+ */
368
+ logoURL?: string;
369
+
370
+ /**
371
+ * The mailing class of this order. If not provided, automatically set to
372
+ * `first_class`.
373
+ */
374
+ mailingClass?:
375
+ | 'first_class'
376
+ | 'standard_class'
377
+ | 'express'
378
+ | 'certified'
379
+ | 'certified_return_receipt'
380
+ | 'registered'
381
+ | 'usps_first_class'
382
+ | 'usps_standard_class'
383
+ | 'usps_eddm'
384
+ | 'usps_express_2_day'
385
+ | 'usps_express_3_day'
386
+ | 'usps_first_class_certified'
387
+ | 'usps_first_class_certified_return_receipt'
388
+ | 'usps_first_class_registered'
389
+ | 'usps_express_3_day_signature_confirmation'
390
+ | 'usps_express_3_day_certified'
391
+ | 'usps_express_3_day_certified_return_receipt'
392
+ | 'ca_post_lettermail'
393
+ | 'ca_post_personalized'
394
+ | 'ca_post_neighbourhood_mail'
395
+ | 'ups_express_overnight'
396
+ | 'ups_express_2_day'
397
+ | 'ups_express_3_day'
398
+ | 'royal_mail_first_class'
399
+ | 'royal_mail_second_class'
400
+ | 'au_post_second_class';
401
+
402
+ /**
403
+ * The memo of the cheque.
404
+ */
405
+ memo?: string;
406
+
407
+ /**
408
+ * These will be merged with the variables in the template or HTML you create this
409
+ * order with. The keys in this object should match the variable names in the
410
+ * template _exactly_ as they are case-sensitive. Note that these _do not_ apply to
411
+ * PDFs uploaded with the order.
412
+ */
413
+ mergeVariables?: Record<string, unknown>;
414
+
415
+ /**
416
+ * The message of the cheque.
417
+ */
418
+ message?: string;
419
+
420
+ /**
421
+ * See the section on Metadata.
422
+ */
423
+ metadata?: Record<string, unknown>;
424
+
425
+ /**
426
+ * The number of the cheque. If you don't provide this, it will automatically be
427
+ * set to an incrementing number starting from 1 across your entire account,
428
+ * ensuring that every cheque has a unique number.
429
+ */
430
+ number?: number;
431
+
432
+ /**
433
+ * Providing this inserts a blank page at the start of the cheque with the
434
+ * recipient you provide here. This leaves the cheque that follows intact, which
435
+ * means you can use this to intercept at cheque at the redirected address and then
436
+ * mail it forward to the final recipient yourself. One use case for this is
437
+ * signing cheques at your office before mailing them out yourself.
438
+ */
439
+ redirectTo?: Shared.ContactCreateWithFirstName | Shared.ContactCreateWithCompanyName | string;
440
+
441
+ /**
442
+ * This order will transition from `ready` to `printing` on the day after this
443
+ * date. You can use this parameter to schedule orders for a future date.
444
+ */
445
+ sendDate?: string;
446
+
447
+ /**
448
+ * Enum representing the supported cheque sizes.
449
+ */
450
+ size?: 'us_letter' | 'us_legal';
451
+ }
452
+
453
+ export namespace ChequeCreateParams {
454
+ /**
455
+ * The digitalOnly object contains data for digital-only cheques. A watermark must
456
+ * be provided.
457
+ */
458
+ export interface DigitalOnly {
459
+ /**
460
+ * Text to be displayed as a watermark on the digital cheque.
461
+ */
462
+ watermark: string;
463
+ }
464
+ }
465
+
466
+ export interface ChequeListParams extends ListParams {
467
+ /**
468
+ * You can supply any string to help narrow down the list of resources. For
469
+ * example, if you pass `"New York"` (quoted), it will return resources that have
470
+ * that string present somewhere in their response. Alternatively, you can supply a
471
+ * structured search query. See the documentation on `StructuredSearchQuery` for
472
+ * more details.
473
+ */
474
+ search?: string;
475
+ }
476
+
477
+ Cheques.ChequesList = ChequesList;
478
+ Cheques.URL = URL;
479
+ Cheques.WithDepositReadyPdf = WithDepositReadyPdf;
480
+
481
+ export declare namespace Cheques {
482
+ export {
483
+ type Cheque as Cheque,
484
+ type ChequeList as ChequeList,
485
+ ChequesList as ChequesList,
486
+ type ChequeCreateParams as ChequeCreateParams,
487
+ type ChequeListParams as ChequeListParams,
488
+ };
489
+
490
+ export { URL as URL, type URLRetrieveResponse as URLRetrieveResponse };
491
+
492
+ export { WithDepositReadyPdf as WithDepositReadyPdf };
493
+ }
@@ -0,0 +1,12 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ export {
4
+ ChequesList,
5
+ Cheques,
6
+ type Cheque,
7
+ type ChequeList,
8
+ type ChequeCreateParams,
9
+ type ChequeListParams,
10
+ } from './cheques';
11
+ export { URL, type URLRetrieveResponse } from './url';
12
+ export { WithDepositReadyPdf } from './with-deposit-ready-pdf';
@@ -0,0 +1,37 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ import { APIResource } from '../../resource';
4
+ import * as Core from '../../core';
5
+
6
+ export class URL extends APIResource {
7
+ /**
8
+ * Retrieve a cheque preview URL.
9
+ *
10
+ * This is only available for customers with our document management addon, which
11
+ * offers document generation and hosting capabilities. This endpoint has a much
12
+ * higher rate limit than the regular order retrieval endpoint, so it is suitable
13
+ * for customer-facing use-cases.
14
+ */
15
+ retrieve(id: string, options?: Core.RequestOptions): Core.APIPromise<URLRetrieveResponse> {
16
+ return this._client.get(`/cheques/${id}/url`, options);
17
+ }
18
+ }
19
+
20
+ export interface URLRetrieveResponse {
21
+ /**
22
+ * A unique ID prefixed with cheque\_
23
+ */
24
+ id: string;
25
+
26
+ object: string;
27
+
28
+ /**
29
+ * A signed URL linking to the order preview PDF. The link remains valid for 15
30
+ * minutes from the time of the API call.
31
+ */
32
+ url: string;
33
+ }
34
+
35
+ export declare namespace URL {
36
+ export { type URLRetrieveResponse as URLRetrieveResponse };
37
+ }
@@ -0,0 +1,17 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ import { APIResource } from '../../resource';
4
+ import * as Core from '../../core';
5
+ import * as ChequesAPI from './cheques';
6
+
7
+ export class WithDepositReadyPdf extends APIResource {
8
+ /**
9
+ * Retrieve the deposit-ready PDF for a digital-only cheque. The endpoint can only
10
+ * be called by users with 'Admin' role. In test mode, the preview PDF of the
11
+ * digitalOnly cheque and the deposit-ready PDF are the same. In live mode, the
12
+ * deposit-ready will have the full account number.
13
+ */
14
+ retrieve(id: string, options?: Core.RequestOptions): Core.APIPromise<ChequesAPI.Cheque> {
15
+ return this._client.get(`/cheques/${id}/with_deposit_ready_pdf`, options);
16
+ }
17
+ }