@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.
- package/LICENSE +201 -0
- package/README.md +87 -0
- package/dist/admin/booking-contract-dialog.d.ts +22 -0
- package/dist/admin/booking-contract-dialog.d.ts.map +1 -0
- package/dist/admin/booking-contract-dialog.js +161 -0
- package/dist/admin/booking-detail-host.d.ts +103 -0
- package/dist/admin/booking-detail-host.d.ts.map +1 -0
- package/dist/admin/booking-detail-host.js +127 -0
- package/dist/admin/booking-detail-skeleton.d.ts +7 -0
- package/dist/admin/booking-detail-skeleton.d.ts.map +1 -0
- package/dist/admin/booking-detail-skeleton.js +24 -0
- package/dist/admin/booking-documents-table.d.ts +13 -0
- package/dist/admin/booking-documents-table.d.ts.map +1 -0
- package/dist/admin/booking-documents-table.js +259 -0
- package/dist/admin/booking-invoice-sheet.d.ts +18 -0
- package/dist/admin/booking-invoice-sheet.d.ts.map +1 -0
- package/dist/admin/booking-invoice-sheet.js +101 -0
- package/dist/admin/booking-journey-host.d.ts +24 -0
- package/dist/admin/booking-journey-host.d.ts.map +1 -0
- package/dist/admin/booking-journey-host.js +278 -0
- package/dist/admin/bookings-host.d.ts +26 -0
- package/dist/admin/bookings-host.d.ts.map +1 -0
- package/dist/admin/bookings-host.js +18 -0
- package/dist/admin/bookings-list-skeleton.d.ts +10 -0
- package/dist/admin/bookings-list-skeleton.d.ts.map +1 -0
- package/dist/admin/bookings-list-skeleton.js +25 -0
- package/dist/admin/index.d.ts +273 -0
- package/dist/admin/index.d.ts.map +1 -0
- package/dist/admin/index.js +331 -0
- package/dist/admin/journey-billing-duplicate-warning.d.ts +3 -0
- package/dist/admin/journey-billing-duplicate-warning.d.ts.map +1 -0
- package/dist/admin/journey-billing-duplicate-warning.js +26 -0
- package/dist/admin/journey-departure-picker.d.ts +7 -0
- package/dist/admin/journey-departure-picker.d.ts.map +1 -0
- package/dist/admin/journey-departure-picker.js +100 -0
- package/dist/admin/journey-units-picker.d.ts +11 -0
- package/dist/admin/journey-units-picker.d.ts.map +1 -0
- package/dist/admin/journey-units-picker.js +60 -0
- package/dist/admin/journey-voucher-picker.d.ts +3 -0
- package/dist/admin/journey-voucher-picker.d.ts.map +1 -0
- package/dist/admin/journey-voucher-picker.js +71 -0
- package/dist/admin/pages/booking-compose-page.d.ts +9 -0
- package/dist/admin/pages/booking-compose-page.d.ts.map +1 -0
- package/dist/admin/pages/booking-compose-page.js +17 -0
- package/dist/admin/pages/booking-detail-page.d.ts +11 -0
- package/dist/admin/pages/booking-detail-page.d.ts.map +1 -0
- package/dist/admin/pages/booking-detail-page.js +14 -0
- package/dist/admin/pages/booking-journey-page.d.ts +12 -0
- package/dist/admin/pages/booking-journey-page.d.ts.map +1 -0
- package/dist/admin/pages/booking-journey-page.js +26 -0
- package/dist/admin/pages/booking-new-page.d.ts +15 -0
- package/dist/admin/pages/booking-new-page.d.ts.map +1 -0
- package/dist/admin/pages/booking-new-page.js +50 -0
- package/dist/admin/pages/bookings-index-page.d.ts +20 -0
- package/dist/admin/pages/bookings-index-page.d.ts.map +1 -0
- package/dist/admin/pages/bookings-index-page.js +18 -0
- package/dist/admin/person-bookings-widget.d.ts +13 -0
- package/dist/admin/person-bookings-widget.d.ts.map +1 -0
- package/dist/admin/person-bookings-widget.js +48 -0
- package/dist/admin/slots.d.ts +31 -0
- package/dist/admin/slots.d.ts.map +1 -0
- package/dist/admin/slots.js +30 -0
- package/dist/admin/use-booking-action-ledger-events.d.ts +15 -0
- package/dist/admin/use-booking-action-ledger-events.d.ts.map +1 -0
- package/dist/admin/use-booking-action-ledger-events.js +66 -0
- package/dist/client.d.ts +14 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +59 -0
- package/dist/components/booking-activity-timeline.d.ts +32 -0
- package/dist/components/booking-activity-timeline.d.ts.map +1 -0
- package/dist/components/booking-activity-timeline.js +147 -0
- package/dist/components/booking-billing-dialog.d.ts +16 -0
- package/dist/components/booking-billing-dialog.d.ts.map +1 -0
- package/dist/components/booking-billing-dialog.js +315 -0
- package/dist/components/booking-cancellation-dialog.d.ts +18 -0
- package/dist/components/booking-cancellation-dialog.d.ts.map +1 -0
- package/dist/components/booking-cancellation-dialog.js +79 -0
- package/dist/components/booking-combobox.d.ts +13 -0
- package/dist/components/booking-combobox.d.ts.map +1 -0
- package/dist/components/booking-combobox.js +44 -0
- package/dist/components/booking-create-form-utils.d.ts +56 -0
- package/dist/components/booking-create-form-utils.d.ts.map +1 -0
- package/dist/components/booking-create-form-utils.js +216 -0
- package/dist/components/booking-create-page.d.ts +14 -0
- package/dist/components/booking-create-page.d.ts.map +1 -0
- package/dist/components/booking-create-page.js +11 -0
- package/dist/components/booking-create-preview-card.d.ts +26 -0
- package/dist/components/booking-create-preview-card.d.ts.map +1 -0
- package/dist/components/booking-create-preview-card.js +107 -0
- package/dist/components/booking-create-product-extras-picker.d.ts +18 -0
- package/dist/components/booking-create-product-extras-picker.d.ts.map +1 -0
- package/dist/components/booking-create-product-extras-picker.js +82 -0
- package/dist/components/booking-create-sheet.d.ts +34 -0
- package/dist/components/booking-create-sheet.d.ts.map +1 -0
- package/dist/components/booking-create-sheet.js +811 -0
- package/dist/components/booking-create-utils.d.ts +66 -0
- package/dist/components/booking-create-utils.d.ts.map +1 -0
- package/dist/components/booking-create-utils.js +185 -0
- package/dist/components/booking-detail-page.d.ts +126 -0
- package/dist/components/booking-detail-page.d.ts.map +1 -0
- package/dist/components/booking-detail-page.js +264 -0
- package/dist/components/booking-dialog.d.ts +28 -0
- package/dist/components/booking-dialog.d.ts.map +1 -0
- package/dist/components/booking-dialog.js +130 -0
- package/dist/components/booking-document-dialog.d.ts +8 -0
- package/dist/components/booking-document-dialog.d.ts.map +1 -0
- package/dist/components/booking-document-dialog.js +83 -0
- package/dist/components/booking-document-list.d.ts +5 -0
- package/dist/components/booking-document-list.d.ts.map +1 -0
- package/dist/components/booking-document-list.js +43 -0
- package/dist/components/booking-group-link-dialog.d.ts +10 -0
- package/dist/components/booking-group-link-dialog.d.ts.map +1 -0
- package/dist/components/booking-group-link-dialog.js +79 -0
- package/dist/components/booking-group-section.d.ts +27 -0
- package/dist/components/booking-group-section.d.ts.map +1 -0
- package/dist/components/booking-group-section.js +51 -0
- package/dist/components/booking-guarantee-dialog.d.ts +10 -0
- package/dist/components/booking-guarantee-dialog.d.ts.map +1 -0
- package/dist/components/booking-guarantee-dialog.js +123 -0
- package/dist/components/booking-guarantee-list.d.ts +5 -0
- package/dist/components/booking-guarantee-list.d.ts.map +1 -0
- package/dist/components/booking-guarantee-list.js +86 -0
- package/dist/components/booking-item-dialog.d.ts +10 -0
- package/dist/components/booking-item-dialog.d.ts.map +1 -0
- package/dist/components/booking-item-dialog.js +155 -0
- package/dist/components/booking-item-list.d.ts +12 -0
- package/dist/components/booking-item-list.d.ts.map +1 -0
- package/dist/components/booking-item-list.js +191 -0
- package/dist/components/booking-item-travelers.d.ts +6 -0
- package/dist/components/booking-item-travelers.d.ts.map +1 -0
- package/dist/components/booking-item-travelers.js +57 -0
- package/dist/components/booking-list-filters.d.ts +43 -0
- package/dist/components/booking-list-filters.d.ts.map +1 -0
- package/dist/components/booking-list-filters.js +192 -0
- package/dist/components/booking-list.d.ts +50 -0
- package/dist/components/booking-list.d.ts.map +1 -0
- package/dist/components/booking-list.js +352 -0
- package/dist/components/booking-note-dialog.d.ts +16 -0
- package/dist/components/booking-note-dialog.d.ts.map +1 -0
- package/dist/components/booking-note-dialog.js +41 -0
- package/dist/components/booking-notes.d.ts +5 -0
- package/dist/components/booking-notes.d.ts.map +1 -0
- package/dist/components/booking-notes.js +45 -0
- package/dist/components/booking-payment-reconciliation-banner.d.ts +5 -0
- package/dist/components/booking-payment-reconciliation-banner.d.ts.map +1 -0
- package/dist/components/booking-payment-reconciliation-banner.js +91 -0
- package/dist/components/booking-payment-schedule-dialog.d.ts +10 -0
- package/dist/components/booking-payment-schedule-dialog.d.ts.map +1 -0
- package/dist/components/booking-payment-schedule-dialog.js +117 -0
- package/dist/components/booking-payment-schedule-list.d.ts +10 -0
- package/dist/components/booking-payment-schedule-list.d.ts.map +1 -0
- package/dist/components/booking-payment-schedule-list.js +217 -0
- package/dist/components/booking-payments-summary.d.ts +83 -0
- package/dist/components/booking-payments-summary.d.ts.map +1 -0
- package/dist/components/booking-payments-summary.js +176 -0
- package/dist/components/booking-quick-view-sheet.d.ts +14 -0
- package/dist/components/booking-quick-view-sheet.d.ts.map +1 -0
- package/dist/components/booking-quick-view-sheet.js +283 -0
- package/dist/components/bookings-page.d.ts +19 -0
- package/dist/components/bookings-page.d.ts.map +1 -0
- package/dist/components/bookings-page.js +9 -0
- package/dist/components/file-dropzone.d.ts +25 -0
- package/dist/components/file-dropzone.d.ts.map +1 -0
- package/dist/components/file-dropzone.js +102 -0
- package/dist/components/icon-action-button.d.ts +18 -0
- package/dist/components/icon-action-button.d.ts.map +1 -0
- package/dist/components/icon-action-button.js +13 -0
- package/dist/components/option-units-stepper-section.d.ts +111 -0
- package/dist/components/option-units-stepper-section.d.ts.map +1 -0
- package/dist/components/option-units-stepper-section.js +276 -0
- package/dist/components/payment-schedule-section.d.ts +91 -0
- package/dist/components/payment-schedule-section.d.ts.map +1 -0
- package/dist/components/payment-schedule-section.js +206 -0
- package/dist/components/person-picker-section.d.ts +71 -0
- package/dist/components/person-picker-section.d.ts.map +1 -0
- package/dist/components/person-picker-section.js +160 -0
- package/dist/components/price-breakdown-section.d.ts +83 -0
- package/dist/components/price-breakdown-section.d.ts.map +1 -0
- package/dist/components/price-breakdown-section.js +278 -0
- package/dist/components/product-picker-section.d.ts +29 -0
- package/dist/components/product-picker-section.d.ts.map +1 -0
- package/dist/components/product-picker-section.js +74 -0
- package/dist/components/shared-room-section.d.ts +40 -0
- package/dist/components/shared-room-section.d.ts.map +1 -0
- package/dist/components/shared-room-section.js +99 -0
- package/dist/components/status-badge.d.ts +24 -0
- package/dist/components/status-badge.d.ts.map +1 -0
- package/dist/components/status-badge.js +65 -0
- package/dist/components/status-change-dialog.d.ts +10 -0
- package/dist/components/status-change-dialog.d.ts.map +1 -0
- package/dist/components/status-change-dialog.js +57 -0
- package/dist/components/supplier-status-dialog.d.ts +10 -0
- package/dist/components/supplier-status-dialog.d.ts.map +1 -0
- package/dist/components/supplier-status-dialog.js +98 -0
- package/dist/components/supplier-status-list.d.ts +5 -0
- package/dist/components/supplier-status-list.d.ts.map +1 -0
- package/dist/components/supplier-status-list.js +115 -0
- package/dist/components/traveler-category-buttons.d.ts +26 -0
- package/dist/components/traveler-category-buttons.d.ts.map +1 -0
- package/dist/components/traveler-category-buttons.js +35 -0
- package/dist/components/traveler-dialog.d.ts +10 -0
- package/dist/components/traveler-dialog.d.ts.map +1 -0
- package/dist/components/traveler-dialog.js +256 -0
- package/dist/components/traveler-list.d.ts +6 -0
- package/dist/components/traveler-list.d.ts.map +1 -0
- package/dist/components/traveler-list.js +295 -0
- package/dist/components/travelers-section-controls.d.ts +52 -0
- package/dist/components/travelers-section-controls.d.ts.map +1 -0
- package/dist/components/travelers-section-controls.js +206 -0
- package/dist/components/travelers-section.d.ts +159 -0
- package/dist/components/travelers-section.d.ts.map +1 -0
- package/dist/components/travelers-section.js +355 -0
- package/dist/components/voucher-picker-section.d.ts +50 -0
- package/dist/components/voucher-picker-section.d.ts.map +1 -0
- package/dist/components/voucher-picker-section.js +79 -0
- package/dist/extras/client.d.ts +14 -0
- package/dist/extras/client.d.ts.map +1 -0
- package/dist/extras/client.js +58 -0
- package/dist/extras/components/extra-catalog-card.d.ts +13 -0
- package/dist/extras/components/extra-catalog-card.d.ts.map +1 -0
- package/dist/extras/components/extra-catalog-card.js +52 -0
- package/dist/extras/components/product-combobox.d.ts +9 -0
- package/dist/extras/components/product-combobox.d.ts.map +1 -0
- package/dist/extras/components/product-combobox.js +46 -0
- package/dist/extras/components/slot-extras-manifest-panel.d.ts +6 -0
- package/dist/extras/components/slot-extras-manifest-panel.d.ts.map +1 -0
- package/dist/extras/components/slot-extras-manifest-panel.js +108 -0
- package/dist/extras/hooks/index.d.ts +5 -0
- package/dist/extras/hooks/index.d.ts.map +1 -0
- package/dist/extras/hooks/index.js +4 -0
- package/dist/extras/hooks/use-product-extra.d.ts +24 -0
- package/dist/extras/hooks/use-product-extra.d.ts.map +1 -0
- package/dist/extras/hooks/use-product-extra.js +12 -0
- package/dist/extras/hooks/use-product-extras.d.ts +30 -0
- package/dist/extras/hooks/use-product-extras.d.ts.map +1 -0
- package/dist/extras/hooks/use-product-extras.js +12 -0
- package/dist/extras/hooks/use-slot-extra-manifest-mutation.d.ts +48 -0
- package/dist/extras/hooks/use-slot-extra-manifest-mutation.d.ts.map +1 -0
- package/dist/extras/hooks/use-slot-extra-manifest-mutation.js +26 -0
- package/dist/extras/hooks/use-slot-extra-manifest.d.ts +68 -0
- package/dist/extras/hooks/use-slot-extra-manifest.d.ts.map +1 -0
- package/dist/extras/hooks/use-slot-extra-manifest.js +11 -0
- package/dist/extras/i18n/en.d.ts +52 -0
- package/dist/extras/i18n/en.d.ts.map +1 -0
- package/dist/extras/i18n/en.js +51 -0
- package/dist/extras/i18n/index.d.ts +5 -0
- package/dist/extras/i18n/index.d.ts.map +1 -0
- package/dist/extras/i18n/index.js +3 -0
- package/dist/extras/i18n/messages.d.ts +37 -0
- package/dist/extras/i18n/messages.d.ts.map +1 -0
- package/dist/extras/i18n/messages.js +1 -0
- package/dist/extras/i18n/provider.d.ts +126 -0
- package/dist/extras/i18n/provider.d.ts.map +1 -0
- package/dist/extras/i18n/provider.js +44 -0
- package/dist/extras/i18n/ro.d.ts +52 -0
- package/dist/extras/i18n/ro.d.ts.map +1 -0
- package/dist/extras/i18n/ro.js +51 -0
- package/dist/extras/index.d.ts +7 -0
- package/dist/extras/index.d.ts.map +1 -0
- package/dist/extras/index.js +6 -0
- package/dist/extras/provider.d.ts +2 -0
- package/dist/extras/provider.d.ts.map +1 -0
- package/dist/extras/provider.js +1 -0
- package/dist/extras/query-keys.d.ts +16 -0
- package/dist/extras/query-keys.d.ts.map +1 -0
- package/dist/extras/query-keys.js +8 -0
- package/dist/extras/query-options.d.ts +455 -0
- package/dist/extras/query-options.d.ts.map +1 -0
- package/dist/extras/query-options.js +44 -0
- package/dist/extras/schemas.d.ts +416 -0
- package/dist/extras/schemas.d.ts.map +1 -0
- package/dist/extras/schemas.js +89 -0
- package/dist/extras/ui.d.ts +4 -0
- package/dist/extras/ui.d.ts.map +1 -0
- package/dist/extras/ui.js +3 -0
- package/dist/extras.d.ts +10 -0
- package/dist/extras.d.ts.map +1 -0
- package/dist/extras.js +9 -0
- package/dist/hooks/index.d.ts +36 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +35 -0
- package/dist/hooks/use-booking-action-ledger.d.ts +63 -0
- package/dist/hooks/use-booking-action-ledger.d.ts.map +1 -0
- package/dist/hooks/use-booking-action-ledger.js +34 -0
- package/dist/hooks/use-booking-activity.d.ts +17 -0
- package/dist/hooks/use-booking-activity.d.ts.map +1 -0
- package/dist/hooks/use-booking-activity.js +12 -0
- package/dist/hooks/use-booking-cancel-mutation.d.ts +69 -0
- package/dist/hooks/use-booking-cancel-mutation.d.ts.map +1 -0
- package/dist/hooks/use-booking-cancel-mutation.js +24 -0
- package/dist/hooks/use-booking-contract-generation.d.ts +31 -0
- package/dist/hooks/use-booking-contract-generation.d.ts.map +1 -0
- package/dist/hooks/use-booking-contract-generation.js +36 -0
- package/dist/hooks/use-booking-convert-mutation.d.ts +81 -0
- package/dist/hooks/use-booking-convert-mutation.d.ts.map +1 -0
- package/dist/hooks/use-booking-convert-mutation.js +24 -0
- package/dist/hooks/use-booking-create-mutation.d.ts +337 -0
- package/dist/hooks/use-booking-create-mutation.d.ts.map +1 -0
- package/dist/hooks/use-booking-create-mutation.js +43 -0
- package/dist/hooks/use-booking-documents.d.ts +41 -0
- package/dist/hooks/use-booking-documents.d.ts.map +1 -0
- package/dist/hooks/use-booking-documents.js +46 -0
- package/dist/hooks/use-booking-dual-create-mutation.d.ts +338 -0
- package/dist/hooks/use-booking-dual-create-mutation.d.ts.map +1 -0
- package/dist/hooks/use-booking-dual-create-mutation.js +45 -0
- package/dist/hooks/use-booking-group-for-booking.d.ts +24 -0
- package/dist/hooks/use-booking-group-for-booking.d.ts.map +1 -0
- package/dist/hooks/use-booking-group-for-booking.js +12 -0
- package/dist/hooks/use-booking-group-member-mutation.d.ts +27 -0
- package/dist/hooks/use-booking-group-member-mutation.d.ts.map +1 -0
- package/dist/hooks/use-booking-group-member-mutation.js +38 -0
- package/dist/hooks/use-booking-group-mutation.d.ts +40 -0
- package/dist/hooks/use-booking-group-mutation.d.ts.map +1 -0
- package/dist/hooks/use-booking-group-mutation.js +32 -0
- package/dist/hooks/use-booking-group.d.ts +85 -0
- package/dist/hooks/use-booking-group.d.ts.map +1 -0
- package/dist/hooks/use-booking-group.js +12 -0
- package/dist/hooks/use-booking-groups.d.ts +21 -0
- package/dist/hooks/use-booking-groups.d.ts.map +1 -0
- package/dist/hooks/use-booking-groups.js +12 -0
- package/dist/hooks/use-booking-item-mutation.d.ts +101 -0
- package/dist/hooks/use-booking-item-mutation.d.ts.map +1 -0
- package/dist/hooks/use-booking-item-mutation.js +42 -0
- package/dist/hooks/use-booking-item-travelers.d.ts +32 -0
- package/dist/hooks/use-booking-item-travelers.d.ts.map +1 -0
- package/dist/hooks/use-booking-item-travelers.js +48 -0
- package/dist/hooks/use-booking-items.d.ts +36 -0
- package/dist/hooks/use-booking-items.d.ts.map +1 -0
- package/dist/hooks/use-booking-items.js +12 -0
- package/dist/hooks/use-booking-mutation.d.ts +158 -0
- package/dist/hooks/use-booking-mutation.d.ts.map +1 -0
- package/dist/hooks/use-booking-mutation.js +39 -0
- package/dist/hooks/use-booking-note-mutation.d.ts +39 -0
- package/dist/hooks/use-booking-note-mutation.d.ts.map +1 -0
- package/dist/hooks/use-booking-note-mutation.js +44 -0
- package/dist/hooks/use-booking-notes.d.ts +15 -0
- package/dist/hooks/use-booking-notes.d.ts.map +1 -0
- package/dist/hooks/use-booking-notes.js +12 -0
- package/dist/hooks/use-booking-primary-product.d.ts +28 -0
- package/dist/hooks/use-booking-primary-product.d.ts.map +1 -0
- package/dist/hooks/use-booking-primary-product.js +20 -0
- package/dist/hooks/use-booking-status-mutation.d.ts +156 -0
- package/dist/hooks/use-booking-status-mutation.d.ts.map +1 -0
- package/dist/hooks/use-booking-status-mutation.js +54 -0
- package/dist/hooks/use-booking-tax-preview.d.ts +29 -0
- package/dist/hooks/use-booking-tax-preview.d.ts.map +1 -0
- package/dist/hooks/use-booking-tax-preview.js +21 -0
- package/dist/hooks/use-booking.d.ts +67 -0
- package/dist/hooks/use-booking.d.ts.map +1 -0
- package/dist/hooks/use-booking.js +12 -0
- package/dist/hooks/use-bookings.d.ts +71 -0
- package/dist/hooks/use-bookings.d.ts.map +1 -0
- package/dist/hooks/use-bookings.js +12 -0
- package/dist/hooks/use-pricing-preview.d.ts +61 -0
- package/dist/hooks/use-pricing-preview.d.ts.map +1 -0
- package/dist/hooks/use-pricing-preview.js +18 -0
- package/dist/hooks/use-public-booking-session-flow-mutation.d.ts +148 -0
- package/dist/hooks/use-public-booking-session-flow-mutation.d.ts.map +1 -0
- package/dist/hooks/use-public-booking-session-flow-mutation.js +35 -0
- package/dist/hooks/use-public-booking-session-state.d.ts +16 -0
- package/dist/hooks/use-public-booking-session-state.d.ts.map +1 -0
- package/dist/hooks/use-public-booking-session-state.js +12 -0
- package/dist/hooks/use-public-booking-session.d.ts +101 -0
- package/dist/hooks/use-public-booking-session.d.ts.map +1 -0
- package/dist/hooks/use-public-booking-session.js +12 -0
- package/dist/hooks/use-reveal-traveler.d.ts +54 -0
- package/dist/hooks/use-reveal-traveler.d.ts.map +1 -0
- package/dist/hooks/use-reveal-traveler.js +18 -0
- package/dist/hooks/use-sharing-groups.d.ts +41 -0
- package/dist/hooks/use-sharing-groups.d.ts.map +1 -0
- package/dist/hooks/use-sharing-groups.js +20 -0
- package/dist/hooks/use-supplier-status-mutation.d.ts +46 -0
- package/dist/hooks/use-supplier-status-mutation.d.ts.map +1 -0
- package/dist/hooks/use-supplier-status-mutation.js +39 -0
- package/dist/hooks/use-supplier-statuses.d.ts +20 -0
- package/dist/hooks/use-supplier-statuses.d.ts.map +1 -0
- package/dist/hooks/use-supplier-statuses.js +12 -0
- package/dist/hooks/use-traveler-mutation.d.ts +55 -0
- package/dist/hooks/use-traveler-mutation.d.ts.map +1 -0
- package/dist/hooks/use-traveler-mutation.js +42 -0
- package/dist/hooks/use-traveler-with-travel-details-mutation.d.ts +120 -0
- package/dist/hooks/use-traveler-with-travel-details-mutation.d.ts.map +1 -0
- package/dist/hooks/use-traveler-with-travel-details-mutation.js +43 -0
- package/dist/hooks/use-travelers.d.ts +23 -0
- package/dist/hooks/use-travelers.d.ts.map +1 -0
- package/dist/hooks/use-travelers.js +12 -0
- package/dist/i18n/en-base.d.ts +295 -0
- package/dist/i18n/en-base.d.ts.map +1 -0
- package/dist/i18n/en-base.js +294 -0
- package/dist/i18n/en-create-list.d.ts +327 -0
- package/dist/i18n/en-create-list.d.ts.map +1 -0
- package/dist/i18n/en-create-list.js +326 -0
- package/dist/i18n/en-journey.d.ts +229 -0
- package/dist/i18n/en-journey.d.ts.map +1 -0
- package/dist/i18n/en-journey.js +228 -0
- package/dist/i18n/en-operations.d.ts +382 -0
- package/dist/i18n/en-operations.d.ts.map +1 -0
- package/dist/i18n/en-operations.js +381 -0
- package/dist/i18n/en-sections.d.ts +360 -0
- package/dist/i18n/en-sections.d.ts.map +1 -0
- package/dist/i18n/en-sections.js +359 -0
- package/dist/i18n/en.d.ts +1581 -0
- package/dist/i18n/en.d.ts.map +1 -0
- package/dist/i18n/en.js +12 -0
- package/dist/i18n/index.d.ts +5 -0
- package/dist/i18n/index.d.ts.map +1 -0
- package/dist/i18n/index.js +3 -0
- package/dist/i18n/messages-base.d.ts +251 -0
- package/dist/i18n/messages-base.d.ts.map +1 -0
- package/dist/i18n/messages-base.js +1 -0
- package/dist/i18n/messages-create-list.d.ts +310 -0
- package/dist/i18n/messages-create-list.d.ts.map +1 -0
- package/dist/i18n/messages-create-list.js +1 -0
- package/dist/i18n/messages-journey.d.ts +198 -0
- package/dist/i18n/messages-journey.d.ts.map +1 -0
- package/dist/i18n/messages-journey.js +1 -0
- package/dist/i18n/messages-operations.d.ts +362 -0
- package/dist/i18n/messages-operations.d.ts.map +1 -0
- package/dist/i18n/messages-operations.js +1 -0
- package/dist/i18n/messages-sections.d.ts +312 -0
- package/dist/i18n/messages-sections.d.ts.map +1 -0
- package/dist/i18n/messages-sections.js +1 -0
- package/dist/i18n/messages.d.ts +7 -0
- package/dist/i18n/messages.d.ts.map +1 -0
- package/dist/i18n/messages.js +1 -0
- package/dist/i18n/provider.d.ts +3185 -0
- package/dist/i18n/provider.d.ts.map +1 -0
- package/dist/i18n/provider.js +45 -0
- package/dist/i18n/ro-base.d.ts +295 -0
- package/dist/i18n/ro-base.d.ts.map +1 -0
- package/dist/i18n/ro-base.js +294 -0
- package/dist/i18n/ro-create-list.d.ts +327 -0
- package/dist/i18n/ro-create-list.d.ts.map +1 -0
- package/dist/i18n/ro-create-list.js +326 -0
- package/dist/i18n/ro-journey.d.ts +229 -0
- package/dist/i18n/ro-journey.d.ts.map +1 -0
- package/dist/i18n/ro-journey.js +228 -0
- package/dist/i18n/ro-operations.d.ts +382 -0
- package/dist/i18n/ro-operations.d.ts.map +1 -0
- package/dist/i18n/ro-operations.js +381 -0
- package/dist/i18n/ro-sections.d.ts +360 -0
- package/dist/i18n/ro-sections.d.ts.map +1 -0
- package/dist/i18n/ro-sections.js +359 -0
- package/dist/i18n/ro.d.ts +1581 -0
- package/dist/i18n/ro.d.ts.map +1 -0
- package/dist/i18n/ro.js +12 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +8 -0
- package/dist/journey/components/booking-journey-rules.d.ts +48 -0
- package/dist/journey/components/booking-journey-rules.d.ts.map +1 -0
- package/dist/journey/components/booking-journey-rules.js +235 -0
- package/dist/journey/components/booking-journey.d.ts +3 -0
- package/dist/journey/components/booking-journey.d.ts.map +1 -0
- package/dist/journey/components/booking-journey.js +368 -0
- package/dist/journey/components/configure-step-skeleton.d.ts +8 -0
- package/dist/journey/components/configure-step-skeleton.d.ts.map +1 -0
- package/dist/journey/components/configure-step-skeleton.js +11 -0
- package/dist/journey/components/contract-preview-dialog.d.ts +47 -0
- package/dist/journey/components/contract-preview-dialog.d.ts.map +1 -0
- package/dist/journey/components/contract-preview-dialog.js +124 -0
- package/dist/journey/components/journey-steps/accommodation-step.d.ts +3 -0
- package/dist/journey/components/journey-steps/accommodation-step.d.ts.map +1 -0
- package/dist/journey/components/journey-steps/accommodation-step.js +71 -0
- package/dist/journey/components/journey-steps/addons-step.d.ts +3 -0
- package/dist/journey/components/journey-steps/addons-step.d.ts.map +1 -0
- package/dist/journey/components/journey-steps/addons-step.js +40 -0
- package/dist/journey/components/journey-steps/billing-step.d.ts +8 -0
- package/dist/journey/components/journey-steps/billing-step.d.ts.map +1 -0
- package/dist/journey/components/journey-steps/billing-step.js +78 -0
- package/dist/journey/components/journey-steps/configure-steps.d.ts +28 -0
- package/dist/journey/components/journey-steps/configure-steps.d.ts.map +1 -0
- package/dist/journey/components/journey-steps/configure-steps.js +232 -0
- package/dist/journey/components/journey-steps/documents-step.d.ts +11 -0
- package/dist/journey/components/journey-steps/documents-step.d.ts.map +1 -0
- package/dist/journey/components/journey-steps/documents-step.js +36 -0
- package/dist/journey/components/journey-steps/payment-step.d.ts +29 -0
- package/dist/journey/components/journey-steps/payment-step.d.ts.map +1 -0
- package/dist/journey/components/journey-steps/payment-step.js +225 -0
- package/dist/journey/components/journey-steps/review-step.d.ts +27 -0
- package/dist/journey/components/journey-steps/review-step.d.ts.map +1 -0
- package/dist/journey/components/journey-steps/review-step.js +18 -0
- package/dist/journey/components/journey-steps/shared.d.ts +75 -0
- package/dist/journey/components/journey-steps/shared.d.ts.map +1 -0
- package/dist/journey/components/journey-steps/shared.js +108 -0
- package/dist/journey/components/journey-steps/travelers-step.d.ts +7 -0
- package/dist/journey/components/journey-steps/travelers-step.d.ts.map +1 -0
- package/dist/journey/components/journey-steps/travelers-step.js +201 -0
- package/dist/journey/components/journey-steps.d.ts +21 -0
- package/dist/journey/components/journey-steps.d.ts.map +1 -0
- package/dist/journey/components/journey-steps.js +20 -0
- package/dist/journey/components/side-panel.d.ts +17 -0
- package/dist/journey/components/side-panel.d.ts.map +1 -0
- package/dist/journey/components/side-panel.js +245 -0
- package/dist/journey/components/stacked-journey.d.ts +30 -0
- package/dist/journey/components/stacked-journey.d.ts.map +1 -0
- package/dist/journey/components/stacked-journey.js +50 -0
- package/dist/journey/components/step-header.d.ts +7 -0
- package/dist/journey/components/step-header.d.ts.map +1 -0
- package/dist/journey/components/step-header.js +12 -0
- package/dist/journey/index.d.ts +18 -0
- package/dist/journey/index.d.ts.map +1 -0
- package/dist/journey/index.js +17 -0
- package/dist/journey/lib/draft-state.d.ts +35 -0
- package/dist/journey/lib/draft-state.d.ts.map +1 -0
- package/dist/journey/lib/draft-state.js +57 -0
- package/dist/journey/lib/pax-band-dependencies.d.ts +27 -0
- package/dist/journey/lib/pax-band-dependencies.d.ts.map +1 -0
- package/dist/journey/lib/pax-band-dependencies.js +50 -0
- package/dist/journey/lib/payment-schedule.d.ts +19 -0
- package/dist/journey/lib/payment-schedule.d.ts.map +1 -0
- package/dist/journey/lib/payment-schedule.js +90 -0
- package/dist/journey/types.d.ts +403 -0
- package/dist/journey/types.d.ts.map +1 -0
- package/dist/journey/types.js +19 -0
- package/dist/provider.d.ts +2 -0
- package/dist/provider.d.ts.map +1 -0
- package/dist/provider.js +1 -0
- package/dist/query-keys.d.ts +74 -0
- package/dist/query-keys.d.ts.map +1 -0
- package/dist/query-keys.js +26 -0
- package/dist/query-options.d.ts +2534 -0
- package/dist/query-options.d.ts.map +1 -0
- package/dist/query-options.js +233 -0
- package/dist/requirements/client.d.ts +14 -0
- package/dist/requirements/client.d.ts.map +1 -0
- package/dist/requirements/client.js +59 -0
- package/dist/requirements/components/booking-requirements-contact-tab.d.ts +8 -0
- package/dist/requirements/components/booking-requirements-contact-tab.d.ts.map +1 -0
- package/dist/requirements/components/booking-requirements-contact-tab.js +8 -0
- package/dist/requirements/components/booking-requirements-questions-tab.d.ts +14 -0
- package/dist/requirements/components/booking-requirements-questions-tab.d.ts.map +1 -0
- package/dist/requirements/components/booking-requirements-questions-tab.js +17 -0
- package/dist/requirements/constants.d.ts +114 -0
- package/dist/requirements/constants.d.ts.map +1 -0
- package/dist/requirements/constants.js +45 -0
- package/dist/requirements/hooks/index.d.ts +6 -0
- package/dist/requirements/hooks/index.d.ts.map +1 -0
- package/dist/requirements/hooks/index.js +6 -0
- package/dist/requirements/hooks/use-booking-questions.d.ts +24 -0
- package/dist/requirements/hooks/use-booking-questions.d.ts.map +1 -0
- package/dist/requirements/hooks/use-booking-questions.js +9 -0
- package/dist/requirements/hooks/use-contact-requirements.d.ts +22 -0
- package/dist/requirements/hooks/use-contact-requirements.d.ts.map +1 -0
- package/dist/requirements/hooks/use-contact-requirements.js +9 -0
- package/dist/requirements/hooks/use-products.d.ts +16 -0
- package/dist/requirements/hooks/use-products.d.ts.map +1 -0
- package/dist/requirements/hooks/use-products.js +9 -0
- package/dist/requirements/hooks/use-question-options.d.ts +19 -0
- package/dist/requirements/hooks/use-question-options.d.ts.map +1 -0
- package/dist/requirements/hooks/use-question-options.js +9 -0
- package/dist/requirements/hooks/use-transport-requirements.d.ts +30 -0
- package/dist/requirements/hooks/use-transport-requirements.d.ts.map +1 -0
- package/dist/requirements/hooks/use-transport-requirements.js +9 -0
- package/dist/requirements/i18n/en.d.ts +94 -0
- package/dist/requirements/i18n/en.d.ts.map +1 -0
- package/dist/requirements/i18n/en.js +93 -0
- package/dist/requirements/i18n/index.d.ts +5 -0
- package/dist/requirements/i18n/index.d.ts.map +1 -0
- package/dist/requirements/i18n/index.js +3 -0
- package/dist/requirements/i18n/messages.d.ts +59 -0
- package/dist/requirements/i18n/messages.d.ts.map +1 -0
- package/dist/requirements/i18n/messages.js +1 -0
- package/dist/requirements/i18n/provider.d.ts +210 -0
- package/dist/requirements/i18n/provider.d.ts.map +1 -0
- package/dist/requirements/i18n/provider.js +44 -0
- package/dist/requirements/i18n/ro.d.ts +94 -0
- package/dist/requirements/i18n/ro.d.ts.map +1 -0
- package/dist/requirements/i18n/ro.js +93 -0
- package/dist/requirements/index.d.ts +9 -0
- package/dist/requirements/index.d.ts.map +1 -0
- package/dist/requirements/index.js +8 -0
- package/dist/requirements/provider.d.ts +2 -0
- package/dist/requirements/provider.d.ts.map +1 -0
- package/dist/requirements/provider.js +1 -0
- package/dist/requirements/query-keys.d.ts +33 -0
- package/dist/requirements/query-keys.d.ts.map +1 -0
- package/dist/requirements/query-keys.js +13 -0
- package/dist/requirements/query-options.d.ts +371 -0
- package/dist/requirements/query-options.d.ts.map +1 -0
- package/dist/requirements/query-options.js +80 -0
- package/dist/requirements/schemas.d.ts +320 -0
- package/dist/requirements/schemas.d.ts.map +1 -0
- package/dist/requirements/schemas.js +121 -0
- package/dist/requirements/ui.d.ts +4 -0
- package/dist/requirements/ui.d.ts.map +1 -0
- package/dist/requirements/ui.js +3 -0
- package/dist/requirements/utils.d.ts +2 -0
- package/dist/requirements/utils.d.ts.map +1 -0
- package/dist/requirements/utils.js +4 -0
- package/dist/schemas.d.ts +2070 -0
- package/dist/schemas.d.ts.map +1 -0
- package/dist/schemas.js +507 -0
- package/dist/status-presentation.d.ts +34 -0
- package/dist/status-presentation.d.ts.map +1 -0
- package/dist/status-presentation.js +38 -0
- package/dist/ui.d.ts +43 -0
- package/dist/ui.d.ts.map +1 -0
- package/dist/ui.js +42 -0
- package/package.json +256 -0
- package/src/requirements/styles.css +1 -0
- 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"}
|