@voyant-travel/bookings-react 0.119.3

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 (602) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +87 -0
  3. package/dist/admin/booking-contract-dialog.d.ts +22 -0
  4. package/dist/admin/booking-contract-dialog.d.ts.map +1 -0
  5. package/dist/admin/booking-contract-dialog.js +161 -0
  6. package/dist/admin/booking-detail-host.d.ts +103 -0
  7. package/dist/admin/booking-detail-host.d.ts.map +1 -0
  8. package/dist/admin/booking-detail-host.js +127 -0
  9. package/dist/admin/booking-detail-skeleton.d.ts +7 -0
  10. package/dist/admin/booking-detail-skeleton.d.ts.map +1 -0
  11. package/dist/admin/booking-detail-skeleton.js +24 -0
  12. package/dist/admin/booking-documents-table.d.ts +13 -0
  13. package/dist/admin/booking-documents-table.d.ts.map +1 -0
  14. package/dist/admin/booking-documents-table.js +259 -0
  15. package/dist/admin/booking-invoice-sheet.d.ts +18 -0
  16. package/dist/admin/booking-invoice-sheet.d.ts.map +1 -0
  17. package/dist/admin/booking-invoice-sheet.js +101 -0
  18. package/dist/admin/booking-journey-host.d.ts +24 -0
  19. package/dist/admin/booking-journey-host.d.ts.map +1 -0
  20. package/dist/admin/booking-journey-host.js +278 -0
  21. package/dist/admin/bookings-host.d.ts +26 -0
  22. package/dist/admin/bookings-host.d.ts.map +1 -0
  23. package/dist/admin/bookings-host.js +18 -0
  24. package/dist/admin/bookings-list-skeleton.d.ts +10 -0
  25. package/dist/admin/bookings-list-skeleton.d.ts.map +1 -0
  26. package/dist/admin/bookings-list-skeleton.js +25 -0
  27. package/dist/admin/index.d.ts +273 -0
  28. package/dist/admin/index.d.ts.map +1 -0
  29. package/dist/admin/index.js +331 -0
  30. package/dist/admin/journey-billing-duplicate-warning.d.ts +3 -0
  31. package/dist/admin/journey-billing-duplicate-warning.d.ts.map +1 -0
  32. package/dist/admin/journey-billing-duplicate-warning.js +26 -0
  33. package/dist/admin/journey-departure-picker.d.ts +7 -0
  34. package/dist/admin/journey-departure-picker.d.ts.map +1 -0
  35. package/dist/admin/journey-departure-picker.js +100 -0
  36. package/dist/admin/journey-units-picker.d.ts +11 -0
  37. package/dist/admin/journey-units-picker.d.ts.map +1 -0
  38. package/dist/admin/journey-units-picker.js +60 -0
  39. package/dist/admin/journey-voucher-picker.d.ts +3 -0
  40. package/dist/admin/journey-voucher-picker.d.ts.map +1 -0
  41. package/dist/admin/journey-voucher-picker.js +71 -0
  42. package/dist/admin/pages/booking-compose-page.d.ts +9 -0
  43. package/dist/admin/pages/booking-compose-page.d.ts.map +1 -0
  44. package/dist/admin/pages/booking-compose-page.js +17 -0
  45. package/dist/admin/pages/booking-detail-page.d.ts +11 -0
  46. package/dist/admin/pages/booking-detail-page.d.ts.map +1 -0
  47. package/dist/admin/pages/booking-detail-page.js +14 -0
  48. package/dist/admin/pages/booking-journey-page.d.ts +12 -0
  49. package/dist/admin/pages/booking-journey-page.d.ts.map +1 -0
  50. package/dist/admin/pages/booking-journey-page.js +26 -0
  51. package/dist/admin/pages/booking-new-page.d.ts +15 -0
  52. package/dist/admin/pages/booking-new-page.d.ts.map +1 -0
  53. package/dist/admin/pages/booking-new-page.js +50 -0
  54. package/dist/admin/pages/bookings-index-page.d.ts +20 -0
  55. package/dist/admin/pages/bookings-index-page.d.ts.map +1 -0
  56. package/dist/admin/pages/bookings-index-page.js +18 -0
  57. package/dist/admin/person-bookings-widget.d.ts +13 -0
  58. package/dist/admin/person-bookings-widget.d.ts.map +1 -0
  59. package/dist/admin/person-bookings-widget.js +48 -0
  60. package/dist/admin/slots.d.ts +31 -0
  61. package/dist/admin/slots.d.ts.map +1 -0
  62. package/dist/admin/slots.js +30 -0
  63. package/dist/admin/use-booking-action-ledger-events.d.ts +15 -0
  64. package/dist/admin/use-booking-action-ledger-events.d.ts.map +1 -0
  65. package/dist/admin/use-booking-action-ledger-events.js +66 -0
  66. package/dist/client.d.ts +14 -0
  67. package/dist/client.d.ts.map +1 -0
  68. package/dist/client.js +59 -0
  69. package/dist/components/booking-activity-timeline.d.ts +32 -0
  70. package/dist/components/booking-activity-timeline.d.ts.map +1 -0
  71. package/dist/components/booking-activity-timeline.js +147 -0
  72. package/dist/components/booking-billing-dialog.d.ts +16 -0
  73. package/dist/components/booking-billing-dialog.d.ts.map +1 -0
  74. package/dist/components/booking-billing-dialog.js +315 -0
  75. package/dist/components/booking-cancellation-dialog.d.ts +18 -0
  76. package/dist/components/booking-cancellation-dialog.d.ts.map +1 -0
  77. package/dist/components/booking-cancellation-dialog.js +79 -0
  78. package/dist/components/booking-combobox.d.ts +13 -0
  79. package/dist/components/booking-combobox.d.ts.map +1 -0
  80. package/dist/components/booking-combobox.js +44 -0
  81. package/dist/components/booking-create-form-utils.d.ts +56 -0
  82. package/dist/components/booking-create-form-utils.d.ts.map +1 -0
  83. package/dist/components/booking-create-form-utils.js +216 -0
  84. package/dist/components/booking-create-page.d.ts +14 -0
  85. package/dist/components/booking-create-page.d.ts.map +1 -0
  86. package/dist/components/booking-create-page.js +11 -0
  87. package/dist/components/booking-create-preview-card.d.ts +26 -0
  88. package/dist/components/booking-create-preview-card.d.ts.map +1 -0
  89. package/dist/components/booking-create-preview-card.js +107 -0
  90. package/dist/components/booking-create-product-extras-picker.d.ts +18 -0
  91. package/dist/components/booking-create-product-extras-picker.d.ts.map +1 -0
  92. package/dist/components/booking-create-product-extras-picker.js +82 -0
  93. package/dist/components/booking-create-sheet.d.ts +34 -0
  94. package/dist/components/booking-create-sheet.d.ts.map +1 -0
  95. package/dist/components/booking-create-sheet.js +811 -0
  96. package/dist/components/booking-create-utils.d.ts +66 -0
  97. package/dist/components/booking-create-utils.d.ts.map +1 -0
  98. package/dist/components/booking-create-utils.js +185 -0
  99. package/dist/components/booking-detail-page.d.ts +126 -0
  100. package/dist/components/booking-detail-page.d.ts.map +1 -0
  101. package/dist/components/booking-detail-page.js +264 -0
  102. package/dist/components/booking-dialog.d.ts +28 -0
  103. package/dist/components/booking-dialog.d.ts.map +1 -0
  104. package/dist/components/booking-dialog.js +130 -0
  105. package/dist/components/booking-document-dialog.d.ts +8 -0
  106. package/dist/components/booking-document-dialog.d.ts.map +1 -0
  107. package/dist/components/booking-document-dialog.js +83 -0
  108. package/dist/components/booking-document-list.d.ts +5 -0
  109. package/dist/components/booking-document-list.d.ts.map +1 -0
  110. package/dist/components/booking-document-list.js +43 -0
  111. package/dist/components/booking-group-link-dialog.d.ts +10 -0
  112. package/dist/components/booking-group-link-dialog.d.ts.map +1 -0
  113. package/dist/components/booking-group-link-dialog.js +79 -0
  114. package/dist/components/booking-group-section.d.ts +27 -0
  115. package/dist/components/booking-group-section.d.ts.map +1 -0
  116. package/dist/components/booking-group-section.js +51 -0
  117. package/dist/components/booking-guarantee-dialog.d.ts +10 -0
  118. package/dist/components/booking-guarantee-dialog.d.ts.map +1 -0
  119. package/dist/components/booking-guarantee-dialog.js +123 -0
  120. package/dist/components/booking-guarantee-list.d.ts +5 -0
  121. package/dist/components/booking-guarantee-list.d.ts.map +1 -0
  122. package/dist/components/booking-guarantee-list.js +86 -0
  123. package/dist/components/booking-item-dialog.d.ts +10 -0
  124. package/dist/components/booking-item-dialog.d.ts.map +1 -0
  125. package/dist/components/booking-item-dialog.js +155 -0
  126. package/dist/components/booking-item-list.d.ts +12 -0
  127. package/dist/components/booking-item-list.d.ts.map +1 -0
  128. package/dist/components/booking-item-list.js +191 -0
  129. package/dist/components/booking-item-travelers.d.ts +6 -0
  130. package/dist/components/booking-item-travelers.d.ts.map +1 -0
  131. package/dist/components/booking-item-travelers.js +57 -0
  132. package/dist/components/booking-list-filters.d.ts +43 -0
  133. package/dist/components/booking-list-filters.d.ts.map +1 -0
  134. package/dist/components/booking-list-filters.js +192 -0
  135. package/dist/components/booking-list.d.ts +50 -0
  136. package/dist/components/booking-list.d.ts.map +1 -0
  137. package/dist/components/booking-list.js +352 -0
  138. package/dist/components/booking-note-dialog.d.ts +16 -0
  139. package/dist/components/booking-note-dialog.d.ts.map +1 -0
  140. package/dist/components/booking-note-dialog.js +41 -0
  141. package/dist/components/booking-notes.d.ts +5 -0
  142. package/dist/components/booking-notes.d.ts.map +1 -0
  143. package/dist/components/booking-notes.js +45 -0
  144. package/dist/components/booking-payment-reconciliation-banner.d.ts +5 -0
  145. package/dist/components/booking-payment-reconciliation-banner.d.ts.map +1 -0
  146. package/dist/components/booking-payment-reconciliation-banner.js +91 -0
  147. package/dist/components/booking-payment-schedule-dialog.d.ts +10 -0
  148. package/dist/components/booking-payment-schedule-dialog.d.ts.map +1 -0
  149. package/dist/components/booking-payment-schedule-dialog.js +117 -0
  150. package/dist/components/booking-payment-schedule-list.d.ts +10 -0
  151. package/dist/components/booking-payment-schedule-list.d.ts.map +1 -0
  152. package/dist/components/booking-payment-schedule-list.js +217 -0
  153. package/dist/components/booking-payments-summary.d.ts +83 -0
  154. package/dist/components/booking-payments-summary.d.ts.map +1 -0
  155. package/dist/components/booking-payments-summary.js +176 -0
  156. package/dist/components/booking-quick-view-sheet.d.ts +14 -0
  157. package/dist/components/booking-quick-view-sheet.d.ts.map +1 -0
  158. package/dist/components/booking-quick-view-sheet.js +283 -0
  159. package/dist/components/bookings-page.d.ts +19 -0
  160. package/dist/components/bookings-page.d.ts.map +1 -0
  161. package/dist/components/bookings-page.js +9 -0
  162. package/dist/components/file-dropzone.d.ts +25 -0
  163. package/dist/components/file-dropzone.d.ts.map +1 -0
  164. package/dist/components/file-dropzone.js +102 -0
  165. package/dist/components/icon-action-button.d.ts +18 -0
  166. package/dist/components/icon-action-button.d.ts.map +1 -0
  167. package/dist/components/icon-action-button.js +13 -0
  168. package/dist/components/option-units-stepper-section.d.ts +111 -0
  169. package/dist/components/option-units-stepper-section.d.ts.map +1 -0
  170. package/dist/components/option-units-stepper-section.js +276 -0
  171. package/dist/components/payment-schedule-section.d.ts +91 -0
  172. package/dist/components/payment-schedule-section.d.ts.map +1 -0
  173. package/dist/components/payment-schedule-section.js +206 -0
  174. package/dist/components/person-picker-section.d.ts +71 -0
  175. package/dist/components/person-picker-section.d.ts.map +1 -0
  176. package/dist/components/person-picker-section.js +160 -0
  177. package/dist/components/price-breakdown-section.d.ts +83 -0
  178. package/dist/components/price-breakdown-section.d.ts.map +1 -0
  179. package/dist/components/price-breakdown-section.js +278 -0
  180. package/dist/components/product-picker-section.d.ts +29 -0
  181. package/dist/components/product-picker-section.d.ts.map +1 -0
  182. package/dist/components/product-picker-section.js +74 -0
  183. package/dist/components/shared-room-section.d.ts +40 -0
  184. package/dist/components/shared-room-section.d.ts.map +1 -0
  185. package/dist/components/shared-room-section.js +99 -0
  186. package/dist/components/status-badge.d.ts +24 -0
  187. package/dist/components/status-badge.d.ts.map +1 -0
  188. package/dist/components/status-badge.js +65 -0
  189. package/dist/components/status-change-dialog.d.ts +10 -0
  190. package/dist/components/status-change-dialog.d.ts.map +1 -0
  191. package/dist/components/status-change-dialog.js +57 -0
  192. package/dist/components/supplier-status-dialog.d.ts +10 -0
  193. package/dist/components/supplier-status-dialog.d.ts.map +1 -0
  194. package/dist/components/supplier-status-dialog.js +98 -0
  195. package/dist/components/supplier-status-list.d.ts +5 -0
  196. package/dist/components/supplier-status-list.d.ts.map +1 -0
  197. package/dist/components/supplier-status-list.js +115 -0
  198. package/dist/components/traveler-category-buttons.d.ts +26 -0
  199. package/dist/components/traveler-category-buttons.d.ts.map +1 -0
  200. package/dist/components/traveler-category-buttons.js +35 -0
  201. package/dist/components/traveler-dialog.d.ts +10 -0
  202. package/dist/components/traveler-dialog.d.ts.map +1 -0
  203. package/dist/components/traveler-dialog.js +256 -0
  204. package/dist/components/traveler-list.d.ts +6 -0
  205. package/dist/components/traveler-list.d.ts.map +1 -0
  206. package/dist/components/traveler-list.js +295 -0
  207. package/dist/components/travelers-section-controls.d.ts +52 -0
  208. package/dist/components/travelers-section-controls.d.ts.map +1 -0
  209. package/dist/components/travelers-section-controls.js +206 -0
  210. package/dist/components/travelers-section.d.ts +159 -0
  211. package/dist/components/travelers-section.d.ts.map +1 -0
  212. package/dist/components/travelers-section.js +355 -0
  213. package/dist/components/voucher-picker-section.d.ts +50 -0
  214. package/dist/components/voucher-picker-section.d.ts.map +1 -0
  215. package/dist/components/voucher-picker-section.js +79 -0
  216. package/dist/extras/client.d.ts +14 -0
  217. package/dist/extras/client.d.ts.map +1 -0
  218. package/dist/extras/client.js +58 -0
  219. package/dist/extras/components/extra-catalog-card.d.ts +13 -0
  220. package/dist/extras/components/extra-catalog-card.d.ts.map +1 -0
  221. package/dist/extras/components/extra-catalog-card.js +52 -0
  222. package/dist/extras/components/product-combobox.d.ts +9 -0
  223. package/dist/extras/components/product-combobox.d.ts.map +1 -0
  224. package/dist/extras/components/product-combobox.js +46 -0
  225. package/dist/extras/components/slot-extras-manifest-panel.d.ts +6 -0
  226. package/dist/extras/components/slot-extras-manifest-panel.d.ts.map +1 -0
  227. package/dist/extras/components/slot-extras-manifest-panel.js +108 -0
  228. package/dist/extras/hooks/index.d.ts +5 -0
  229. package/dist/extras/hooks/index.d.ts.map +1 -0
  230. package/dist/extras/hooks/index.js +4 -0
  231. package/dist/extras/hooks/use-product-extra.d.ts +24 -0
  232. package/dist/extras/hooks/use-product-extra.d.ts.map +1 -0
  233. package/dist/extras/hooks/use-product-extra.js +12 -0
  234. package/dist/extras/hooks/use-product-extras.d.ts +30 -0
  235. package/dist/extras/hooks/use-product-extras.d.ts.map +1 -0
  236. package/dist/extras/hooks/use-product-extras.js +12 -0
  237. package/dist/extras/hooks/use-slot-extra-manifest-mutation.d.ts +48 -0
  238. package/dist/extras/hooks/use-slot-extra-manifest-mutation.d.ts.map +1 -0
  239. package/dist/extras/hooks/use-slot-extra-manifest-mutation.js +26 -0
  240. package/dist/extras/hooks/use-slot-extra-manifest.d.ts +68 -0
  241. package/dist/extras/hooks/use-slot-extra-manifest.d.ts.map +1 -0
  242. package/dist/extras/hooks/use-slot-extra-manifest.js +11 -0
  243. package/dist/extras/i18n/en.d.ts +52 -0
  244. package/dist/extras/i18n/en.d.ts.map +1 -0
  245. package/dist/extras/i18n/en.js +51 -0
  246. package/dist/extras/i18n/index.d.ts +5 -0
  247. package/dist/extras/i18n/index.d.ts.map +1 -0
  248. package/dist/extras/i18n/index.js +3 -0
  249. package/dist/extras/i18n/messages.d.ts +37 -0
  250. package/dist/extras/i18n/messages.d.ts.map +1 -0
  251. package/dist/extras/i18n/messages.js +1 -0
  252. package/dist/extras/i18n/provider.d.ts +126 -0
  253. package/dist/extras/i18n/provider.d.ts.map +1 -0
  254. package/dist/extras/i18n/provider.js +44 -0
  255. package/dist/extras/i18n/ro.d.ts +52 -0
  256. package/dist/extras/i18n/ro.d.ts.map +1 -0
  257. package/dist/extras/i18n/ro.js +51 -0
  258. package/dist/extras/index.d.ts +7 -0
  259. package/dist/extras/index.d.ts.map +1 -0
  260. package/dist/extras/index.js +6 -0
  261. package/dist/extras/provider.d.ts +2 -0
  262. package/dist/extras/provider.d.ts.map +1 -0
  263. package/dist/extras/provider.js +1 -0
  264. package/dist/extras/query-keys.d.ts +16 -0
  265. package/dist/extras/query-keys.d.ts.map +1 -0
  266. package/dist/extras/query-keys.js +8 -0
  267. package/dist/extras/query-options.d.ts +455 -0
  268. package/dist/extras/query-options.d.ts.map +1 -0
  269. package/dist/extras/query-options.js +44 -0
  270. package/dist/extras/schemas.d.ts +416 -0
  271. package/dist/extras/schemas.d.ts.map +1 -0
  272. package/dist/extras/schemas.js +89 -0
  273. package/dist/extras/ui.d.ts +4 -0
  274. package/dist/extras/ui.d.ts.map +1 -0
  275. package/dist/extras/ui.js +3 -0
  276. package/dist/extras.d.ts +10 -0
  277. package/dist/extras.d.ts.map +1 -0
  278. package/dist/extras.js +9 -0
  279. package/dist/hooks/index.d.ts +36 -0
  280. package/dist/hooks/index.d.ts.map +1 -0
  281. package/dist/hooks/index.js +35 -0
  282. package/dist/hooks/use-booking-action-ledger.d.ts +63 -0
  283. package/dist/hooks/use-booking-action-ledger.d.ts.map +1 -0
  284. package/dist/hooks/use-booking-action-ledger.js +34 -0
  285. package/dist/hooks/use-booking-activity.d.ts +17 -0
  286. package/dist/hooks/use-booking-activity.d.ts.map +1 -0
  287. package/dist/hooks/use-booking-activity.js +12 -0
  288. package/dist/hooks/use-booking-cancel-mutation.d.ts +69 -0
  289. package/dist/hooks/use-booking-cancel-mutation.d.ts.map +1 -0
  290. package/dist/hooks/use-booking-cancel-mutation.js +24 -0
  291. package/dist/hooks/use-booking-contract-generation.d.ts +31 -0
  292. package/dist/hooks/use-booking-contract-generation.d.ts.map +1 -0
  293. package/dist/hooks/use-booking-contract-generation.js +36 -0
  294. package/dist/hooks/use-booking-convert-mutation.d.ts +81 -0
  295. package/dist/hooks/use-booking-convert-mutation.d.ts.map +1 -0
  296. package/dist/hooks/use-booking-convert-mutation.js +24 -0
  297. package/dist/hooks/use-booking-create-mutation.d.ts +337 -0
  298. package/dist/hooks/use-booking-create-mutation.d.ts.map +1 -0
  299. package/dist/hooks/use-booking-create-mutation.js +43 -0
  300. package/dist/hooks/use-booking-documents.d.ts +41 -0
  301. package/dist/hooks/use-booking-documents.d.ts.map +1 -0
  302. package/dist/hooks/use-booking-documents.js +46 -0
  303. package/dist/hooks/use-booking-dual-create-mutation.d.ts +338 -0
  304. package/dist/hooks/use-booking-dual-create-mutation.d.ts.map +1 -0
  305. package/dist/hooks/use-booking-dual-create-mutation.js +45 -0
  306. package/dist/hooks/use-booking-group-for-booking.d.ts +24 -0
  307. package/dist/hooks/use-booking-group-for-booking.d.ts.map +1 -0
  308. package/dist/hooks/use-booking-group-for-booking.js +12 -0
  309. package/dist/hooks/use-booking-group-member-mutation.d.ts +27 -0
  310. package/dist/hooks/use-booking-group-member-mutation.d.ts.map +1 -0
  311. package/dist/hooks/use-booking-group-member-mutation.js +38 -0
  312. package/dist/hooks/use-booking-group-mutation.d.ts +40 -0
  313. package/dist/hooks/use-booking-group-mutation.d.ts.map +1 -0
  314. package/dist/hooks/use-booking-group-mutation.js +32 -0
  315. package/dist/hooks/use-booking-group.d.ts +85 -0
  316. package/dist/hooks/use-booking-group.d.ts.map +1 -0
  317. package/dist/hooks/use-booking-group.js +12 -0
  318. package/dist/hooks/use-booking-groups.d.ts +21 -0
  319. package/dist/hooks/use-booking-groups.d.ts.map +1 -0
  320. package/dist/hooks/use-booking-groups.js +12 -0
  321. package/dist/hooks/use-booking-item-mutation.d.ts +101 -0
  322. package/dist/hooks/use-booking-item-mutation.d.ts.map +1 -0
  323. package/dist/hooks/use-booking-item-mutation.js +42 -0
  324. package/dist/hooks/use-booking-item-travelers.d.ts +32 -0
  325. package/dist/hooks/use-booking-item-travelers.d.ts.map +1 -0
  326. package/dist/hooks/use-booking-item-travelers.js +48 -0
  327. package/dist/hooks/use-booking-items.d.ts +36 -0
  328. package/dist/hooks/use-booking-items.d.ts.map +1 -0
  329. package/dist/hooks/use-booking-items.js +12 -0
  330. package/dist/hooks/use-booking-mutation.d.ts +158 -0
  331. package/dist/hooks/use-booking-mutation.d.ts.map +1 -0
  332. package/dist/hooks/use-booking-mutation.js +39 -0
  333. package/dist/hooks/use-booking-note-mutation.d.ts +39 -0
  334. package/dist/hooks/use-booking-note-mutation.d.ts.map +1 -0
  335. package/dist/hooks/use-booking-note-mutation.js +44 -0
  336. package/dist/hooks/use-booking-notes.d.ts +15 -0
  337. package/dist/hooks/use-booking-notes.d.ts.map +1 -0
  338. package/dist/hooks/use-booking-notes.js +12 -0
  339. package/dist/hooks/use-booking-primary-product.d.ts +28 -0
  340. package/dist/hooks/use-booking-primary-product.d.ts.map +1 -0
  341. package/dist/hooks/use-booking-primary-product.js +20 -0
  342. package/dist/hooks/use-booking-status-mutation.d.ts +156 -0
  343. package/dist/hooks/use-booking-status-mutation.d.ts.map +1 -0
  344. package/dist/hooks/use-booking-status-mutation.js +54 -0
  345. package/dist/hooks/use-booking-tax-preview.d.ts +29 -0
  346. package/dist/hooks/use-booking-tax-preview.d.ts.map +1 -0
  347. package/dist/hooks/use-booking-tax-preview.js +21 -0
  348. package/dist/hooks/use-booking.d.ts +67 -0
  349. package/dist/hooks/use-booking.d.ts.map +1 -0
  350. package/dist/hooks/use-booking.js +12 -0
  351. package/dist/hooks/use-bookings.d.ts +71 -0
  352. package/dist/hooks/use-bookings.d.ts.map +1 -0
  353. package/dist/hooks/use-bookings.js +12 -0
  354. package/dist/hooks/use-pricing-preview.d.ts +61 -0
  355. package/dist/hooks/use-pricing-preview.d.ts.map +1 -0
  356. package/dist/hooks/use-pricing-preview.js +18 -0
  357. package/dist/hooks/use-public-booking-session-flow-mutation.d.ts +148 -0
  358. package/dist/hooks/use-public-booking-session-flow-mutation.d.ts.map +1 -0
  359. package/dist/hooks/use-public-booking-session-flow-mutation.js +35 -0
  360. package/dist/hooks/use-public-booking-session-state.d.ts +16 -0
  361. package/dist/hooks/use-public-booking-session-state.d.ts.map +1 -0
  362. package/dist/hooks/use-public-booking-session-state.js +12 -0
  363. package/dist/hooks/use-public-booking-session.d.ts +101 -0
  364. package/dist/hooks/use-public-booking-session.d.ts.map +1 -0
  365. package/dist/hooks/use-public-booking-session.js +12 -0
  366. package/dist/hooks/use-reveal-traveler.d.ts +54 -0
  367. package/dist/hooks/use-reveal-traveler.d.ts.map +1 -0
  368. package/dist/hooks/use-reveal-traveler.js +18 -0
  369. package/dist/hooks/use-sharing-groups.d.ts +41 -0
  370. package/dist/hooks/use-sharing-groups.d.ts.map +1 -0
  371. package/dist/hooks/use-sharing-groups.js +20 -0
  372. package/dist/hooks/use-supplier-status-mutation.d.ts +46 -0
  373. package/dist/hooks/use-supplier-status-mutation.d.ts.map +1 -0
  374. package/dist/hooks/use-supplier-status-mutation.js +39 -0
  375. package/dist/hooks/use-supplier-statuses.d.ts +20 -0
  376. package/dist/hooks/use-supplier-statuses.d.ts.map +1 -0
  377. package/dist/hooks/use-supplier-statuses.js +12 -0
  378. package/dist/hooks/use-traveler-mutation.d.ts +55 -0
  379. package/dist/hooks/use-traveler-mutation.d.ts.map +1 -0
  380. package/dist/hooks/use-traveler-mutation.js +42 -0
  381. package/dist/hooks/use-traveler-with-travel-details-mutation.d.ts +120 -0
  382. package/dist/hooks/use-traveler-with-travel-details-mutation.d.ts.map +1 -0
  383. package/dist/hooks/use-traveler-with-travel-details-mutation.js +43 -0
  384. package/dist/hooks/use-travelers.d.ts +23 -0
  385. package/dist/hooks/use-travelers.d.ts.map +1 -0
  386. package/dist/hooks/use-travelers.js +12 -0
  387. package/dist/i18n/en-base.d.ts +295 -0
  388. package/dist/i18n/en-base.d.ts.map +1 -0
  389. package/dist/i18n/en-base.js +294 -0
  390. package/dist/i18n/en-create-list.d.ts +327 -0
  391. package/dist/i18n/en-create-list.d.ts.map +1 -0
  392. package/dist/i18n/en-create-list.js +326 -0
  393. package/dist/i18n/en-journey.d.ts +229 -0
  394. package/dist/i18n/en-journey.d.ts.map +1 -0
  395. package/dist/i18n/en-journey.js +228 -0
  396. package/dist/i18n/en-operations.d.ts +382 -0
  397. package/dist/i18n/en-operations.d.ts.map +1 -0
  398. package/dist/i18n/en-operations.js +381 -0
  399. package/dist/i18n/en-sections.d.ts +360 -0
  400. package/dist/i18n/en-sections.d.ts.map +1 -0
  401. package/dist/i18n/en-sections.js +359 -0
  402. package/dist/i18n/en.d.ts +1581 -0
  403. package/dist/i18n/en.d.ts.map +1 -0
  404. package/dist/i18n/en.js +12 -0
  405. package/dist/i18n/index.d.ts +5 -0
  406. package/dist/i18n/index.d.ts.map +1 -0
  407. package/dist/i18n/index.js +3 -0
  408. package/dist/i18n/messages-base.d.ts +251 -0
  409. package/dist/i18n/messages-base.d.ts.map +1 -0
  410. package/dist/i18n/messages-base.js +1 -0
  411. package/dist/i18n/messages-create-list.d.ts +310 -0
  412. package/dist/i18n/messages-create-list.d.ts.map +1 -0
  413. package/dist/i18n/messages-create-list.js +1 -0
  414. package/dist/i18n/messages-journey.d.ts +198 -0
  415. package/dist/i18n/messages-journey.d.ts.map +1 -0
  416. package/dist/i18n/messages-journey.js +1 -0
  417. package/dist/i18n/messages-operations.d.ts +362 -0
  418. package/dist/i18n/messages-operations.d.ts.map +1 -0
  419. package/dist/i18n/messages-operations.js +1 -0
  420. package/dist/i18n/messages-sections.d.ts +312 -0
  421. package/dist/i18n/messages-sections.d.ts.map +1 -0
  422. package/dist/i18n/messages-sections.js +1 -0
  423. package/dist/i18n/messages.d.ts +7 -0
  424. package/dist/i18n/messages.d.ts.map +1 -0
  425. package/dist/i18n/messages.js +1 -0
  426. package/dist/i18n/provider.d.ts +3185 -0
  427. package/dist/i18n/provider.d.ts.map +1 -0
  428. package/dist/i18n/provider.js +45 -0
  429. package/dist/i18n/ro-base.d.ts +295 -0
  430. package/dist/i18n/ro-base.d.ts.map +1 -0
  431. package/dist/i18n/ro-base.js +294 -0
  432. package/dist/i18n/ro-create-list.d.ts +327 -0
  433. package/dist/i18n/ro-create-list.d.ts.map +1 -0
  434. package/dist/i18n/ro-create-list.js +326 -0
  435. package/dist/i18n/ro-journey.d.ts +229 -0
  436. package/dist/i18n/ro-journey.d.ts.map +1 -0
  437. package/dist/i18n/ro-journey.js +228 -0
  438. package/dist/i18n/ro-operations.d.ts +382 -0
  439. package/dist/i18n/ro-operations.d.ts.map +1 -0
  440. package/dist/i18n/ro-operations.js +381 -0
  441. package/dist/i18n/ro-sections.d.ts +360 -0
  442. package/dist/i18n/ro-sections.d.ts.map +1 -0
  443. package/dist/i18n/ro-sections.js +359 -0
  444. package/dist/i18n/ro.d.ts +1581 -0
  445. package/dist/i18n/ro.d.ts.map +1 -0
  446. package/dist/i18n/ro.js +12 -0
  447. package/dist/index.d.ts +9 -0
  448. package/dist/index.d.ts.map +1 -0
  449. package/dist/index.js +8 -0
  450. package/dist/journey/components/booking-journey-rules.d.ts +48 -0
  451. package/dist/journey/components/booking-journey-rules.d.ts.map +1 -0
  452. package/dist/journey/components/booking-journey-rules.js +235 -0
  453. package/dist/journey/components/booking-journey.d.ts +3 -0
  454. package/dist/journey/components/booking-journey.d.ts.map +1 -0
  455. package/dist/journey/components/booking-journey.js +368 -0
  456. package/dist/journey/components/configure-step-skeleton.d.ts +8 -0
  457. package/dist/journey/components/configure-step-skeleton.d.ts.map +1 -0
  458. package/dist/journey/components/configure-step-skeleton.js +11 -0
  459. package/dist/journey/components/contract-preview-dialog.d.ts +47 -0
  460. package/dist/journey/components/contract-preview-dialog.d.ts.map +1 -0
  461. package/dist/journey/components/contract-preview-dialog.js +124 -0
  462. package/dist/journey/components/journey-steps/accommodation-step.d.ts +3 -0
  463. package/dist/journey/components/journey-steps/accommodation-step.d.ts.map +1 -0
  464. package/dist/journey/components/journey-steps/accommodation-step.js +71 -0
  465. package/dist/journey/components/journey-steps/addons-step.d.ts +3 -0
  466. package/dist/journey/components/journey-steps/addons-step.d.ts.map +1 -0
  467. package/dist/journey/components/journey-steps/addons-step.js +40 -0
  468. package/dist/journey/components/journey-steps/billing-step.d.ts +8 -0
  469. package/dist/journey/components/journey-steps/billing-step.d.ts.map +1 -0
  470. package/dist/journey/components/journey-steps/billing-step.js +78 -0
  471. package/dist/journey/components/journey-steps/configure-steps.d.ts +28 -0
  472. package/dist/journey/components/journey-steps/configure-steps.d.ts.map +1 -0
  473. package/dist/journey/components/journey-steps/configure-steps.js +232 -0
  474. package/dist/journey/components/journey-steps/documents-step.d.ts +11 -0
  475. package/dist/journey/components/journey-steps/documents-step.d.ts.map +1 -0
  476. package/dist/journey/components/journey-steps/documents-step.js +36 -0
  477. package/dist/journey/components/journey-steps/payment-step.d.ts +29 -0
  478. package/dist/journey/components/journey-steps/payment-step.d.ts.map +1 -0
  479. package/dist/journey/components/journey-steps/payment-step.js +225 -0
  480. package/dist/journey/components/journey-steps/review-step.d.ts +27 -0
  481. package/dist/journey/components/journey-steps/review-step.d.ts.map +1 -0
  482. package/dist/journey/components/journey-steps/review-step.js +18 -0
  483. package/dist/journey/components/journey-steps/shared.d.ts +75 -0
  484. package/dist/journey/components/journey-steps/shared.d.ts.map +1 -0
  485. package/dist/journey/components/journey-steps/shared.js +108 -0
  486. package/dist/journey/components/journey-steps/travelers-step.d.ts +7 -0
  487. package/dist/journey/components/journey-steps/travelers-step.d.ts.map +1 -0
  488. package/dist/journey/components/journey-steps/travelers-step.js +201 -0
  489. package/dist/journey/components/journey-steps.d.ts +21 -0
  490. package/dist/journey/components/journey-steps.d.ts.map +1 -0
  491. package/dist/journey/components/journey-steps.js +20 -0
  492. package/dist/journey/components/side-panel.d.ts +17 -0
  493. package/dist/journey/components/side-panel.d.ts.map +1 -0
  494. package/dist/journey/components/side-panel.js +245 -0
  495. package/dist/journey/components/stacked-journey.d.ts +30 -0
  496. package/dist/journey/components/stacked-journey.d.ts.map +1 -0
  497. package/dist/journey/components/stacked-journey.js +50 -0
  498. package/dist/journey/components/step-header.d.ts +7 -0
  499. package/dist/journey/components/step-header.d.ts.map +1 -0
  500. package/dist/journey/components/step-header.js +12 -0
  501. package/dist/journey/index.d.ts +18 -0
  502. package/dist/journey/index.d.ts.map +1 -0
  503. package/dist/journey/index.js +17 -0
  504. package/dist/journey/lib/draft-state.d.ts +35 -0
  505. package/dist/journey/lib/draft-state.d.ts.map +1 -0
  506. package/dist/journey/lib/draft-state.js +57 -0
  507. package/dist/journey/lib/pax-band-dependencies.d.ts +27 -0
  508. package/dist/journey/lib/pax-band-dependencies.d.ts.map +1 -0
  509. package/dist/journey/lib/pax-band-dependencies.js +50 -0
  510. package/dist/journey/lib/payment-schedule.d.ts +19 -0
  511. package/dist/journey/lib/payment-schedule.d.ts.map +1 -0
  512. package/dist/journey/lib/payment-schedule.js +90 -0
  513. package/dist/journey/types.d.ts +403 -0
  514. package/dist/journey/types.d.ts.map +1 -0
  515. package/dist/journey/types.js +19 -0
  516. package/dist/provider.d.ts +2 -0
  517. package/dist/provider.d.ts.map +1 -0
  518. package/dist/provider.js +1 -0
  519. package/dist/query-keys.d.ts +74 -0
  520. package/dist/query-keys.d.ts.map +1 -0
  521. package/dist/query-keys.js +26 -0
  522. package/dist/query-options.d.ts +2534 -0
  523. package/dist/query-options.d.ts.map +1 -0
  524. package/dist/query-options.js +233 -0
  525. package/dist/requirements/client.d.ts +14 -0
  526. package/dist/requirements/client.d.ts.map +1 -0
  527. package/dist/requirements/client.js +59 -0
  528. package/dist/requirements/components/booking-requirements-contact-tab.d.ts +8 -0
  529. package/dist/requirements/components/booking-requirements-contact-tab.d.ts.map +1 -0
  530. package/dist/requirements/components/booking-requirements-contact-tab.js +8 -0
  531. package/dist/requirements/components/booking-requirements-questions-tab.d.ts +14 -0
  532. package/dist/requirements/components/booking-requirements-questions-tab.d.ts.map +1 -0
  533. package/dist/requirements/components/booking-requirements-questions-tab.js +17 -0
  534. package/dist/requirements/constants.d.ts +114 -0
  535. package/dist/requirements/constants.d.ts.map +1 -0
  536. package/dist/requirements/constants.js +45 -0
  537. package/dist/requirements/hooks/index.d.ts +6 -0
  538. package/dist/requirements/hooks/index.d.ts.map +1 -0
  539. package/dist/requirements/hooks/index.js +6 -0
  540. package/dist/requirements/hooks/use-booking-questions.d.ts +24 -0
  541. package/dist/requirements/hooks/use-booking-questions.d.ts.map +1 -0
  542. package/dist/requirements/hooks/use-booking-questions.js +9 -0
  543. package/dist/requirements/hooks/use-contact-requirements.d.ts +22 -0
  544. package/dist/requirements/hooks/use-contact-requirements.d.ts.map +1 -0
  545. package/dist/requirements/hooks/use-contact-requirements.js +9 -0
  546. package/dist/requirements/hooks/use-products.d.ts +16 -0
  547. package/dist/requirements/hooks/use-products.d.ts.map +1 -0
  548. package/dist/requirements/hooks/use-products.js +9 -0
  549. package/dist/requirements/hooks/use-question-options.d.ts +19 -0
  550. package/dist/requirements/hooks/use-question-options.d.ts.map +1 -0
  551. package/dist/requirements/hooks/use-question-options.js +9 -0
  552. package/dist/requirements/hooks/use-transport-requirements.d.ts +30 -0
  553. package/dist/requirements/hooks/use-transport-requirements.d.ts.map +1 -0
  554. package/dist/requirements/hooks/use-transport-requirements.js +9 -0
  555. package/dist/requirements/i18n/en.d.ts +94 -0
  556. package/dist/requirements/i18n/en.d.ts.map +1 -0
  557. package/dist/requirements/i18n/en.js +93 -0
  558. package/dist/requirements/i18n/index.d.ts +5 -0
  559. package/dist/requirements/i18n/index.d.ts.map +1 -0
  560. package/dist/requirements/i18n/index.js +3 -0
  561. package/dist/requirements/i18n/messages.d.ts +59 -0
  562. package/dist/requirements/i18n/messages.d.ts.map +1 -0
  563. package/dist/requirements/i18n/messages.js +1 -0
  564. package/dist/requirements/i18n/provider.d.ts +210 -0
  565. package/dist/requirements/i18n/provider.d.ts.map +1 -0
  566. package/dist/requirements/i18n/provider.js +44 -0
  567. package/dist/requirements/i18n/ro.d.ts +94 -0
  568. package/dist/requirements/i18n/ro.d.ts.map +1 -0
  569. package/dist/requirements/i18n/ro.js +93 -0
  570. package/dist/requirements/index.d.ts +9 -0
  571. package/dist/requirements/index.d.ts.map +1 -0
  572. package/dist/requirements/index.js +8 -0
  573. package/dist/requirements/provider.d.ts +2 -0
  574. package/dist/requirements/provider.d.ts.map +1 -0
  575. package/dist/requirements/provider.js +1 -0
  576. package/dist/requirements/query-keys.d.ts +33 -0
  577. package/dist/requirements/query-keys.d.ts.map +1 -0
  578. package/dist/requirements/query-keys.js +13 -0
  579. package/dist/requirements/query-options.d.ts +371 -0
  580. package/dist/requirements/query-options.d.ts.map +1 -0
  581. package/dist/requirements/query-options.js +80 -0
  582. package/dist/requirements/schemas.d.ts +320 -0
  583. package/dist/requirements/schemas.d.ts.map +1 -0
  584. package/dist/requirements/schemas.js +121 -0
  585. package/dist/requirements/ui.d.ts +4 -0
  586. package/dist/requirements/ui.d.ts.map +1 -0
  587. package/dist/requirements/ui.js +3 -0
  588. package/dist/requirements/utils.d.ts +2 -0
  589. package/dist/requirements/utils.d.ts.map +1 -0
  590. package/dist/requirements/utils.js +4 -0
  591. package/dist/schemas.d.ts +2070 -0
  592. package/dist/schemas.d.ts.map +1 -0
  593. package/dist/schemas.js +507 -0
  594. package/dist/status-presentation.d.ts +34 -0
  595. package/dist/status-presentation.d.ts.map +1 -0
  596. package/dist/status-presentation.js +38 -0
  597. package/dist/ui.d.ts +43 -0
  598. package/dist/ui.d.ts.map +1 -0
  599. package/dist/ui.js +42 -0
  600. package/package.json +256 -0
  601. package/src/requirements/styles.css +1 -0
  602. package/src/styles.css +13 -0
@@ -0,0 +1,191 @@
1
+ "use client";
2
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
+ import { AlertDialog, AlertDialogAction, AlertDialogCancel, AlertDialogContent, AlertDialogDescription, AlertDialogFooter, AlertDialogHeader, AlertDialogTitle, Button, } from "@voyant-travel/ui/components";
4
+ import { DataTable } from "@voyant-travel/ui/components/data-table";
5
+ import { Sheet, SheetContent, SheetDescription, SheetHeader, SheetTitle, } from "@voyant-travel/ui/components/sheet";
6
+ import { Eye, Package, Pencil, Plus, Trash2 } from "lucide-react";
7
+ import * as React from "react";
8
+ import { useBookingsUiI18nOrDefault, useBookingsUiMessagesOrDefault } from "../i18n/provider.js";
9
+ import { useBookingItemMutation, useBookingItems } from "../index.js";
10
+ import { BookingItemDialog } from "./booking-item-dialog.js";
11
+ import { IconActionButton } from "./icon-action-button.js";
12
+ import { StatusBadge } from "./status-badge.js";
13
+ export function BookingItemList({ bookingId, onResourceOpen }) {
14
+ const [dialogOpen, setDialogOpen] = React.useState(false);
15
+ const [editing, setEditing] = React.useState(undefined);
16
+ const [deleteTarget, setDeleteTarget] = React.useState(null);
17
+ const [viewing, setViewing] = React.useState(null);
18
+ const { data } = useBookingItems(bookingId);
19
+ const { remove } = useBookingItemMutation(bookingId);
20
+ const { formatCurrency, formatDateTime } = useBookingsUiI18nOrDefault();
21
+ const messages = useBookingsUiMessagesOrDefault();
22
+ const items = data?.data ?? [];
23
+ const deleteMessages = messages.bookingItemList.actions.deleteConfirm;
24
+ const handleConfirmDelete = async () => {
25
+ if (!deleteTarget)
26
+ return;
27
+ await remove.mutateAsync(deleteTarget.id);
28
+ setDeleteTarget(null);
29
+ };
30
+ const columns = React.useMemo(() => [
31
+ {
32
+ accessorKey: "title",
33
+ header: messages.bookingItemList.columns.title,
34
+ cell: ({ row }) => (_jsx("span", { className: "font-medium", children: row.original.productNameSnapshot ?? row.original.title })),
35
+ },
36
+ {
37
+ id: "option",
38
+ header: messages.bookingItemList.columns.option,
39
+ cell: ({ row }) => row.original.optionNameSnapshot ?? "—",
40
+ },
41
+ {
42
+ id: "unit",
43
+ header: messages.bookingItemList.columns.unit,
44
+ cell: ({ row }) => {
45
+ const item = row.original;
46
+ const unit = item.unitNameSnapshot ?? (item.productNameSnapshot ? item.title : null);
47
+ return unit ?? "—";
48
+ },
49
+ },
50
+ {
51
+ accessorKey: "itemType",
52
+ header: messages.bookingItemList.columns.type,
53
+ cell: ({ row }) => messages.bookingItemDialog.itemTypeLabels[row.original.itemType],
54
+ },
55
+ {
56
+ accessorKey: "status",
57
+ header: messages.bookingItemList.columns.status,
58
+ cell: ({ row }) => (_jsx(StatusBadge, { status: row.original.status, children: messages.bookingItemDialog.itemStatusLabels[row.original.status] })),
59
+ },
60
+ {
61
+ accessorKey: "quantity",
62
+ header: () => _jsx("div", { className: "text-right", children: messages.bookingItemList.columns.quantity }),
63
+ cell: ({ row }) => _jsx("div", { className: "text-right font-mono", children: row.original.quantity }),
64
+ },
65
+ {
66
+ accessorKey: "totalSellAmountCents",
67
+ header: () => _jsx("div", { className: "text-right", children: messages.bookingItemList.columns.total }),
68
+ cell: ({ row }) => (_jsx("div", { className: "text-right font-mono", children: row.original.totalSellAmountCents == null
69
+ ? messages.bookingItemList.values.totalUnavailable
70
+ : formatCurrency(row.original.totalSellAmountCents / 100, row.original.sellCurrency) })),
71
+ },
72
+ {
73
+ accessorKey: "totalCostAmountCents",
74
+ header: messages.bookingItemList.columns.cost,
75
+ cell: ({ row }) => (_jsx("span", { className: "font-mono text-muted-foreground", children: row.original.totalCostAmountCents == null || !row.original.costCurrency
76
+ ? messages.bookingItemList.values.costUnavailable
77
+ : formatCurrency(row.original.totalCostAmountCents / 100, row.original.costCurrency) })),
78
+ },
79
+ {
80
+ id: "dates",
81
+ header: messages.bookingItemList.columns.serviceDate,
82
+ cell: ({ row }) => (_jsx("span", { className: "text-xs", children: formatItemDateRange(row.original, formatDateTime) ??
83
+ messages.bookingItemList.values.serviceDateUnavailable })),
84
+ },
85
+ {
86
+ id: "actions",
87
+ header: "",
88
+ cell: ({ row }) => (_jsxs("div", { className: "flex items-center justify-end gap-1", children: [_jsx(IconActionButton, { label: messages.bookingItemList.actions.viewItem, icon: _jsx(Eye, { className: "h-3.5 w-3.5" }), onClick: (e) => {
89
+ e.stopPropagation();
90
+ setViewing(row.original);
91
+ } }), _jsx(IconActionButton, { label: messages.bookingItemList.actions.editItem, icon: _jsx(Pencil, { className: "h-3.5 w-3.5" }), onClick: (e) => {
92
+ e.stopPropagation();
93
+ setEditing(row.original);
94
+ setDialogOpen(true);
95
+ } }), _jsx(IconActionButton, { label: messages.bookingItemList.actions.deleteItem, icon: _jsx(Trash2, { className: "h-3.5 w-3.5" }), className: "text-muted-foreground hover:bg-destructive/10 hover:text-destructive", onClick: (e) => {
96
+ e.stopPropagation();
97
+ setDeleteTarget(row.original);
98
+ } })] })),
99
+ },
100
+ ], [formatCurrency, formatDateTime, messages]);
101
+ return (_jsxs("div", { "data-slot": "booking-item-list", className: "flex flex-col gap-3", children: [_jsxs("div", { className: "flex items-center justify-between", children: [_jsxs("h2", { className: "flex items-center gap-2 text-base font-semibold", children: [_jsx(Package, { className: "h-4 w-4" }), messages.bookingItemList.title] }), _jsxs(Button, { variant: "outline", size: "sm", onClick: () => {
102
+ setEditing(undefined);
103
+ setDialogOpen(true);
104
+ }, children: [_jsx(Plus, { className: "mr-2 h-4 w-4" }), messages.bookingItemList.addItem] })] }), _jsx(DataTable, { columns: columns, data: items, emptyMessage: messages.bookingItemList.empty, showPagination: false }), _jsx(BookingItemDialog, { open: dialogOpen, onOpenChange: (nextOpen) => {
105
+ setDialogOpen(nextOpen);
106
+ if (!nextOpen) {
107
+ setEditing(undefined);
108
+ }
109
+ }, bookingId: bookingId, item: editing, onSuccess: () => {
110
+ setEditing(undefined);
111
+ } }), _jsx(Sheet, { open: Boolean(viewing), onOpenChange: (next) => {
112
+ if (!next)
113
+ setViewing(null);
114
+ }, children: _jsxs(SheetContent, { side: "right", className: "sm:max-w-2xl", children: [_jsxs(SheetHeader, { children: [_jsx(SheetTitle, { children: messages.bookingItemList.snapshot.title }), _jsx(SheetDescription, { children: messages.bookingItemList.snapshot.subtitle })] }), viewing ? (_jsx(ItemSnapshotBody, { item: viewing, formatCurrency: formatCurrency, onResourceOpen: onResourceOpen })) : null] }) }), _jsx(AlertDialog, { open: Boolean(deleteTarget), onOpenChange: (next) => {
115
+ if (!next && !remove.isPending)
116
+ setDeleteTarget(null);
117
+ }, children: _jsxs(AlertDialogContent, { size: "sm", children: [_jsxs(AlertDialogHeader, { children: [_jsx(AlertDialogTitle, { children: deleteMessages.title }), _jsx(AlertDialogDescription, { children: deleteMessages.description })] }), _jsxs(AlertDialogFooter, { children: [_jsx(AlertDialogCancel, { disabled: remove.isPending, children: deleteMessages.cancel }), _jsx(AlertDialogAction, { variant: "destructive", disabled: remove.isPending, onClick: () => void handleConfirmDelete(), children: deleteMessages.confirm })] })] }) })] }));
118
+ }
119
+ function ItemSnapshotBody({ item, formatCurrency, onResourceOpen, }) {
120
+ const messages = useBookingsUiMessagesOrDefault();
121
+ const { formatDateTime } = useBookingsUiI18nOrDefault();
122
+ const labels = messages.bookingItemList.snapshot;
123
+ const empty = labels.empty;
124
+ const productName = item.productNameSnapshot ?? item.title;
125
+ const dateRange = formatItemDateRange(item, formatDateTime);
126
+ const unitSell = item.unitSellAmountCents != null
127
+ ? formatCurrency(item.unitSellAmountCents / 100, item.sellCurrency)
128
+ : empty;
129
+ const totalSell = item.totalSellAmountCents != null
130
+ ? formatCurrency(item.totalSellAmountCents / 100, item.sellCurrency)
131
+ : empty;
132
+ const unitCost = item.unitCostAmountCents != null && item.costCurrency
133
+ ? formatCurrency(item.unitCostAmountCents / 100, item.costCurrency)
134
+ : empty;
135
+ const totalCost = item.totalCostAmountCents != null && item.costCurrency
136
+ ? formatCurrency(item.totalCostAmountCents / 100, item.costCurrency)
137
+ : empty;
138
+ const productLink = item.productId && onResourceOpen
139
+ ? () => onResourceOpen("product", item.productId)
140
+ : undefined;
141
+ const dateLink = item.availabilitySlotId && onResourceOpen
142
+ ? () => onResourceOpen("availabilitySlot", item.availabilitySlotId)
143
+ : undefined;
144
+ return (_jsxs("div", { className: "flex-1 overflow-y-auto px-4 pb-4", children: [_jsxs(SnapshotSection, { title: labels.sectionSummary, children: [_jsx(SnapshotRow, { label: labels.productLabel, value: _jsx(LinkOrText, { text: productName, onClick: productLink }) }), _jsx(SnapshotRow, { label: labels.optionLabel, value: item.optionNameSnapshot || empty }), _jsx(SnapshotRow, { label: labels.unitLabel, value: item.unitNameSnapshot || empty }), _jsx(SnapshotRow, { label: labels.typeLabel, value: messages.bookingItemDialog.itemTypeLabels[item.itemType] }), _jsx(SnapshotRow, { label: labels.statusLabel, value: _jsx(StatusBadge, { status: item.status, children: messages.bookingItemDialog.itemStatusLabels[item.status] }) }), _jsx(SnapshotRow, { label: labels.datesLabel, value: _jsx(LinkOrText, { text: dateRange ?? empty, onClick: dateLink }) }), _jsx(SnapshotRow, { label: labels.descriptionLabel, value: item.description || empty, multiline: true }), _jsx(SnapshotRow, { label: labels.notesLabel, value: item.notes || empty, multiline: true })] }), _jsxs(SnapshotSection, { title: labels.sectionPricing, children: [_jsx(SnapshotRow, { label: labels.quantityLabel, value: String(item.quantity) }), _jsx(SnapshotRow, { label: labels.unitSellLabel, value: unitSell, mono: true }), _jsx(SnapshotRow, { label: labels.totalSellLabel, value: totalSell, mono: true }), _jsx(SnapshotRow, { label: labels.unitCostLabel, value: unitCost, mono: true }), _jsx(SnapshotRow, { label: labels.totalCostLabel, value: totalCost, mono: true })] }), _jsxs(SnapshotSection, { title: labels.sectionMeta, children: [_jsx(SnapshotRow, { label: labels.createdAtLabel, value: formatTimestampIso(item.createdAt, formatDateTime) ?? empty }), _jsx(SnapshotRow, { label: labels.updatedAtLabel, value: formatTimestampIso(item.updatedAt, formatDateTime) ?? empty })] })] }));
145
+ }
146
+ function LinkOrText({ text, onClick }) {
147
+ if (!onClick)
148
+ return _jsx(_Fragment, { children: text });
149
+ return (_jsx("button", { type: "button", onClick: onClick, className: "text-left text-primary hover:underline", children: text }));
150
+ }
151
+ function SnapshotSection({ title, children }) {
152
+ return (_jsxs("section", { className: "mb-6", children: [_jsx("h3", { className: "mb-2 text-xs font-medium uppercase tracking-wide text-muted-foreground", children: title }), _jsx("dl", { className: "divide-y divide-border rounded-md border", children: children })] }));
153
+ }
154
+ function SnapshotRow({ label, value, mono, multiline, }) {
155
+ return (_jsxs("div", { className: "grid grid-cols-[10rem_1fr] items-baseline gap-3 px-3 py-2 text-sm", children: [_jsx("dt", { className: "text-xs text-muted-foreground", children: label }), _jsx("dd", { className: mono
156
+ ? "font-mono text-sm"
157
+ : multiline
158
+ ? "whitespace-pre-wrap text-sm"
159
+ : "truncate text-sm", children: value })] }));
160
+ }
161
+ function formatTimestampIso(iso, formatDateTime) {
162
+ if (!iso)
163
+ return null;
164
+ const d = new Date(iso);
165
+ if (!Number.isFinite(d.getTime()))
166
+ return null;
167
+ return formatDateTime(d);
168
+ }
169
+ function formatItemDateRange(item, formatDateTime) {
170
+ // Prefer the explicit start/end timestamps over the snapshot label —
171
+ // the snapshot was rendered in whatever locale was active when the
172
+ // booking was created, so it can be stale (English text on a Romanian
173
+ // dashboard, missing arrival, etc.). We only fall back to the snapshot
174
+ // when we have nothing better.
175
+ const start = item.startsAt ? new Date(item.startsAt) : null;
176
+ const end = item.endsAt ? new Date(item.endsAt) : null;
177
+ if (start && Number.isFinite(start.getTime())) {
178
+ if (end && Number.isFinite(end.getTime()) && end.getTime() !== start.getTime()) {
179
+ return `${formatDateTime(start)} → ${formatDateTime(end)}`;
180
+ }
181
+ return formatDateTime(start);
182
+ }
183
+ if (item.serviceDate) {
184
+ const d = new Date(item.serviceDate);
185
+ if (Number.isFinite(d.getTime())) {
186
+ return formatDateTime(d, { dateStyle: "medium" });
187
+ }
188
+ return item.serviceDate;
189
+ }
190
+ return item.departureLabelSnapshot ?? null;
191
+ }
@@ -0,0 +1,6 @@
1
+ export interface BookingItemTravelersProps {
2
+ bookingId: string;
3
+ itemId: string;
4
+ }
5
+ export declare function BookingItemTravelers({ bookingId, itemId }: BookingItemTravelersProps): import("react/jsx-runtime").JSX.Element;
6
+ //# sourceMappingURL=booking-item-travelers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"booking-item-travelers.d.ts","sourceRoot":"","sources":["../../src/components/booking-item-travelers.tsx"],"names":[],"mappings":"AA+BA,MAAM,WAAW,yBAAyB;IACxC,SAAS,EAAE,MAAM,CAAA;IACjB,MAAM,EAAE,MAAM,CAAA;CACf;AAED,wBAAgB,oBAAoB,CAAC,EAAE,SAAS,EAAE,MAAM,EAAE,EAAE,yBAAyB,2CAwJpF"}
@@ -0,0 +1,57 @@
1
+ "use client";
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { Badge, Button, Select, SelectContent, SelectItem, SelectTrigger, SelectValue, } from "@voyant-travel/ui/components";
4
+ import { Plus, Trash2, UserCheck } from "lucide-react";
5
+ import * as React from "react";
6
+ import { useBookingsUiMessagesOrDefault } from "../i18n/provider.js";
7
+ import { useBookingItemTravelerMutation, useBookingItemTravelers, useTravelers, } from "../index.js";
8
+ const roles = [
9
+ "traveler",
10
+ "occupant",
11
+ "primary_contact",
12
+ "service_assignee",
13
+ "beneficiary",
14
+ "other",
15
+ ];
16
+ export function BookingItemTravelers({ bookingId, itemId }) {
17
+ const { data: travelerLinksData } = useBookingItemTravelers(bookingId, itemId);
18
+ const { data: travelersData } = useTravelers(bookingId);
19
+ const { add, remove } = useBookingItemTravelerMutation(bookingId, itemId);
20
+ const messages = useBookingsUiMessagesOrDefault();
21
+ const [selectedTravelerId, setSelectedTravelerId] = React.useState("");
22
+ const [selectedRole, setSelectedRole] = React.useState("traveler");
23
+ const assignedTravelers = travelerLinksData?.data ?? [];
24
+ const travelers = travelersData?.data ?? [];
25
+ const assignedIds = new Set(assignedTravelers.map((link) => link.travelerId));
26
+ const availableTravelers = travelers.filter((traveler) => !assignedIds.has(traveler.id));
27
+ const travelerItems = React.useMemo(() => availableTravelers.map((t) => ({
28
+ value: t.id,
29
+ label: `${t.firstName} ${t.lastName}`,
30
+ })), [availableTravelers]);
31
+ const roleItems = React.useMemo(() => roles.map((r) => ({
32
+ value: r,
33
+ label: messages.bookingItemTravelers.roleLabels[r],
34
+ })), [messages.bookingItemTravelers.roleLabels]);
35
+ const travelerMap = new Map();
36
+ for (const traveler of travelers) {
37
+ travelerMap.set(traveler.id, traveler);
38
+ }
39
+ const handleAssign = () => {
40
+ if (!selectedTravelerId)
41
+ return;
42
+ add.mutate({ travelerId: selectedTravelerId, role: selectedRole }, {
43
+ onSuccess: () => {
44
+ setSelectedTravelerId("");
45
+ setSelectedRole("traveler");
46
+ },
47
+ });
48
+ };
49
+ return (_jsxs("div", { className: "space-y-3 rounded-md border bg-muted/30 p-3", children: [_jsxs("div", { className: "flex items-center gap-2 text-xs font-medium text-muted-foreground", children: [_jsx(UserCheck, { className: "h-3.5 w-3.5" }), messages.bookingItemTravelers.title] }), assignedTravelers.length === 0 ? (_jsx("p", { className: "text-xs text-muted-foreground", children: messages.bookingItemTravelers.empty })) : (_jsx("div", { className: "space-y-1", children: assignedTravelers.map((link) => {
50
+ const traveler = travelerMap.get(link.travelerId);
51
+ return (_jsxs("div", { className: "flex items-center justify-between rounded px-2 py-1 text-sm", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx("span", { children: traveler ? `${traveler.firstName} ${traveler.lastName}` : link.travelerId }), _jsx(Badge, { variant: "outline", className: "text-xs", children: messages.bookingItemTravelers.roleLabels[link.role] }), link.isPrimary && (_jsx(Badge, { variant: "default", className: "text-xs", children: messages.bookingItemTravelers.primaryBadge }))] }), _jsx("button", { type: "button", onClick: () => {
52
+ if (confirm(messages.bookingItemTravelers.actions.removeConfirm)) {
53
+ remove.mutate(link.id);
54
+ }
55
+ }, className: "text-muted-foreground hover:text-destructive", children: _jsx(Trash2, { className: "h-3.5 w-3.5" }) })] }, link.id));
56
+ }) })), availableTravelers.length > 0 && (_jsxs("div", { className: "flex items-end gap-2 border-t pt-3", children: [_jsx("div", { className: "flex-1", children: _jsxs(Select, { items: travelerItems, value: selectedTravelerId, onValueChange: (v) => setSelectedTravelerId(v ?? ""), children: [_jsx(SelectTrigger, { className: "w-full h-8 text-xs", children: _jsx(SelectValue, { placeholder: messages.bookingItemTravelers.selectTravelerPlaceholder }) }), _jsx(SelectContent, { children: availableTravelers.map((traveler) => (_jsxs(SelectItem, { value: traveler.id, children: [traveler.firstName, " ", traveler.lastName] }, traveler.id))) })] }) }), _jsx("div", { className: "w-36", children: _jsxs(Select, { items: roleItems, value: selectedRole, onValueChange: (v) => setSelectedRole(v ?? "traveler"), children: [_jsx(SelectTrigger, { className: "w-full h-8 text-xs", children: _jsx(SelectValue, {}) }), _jsx(SelectContent, { children: roles.map((r) => (_jsx(SelectItem, { value: r, children: messages.bookingItemTravelers.roleLabels[r] }, r))) })] }) }), _jsxs(Button, { size: "sm", variant: "outline", className: "h-8", onClick: handleAssign, disabled: !selectedTravelerId || add.isPending, children: [_jsx(Plus, { className: "mr-1 h-3.5 w-3.5" }), messages.bookingItemTravelers.actions.assign] })] }))] }));
57
+ }
@@ -0,0 +1,43 @@
1
+ export declare const BOOKING_STATUS_ALL = "__all__";
2
+ export interface BookingListFiltersPopoverProps {
3
+ open: boolean;
4
+ onOpenChange: (open: boolean) => void;
5
+ activeFilterCount: number;
6
+ status: string;
7
+ onStatusChange: (status: string) => void;
8
+ productId: string | null;
9
+ onProductIdChange: (productId: string | null) => void;
10
+ optionId: string | null;
11
+ onOptionIdChange: (optionId: string | null) => void;
12
+ /**
13
+ * Filter to bookings on a specific departure (availability slot).
14
+ * Picker is only populated when a product is selected.
15
+ */
16
+ availabilitySlotId: string | null;
17
+ onAvailabilitySlotIdChange: (availabilitySlotId: string | null) => void;
18
+ supplierId: string | null;
19
+ onSupplierIdChange: (supplierId: string | null) => void;
20
+ productCategoryId: string | null;
21
+ onProductCategoryIdChange: (productCategoryId: string | null) => void;
22
+ personId: string | null;
23
+ onPersonIdChange: (personId: string | null) => void;
24
+ organizationId: string | null;
25
+ onOrganizationIdChange: (organizationId: string | null) => void;
26
+ dateRange: {
27
+ from: string | null;
28
+ to: string | null;
29
+ } | null;
30
+ onDateRangeChange: (dateRange: {
31
+ from: string | null;
32
+ to: string | null;
33
+ } | null) => void;
34
+ paxMin: string;
35
+ onPaxMinChange: (paxMin: string) => void;
36
+ paxMax: string;
37
+ onPaxMaxChange: (paxMax: string) => void;
38
+ onFiltersChanged: () => void;
39
+ hasActiveFilters: boolean;
40
+ onClearFilters: () => void;
41
+ }
42
+ export declare function BookingListFiltersPopover({ open, onOpenChange, activeFilterCount, status, onStatusChange, productId, onProductIdChange, optionId, onOptionIdChange, availabilitySlotId, onAvailabilitySlotIdChange, supplierId, onSupplierIdChange, productCategoryId, onProductCategoryIdChange, personId, onPersonIdChange, organizationId, onOrganizationIdChange, dateRange, onDateRangeChange, paxMin, onPaxMinChange, paxMax, onPaxMaxChange, onFiltersChanged, hasActiveFilters, onClearFilters, }: BookingListFiltersPopoverProps): import("react/jsx-runtime").JSX.Element;
43
+ //# sourceMappingURL=booking-list-filters.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"booking-list-filters.d.ts","sourceRoot":"","sources":["../../src/components/booking-list-filters.tsx"],"names":[],"mappings":"AAqCA,eAAO,MAAM,kBAAkB,YAAY,CAAA;AAE3C,MAAM,WAAW,8BAA8B;IAC7C,IAAI,EAAE,OAAO,CAAA;IACb,YAAY,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAA;IACrC,iBAAiB,EAAE,MAAM,CAAA;IACzB,MAAM,EAAE,MAAM,CAAA;IACd,cAAc,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAA;IACxC,SAAS,EAAE,MAAM,GAAG,IAAI,CAAA;IACxB,iBAAiB,EAAE,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAA;IACrD,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,gBAAgB,EAAE,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAA;IACnD;;;OAGG;IACH,kBAAkB,EAAE,MAAM,GAAG,IAAI,CAAA;IACjC,0BAA0B,EAAE,CAAC,kBAAkB,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAA;IACvE,UAAU,EAAE,MAAM,GAAG,IAAI,CAAA;IACzB,kBAAkB,EAAE,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAA;IACvD,iBAAiB,EAAE,MAAM,GAAG,IAAI,CAAA;IAChC,yBAAyB,EAAE,CAAC,iBAAiB,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAA;IACrE,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,gBAAgB,EAAE,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAA;IACnD,cAAc,EAAE,MAAM,GAAG,IAAI,CAAA;IAC7B,sBAAsB,EAAE,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAA;IAC/D,SAAS,EAAE;QAAE,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;QAAC,EAAE,EAAE,MAAM,GAAG,IAAI,CAAA;KAAE,GAAG,IAAI,CAAA;IAC5D,iBAAiB,EAAE,CAAC,SAAS,EAAE;QAAE,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;QAAC,EAAE,EAAE,MAAM,GAAG,IAAI,CAAA;KAAE,GAAG,IAAI,KAAK,IAAI,CAAA;IACzF,MAAM,EAAE,MAAM,CAAA;IACd,cAAc,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAA;IACxC,MAAM,EAAE,MAAM,CAAA;IACd,cAAc,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAA;IACxC,gBAAgB,EAAE,MAAM,IAAI,CAAA;IAC5B,gBAAgB,EAAE,OAAO,CAAA;IACzB,cAAc,EAAE,MAAM,IAAI,CAAA;CAC3B;AAED,wBAAgB,yBAAyB,CAAC,EACxC,IAAI,EACJ,YAAY,EACZ,iBAAiB,EACjB,MAAM,EACN,cAAc,EACd,SAAS,EACT,iBAAiB,EACjB,QAAQ,EACR,gBAAgB,EAChB,kBAAkB,EAClB,0BAA0B,EAC1B,UAAU,EACV,kBAAkB,EAClB,iBAAiB,EACjB,yBAAyB,EACzB,QAAQ,EACR,gBAAgB,EAChB,cAAc,EACd,sBAAsB,EACtB,SAAS,EACT,iBAAiB,EACjB,MAAM,EACN,cAAc,EACd,MAAM,EACN,cAAc,EACd,gBAAgB,EAChB,gBAAgB,EAChB,cAAc,GACf,EAAE,8BAA8B,2CAoVhC"}
@@ -0,0 +1,192 @@
1
+ "use client";
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { useSuppliers } from "@voyant-travel/distribution-react/suppliers";
4
+ import { useProductCategories, useProductOptions, useProducts, } from "@voyant-travel/inventory-react";
5
+ import { useSlots } from "@voyant-travel/operations-react/availability";
6
+ import { useOrganizations, usePeople } from "@voyant-travel/relationships-react";
7
+ import { AsyncCombobox } from "@voyant-travel/ui/components/async-combobox";
8
+ import { Badge } from "@voyant-travel/ui/components/badge";
9
+ import { Button } from "@voyant-travel/ui/components/button";
10
+ import { DateRangePicker } from "@voyant-travel/ui/components/date-picker";
11
+ import { Input } from "@voyant-travel/ui/components/input";
12
+ import { Label } from "@voyant-travel/ui/components/label";
13
+ import { Popover, PopoverContent, PopoverTrigger } from "@voyant-travel/ui/components/popover";
14
+ import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue, } from "@voyant-travel/ui/components/select";
15
+ import { ListFilter, X } from "lucide-react";
16
+ import * as React from "react";
17
+ import { useBookingsUiMessagesOrDefault } from "../i18n/provider.js";
18
+ import { bookingStatuses } from "../index.js";
19
+ export const BOOKING_STATUS_ALL = "__all__";
20
+ export function BookingListFiltersPopover({ open, onOpenChange, activeFilterCount, status, onStatusChange, productId, onProductIdChange, optionId, onOptionIdChange, availabilitySlotId, onAvailabilitySlotIdChange, supplierId, onSupplierIdChange, productCategoryId, onProductCategoryIdChange, personId, onPersonIdChange, organizationId, onOrganizationIdChange, dateRange, onDateRangeChange, paxMin, onPaxMinChange, paxMax, onPaxMaxChange, onFiltersChanged, hasActiveFilters, onClearFilters, }) {
21
+ const messages = useBookingsUiMessagesOrDefault();
22
+ const filterMessages = messages.bookingList.filters;
23
+ const statusLabels = messages.common.bookingStatusLabels;
24
+ const [selectedProduct, setSelectedProduct] = React.useState(null);
25
+ const [productSearch, setProductSearch] = React.useState("");
26
+ const [selectedOption, setSelectedOption] = React.useState(null);
27
+ const [selectedSlot, setSelectedSlot] = React.useState(null);
28
+ const [selectedSupplier, setSelectedSupplier] = React.useState(null);
29
+ const [supplierSearch, setSupplierSearch] = React.useState("");
30
+ const [selectedProductCategory, setSelectedProductCategory] = React.useState(null);
31
+ const [productCategorySearch, setProductCategorySearch] = React.useState("");
32
+ const [selectedPerson, setSelectedPerson] = React.useState(null);
33
+ const [personSearch, setPersonSearch] = React.useState("");
34
+ const [selectedOrganization, setSelectedOrganization] = React.useState(null);
35
+ const [organizationSearch, setOrganizationSearch] = React.useState("");
36
+ const { data: productsData } = useProducts({
37
+ search: productSearch || undefined,
38
+ limit: 20,
39
+ });
40
+ const products = productsData?.data ?? [];
41
+ const { data: optionsData } = useProductOptions({
42
+ productId: productId ?? undefined,
43
+ status: "active",
44
+ limit: 20,
45
+ enabled: productId !== null,
46
+ });
47
+ const productOptions = optionsData?.data ?? [];
48
+ // Departure picker is product-scoped. The list endpoint orders
49
+ // results most-recent-first; capping at 50 keeps the dropdown
50
+ // workable while still surfacing the active season's slots.
51
+ const { data: slotsData } = useSlots({
52
+ productId: productId ?? undefined,
53
+ limit: 50,
54
+ enabled: productId !== null,
55
+ });
56
+ const slots = slotsData?.data ?? [];
57
+ const { data: suppliersData } = useSuppliers({
58
+ search: supplierSearch || undefined,
59
+ limit: 20,
60
+ });
61
+ const suppliers = suppliersData?.data ?? [];
62
+ const { data: productCategoriesData } = useProductCategories({
63
+ search: productCategorySearch || undefined,
64
+ active: true,
65
+ limit: 20,
66
+ });
67
+ const productCategories = productCategoriesData?.data ?? [];
68
+ const { data: peopleData } = usePeople({
69
+ search: personSearch || undefined,
70
+ limit: 20,
71
+ });
72
+ const people = peopleData?.data ?? [];
73
+ const { data: organizationsData } = useOrganizations({
74
+ search: organizationSearch || undefined,
75
+ limit: 20,
76
+ });
77
+ const organizations = organizationsData?.data ?? [];
78
+ const markChanged = () => onFiltersChanged();
79
+ return (_jsxs(Popover, { open: open, onOpenChange: onOpenChange, children: [_jsx(PopoverTrigger, { render: _jsxs(Button, { variant: "outline", size: "default", children: [_jsx(ListFilter, { className: "mr-2 size-4" }), filterMessages.button, activeFilterCount > 0 && (_jsx(Badge, { variant: "secondary", className: "ml-2 px-1.5", children: activeFilterCount }))] }) }), _jsx(PopoverContent, { align: "start", className: "w-[22rem] p-4", children: _jsxs("div", { className: "flex flex-col gap-4", children: [hasActiveFilters && (_jsx("div", { className: "flex justify-end", children: _jsxs(Button, { variant: "ghost", size: "sm", onClick: () => {
80
+ onClearFilters();
81
+ }, children: [_jsx(X, { className: "mr-1 size-4" }), filterMessages.clear] }) })), _jsxs("div", { className: "flex flex-col gap-1.5", children: [_jsx(Label, { htmlFor: "bookings-filter-status", children: filterMessages.statusLabel }), _jsxs(Select, { value: status, onValueChange: (value) => {
82
+ onStatusChange(value ?? BOOKING_STATUS_ALL);
83
+ markChanged();
84
+ }, children: [_jsx(SelectTrigger, { id: "bookings-filter-status", className: "w-full", children: _jsx(SelectValue, {}) }), _jsxs(SelectContent, { children: [_jsx(SelectItem, { value: BOOKING_STATUS_ALL, children: filterMessages.statusAll }), bookingStatuses.map((value) => (_jsx(SelectItem, { value: value, children: statusLabels[value] }, value)))] })] })] }), _jsxs("div", { className: "flex flex-col gap-1.5", children: [_jsx(Label, { htmlFor: "bookings-filter-product", children: filterMessages.productLabel }), _jsx(AsyncCombobox, { value: productId, onChange: (value) => {
85
+ onProductIdChange(value);
86
+ onOptionIdChange(null);
87
+ setSelectedOption(null);
88
+ if (!value) {
89
+ setSelectedProduct(null);
90
+ }
91
+ else {
92
+ const match = products.find((product) => product.id === value);
93
+ if (match)
94
+ setSelectedProduct(match);
95
+ }
96
+ markChanged();
97
+ }, items: products, selectedItem: selectedProduct, getKey: (product) => product.id, getLabel: (product) => product.name, onSearchChange: setProductSearch, placeholder: filterMessages.product, emptyText: filterMessages.productEmpty })] }), _jsxs("div", { className: "flex flex-col gap-1.5", children: [_jsx(Label, { htmlFor: "bookings-filter-option", children: filterMessages.optionLabel }), _jsx(AsyncCombobox, { value: optionId, onChange: (value) => {
98
+ onOptionIdChange(value);
99
+ if (!value)
100
+ setSelectedOption(null);
101
+ else {
102
+ const match = productOptions.find((option) => option.id === value);
103
+ if (match)
104
+ setSelectedOption(match);
105
+ }
106
+ markChanged();
107
+ }, items: productOptions, selectedItem: selectedOption, getKey: (option) => option.id, getLabel: (option) => option.name, getSecondary: (option) => option.code ?? undefined, placeholder: filterMessages.option, emptyText: productId ? filterMessages.optionEmpty : filterMessages.optionNeedsProduct, disabled: productId === null })] }), _jsxs("div", { className: "flex flex-col gap-1.5", children: [_jsx(Label, { htmlFor: "bookings-filter-departure", children: filterMessages.departureLabel }), _jsx(AsyncCombobox, { value: availabilitySlotId, onChange: (value) => {
108
+ onAvailabilitySlotIdChange(value);
109
+ if (!value)
110
+ setSelectedSlot(null);
111
+ else {
112
+ const match = slots.find((slot) => slot.id === value);
113
+ if (match)
114
+ setSelectedSlot(match);
115
+ }
116
+ markChanged();
117
+ }, items: slots, selectedItem: selectedSlot, getKey: (slot) => slot.id, getLabel: (slot) => formatSlotLabel(slot), getSecondary: (slot) => slot.status, placeholder: filterMessages.departure, emptyText: productId ? filterMessages.departureEmpty : filterMessages.departureNeedsProduct, disabled: productId === null })] }), _jsxs("div", { className: "flex flex-col gap-1.5", children: [_jsx(Label, { htmlFor: "bookings-filter-category", children: filterMessages.categoryLabel }), _jsx(AsyncCombobox, { value: productCategoryId, onChange: (value) => {
118
+ onProductCategoryIdChange(value);
119
+ if (!value)
120
+ setSelectedProductCategory(null);
121
+ else {
122
+ const match = productCategories.find((category) => category.id === value);
123
+ if (match)
124
+ setSelectedProductCategory(match);
125
+ }
126
+ markChanged();
127
+ }, items: productCategories, selectedItem: selectedProductCategory, getKey: (category) => category.id, getLabel: (category) => category.name, onSearchChange: setProductCategorySearch, placeholder: filterMessages.category, emptyText: filterMessages.categoryEmpty })] }), _jsxs("div", { className: "flex flex-col gap-1.5", children: [_jsx(Label, { htmlFor: "bookings-filter-supplier", children: filterMessages.supplierLabel }), _jsx(AsyncCombobox, { value: supplierId, onChange: (value) => {
128
+ onSupplierIdChange(value);
129
+ if (!value)
130
+ setSelectedSupplier(null);
131
+ else {
132
+ const match = suppliers.find((supplier) => supplier.id === value);
133
+ if (match)
134
+ setSelectedSupplier(match);
135
+ }
136
+ markChanged();
137
+ }, items: suppliers, selectedItem: selectedSupplier, getKey: (supplier) => supplier.id, getLabel: (supplier) => supplier.name, getSecondary: (supplier) => supplier.type, onSearchChange: setSupplierSearch, placeholder: filterMessages.supplier, emptyText: filterMessages.supplierEmpty })] }), _jsxs("div", { className: "flex flex-col gap-1.5", children: [_jsx(Label, { htmlFor: "bookings-filter-person", children: filterMessages.personLabel }), _jsx(AsyncCombobox, { value: personId, onChange: (value) => {
138
+ onPersonIdChange(value);
139
+ if (!value)
140
+ setSelectedPerson(null);
141
+ else {
142
+ const match = people.find((person) => person.id === value);
143
+ if (match)
144
+ setSelectedPerson(match);
145
+ }
146
+ markChanged();
147
+ }, items: people, selectedItem: selectedPerson, getKey: (person) => person.id, getLabel: formatPersonName, getSecondary: (person) => person.email ?? undefined, onSearchChange: setPersonSearch, placeholder: filterMessages.person, emptyText: filterMessages.personEmpty })] }), _jsxs("div", { className: "flex flex-col gap-1.5", children: [_jsx(Label, { htmlFor: "bookings-filter-organization", children: filterMessages.organizationLabel }), _jsx(AsyncCombobox, { value: organizationId, onChange: (value) => {
148
+ onOrganizationIdChange(value);
149
+ if (!value)
150
+ setSelectedOrganization(null);
151
+ else {
152
+ const match = organizations.find((organization) => organization.id === value);
153
+ if (match)
154
+ setSelectedOrganization(match);
155
+ }
156
+ markChanged();
157
+ }, items: organizations, selectedItem: selectedOrganization, getKey: (organization) => organization.id, getLabel: (organization) => organization.name, getSecondary: (organization) => organization.taxId ?? undefined, onSearchChange: setOrganizationSearch, placeholder: filterMessages.organization, emptyText: filterMessages.organizationEmpty })] }), _jsxs("div", { className: "flex flex-col gap-1.5", children: [_jsx(Label, { htmlFor: "bookings-filter-date", children: filterMessages.dateRangeLabel }), _jsx(DateRangePicker, { value: dateRange, onChange: (value) => {
158
+ onDateRangeChange(value);
159
+ markChanged();
160
+ }, placeholder: filterMessages.dateRange, clearable: true, className: "w-full" })] }), _jsxs("div", { className: "flex flex-col gap-1.5", children: [_jsx(Label, { children: filterMessages.paxLabel }), _jsxs("div", { className: "flex items-center gap-2", children: [_jsx(Input, { type: "number", min: 0, placeholder: filterMessages.paxMin, value: paxMin, onChange: (event) => {
161
+ onPaxMinChange(event.target.value);
162
+ markChanged();
163
+ }, className: "w-full", "aria-label": filterMessages.paxMin }), _jsx("span", { className: "text-muted-foreground", children: "-" }), _jsx(Input, { type: "number", min: 0, placeholder: filterMessages.paxMax, value: paxMax, onChange: (event) => {
164
+ onPaxMaxChange(event.target.value);
165
+ markChanged();
166
+ }, className: "w-full", "aria-label": filterMessages.paxMax })] })] })] }) })] }));
167
+ }
168
+ function formatPersonName(person) {
169
+ const name = [person.firstName, person.lastName].filter(Boolean).join(" ").trim();
170
+ return name || person.email || person.id;
171
+ }
172
+ /**
173
+ * Human-friendly departure label. Renders the local date + start time
174
+ * in the slot's own timezone so the operator sees what the customer
175
+ * sees, not whatever the admin's browser locale converts it to.
176
+ */
177
+ function formatSlotLabel(slot) {
178
+ try {
179
+ const formatter = new Intl.DateTimeFormat(undefined, {
180
+ day: "numeric",
181
+ month: "short",
182
+ year: "numeric",
183
+ hour: "2-digit",
184
+ minute: "2-digit",
185
+ timeZone: slot.timezone,
186
+ });
187
+ return formatter.format(new Date(slot.startsAt));
188
+ }
189
+ catch {
190
+ return slot.startsAt;
191
+ }
192
+ }
@@ -0,0 +1,50 @@
1
+ import * as React from "react";
2
+ import { type BookingRecord, type BookingsListSortDir, type BookingsListSortField } from "../index.js";
3
+ /**
4
+ * Serializable snapshot of the booking-list filter / sort / paging
5
+ * state. Hosts that want shareable URLs (operator starter) read this
6
+ * from the URL on mount via `initialFilters` and push changes via
7
+ * `onFiltersChange`.
8
+ */
9
+ export interface BookingListFiltersState {
10
+ search: string;
11
+ /** `BOOKING_STATUS_ALL` ("all") or any booking status value. */
12
+ status: string;
13
+ productId: string | null;
14
+ optionId: string | null;
15
+ supplierId: string | null;
16
+ productCategoryId: string | null;
17
+ personId: string | null;
18
+ organizationId: string | null;
19
+ availabilitySlotId: string | null;
20
+ dateFrom: string | null;
21
+ dateTo: string | null;
22
+ paxMin: string;
23
+ paxMax: string;
24
+ sortBy: BookingsListSortField;
25
+ sortDir: BookingsListSortDir;
26
+ offset: number;
27
+ }
28
+ export interface BookingListProps {
29
+ pageSize?: number;
30
+ onSelectBooking?: (booking: BookingRecord) => void;
31
+ onCreateBooking?: () => void;
32
+ /**
33
+ * Extra action(s) rendered next to the primary "New booking" button in
34
+ * the filter bar. Templates use this to surface adjacent flows such as
35
+ * the trips without forking the component.
36
+ */
37
+ headerActions?: React.ReactNode;
38
+ /**
39
+ * Initial filter / sort / paging state, typically parsed from the URL.
40
+ * Only specified keys override the defaults — partial input is fine.
41
+ */
42
+ initialFilters?: Partial<BookingListFiltersState>;
43
+ /**
44
+ * Fires when any filter, sort, or paging value changes. Hosts push
45
+ * the snapshot into the URL so refresh / share preserves the view.
46
+ */
47
+ onFiltersChange?: (filters: BookingListFiltersState) => void;
48
+ }
49
+ export declare function BookingList({ pageSize, onSelectBooking, onCreateBooking, headerActions, initialFilters, onFiltersChange, }?: BookingListProps): import("react/jsx-runtime").JSX.Element;
50
+ //# sourceMappingURL=booking-list.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"booking-list.d.ts","sourceRoot":"","sources":["../../src/components/booking-list.tsx"],"names":[],"mappings":"AAwBA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAM9B,OAAO,EACL,KAAK,aAAa,EAClB,KAAK,mBAAmB,EACxB,KAAK,qBAAqB,EAE3B,MAAM,aAAa,CAAA;AAKpB;;;;;GAKG;AACH,MAAM,WAAW,uBAAuB;IACtC,MAAM,EAAE,MAAM,CAAA;IACd,gEAAgE;IAChE,MAAM,EAAE,MAAM,CAAA;IACd,SAAS,EAAE,MAAM,GAAG,IAAI,CAAA;IACxB,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,UAAU,EAAE,MAAM,GAAG,IAAI,CAAA;IACzB,iBAAiB,EAAE,MAAM,GAAG,IAAI,CAAA;IAChC,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,cAAc,EAAE,MAAM,GAAG,IAAI,CAAA;IAC7B,kBAAkB,EAAE,MAAM,GAAG,IAAI,CAAA;IACjC,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,MAAM,EAAE,MAAM,GAAG,IAAI,CAAA;IACrB,MAAM,EAAE,MAAM,CAAA;IACd,MAAM,EAAE,MAAM,CAAA;IACd,MAAM,EAAE,qBAAqB,CAAA;IAC7B,OAAO,EAAE,mBAAmB,CAAA;IAC5B,MAAM,EAAE,MAAM,CAAA;CACf;AA6BD,MAAM,WAAW,gBAAgB;IAC/B,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,eAAe,CAAC,EAAE,CAAC,OAAO,EAAE,aAAa,KAAK,IAAI,CAAA;IAClD,eAAe,CAAC,EAAE,MAAM,IAAI,CAAA;IAC5B;;;;OAIG;IACH,aAAa,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IAC/B;;;OAGG;IACH,cAAc,CAAC,EAAE,OAAO,CAAC,uBAAuB,CAAC,CAAA;IACjD;;;OAGG;IACH,eAAe,CAAC,EAAE,CAAC,OAAO,EAAE,uBAAuB,KAAK,IAAI,CAAA;CAC7D;AAiBD,wBAAgB,WAAW,CAAC,EAC1B,QAAa,EACb,eAAe,EACf,eAAe,EACf,aAAa,EACb,cAAc,EACd,eAAe,GAChB,GAAE,gBAAqB,2CA+XvB"}