@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,40 @@
|
|
|
1
|
+
export type SharedRoomMode = "create" | "join";
|
|
2
|
+
export interface SharedRoomValue {
|
|
3
|
+
enabled: boolean;
|
|
4
|
+
mode: SharedRoomMode;
|
|
5
|
+
/** Only meaningful in "join" mode. */
|
|
6
|
+
groupId: string;
|
|
7
|
+
/** Optional label used when creating a new shared-room group. */
|
|
8
|
+
groupLabel?: string;
|
|
9
|
+
}
|
|
10
|
+
export declare const emptySharedRoomValue: SharedRoomValue;
|
|
11
|
+
export declare function clearSharedRoomValue(): SharedRoomValue;
|
|
12
|
+
export interface SharedRoomSectionProps {
|
|
13
|
+
value: SharedRoomValue;
|
|
14
|
+
onChange: (value: SharedRoomValue) => void;
|
|
15
|
+
/**
|
|
16
|
+
* The product context for fetching joinable groups. When unset, the join
|
|
17
|
+
* combobox is disabled even if the user toggles into join mode.
|
|
18
|
+
*/
|
|
19
|
+
productId?: string;
|
|
20
|
+
enabled?: boolean;
|
|
21
|
+
labels?: {
|
|
22
|
+
toggle?: string;
|
|
23
|
+
createMode?: string;
|
|
24
|
+
joinMode?: string;
|
|
25
|
+
selectPlaceholder?: string;
|
|
26
|
+
noGroups?: string;
|
|
27
|
+
createHint?: string;
|
|
28
|
+
createSheetTitle?: string;
|
|
29
|
+
groupLabel?: string;
|
|
30
|
+
groupLabelPlaceholder?: string;
|
|
31
|
+
createAction?: string;
|
|
32
|
+
remove?: string;
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Shared-room (partaj) attachment section. Operators can create a new group in
|
|
37
|
+
* a sheet or join an existing product-scoped group with an async combobox.
|
|
38
|
+
*/
|
|
39
|
+
export declare function SharedRoomSection({ value, onChange, productId, enabled, labels, }: SharedRoomSectionProps): import("react/jsx-runtime").JSX.Element;
|
|
40
|
+
//# sourceMappingURL=shared-room-section.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shared-room-section.d.ts","sourceRoot":"","sources":["../../src/components/shared-room-section.tsx"],"names":[],"mappings":"AA2BA,MAAM,MAAM,cAAc,GAAG,QAAQ,GAAG,MAAM,CAAA;AAE9C,MAAM,WAAW,eAAe;IAC9B,OAAO,EAAE,OAAO,CAAA;IAChB,IAAI,EAAE,cAAc,CAAA;IACpB,sCAAsC;IACtC,OAAO,EAAE,MAAM,CAAA;IACf,iEAAiE;IACjE,UAAU,CAAC,EAAE,MAAM,CAAA;CACpB;AAED,eAAO,MAAM,oBAAoB,EAAE,eAKlC,CAAA;AAED,wBAAgB,oBAAoB,IAAI,eAAe,CAEtD;AAED,MAAM,WAAW,sBAAsB;IACrC,KAAK,EAAE,eAAe,CAAA;IACtB,QAAQ,EAAE,CAAC,KAAK,EAAE,eAAe,KAAK,IAAI,CAAA;IAC1C;;;OAGG;IACH,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,MAAM,CAAC,EAAE;QACP,MAAM,CAAC,EAAE,MAAM,CAAA;QACf,UAAU,CAAC,EAAE,MAAM,CAAA;QACnB,QAAQ,CAAC,EAAE,MAAM,CAAA;QACjB,iBAAiB,CAAC,EAAE,MAAM,CAAA;QAC1B,QAAQ,CAAC,EAAE,MAAM,CAAA;QACjB,UAAU,CAAC,EAAE,MAAM,CAAA;QACnB,gBAAgB,CAAC,EAAE,MAAM,CAAA;QACzB,UAAU,CAAC,EAAE,MAAM,CAAA;QACnB,qBAAqB,CAAC,EAAE,MAAM,CAAA;QAC9B,YAAY,CAAC,EAAE,MAAM,CAAA;QACrB,MAAM,CAAC,EAAE,MAAM,CAAA;KAChB,CAAA;CACF;AAED;;;GAGG;AACH,wBAAgB,iBAAiB,CAAC,EAChC,KAAK,EACL,QAAQ,EACR,SAAS,EACT,OAAc,EACd,MAAM,GACP,EAAE,sBAAsB,2CAyKxB"}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
3
|
+
import { Button, Input, Label, Sheet, SheetBody, SheetContent, SheetFooter, SheetHeader, SheetTitle, } from "@voyant-travel/ui/components";
|
|
4
|
+
import { Combobox, ComboboxCollection, ComboboxContent, ComboboxEmpty, ComboboxInput, ComboboxItem, ComboboxList, } from "@voyant-travel/ui/components/combobox";
|
|
5
|
+
import { Link2, Plus, X } from "lucide-react";
|
|
6
|
+
import * as React from "react";
|
|
7
|
+
import { useBookingsUiMessagesOrDefault } from "../i18n/provider.js";
|
|
8
|
+
import { useBookingGroups } from "../index.js";
|
|
9
|
+
export const emptySharedRoomValue = {
|
|
10
|
+
enabled: false,
|
|
11
|
+
mode: "create",
|
|
12
|
+
groupId: "",
|
|
13
|
+
groupLabel: "",
|
|
14
|
+
};
|
|
15
|
+
export function clearSharedRoomValue() {
|
|
16
|
+
return { ...emptySharedRoomValue };
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Shared-room (partaj) attachment section. Operators can create a new group in
|
|
20
|
+
* a sheet or join an existing product-scoped group with an async combobox.
|
|
21
|
+
*/
|
|
22
|
+
export function SharedRoomSection({ value, onChange, productId, enabled = true, labels, }) {
|
|
23
|
+
const [groupSearch, setGroupSearch] = React.useState("");
|
|
24
|
+
const [groupInputValue, setGroupInputValue] = React.useState("");
|
|
25
|
+
const [createSheetOpen, setCreateSheetOpen] = React.useState(false);
|
|
26
|
+
const [draftGroupLabel, setDraftGroupLabel] = React.useState(value.groupLabel ?? "");
|
|
27
|
+
const messages = useBookingsUiMessagesOrDefault();
|
|
28
|
+
const merged = { ...messages.sharedRoomSection.labels, ...labels };
|
|
29
|
+
const { data: groupsData } = useBookingGroups({
|
|
30
|
+
kind: "shared_room",
|
|
31
|
+
productId: productId || undefined,
|
|
32
|
+
limit: 50,
|
|
33
|
+
enabled: enabled && value.enabled && value.mode === "join" && Boolean(productId),
|
|
34
|
+
});
|
|
35
|
+
const existingGroups = React.useMemo(() => {
|
|
36
|
+
const normalizedSearch = groupSearch.trim().toLowerCase();
|
|
37
|
+
const groups = groupsData?.data ?? [];
|
|
38
|
+
if (!normalizedSearch)
|
|
39
|
+
return groups;
|
|
40
|
+
return groups.filter((group) => group.label.toLowerCase().includes(normalizedSearch));
|
|
41
|
+
}, [groupsData?.data, groupSearch]);
|
|
42
|
+
const groupsMap = React.useMemo(() => new Map((groupsData?.data ?? []).map((group) => [group.id, group])), [groupsData?.data]);
|
|
43
|
+
const selectedGroupLabel = value.groupId ? (groupsMap.get(value.groupId)?.label ?? "") : "";
|
|
44
|
+
React.useEffect(() => {
|
|
45
|
+
if (selectedGroupLabel)
|
|
46
|
+
setGroupInputValue(selectedGroupLabel);
|
|
47
|
+
}, [selectedGroupLabel]);
|
|
48
|
+
React.useEffect(() => {
|
|
49
|
+
if (createSheetOpen)
|
|
50
|
+
setDraftGroupLabel(value.groupLabel ?? "");
|
|
51
|
+
}, [createSheetOpen, value.groupLabel]);
|
|
52
|
+
const set = (patch) => onChange({ ...value, ...patch });
|
|
53
|
+
const clear = () => {
|
|
54
|
+
if (!enabled)
|
|
55
|
+
return;
|
|
56
|
+
setCreateSheetOpen(false);
|
|
57
|
+
setDraftGroupLabel("");
|
|
58
|
+
setGroupInputValue("");
|
|
59
|
+
setGroupSearch("");
|
|
60
|
+
onChange(clearSharedRoomValue());
|
|
61
|
+
};
|
|
62
|
+
const selectCreateMode = () => {
|
|
63
|
+
if (!enabled)
|
|
64
|
+
return;
|
|
65
|
+
setCreateSheetOpen(true);
|
|
66
|
+
};
|
|
67
|
+
const selectJoinMode = () => {
|
|
68
|
+
if (!enabled)
|
|
69
|
+
return;
|
|
70
|
+
set({ enabled: true, mode: "join", groupLabel: "" });
|
|
71
|
+
};
|
|
72
|
+
const saveCreateLabel = () => {
|
|
73
|
+
set({
|
|
74
|
+
enabled: true,
|
|
75
|
+
mode: "create",
|
|
76
|
+
groupId: "",
|
|
77
|
+
groupLabel: draftGroupLabel.trim(),
|
|
78
|
+
});
|
|
79
|
+
setCreateSheetOpen(false);
|
|
80
|
+
};
|
|
81
|
+
return (_jsxs(_Fragment, { children: [_jsxs("div", { className: "flex flex-col gap-3 rounded-md border p-3", children: [_jsxs("div", { className: "flex flex-wrap items-start justify-between gap-2", children: [_jsxs("div", { className: "flex min-w-0 flex-col gap-1", children: [_jsx(Label, { children: merged.toggle }), value.enabled && value.mode === "create" && value.groupLabel ? (_jsx("p", { className: "truncate text-xs text-muted-foreground", children: value.groupLabel })) : value.enabled && value.mode === "create" ? (_jsx("p", { className: "text-xs text-muted-foreground", children: merged.createHint })) : null] }), value.enabled ? (_jsxs(Button, { type: "button", size: "sm", variant: "ghost", onClick: clear, disabled: !enabled, children: [_jsx(X, { className: "mr-2 h-4 w-4" }), merged.remove] })) : null] }), _jsxs("div", { className: "grid gap-2 sm:grid-cols-2", children: [_jsxs(Button, { type: "button", size: "sm", variant: value.enabled && value.mode === "create" ? "default" : "outline", onClick: selectCreateMode, disabled: !enabled, children: [_jsx(Plus, { className: "mr-2 h-4 w-4" }), merged.createMode] }), _jsxs(Button, { type: "button", size: "sm", variant: value.enabled && value.mode === "join" ? "default" : "outline", onClick: selectJoinMode, disabled: !enabled || !productId, children: [_jsx(Link2, { className: "mr-2 h-4 w-4" }), merged.joinMode] })] }), value.enabled && value.mode === "join" ? (_jsxs(Combobox, { items: existingGroups.map((group) => group.id), value: value.groupId || null, inputValue: groupInputValue, autoHighlight: true, disabled: !enabled || !productId, itemToStringValue: (id) => groupsMap.get(id)?.label ?? "", onInputValueChange: (next) => {
|
|
82
|
+
setGroupInputValue(next);
|
|
83
|
+
setGroupSearch(next);
|
|
84
|
+
if (!next)
|
|
85
|
+
set({ groupId: "" });
|
|
86
|
+
}, onValueChange: (next) => {
|
|
87
|
+
const groupId = next ?? "";
|
|
88
|
+
set({ groupId });
|
|
89
|
+
setGroupInputValue(groupId ? (groupsMap.get(groupId)?.label ?? "") : "");
|
|
90
|
+
}, children: [_jsx(ComboboxInput, { placeholder: merged.selectPlaceholder, showClear: !!value.groupId }), _jsxs(ComboboxContent, { children: [_jsx(ComboboxEmpty, { children: merged.noGroups }), _jsx(ComboboxList, { children: _jsx(ComboboxCollection, { children: (id) => {
|
|
91
|
+
const group = groupsMap.get(id);
|
|
92
|
+
if (!group)
|
|
93
|
+
return null;
|
|
94
|
+
return _jsx(SharedRoomGroupItem, { group: group }, group.id);
|
|
95
|
+
} }) })] })] })) : null] }), _jsx(Sheet, { open: createSheetOpen, onOpenChange: setCreateSheetOpen, children: _jsxs(SheetContent, { side: "right", size: "default", children: [_jsx(SheetHeader, { children: _jsx(SheetTitle, { children: merged.createSheetTitle }) }), _jsx(SheetBody, { children: _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { htmlFor: "shared-room-group-label", children: merged.groupLabel }), _jsx(Input, { id: "shared-room-group-label", value: draftGroupLabel, onChange: (event) => setDraftGroupLabel(event.target.value), placeholder: merged.groupLabelPlaceholder }), _jsx("p", { className: "text-xs text-muted-foreground", children: merged.createHint })] }) }), _jsxs(SheetFooter, { children: [_jsx(Button, { type: "button", variant: "ghost", onClick: () => setCreateSheetOpen(false), children: messages.common.cancel }), _jsx(Button, { type: "button", onClick: saveCreateLabel, children: merged.createAction })] })] }) })] }));
|
|
96
|
+
}
|
|
97
|
+
function SharedRoomGroupItem({ group }) {
|
|
98
|
+
return (_jsx(ComboboxItem, { value: group.id, children: _jsx("span", { className: "truncate font-medium", children: group.label }) }));
|
|
99
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type * as React from "react";
|
|
2
|
+
/**
|
|
3
|
+
* Domain-agnostic semantic tier used to colour-code workflow statuses
|
|
4
|
+
* across the booking detail tables. Map your status string to one of
|
|
5
|
+
* these tones via `getStatusTone()` (or pass a tone explicitly).
|
|
6
|
+
*/
|
|
7
|
+
export type StatusTone = "success" | "warning" | "danger" | "neutral";
|
|
8
|
+
/**
|
|
9
|
+
* Best-effort mapping of a status string to a colour tier. Unknown
|
|
10
|
+
* values fall back to `neutral` so the badge renders with the default
|
|
11
|
+
* outline treatment — no accidental green-on-unknown surprises.
|
|
12
|
+
*/
|
|
13
|
+
export declare function getStatusTone(status: string): StatusTone;
|
|
14
|
+
/**
|
|
15
|
+
* Colour-coded status badge. Pass either a raw `status` string (mapped
|
|
16
|
+
* via `getStatusTone()`) or an explicit `tone`.
|
|
17
|
+
*/
|
|
18
|
+
export declare function StatusBadge({ status, tone, className, children, }: {
|
|
19
|
+
status?: string;
|
|
20
|
+
tone?: StatusTone;
|
|
21
|
+
className?: string;
|
|
22
|
+
children: React.ReactNode;
|
|
23
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
24
|
+
//# sourceMappingURL=status-badge.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status-badge.d.ts","sourceRoot":"","sources":["../../src/components/status-badge.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,KAAK,MAAM,OAAO,CAAA;AAEnC;;;;GAIG;AACH,MAAM,MAAM,UAAU,GAAG,SAAS,GAAG,SAAS,GAAG,QAAQ,GAAG,SAAS,CAAA;AAsCrE;;;;GAIG;AACH,wBAAgB,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,UAAU,CAMxD;AASD;;;GAGG;AACH,wBAAgB,WAAW,CAAC,EAC1B,MAAM,EACN,IAAI,EACJ,SAAS,EACT,QAAQ,GACT,EAAE;IACD,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,IAAI,CAAC,EAAE,UAAU,CAAA;IACjB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;CAC1B,2CAOA"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { Badge } from "@voyant-travel/ui/components/badge";
|
|
3
|
+
import { cn } from "@voyant-travel/ui/lib/utils";
|
|
4
|
+
const SUCCESS_STATUSES = new Set([
|
|
5
|
+
"paid",
|
|
6
|
+
"completed",
|
|
7
|
+
"confirmed",
|
|
8
|
+
"fulfilled",
|
|
9
|
+
"active",
|
|
10
|
+
"succeeded",
|
|
11
|
+
"captured",
|
|
12
|
+
"approved",
|
|
13
|
+
"settled",
|
|
14
|
+
"issued",
|
|
15
|
+
]);
|
|
16
|
+
const WARNING_STATUSES = new Set([
|
|
17
|
+
"pending",
|
|
18
|
+
"due",
|
|
19
|
+
"on_hold",
|
|
20
|
+
"in_progress",
|
|
21
|
+
"awaiting_payment",
|
|
22
|
+
"draft",
|
|
23
|
+
"partially_paid",
|
|
24
|
+
"authorized",
|
|
25
|
+
"pending_external_allocation",
|
|
26
|
+
]);
|
|
27
|
+
const DANGER_STATUSES = new Set([
|
|
28
|
+
"cancelled",
|
|
29
|
+
"failed",
|
|
30
|
+
"refunded",
|
|
31
|
+
"expired",
|
|
32
|
+
"void",
|
|
33
|
+
"overdue",
|
|
34
|
+
"rejected",
|
|
35
|
+
"declined",
|
|
36
|
+
]);
|
|
37
|
+
/**
|
|
38
|
+
* Best-effort mapping of a status string to a colour tier. Unknown
|
|
39
|
+
* values fall back to `neutral` so the badge renders with the default
|
|
40
|
+
* outline treatment — no accidental green-on-unknown surprises.
|
|
41
|
+
*/
|
|
42
|
+
export function getStatusTone(status) {
|
|
43
|
+
const key = status.toLowerCase();
|
|
44
|
+
if (SUCCESS_STATUSES.has(key))
|
|
45
|
+
return "success";
|
|
46
|
+
if (WARNING_STATUSES.has(key))
|
|
47
|
+
return "warning";
|
|
48
|
+
if (DANGER_STATUSES.has(key))
|
|
49
|
+
return "danger";
|
|
50
|
+
return "neutral";
|
|
51
|
+
}
|
|
52
|
+
const TONE_CLASS = {
|
|
53
|
+
success: "border-transparent bg-green-500/10 text-green-600 dark:text-green-400",
|
|
54
|
+
warning: "border-transparent bg-yellow-500/10 text-yellow-700 dark:text-yellow-400",
|
|
55
|
+
danger: "border-transparent bg-red-500/10 text-red-600 dark:text-red-400",
|
|
56
|
+
neutral: "",
|
|
57
|
+
};
|
|
58
|
+
/**
|
|
59
|
+
* Colour-coded status badge. Pass either a raw `status` string (mapped
|
|
60
|
+
* via `getStatusTone()`) or an explicit `tone`.
|
|
61
|
+
*/
|
|
62
|
+
export function StatusBadge({ status, tone, className, children, }) {
|
|
63
|
+
const resolved = tone ?? (status ? getStatusTone(status) : "neutral");
|
|
64
|
+
return (_jsx(Badge, { variant: "outline", className: cn(TONE_CLASS[resolved], className), children: children }));
|
|
65
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { type BookingRecord } from "../index.js";
|
|
2
|
+
export interface StatusChangeDialogProps {
|
|
3
|
+
open: boolean;
|
|
4
|
+
onOpenChange: (open: boolean) => void;
|
|
5
|
+
bookingId: string;
|
|
6
|
+
currentStatus: BookingRecord["status"];
|
|
7
|
+
onSuccess?: () => void;
|
|
8
|
+
}
|
|
9
|
+
export declare function StatusChangeDialog({ open, onOpenChange, bookingId, currentStatus, onSuccess, }: StatusChangeDialogProps): import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
//# sourceMappingURL=status-change-dialog.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status-change-dialog.d.ts","sourceRoot":"","sources":["../../src/components/status-change-dialog.tsx"],"names":[],"mappings":"AAyBA,OAAO,EACL,KAAK,aAAa,EAInB,MAAM,aAAa,CAAA;AAWpB,MAAM,WAAW,uBAAuB;IACtC,IAAI,EAAE,OAAO,CAAA;IACb,YAAY,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAA;IACrC,SAAS,EAAE,MAAM,CAAA;IACjB,aAAa,EAAE,aAAa,CAAC,QAAQ,CAAC,CAAA;IACtC,SAAS,CAAC,EAAE,MAAM,IAAI,CAAA;CACvB;AAED,wBAAgB,kBAAkB,CAAC,EACjC,IAAI,EACJ,YAAY,EACZ,SAAS,EACT,aAAa,EACb,SAAS,GACV,EAAE,uBAAuB,2CAkIzB"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { Button, Dialog, DialogBody, DialogContent, DialogFooter, DialogHeader, DialogTitle, Label, Select, SelectContent, SelectItem, SelectTrigger, SelectValue, Switch, Textarea, } from "@voyant-travel/ui/components";
|
|
4
|
+
import { zodResolver } from "@voyant-travel/ui/lib/zod-resolver";
|
|
5
|
+
import { Loader2 } from "lucide-react";
|
|
6
|
+
import { useEffect, useMemo } from "react";
|
|
7
|
+
import { useForm } from "react-hook-form";
|
|
8
|
+
import { z } from "zod/v4";
|
|
9
|
+
import { useBookingsUiMessagesOrDefault } from "../i18n/provider.js";
|
|
10
|
+
import { bookingStatusOptions, bookingStatusSchema, useBookingStatusMutation, } from "../index.js";
|
|
11
|
+
const statusChangeFormSchema = z.object({
|
|
12
|
+
status: bookingStatusSchema,
|
|
13
|
+
note: z.string().optional().nullable(),
|
|
14
|
+
suppressNotifications: z.boolean(),
|
|
15
|
+
});
|
|
16
|
+
export function StatusChangeDialog({ open, onOpenChange, bookingId, currentStatus, onSuccess, }) {
|
|
17
|
+
const mutation = useBookingStatusMutation(bookingId);
|
|
18
|
+
const messages = useBookingsUiMessagesOrDefault();
|
|
19
|
+
const statusItems = useMemo(() => bookingStatusOptions.map((s) => ({
|
|
20
|
+
value: s.value,
|
|
21
|
+
label: messages.common.bookingStatusLabels[s.value] ?? s.value,
|
|
22
|
+
})), [messages.common.bookingStatusLabels]);
|
|
23
|
+
const form = useForm({
|
|
24
|
+
resolver: zodResolver(statusChangeFormSchema),
|
|
25
|
+
defaultValues: {
|
|
26
|
+
status: "draft",
|
|
27
|
+
note: "",
|
|
28
|
+
suppressNotifications: false,
|
|
29
|
+
},
|
|
30
|
+
});
|
|
31
|
+
useEffect(() => {
|
|
32
|
+
if (open) {
|
|
33
|
+
form.reset({
|
|
34
|
+
status: currentStatus,
|
|
35
|
+
note: "",
|
|
36
|
+
suppressNotifications: false,
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
}, [currentStatus, form, open]);
|
|
40
|
+
// Suppression only takes effect on the `confirm` verb today (see
|
|
41
|
+
// status-dispatch.ts), so only show the toggle when the target is
|
|
42
|
+
// `confirmed`. Hide it otherwise to keep the dialog focused.
|
|
43
|
+
const targetStatus = form.watch("status");
|
|
44
|
+
const suppressNotifications = form.watch("suppressNotifications");
|
|
45
|
+
const showSuppressToggle = targetStatus === "confirmed";
|
|
46
|
+
const onSubmit = async (values) => {
|
|
47
|
+
await mutation.mutateAsync({
|
|
48
|
+
currentStatus,
|
|
49
|
+
status: values.status,
|
|
50
|
+
note: values.note || null,
|
|
51
|
+
suppressNotifications: values.suppressNotifications || undefined,
|
|
52
|
+
});
|
|
53
|
+
onOpenChange(false);
|
|
54
|
+
onSuccess?.();
|
|
55
|
+
};
|
|
56
|
+
return (_jsx(Dialog, { open: open, onOpenChange: onOpenChange, children: _jsxs(DialogContent, { children: [_jsx(DialogHeader, { children: _jsx(DialogTitle, { children: messages.statusChangeDialog.title }) }), _jsxs("form", { onSubmit: form.handleSubmit(onSubmit), className: "flex flex-1 flex-col overflow-hidden", children: [_jsxs(DialogBody, { className: "grid gap-4", children: [_jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.statusChangeDialog.fields.status }), _jsxs(Select, { items: statusItems, value: form.watch("status"), onValueChange: (value) => form.setValue("status", value), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsx(SelectContent, { children: bookingStatusOptions.map((status) => (_jsx(SelectItem, { value: status.value, children: messages.common.bookingStatusLabels[status.value] }, status.value))) })] })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.statusChangeDialog.fields.note }), _jsx(Textarea, { ...form.register("note"), placeholder: messages.statusChangeDialog.placeholders.note })] }), showSuppressToggle ? (_jsxs("div", { className: "flex flex-col gap-2 rounded-md border bg-muted/30 p-3", children: [_jsxs("div", { className: "flex items-center justify-between gap-3", children: [_jsx(Label, { htmlFor: "suppress-notifications", children: messages.statusChangeDialog.fields.suppressNotifications }), _jsx(Switch, { id: "suppress-notifications", checked: suppressNotifications, onCheckedChange: (checked) => form.setValue("suppressNotifications", checked === true) })] }), _jsx("p", { className: "text-muted-foreground text-xs", children: messages.statusChangeDialog.helpers.suppressNotifications })] })) : null] }), _jsxs(DialogFooter, { children: [_jsx(Button, { type: "button", variant: "ghost", size: "sm", onClick: () => onOpenChange(false), children: messages.common.cancel }), _jsxs(Button, { type: "submit", size: "sm", disabled: mutation.isPending, children: [mutation.isPending && _jsx(Loader2, { className: "mr-2 h-4 w-4 animate-spin" }), messages.statusChangeDialog.actions.updateStatus] })] })] })] }) }));
|
|
57
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { type BookingSupplierStatusRecord } from "../index.js";
|
|
2
|
+
export interface SupplierStatusDialogProps {
|
|
3
|
+
open: boolean;
|
|
4
|
+
onOpenChange: (open: boolean) => void;
|
|
5
|
+
bookingId: string;
|
|
6
|
+
supplierStatus?: BookingSupplierStatusRecord;
|
|
7
|
+
onSuccess?: () => void;
|
|
8
|
+
}
|
|
9
|
+
export declare function SupplierStatusDialog({ open, onOpenChange, bookingId, supplierStatus, onSuccess, }: SupplierStatusDialogProps): import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
//# sourceMappingURL=supplier-status-dialog.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"supplier-status-dialog.d.ts","sourceRoot":"","sources":["../../src/components/supplier-status-dialog.tsx"],"names":[],"mappings":"AA2BA,OAAO,EAAE,KAAK,2BAA2B,EAA6B,MAAM,aAAa,CAAA;AAqBzF,MAAM,WAAW,yBAAyB;IACxC,IAAI,EAAE,OAAO,CAAA;IACb,YAAY,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAA;IACrC,SAAS,EAAE,MAAM,CAAA;IACjB,cAAc,CAAC,EAAE,2BAA2B,CAAA;IAC5C,SAAS,CAAC,EAAE,MAAM,IAAI,CAAA;CACvB;AAUD,wBAAgB,oBAAoB,CAAC,EACnC,IAAI,EACJ,YAAY,EACZ,SAAS,EACT,cAAc,EACd,SAAS,GACV,EAAE,yBAAyB,2CA8K3B"}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { Button, Dialog, DialogBody, DialogContent, DialogFooter, DialogHeader, DialogTitle, Input, Label, Select, SelectContent, SelectItem, SelectTrigger, SelectValue, Textarea, } from "@voyant-travel/ui/components";
|
|
4
|
+
import { CurrencyCombobox } from "@voyant-travel/ui/components/currency-combobox";
|
|
5
|
+
import { CurrencyInput } from "@voyant-travel/ui/components/currency-input";
|
|
6
|
+
import { zodResolver } from "@voyant-travel/ui/lib/zod-resolver";
|
|
7
|
+
import { Loader2 } from "lucide-react";
|
|
8
|
+
import { useEffect, useMemo } from "react";
|
|
9
|
+
import { useForm } from "react-hook-form";
|
|
10
|
+
import { z } from "zod/v4";
|
|
11
|
+
import { useBookingsUiMessagesOrDefault } from "../i18n/provider.js";
|
|
12
|
+
import { useSupplierStatusMutation } from "../index.js";
|
|
13
|
+
function createSupplierStatusFormSchema(messages) {
|
|
14
|
+
return z.object({
|
|
15
|
+
serviceName: z.string().min(1, messages.supplierStatusDialog.validation.serviceNameRequired),
|
|
16
|
+
status: z.enum(["pending", "confirmed", "rejected", "cancelled"]),
|
|
17
|
+
supplierReference: z.string().optional().nullable(),
|
|
18
|
+
costCurrency: z
|
|
19
|
+
.string()
|
|
20
|
+
.min(3)
|
|
21
|
+
.max(3, messages.supplierStatusDialog.validation.costCurrencyInvalid),
|
|
22
|
+
costAmountCents: z.coerce.number().int().min(0),
|
|
23
|
+
notes: z.string().optional().nullable(),
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
const CONFIRMATION_STATUSES = [
|
|
27
|
+
{ value: "pending" },
|
|
28
|
+
{ value: "confirmed" },
|
|
29
|
+
{ value: "rejected" },
|
|
30
|
+
{ value: "cancelled" },
|
|
31
|
+
];
|
|
32
|
+
const DEFAULT_CURRENCY = "EUR"; // i18n-literal-ok ISO default currency
|
|
33
|
+
export function SupplierStatusDialog({ open, onOpenChange, bookingId, supplierStatus, onSuccess, }) {
|
|
34
|
+
const isEditing = Boolean(supplierStatus);
|
|
35
|
+
const { create, update } = useSupplierStatusMutation(bookingId);
|
|
36
|
+
const messages = useBookingsUiMessagesOrDefault();
|
|
37
|
+
const supplierStatusFormSchema = createSupplierStatusFormSchema(messages);
|
|
38
|
+
const statusItems = useMemo(() => CONFIRMATION_STATUSES.map((s) => ({
|
|
39
|
+
value: s.value,
|
|
40
|
+
label: messages.common.supplierStatusLabels[s.value],
|
|
41
|
+
})), [messages.common.supplierStatusLabels]);
|
|
42
|
+
const form = useForm({
|
|
43
|
+
resolver: zodResolver(supplierStatusFormSchema),
|
|
44
|
+
defaultValues: {
|
|
45
|
+
serviceName: "",
|
|
46
|
+
status: "pending",
|
|
47
|
+
supplierReference: "",
|
|
48
|
+
costCurrency: DEFAULT_CURRENCY,
|
|
49
|
+
costAmountCents: 0,
|
|
50
|
+
notes: "",
|
|
51
|
+
},
|
|
52
|
+
});
|
|
53
|
+
useEffect(() => {
|
|
54
|
+
if (open && supplierStatus) {
|
|
55
|
+
form.reset({
|
|
56
|
+
serviceName: supplierStatus.serviceName,
|
|
57
|
+
status: supplierStatus.status,
|
|
58
|
+
supplierReference: supplierStatus.supplierReference ?? "",
|
|
59
|
+
costCurrency: supplierStatus.costCurrency,
|
|
60
|
+
costAmountCents: supplierStatus.costAmountCents,
|
|
61
|
+
notes: supplierStatus.notes ?? "",
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
else if (open) {
|
|
65
|
+
form.reset();
|
|
66
|
+
}
|
|
67
|
+
}, [form, open, supplierStatus]);
|
|
68
|
+
const onSubmit = async (values) => {
|
|
69
|
+
const payload = {
|
|
70
|
+
serviceName: values.serviceName,
|
|
71
|
+
status: values.status,
|
|
72
|
+
supplierReference: values.supplierReference || null,
|
|
73
|
+
costCurrency: values.costCurrency,
|
|
74
|
+
costAmountCents: values.costAmountCents,
|
|
75
|
+
notes: values.notes || null,
|
|
76
|
+
};
|
|
77
|
+
if (isEditing) {
|
|
78
|
+
await update.mutateAsync({ id: supplierStatus.id, input: payload });
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
await create.mutateAsync(payload);
|
|
82
|
+
}
|
|
83
|
+
onOpenChange(false);
|
|
84
|
+
onSuccess?.();
|
|
85
|
+
};
|
|
86
|
+
const isSubmitting = create.isPending || update.isPending;
|
|
87
|
+
return (_jsx(Dialog, { open: open, onOpenChange: onOpenChange, children: _jsxs(DialogContent, { size: "lg", children: [_jsx(DialogHeader, { children: _jsx(DialogTitle, { children: isEditing
|
|
88
|
+
? messages.supplierStatusDialog.titles.edit
|
|
89
|
+
: messages.supplierStatusDialog.titles.create }) }), _jsxs("form", { onSubmit: form.handleSubmit(onSubmit), className: "flex flex-1 flex-col overflow-hidden", children: [_jsxs(DialogBody, { className: "grid gap-4", children: [_jsxs("div", { className: "grid grid-cols-2 gap-4", children: [_jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.supplierStatusDialog.fields.serviceName }), _jsx(Input, { ...form.register("serviceName"), placeholder: messages.supplierStatusDialog.placeholders.serviceName, disabled: isEditing }), form.formState.errors.serviceName && (_jsx("p", { className: "text-xs text-destructive", children: form.formState.errors.serviceName.message }))] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.supplierStatusDialog.fields.status }), _jsxs(Select, { items: statusItems, value: form.watch("status"), onValueChange: (value) => form.setValue("status", value), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsx(SelectContent, { children: CONFIRMATION_STATUSES.map((status) => (_jsx(SelectItem, { value: status.value, children: messages.common.supplierStatusLabels[status.value] }, status.value))) })] })] })] }), _jsxs("div", { className: "grid grid-cols-3 gap-4", children: [_jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.supplierStatusDialog.fields.costCurrency }), _jsx(CurrencyCombobox, { value: form.watch("costCurrency") || null, onChange: (next) => form.setValue("costCurrency", next ?? DEFAULT_CURRENCY, {
|
|
90
|
+
shouldValidate: true,
|
|
91
|
+
shouldDirty: true,
|
|
92
|
+
}) })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.supplierStatusDialog.fields.costAmountCents }), _jsx(CurrencyInput, { value: form.watch("costAmountCents"), onChange: (next) => form.setValue("costAmountCents", next ?? 0, {
|
|
93
|
+
shouldDirty: true,
|
|
94
|
+
shouldValidate: true,
|
|
95
|
+
}), currency: form.watch("costCurrency") })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.supplierStatusDialog.fields.supplierReference }), _jsx(Input, { ...form.register("supplierReference"), placeholder: messages.supplierStatusDialog.placeholders.supplierReference })] })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.supplierStatusDialog.fields.notes }), _jsx(Textarea, { ...form.register("notes"), placeholder: messages.supplierStatusDialog.placeholders.notes })] })] }), _jsxs(DialogFooter, { children: [_jsx(Button, { type: "button", variant: "ghost", size: "sm", onClick: () => onOpenChange(false), children: messages.common.cancel }), _jsxs(Button, { type: "submit", size: "sm", disabled: isSubmitting, children: [isSubmitting && _jsx(Loader2, { className: "mr-2 h-4 w-4 animate-spin" }), isEditing
|
|
96
|
+
? messages.common.saveChanges
|
|
97
|
+
: messages.supplierStatusDialog.actions.addSupplierStatus] })] })] })] }) }));
|
|
98
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"supplier-status-list.d.ts","sourceRoot":"","sources":["../../src/components/supplier-status-list.tsx"],"names":[],"mappings":"AAaA,MAAM,WAAW,uBAAuB;IACtC,SAAS,EAAE,MAAM,CAAA;CAClB;AAYD,wBAAgB,kBAAkB,CAAC,EAAE,SAAS,EAAE,EAAE,uBAAuB,2CAqJxE"}
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { Button } from "@voyant-travel/ui/components";
|
|
4
|
+
import { DataTable } from "@voyant-travel/ui/components/data-table";
|
|
5
|
+
import { Package, Pencil, Plus } from "lucide-react";
|
|
6
|
+
import * as React from "react";
|
|
7
|
+
import { useBookingsUiI18nOrDefault, useBookingsUiMessagesOrDefault } from "../i18n/provider.js";
|
|
8
|
+
import { useSupplierStatuses } from "../index.js";
|
|
9
|
+
import { IconActionButton } from "./icon-action-button.js";
|
|
10
|
+
import { StatusBadge } from "./status-badge.js";
|
|
11
|
+
import { SupplierStatusDialog } from "./supplier-status-dialog.js";
|
|
12
|
+
export function SupplierStatusList({ bookingId }) {
|
|
13
|
+
const [dialogOpen, setDialogOpen] = React.useState(false);
|
|
14
|
+
const [editing, setEditing] = React.useState(undefined);
|
|
15
|
+
const { data } = useSupplierStatuses(bookingId);
|
|
16
|
+
const { formatCurrency, formatDate } = useBookingsUiI18nOrDefault();
|
|
17
|
+
const messages = useBookingsUiMessagesOrDefault();
|
|
18
|
+
const card = messages.supplierStatusList;
|
|
19
|
+
const statuses = data?.data ?? [];
|
|
20
|
+
// `bookingSupplierStatuses` gets one row per `product_day_services`
|
|
21
|
+
// entry — so a 2-day itinerary that includes the same service on
|
|
22
|
+
// both days lands two visually-identical rows. The operator only
|
|
23
|
+
// cares about the per-service total, so collapse identical rows
|
|
24
|
+
// (same service id, name, status, cost) into one with a `× N`
|
|
25
|
+
// badge. The edit pencil opens the first row of the group.
|
|
26
|
+
const rows = React.useMemo(() => groupSupplierStatuses(statuses).map((group) => {
|
|
27
|
+
const head = group.statuses[0];
|
|
28
|
+
return {
|
|
29
|
+
head,
|
|
30
|
+
count: group.statuses.length,
|
|
31
|
+
totalCostCents: group.statuses.reduce((sum, s) => sum + (s.costAmountCents ?? 0), 0),
|
|
32
|
+
reference: group.statuses.find((s) => s.supplierReference)?.supplierReference ?? null,
|
|
33
|
+
confirmedAt: group.statuses.find((s) => s.confirmedAt)?.confirmedAt ?? null,
|
|
34
|
+
};
|
|
35
|
+
}), [statuses]);
|
|
36
|
+
const columns = React.useMemo(() => [
|
|
37
|
+
{
|
|
38
|
+
accessorKey: "serviceName",
|
|
39
|
+
header: card.columns.service,
|
|
40
|
+
cell: ({ row }) => (_jsxs("span", { className: "inline-flex items-center gap-1.5", children: [row.original.head.serviceName, row.original.count > 1 ? (_jsxs("span", { className: "rounded bg-muted px-1.5 py-0.5 text-[10px] text-muted-foreground", children: ["\u00D7 ", row.original.count] })) : null] })),
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
accessorKey: "status",
|
|
44
|
+
header: card.columns.status,
|
|
45
|
+
cell: ({ row }) => (_jsx(StatusBadge, { status: row.original.head.status, children: messages.common.supplierStatusLabels[row.original.head.status] })),
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
accessorKey: "totalCostCents",
|
|
49
|
+
header: card.columns.cost,
|
|
50
|
+
cell: ({ row }) => {
|
|
51
|
+
const { totalCostCents, head } = row.original;
|
|
52
|
+
if (totalCostCents === 0 || !head.costCurrency) {
|
|
53
|
+
return _jsx("span", { className: "text-muted-foreground", children: card.values.costUnavailable });
|
|
54
|
+
}
|
|
55
|
+
return (_jsx("span", { className: "font-mono", children: formatCurrency(totalCostCents / 100, head.costCurrency) }));
|
|
56
|
+
},
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
accessorKey: "reference",
|
|
60
|
+
header: card.columns.reference,
|
|
61
|
+
cell: ({ row }) => (_jsx("span", { title: row.original.reference ?? undefined, className: "inline-block max-w-[180px] truncate font-mono text-muted-foreground text-xs", children: row.original.reference ?? card.values.referenceUnavailable })),
|
|
62
|
+
},
|
|
63
|
+
{
|
|
64
|
+
accessorKey: "confirmedAt",
|
|
65
|
+
header: card.columns.confirmed,
|
|
66
|
+
cell: ({ row }) => row.original.confirmedAt
|
|
67
|
+
? formatDate(row.original.confirmedAt)
|
|
68
|
+
: card.values.confirmedUnavailable,
|
|
69
|
+
},
|
|
70
|
+
{
|
|
71
|
+
id: "actions",
|
|
72
|
+
header: () => _jsx("span", { className: "sr-only", children: card.columns.actions }),
|
|
73
|
+
cell: ({ row }) => (_jsx("div", { className: "flex items-center justify-end gap-1", children: _jsx(IconActionButton, { label: card.actions.edit, icon: _jsx(Pencil, { className: "h-3.5 w-3.5" }), onClick: (e) => {
|
|
74
|
+
e.stopPropagation();
|
|
75
|
+
setEditing(row.original.head);
|
|
76
|
+
setDialogOpen(true);
|
|
77
|
+
} }) })),
|
|
78
|
+
},
|
|
79
|
+
], [card, formatCurrency, formatDate, messages.common.supplierStatusLabels]);
|
|
80
|
+
return (_jsxs("div", { "data-slot": "supplier-status-list", className: "flex flex-col gap-3", children: [_jsxs("div", { className: "flex items-center justify-between gap-3", children: [_jsxs("h2", { className: "flex items-center gap-2 text-base font-semibold", children: [_jsx(Package, { className: "h-4 w-4 text-muted-foreground" }), card.title] }), _jsxs(Button, { variant: "outline", size: "sm", onClick: () => {
|
|
81
|
+
setEditing(undefined);
|
|
82
|
+
setDialogOpen(true);
|
|
83
|
+
}, children: [_jsx(Plus, { className: "mr-1 h-3.5 w-3.5" }), card.addSupplier] })] }), _jsx(DataTable, { columns: columns, data: rows, emptyMessage: card.empty, showPagination: false }), _jsx(SupplierStatusDialog, { open: dialogOpen, onOpenChange: (nextOpen) => {
|
|
84
|
+
setDialogOpen(nextOpen);
|
|
85
|
+
if (!nextOpen) {
|
|
86
|
+
setEditing(undefined);
|
|
87
|
+
}
|
|
88
|
+
}, bookingId: bookingId, supplierStatus: editing, onSuccess: () => {
|
|
89
|
+
setEditing(undefined);
|
|
90
|
+
} })] }));
|
|
91
|
+
}
|
|
92
|
+
function groupSupplierStatuses(statuses) {
|
|
93
|
+
const groups = new Map();
|
|
94
|
+
for (const status of statuses) {
|
|
95
|
+
// Visually-identical rows collapse together. Reference/confirmed
|
|
96
|
+
// timestamps and `id` are intentionally excluded — those differ
|
|
97
|
+
// between sibling rows that the operator nonetheless sees as one
|
|
98
|
+
// line of business.
|
|
99
|
+
const key = [
|
|
100
|
+
status.supplierServiceId ?? "",
|
|
101
|
+
status.serviceName,
|
|
102
|
+
status.status,
|
|
103
|
+
status.costCurrency ?? "",
|
|
104
|
+
status.costAmountCents ?? "",
|
|
105
|
+
].join("|");
|
|
106
|
+
const existing = groups.get(key);
|
|
107
|
+
if (existing) {
|
|
108
|
+
existing.statuses.push(status);
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
groups.set(key, { key, statuses: [status] });
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
return Array.from(groups.values());
|
|
115
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export type TravelerCategoryRole = "lead" | "adult" | "child" | "infant";
|
|
2
|
+
export interface TravelerCategoryState {
|
|
3
|
+
role: TravelerCategoryRole;
|
|
4
|
+
pricingUnitId: string | null;
|
|
5
|
+
}
|
|
6
|
+
export interface TravelerCategoryUnitState {
|
|
7
|
+
unitId: string;
|
|
8
|
+
unitCode: string | null;
|
|
9
|
+
}
|
|
10
|
+
export interface TravelerCategorySelectableUnitState {
|
|
11
|
+
unitType?: string | null;
|
|
12
|
+
}
|
|
13
|
+
export declare function getSelectableTravelerCategoryUnits<TUnit extends TravelerCategorySelectableUnitState>(units: readonly TUnit[]): TUnit[];
|
|
14
|
+
export declare function shouldUseStaticTravelerCategoryFallback(hasGroup: boolean, selectableUnitCount: number): boolean;
|
|
15
|
+
export declare function inferTravelerRoleFromUnit(unit: TravelerCategoryUnitState): Exclude<TravelerCategoryRole, "lead">;
|
|
16
|
+
export declare function getStaticTravelerCategoryButtonState(traveler: TravelerCategoryState, category: Exclude<TravelerCategoryRole, "lead">): {
|
|
17
|
+
active: boolean;
|
|
18
|
+
nextRole: TravelerCategoryRole;
|
|
19
|
+
shouldUpdate: boolean;
|
|
20
|
+
};
|
|
21
|
+
export declare function getDynamicTravelerCategoryButtonState(traveler: TravelerCategoryState, unit: TravelerCategoryUnitState): {
|
|
22
|
+
active: boolean;
|
|
23
|
+
nextRole: TravelerCategoryRole;
|
|
24
|
+
shouldUpdate: boolean;
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=traveler-category-buttons.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"traveler-category-buttons.d.ts","sourceRoot":"","sources":["../../src/components/traveler-category-buttons.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,oBAAoB,GAAG,MAAM,GAAG,OAAO,GAAG,OAAO,GAAG,QAAQ,CAAA;AAExE,MAAM,WAAW,qBAAqB;IACpC,IAAI,EAAE,oBAAoB,CAAA;IAC1B,aAAa,EAAE,MAAM,GAAG,IAAI,CAAA;CAC7B;AAED,MAAM,WAAW,yBAAyB;IACxC,MAAM,EAAE,MAAM,CAAA;IACd,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;CACxB;AAED,MAAM,WAAW,mCAAmC;IAClD,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;CACzB;AAED,wBAAgB,kCAAkC,CAChD,KAAK,SAAS,mCAAmC,EACjD,KAAK,EAAE,SAAS,KAAK,EAAE,GAAG,KAAK,EAAE,CAOlC;AAED,wBAAgB,uCAAuC,CACrD,QAAQ,EAAE,OAAO,EACjB,mBAAmB,EAAE,MAAM,GAC1B,OAAO,CAET;AAED,wBAAgB,yBAAyB,CACvC,IAAI,EAAE,yBAAyB,GAC9B,OAAO,CAAC,oBAAoB,EAAE,MAAM,CAAC,CAKvC;AAED,wBAAgB,oCAAoC,CAClD,QAAQ,EAAE,qBAAqB,EAC/B,QAAQ,EAAE,OAAO,CAAC,oBAAoB,EAAE,MAAM,CAAC,GAC9C;IAAE,MAAM,EAAE,OAAO,CAAC;IAAC,QAAQ,EAAE,oBAAoB,CAAC;IAAC,YAAY,EAAE,OAAO,CAAA;CAAE,CAS5E;AAED,wBAAgB,qCAAqC,CACnD,QAAQ,EAAE,qBAAqB,EAC/B,IAAI,EAAE,yBAAyB,GAC9B;IAAE,MAAM,EAAE,OAAO,CAAC;IAAC,QAAQ,EAAE,oBAAoB,CAAC;IAAC,YAAY,EAAE,OAAO,CAAA;CAAE,CAY5E"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
export function getSelectableTravelerCategoryUnits(units) {
|
|
2
|
+
const hasInventoryUnits = units.some((unit) => unit.unitType === "room" || unit.unitType === "vehicle");
|
|
3
|
+
return units.filter((unit) => unit.unitType === "person" || (!hasInventoryUnits && unit.unitType == null));
|
|
4
|
+
}
|
|
5
|
+
export function shouldUseStaticTravelerCategoryFallback(hasGroup, selectableUnitCount) {
|
|
6
|
+
return !hasGroup || selectableUnitCount === 0;
|
|
7
|
+
}
|
|
8
|
+
export function inferTravelerRoleFromUnit(unit) {
|
|
9
|
+
const codeLower = (unit.unitCode ?? "").toLowerCase();
|
|
10
|
+
if (codeLower === "child")
|
|
11
|
+
return "child";
|
|
12
|
+
if (codeLower === "infant")
|
|
13
|
+
return "infant";
|
|
14
|
+
return "adult";
|
|
15
|
+
}
|
|
16
|
+
export function getStaticTravelerCategoryButtonState(traveler, category) {
|
|
17
|
+
const active = traveler.role === category || (traveler.role === "lead" && category === "adult");
|
|
18
|
+
const nextRole = traveler.role === "lead" && category === "adult" ? "lead" : category;
|
|
19
|
+
return {
|
|
20
|
+
active,
|
|
21
|
+
nextRole,
|
|
22
|
+
shouldUpdate: traveler.role !== nextRole,
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
export function getDynamicTravelerCategoryButtonState(traveler, unit) {
|
|
26
|
+
const inferredRole = inferTravelerRoleFromUnit(unit);
|
|
27
|
+
const active = traveler.pricingUnitId === unit.unitId ||
|
|
28
|
+
(traveler.role === "lead" && inferredRole === "adult" && traveler.pricingUnitId == null);
|
|
29
|
+
const nextRole = traveler.role === "lead" && inferredRole === "adult" ? "lead" : inferredRole;
|
|
30
|
+
return {
|
|
31
|
+
active,
|
|
32
|
+
nextRole,
|
|
33
|
+
shouldUpdate: traveler.pricingUnitId !== unit.unitId || traveler.role !== nextRole,
|
|
34
|
+
};
|
|
35
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { type BookingTravelerRecord } from "../index.js";
|
|
2
|
+
export interface TravelerDialogProps {
|
|
3
|
+
open: boolean;
|
|
4
|
+
onOpenChange: (open: boolean) => void;
|
|
5
|
+
bookingId: string;
|
|
6
|
+
traveler?: BookingTravelerRecord;
|
|
7
|
+
onSuccess?: () => void;
|
|
8
|
+
}
|
|
9
|
+
export declare function TravelerDialog({ open, onOpenChange, bookingId, traveler, onSuccess, }: TravelerDialogProps): import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
//# sourceMappingURL=traveler-dialog.d.ts.map
|