@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,79 @@
|
|
|
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, } from "@voyant-travel/ui/components";
|
|
4
|
+
import { Loader2 } from "lucide-react";
|
|
5
|
+
import * as React from "react";
|
|
6
|
+
import { useBookingsUiI18nOrDefault, useBookingsUiMessagesOrDefault } from "../i18n/provider.js";
|
|
7
|
+
import { useBookingGroupMemberMutation, useBookingGroupMutation, useBookingGroups, } from "../index.js";
|
|
8
|
+
const JOIN_PLACEHOLDER = "__none__";
|
|
9
|
+
export function BookingGroupLinkDialog({ open, onOpenChange, bookingId, productId, optionUnitId, onLinked, }) {
|
|
10
|
+
const [mode, setMode] = React.useState("join");
|
|
11
|
+
const [selectedGroupId, setSelectedGroupId] = React.useState("");
|
|
12
|
+
const [newGroupLabel, setNewGroupLabel] = React.useState("");
|
|
13
|
+
const [error, setError] = React.useState(null);
|
|
14
|
+
const { formatDate } = useBookingsUiI18nOrDefault();
|
|
15
|
+
const messages = useBookingsUiMessagesOrDefault();
|
|
16
|
+
React.useEffect(() => {
|
|
17
|
+
if (!open) {
|
|
18
|
+
setMode("join");
|
|
19
|
+
setSelectedGroupId("");
|
|
20
|
+
setNewGroupLabel("");
|
|
21
|
+
setError(null);
|
|
22
|
+
}
|
|
23
|
+
}, [open]);
|
|
24
|
+
const { data } = useBookingGroups({
|
|
25
|
+
productId: productId ?? undefined,
|
|
26
|
+
optionUnitId: optionUnitId ?? undefined,
|
|
27
|
+
limit: 50,
|
|
28
|
+
enabled: open,
|
|
29
|
+
});
|
|
30
|
+
const groups = data?.data ?? [];
|
|
31
|
+
const { create: createGroup } = useBookingGroupMutation();
|
|
32
|
+
const { add: addMember } = useBookingGroupMemberMutation();
|
|
33
|
+
const handleSubmit = async () => {
|
|
34
|
+
setError(null);
|
|
35
|
+
try {
|
|
36
|
+
let targetGroupId = selectedGroupId;
|
|
37
|
+
let role = "shared";
|
|
38
|
+
if (mode === "create") {
|
|
39
|
+
const label = newGroupLabel.trim() ||
|
|
40
|
+
`${messages.bookingGroupLinkDialog.labels.generatedLabelPrefix} - ${formatDate(new Date())}`;
|
|
41
|
+
const group = await createGroup.mutateAsync({
|
|
42
|
+
kind: "shared_room",
|
|
43
|
+
label,
|
|
44
|
+
productId: productId ?? null,
|
|
45
|
+
optionUnitId: optionUnitId ?? null,
|
|
46
|
+
primaryBookingId: bookingId,
|
|
47
|
+
});
|
|
48
|
+
targetGroupId = group.id;
|
|
49
|
+
role = "primary";
|
|
50
|
+
}
|
|
51
|
+
if (!targetGroupId || targetGroupId === JOIN_PLACEHOLDER) {
|
|
52
|
+
setError(messages.bookingGroupLinkDialog.validation.selectGroup);
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
await addMember.mutateAsync({
|
|
56
|
+
groupId: targetGroupId,
|
|
57
|
+
bookingId,
|
|
58
|
+
role,
|
|
59
|
+
});
|
|
60
|
+
onOpenChange(false);
|
|
61
|
+
onLinked?.(targetGroupId);
|
|
62
|
+
}
|
|
63
|
+
catch (err) {
|
|
64
|
+
const message = err instanceof Error ? err.message : messages.bookingGroupLinkDialog.validation.linkFailed;
|
|
65
|
+
setError(message);
|
|
66
|
+
}
|
|
67
|
+
};
|
|
68
|
+
const isSubmitting = createGroup.isPending || addMember.isPending;
|
|
69
|
+
return (_jsx(Dialog, { open: open, onOpenChange: onOpenChange, children: _jsxs(DialogContent, { children: [_jsx(DialogHeader, { children: _jsx(DialogTitle, { children: messages.bookingGroupLinkDialog.title }) }), _jsxs(DialogBody, { className: "grid gap-4", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(Button, { type: "button", size: "sm", variant: mode === "join" ? "default" : "ghost", onClick: () => setMode("join"), children: messages.bookingGroupLinkDialog.modes.join }), _jsx(Button, { type: "button", size: "sm", variant: mode === "create" ? "default" : "ghost", onClick: () => setMode("create"), children: messages.bookingGroupLinkDialog.modes.create })] }), mode === "join" ? (_jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingGroupLinkDialog.fields.existingGroups }), _jsxs(Select, { items: groups.length === 0
|
|
70
|
+
? [
|
|
71
|
+
{
|
|
72
|
+
label: messages.bookingGroupLinkDialog.placeholders.noExistingGroups,
|
|
73
|
+
value: JOIN_PLACEHOLDER,
|
|
74
|
+
},
|
|
75
|
+
]
|
|
76
|
+
: groups.map((g) => ({ label: g.label, value: g.id })), value: selectedGroupId || JOIN_PLACEHOLDER, onValueChange: (v) => setSelectedGroupId(v === JOIN_PLACEHOLDER ? "" : (v ?? "")), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, { placeholder: messages.bookingGroupLinkDialog.placeholders.selectGroup }) }), _jsx(SelectContent, { children: groups.length === 0 ? (_jsx(SelectItem, { value: JOIN_PLACEHOLDER, disabled: true, children: messages.bookingGroupLinkDialog.placeholders.noExistingGroups })) : (groups.map((g) => (_jsx(SelectItem, { value: g.id, children: g.label }, g.id)))) })] }), productId && (_jsx("p", { className: "text-xs text-muted-foreground", children: messages.bookingGroupLinkDialog.hints.productFiltered }))] })) : (_jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingGroupLinkDialog.fields.groupLabel }), _jsx(Input, { value: newGroupLabel, onChange: (e) => setNewGroupLabel(e.target.value), placeholder: messages.bookingGroupLinkDialog.placeholders.groupLabel }), _jsx("p", { className: "text-xs text-muted-foreground", children: messages.bookingGroupLinkDialog.hints.primaryMember })] })), error && _jsx("p", { className: "text-xs text-destructive", children: error })] }), _jsxs(DialogFooter, { children: [_jsx(Button, { type: "button", variant: "ghost", size: "sm", onClick: () => onOpenChange(false), disabled: isSubmitting, children: messages.common.cancel }), _jsxs(Button, { type: "button", size: "sm", onClick: handleSubmit, disabled: isSubmitting || (mode === "join" && !selectedGroupId), children: [isSubmitting && _jsx(Loader2, { className: "mr-2 h-4 w-4 animate-spin" }), mode === "create"
|
|
77
|
+
? messages.bookingGroupLinkDialog.actions.createAndLink
|
|
78
|
+
: messages.bookingGroupLinkDialog.actions.linkToGroup] })] })] }) }));
|
|
79
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
export interface BookingGroupSectionProps {
|
|
2
|
+
bookingId: string;
|
|
3
|
+
/**
|
|
4
|
+
* Product ID used to scope shared-room group context. Leave unset to
|
|
5
|
+
* auto-resolve from the booking's items; pass an explicit string or `null`
|
|
6
|
+
* to override.
|
|
7
|
+
*/
|
|
8
|
+
productId?: string | null;
|
|
9
|
+
/**
|
|
10
|
+
* Option unit ID used to scope shared-room group context. Leave unset to
|
|
11
|
+
* auto-resolve from the booking's items; pass an explicit string or `null`
|
|
12
|
+
* to override.
|
|
13
|
+
*/
|
|
14
|
+
optionUnitId?: string | null;
|
|
15
|
+
/**
|
|
16
|
+
* When true (default), the section hides itself when the booking
|
|
17
|
+
* has no `accommodation` items AND no existing group — shared-room
|
|
18
|
+
* pairing only makes sense for bookings that include a room. Tours,
|
|
19
|
+
* ground-transfer, and inquiry bookings see no Shared-Room card.
|
|
20
|
+
*
|
|
21
|
+
* Set to `false` to always render the section (e.g. legacy
|
|
22
|
+
* dashboards that display it for every booking regardless).
|
|
23
|
+
*/
|
|
24
|
+
hideWithoutAccommodation?: boolean;
|
|
25
|
+
}
|
|
26
|
+
export declare function BookingGroupSection({ bookingId, productId, optionUnitId, hideWithoutAccommodation, }: BookingGroupSectionProps): import("react/jsx-runtime").JSX.Element | null;
|
|
27
|
+
//# sourceMappingURL=booking-group-section.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"booking-group-section.d.ts","sourceRoot":"","sources":["../../src/components/booking-group-section.tsx"],"names":[],"mappings":"AAsBA,MAAM,WAAW,wBAAwB;IACvC,SAAS,EAAE,MAAM,CAAA;IACjB;;;;OAIG;IACH,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACzB;;;;OAIG;IACH,YAAY,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IAC5B;;;;;;;;OAQG;IACH,wBAAwB,CAAC,EAAE,OAAO,CAAA;CACnC;AAED,wBAAgB,mBAAmB,CAAC,EAClC,SAAS,EACT,SAAS,EACT,YAAY,EACZ,wBAA+B,GAChC,EAAE,wBAAwB,kDA2I1B"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { Badge, Button, Card, CardContent, CardHeader, CardTitle, } from "@voyant-travel/ui/components";
|
|
4
|
+
import { Link2, Unlink, Users } from "lucide-react";
|
|
5
|
+
import * as React from "react";
|
|
6
|
+
import { formatMessage, useBookingsUiMessagesOrDefault } from "../i18n/provider.js";
|
|
7
|
+
import { useBookingGroup, useBookingGroupForBooking, useBookingGroupMemberMutation, useBookingItems, useBookingPrimaryProduct, } from "../index.js";
|
|
8
|
+
import { BookingGroupLinkDialog } from "./booking-group-link-dialog.js";
|
|
9
|
+
export function BookingGroupSection({ bookingId, productId, optionUnitId, hideWithoutAccommodation = true, }) {
|
|
10
|
+
const [linkDialogOpen, setLinkDialogOpen] = React.useState(false);
|
|
11
|
+
const messages = useBookingsUiMessagesOrDefault();
|
|
12
|
+
// Auto-resolve product/option-unit from items when the caller hasn't
|
|
13
|
+
// supplied them. Explicit `null` is respected as an override.
|
|
14
|
+
const shouldAutoResolve = productId === undefined || optionUnitId === undefined;
|
|
15
|
+
const autoResolved = useBookingPrimaryProduct(bookingId, { enabled: shouldAutoResolve });
|
|
16
|
+
const effectiveProductId = productId === undefined ? autoResolved.productId : productId;
|
|
17
|
+
const effectiveOptionUnitId = optionUnitId === undefined ? autoResolved.optionUnitId : optionUnitId;
|
|
18
|
+
// Fetch items to detect whether the booking has accommodation —
|
|
19
|
+
// shared-room pairing is meaningful only for room-style products.
|
|
20
|
+
// The `useBookingItems` query is already in cache from
|
|
21
|
+
// `useBookingPrimaryProduct` above, so this is a free read.
|
|
22
|
+
const { data: itemsData } = useBookingItems(bookingId);
|
|
23
|
+
const items = itemsData?.data ?? [];
|
|
24
|
+
const hasAccommodationItem = items.some((i) => i.itemType === "accommodation");
|
|
25
|
+
const { data: groupForBookingData } = useBookingGroupForBooking(bookingId);
|
|
26
|
+
const group = groupForBookingData?.data ?? null;
|
|
27
|
+
const groupId = group?.id ?? null;
|
|
28
|
+
const { data: groupDetail } = useBookingGroup(groupId, { enabled: Boolean(groupId) });
|
|
29
|
+
const members = groupDetail?.data?.members ?? [];
|
|
30
|
+
const { remove: removeMember } = useBookingGroupMemberMutation();
|
|
31
|
+
// Hide the section entirely when there's nothing to render or
|
|
32
|
+
// pair: no group exists yet AND the booking has no accommodation
|
|
33
|
+
// line item. Operators on tour-only bookings shouldn't see a card
|
|
34
|
+
// they can't usefully act on.
|
|
35
|
+
if (hideWithoutAccommodation && !group && !hasAccommodationItem) {
|
|
36
|
+
return null;
|
|
37
|
+
}
|
|
38
|
+
const handleRemove = async () => {
|
|
39
|
+
if (!groupId)
|
|
40
|
+
return;
|
|
41
|
+
if (!confirm(messages.bookingGroupSection.actions.removeConfirm))
|
|
42
|
+
return;
|
|
43
|
+
await removeMember.mutateAsync({ groupId, bookingId });
|
|
44
|
+
};
|
|
45
|
+
const siblings = members.filter((m) => m.bookingId !== bookingId);
|
|
46
|
+
return (_jsxs(Card, { "data-slot": "booking-group-section", children: [_jsxs(CardHeader, { className: "flex flex-row items-center justify-between", children: [_jsxs(CardTitle, { className: "flex items-center gap-2", children: [_jsx(Users, { className: "h-4 w-4" }), messages.bookingGroupSection.title] }), group ? (_jsxs(Button, { size: "sm", variant: "outline", onClick: handleRemove, disabled: removeMember.isPending, children: [_jsx(Unlink, { className: "mr-2 h-4 w-4" }), messages.bookingGroupSection.actions.removeFromGroup] })) : (_jsxs(Button, { size: "sm", onClick: () => setLinkDialogOpen(true), children: [_jsx(Link2, { className: "mr-2 h-4 w-4" }), messages.bookingGroupSection.actions.linkToSharedRoom] }))] }), _jsx(CardContent, { children: !group ? (_jsx("p", { className: "py-4 text-center text-sm text-muted-foreground", children: messages.bookingGroupSection.empty })) : (_jsxs("div", { className: "space-y-3", children: [_jsxs("div", { className: "flex items-center justify-between rounded-md border bg-muted/30 p-3 text-sm", children: [_jsxs("div", { children: [_jsx("div", { className: "text-xs text-muted-foreground", children: messages.bookingGroupSection.group }), _jsx("div", { className: "font-medium", children: group.label })] }), _jsx(Badge, { variant: "outline", children: group.kind === "shared_room"
|
|
47
|
+
? messages.bookingGroupSection.sharedRoomKind
|
|
48
|
+
: group.kind.replace(/_/g, " ") })] }), _jsxs("div", { children: [_jsx("div", { className: "mb-2 text-xs font-medium text-muted-foreground", children: formatMessage(messages.bookingGroupSection.siblingBookings, {
|
|
49
|
+
count: siblings.length,
|
|
50
|
+
}) }), siblings.length === 0 ? (_jsx("p", { className: "text-xs text-muted-foreground", children: messages.bookingGroupSection.noSiblingBookings })) : (_jsx("ul", { className: "space-y-1", children: siblings.map((m) => (_jsxs("li", { className: "flex items-center justify-between rounded px-2 py-1 text-sm", children: [_jsx("span", { className: "font-mono text-xs", children: m.booking?.bookingNumber ?? m.bookingId }), _jsxs("div", { className: "flex items-center gap-2", children: [m.role === "primary" && (_jsx(Badge, { variant: "default", className: "text-xs", children: messages.bookingGroupSection.primaryBadge })), m.booking?.status && (_jsx("span", { className: "text-xs text-muted-foreground", children: messages.common.bookingStatusLabels[m.booking.status] }))] })] }, m.id))) }))] })] })) }), _jsx(BookingGroupLinkDialog, { open: linkDialogOpen, onOpenChange: setLinkDialogOpen, bookingId: bookingId, productId: effectiveProductId, optionUnitId: effectiveOptionUnitId })] }));
|
|
51
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { type BookingGuaranteeRecord } from "@voyant-travel/finance-react";
|
|
2
|
+
export interface BookingGuaranteeDialogProps {
|
|
3
|
+
open: boolean;
|
|
4
|
+
onOpenChange: (open: boolean) => void;
|
|
5
|
+
bookingId: string;
|
|
6
|
+
guarantee?: BookingGuaranteeRecord;
|
|
7
|
+
onSuccess?: () => void;
|
|
8
|
+
}
|
|
9
|
+
export declare function BookingGuaranteeDialog({ open, onOpenChange, bookingId, guarantee, onSuccess, }: BookingGuaranteeDialogProps): import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
//# sourceMappingURL=booking-guarantee-dialog.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"booking-guarantee-dialog.d.ts","sourceRoot":"","sources":["../../src/components/booking-guarantee-dialog.tsx"],"names":[],"mappings":"AAEA,OAAO,EACL,KAAK,sBAAsB,EAE5B,MAAM,8BAA8B,CAAA;AAiErC,MAAM,WAAW,2BAA2B;IAC1C,IAAI,EAAE,OAAO,CAAA;IACb,YAAY,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAA;IACrC,SAAS,EAAE,MAAM,CAAA;IACjB,SAAS,CAAC,EAAE,sBAAsB,CAAA;IAClC,SAAS,CAAC,EAAE,MAAM,IAAI,CAAA;CACvB;AAED,wBAAgB,sBAAsB,CAAC,EACrC,IAAI,EACJ,YAAY,EACZ,SAAS,EACT,SAAS,EACT,SAAS,GACV,EAAE,2BAA2B,2CA+N7B"}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { useBookingGuaranteeMutation, } from "@voyant-travel/finance-react";
|
|
4
|
+
import { Button, Dialog, DialogBody, DialogContent, DialogFooter, DialogHeader, DialogTitle, Input, Label, Select, SelectContent, SelectItem, SelectTrigger, SelectValue, Textarea, } from "@voyant-travel/ui/components";
|
|
5
|
+
import { CurrencyCombobox } from "@voyant-travel/ui/components/currency-combobox";
|
|
6
|
+
import { CurrencyInput } from "@voyant-travel/ui/components/currency-input";
|
|
7
|
+
import { DateTimePicker } from "@voyant-travel/ui/components/date-time-picker";
|
|
8
|
+
import { zodResolver } from "@voyant-travel/ui/lib/zod-resolver";
|
|
9
|
+
import { Loader2 } from "lucide-react";
|
|
10
|
+
import { useEffect, useMemo } from "react";
|
|
11
|
+
import { useForm } from "react-hook-form";
|
|
12
|
+
import { z } from "zod/v4";
|
|
13
|
+
import { useBookingsUiMessagesOrDefault } from "../i18n/provider.js";
|
|
14
|
+
const guaranteeTypes = [
|
|
15
|
+
"deposit",
|
|
16
|
+
"credit_card",
|
|
17
|
+
"preauth",
|
|
18
|
+
"card_on_file",
|
|
19
|
+
"bank_transfer",
|
|
20
|
+
"voucher",
|
|
21
|
+
"agency_letter",
|
|
22
|
+
"other",
|
|
23
|
+
];
|
|
24
|
+
const guaranteeStatuses = [
|
|
25
|
+
"pending",
|
|
26
|
+
"active",
|
|
27
|
+
"released",
|
|
28
|
+
"failed",
|
|
29
|
+
"cancelled",
|
|
30
|
+
"expired",
|
|
31
|
+
];
|
|
32
|
+
const DEFAULT_CURRENCY = "EUR"; // i18n-literal-ok ISO default currency
|
|
33
|
+
function createGuaranteeFormSchema() {
|
|
34
|
+
return z.object({
|
|
35
|
+
guaranteeType: z.enum(guaranteeTypes),
|
|
36
|
+
status: z.enum(guaranteeStatuses).default("pending"),
|
|
37
|
+
currency: z.string().min(3).max(3).optional().nullable(),
|
|
38
|
+
amountCents: z.coerce.number().int().min(0).optional().nullable(),
|
|
39
|
+
provider: z.string().optional().nullable(),
|
|
40
|
+
referenceNumber: z.string().optional().nullable(),
|
|
41
|
+
expiresAt: z.string().optional().nullable(),
|
|
42
|
+
notes: z.string().optional().nullable(),
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
export function BookingGuaranteeDialog({ open, onOpenChange, bookingId, guarantee, onSuccess, }) {
|
|
46
|
+
const isEditing = Boolean(guarantee);
|
|
47
|
+
const { create, update } = useBookingGuaranteeMutation(bookingId);
|
|
48
|
+
const messages = useBookingsUiMessagesOrDefault();
|
|
49
|
+
const guaranteeFormSchema = createGuaranteeFormSchema();
|
|
50
|
+
const typeItems = useMemo(() => guaranteeTypes.map((t) => ({
|
|
51
|
+
value: t,
|
|
52
|
+
label: messages.bookingGuaranteeDialog.guaranteeTypeLabels[t],
|
|
53
|
+
})), [messages.bookingGuaranteeDialog.guaranteeTypeLabels]);
|
|
54
|
+
const statusItems = useMemo(() => guaranteeStatuses.map((s) => ({
|
|
55
|
+
value: s,
|
|
56
|
+
label: messages.bookingGuaranteeDialog.guaranteeStatusLabels[s],
|
|
57
|
+
})), [messages.bookingGuaranteeDialog.guaranteeStatusLabels]);
|
|
58
|
+
const form = useForm({
|
|
59
|
+
resolver: zodResolver(guaranteeFormSchema),
|
|
60
|
+
defaultValues: {
|
|
61
|
+
guaranteeType: "deposit",
|
|
62
|
+
status: "pending",
|
|
63
|
+
currency: DEFAULT_CURRENCY,
|
|
64
|
+
amountCents: null,
|
|
65
|
+
provider: "",
|
|
66
|
+
referenceNumber: "",
|
|
67
|
+
expiresAt: "",
|
|
68
|
+
notes: "",
|
|
69
|
+
},
|
|
70
|
+
});
|
|
71
|
+
useEffect(() => {
|
|
72
|
+
if (open && guarantee) {
|
|
73
|
+
form.reset({
|
|
74
|
+
guaranteeType: guarantee.guaranteeType,
|
|
75
|
+
status: guarantee.status,
|
|
76
|
+
currency: guarantee.currency,
|
|
77
|
+
amountCents: guarantee.amountCents,
|
|
78
|
+
provider: guarantee.provider ?? "",
|
|
79
|
+
referenceNumber: guarantee.referenceNumber ?? "",
|
|
80
|
+
expiresAt: guarantee.expiresAt ? guarantee.expiresAt.slice(0, 16) : "",
|
|
81
|
+
notes: guarantee.notes ?? "",
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
else if (open) {
|
|
85
|
+
form.reset();
|
|
86
|
+
}
|
|
87
|
+
}, [form, open, guarantee]);
|
|
88
|
+
const onSubmit = async (values) => {
|
|
89
|
+
const payload = {
|
|
90
|
+
guaranteeType: values.guaranteeType,
|
|
91
|
+
status: values.status,
|
|
92
|
+
currency: values.currency || null,
|
|
93
|
+
amountCents: values.amountCents ?? null,
|
|
94
|
+
provider: values.provider || null,
|
|
95
|
+
referenceNumber: values.referenceNumber || null,
|
|
96
|
+
expiresAt: values.expiresAt || null,
|
|
97
|
+
notes: values.notes || null,
|
|
98
|
+
};
|
|
99
|
+
if (isEditing) {
|
|
100
|
+
await update.mutateAsync({ id: guarantee.id, input: payload });
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
await create.mutateAsync(payload);
|
|
104
|
+
}
|
|
105
|
+
onOpenChange(false);
|
|
106
|
+
onSuccess?.();
|
|
107
|
+
};
|
|
108
|
+
const isSubmitting = create.isPending || update.isPending;
|
|
109
|
+
return (_jsx(Dialog, { open: open, onOpenChange: onOpenChange, children: _jsxs(DialogContent, { size: "lg", children: [_jsx(DialogHeader, { children: _jsx(DialogTitle, { children: isEditing
|
|
110
|
+
? messages.bookingGuaranteeDialog.titles.edit
|
|
111
|
+
: messages.bookingGuaranteeDialog.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.bookingGuaranteeDialog.fields.type }), _jsxs(Select, { items: typeItems, value: form.watch("guaranteeType"), onValueChange: (v) => form.setValue("guaranteeType", (v ?? "deposit")), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsx(SelectContent, { children: guaranteeTypes.map((t) => (_jsx(SelectItem, { value: t, children: messages.bookingGuaranteeDialog.guaranteeTypeLabels[t] }, t))) })] })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingGuaranteeDialog.fields.status }), _jsxs(Select, { items: statusItems, value: form.watch("status"), onValueChange: (v) => form.setValue("status", (v ?? "pending")), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsx(SelectContent, { children: guaranteeStatuses.map((s) => (_jsx(SelectItem, { value: s, children: messages.bookingGuaranteeDialog.guaranteeStatusLabels[s] }, s))) })] })] })] }), _jsxs("div", { className: "grid grid-cols-2 gap-4", children: [_jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingGuaranteeDialog.fields.currency }), _jsx(CurrencyCombobox, { value: form.watch("currency") || null, onChange: (next) => form.setValue("currency", next ?? DEFAULT_CURRENCY, {
|
|
112
|
+
shouldValidate: true,
|
|
113
|
+
shouldDirty: true,
|
|
114
|
+
}) })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingGuaranteeDialog.fields.amountCents }), _jsx(CurrencyInput, { value: form.watch("amountCents"), onChange: (next) => form.setValue("amountCents", next, {
|
|
115
|
+
shouldDirty: true,
|
|
116
|
+
shouldValidate: true,
|
|
117
|
+
}), currency: form.watch("currency") })] })] }), _jsxs("div", { className: "grid grid-cols-2 gap-4", children: [_jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingGuaranteeDialog.fields.provider }), _jsx(Input, { ...form.register("provider"), placeholder: messages.bookingGuaranteeDialog.placeholders.provider })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingGuaranteeDialog.fields.referenceNumber }), _jsx(Input, { ...form.register("referenceNumber"), placeholder: messages.bookingGuaranteeDialog.placeholders.referenceNumber })] })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingGuaranteeDialog.fields.expiresAt }), _jsx(DateTimePicker, { value: form.watch("expiresAt") || null, onChange: (next) => form.setValue("expiresAt", next ?? "", {
|
|
118
|
+
shouldValidate: true,
|
|
119
|
+
shouldDirty: true,
|
|
120
|
+
}), placeholder: messages.bookingGuaranteeDialog.placeholders.expiresAt, className: "w-full" })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingGuaranteeDialog.fields.notes }), _jsx(Textarea, { ...form.register("notes"), placeholder: messages.bookingGuaranteeDialog.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
|
|
121
|
+
? messages.common.saveChanges
|
|
122
|
+
: messages.bookingGuaranteeDialog.actions.addGuarantee] })] })] })] }) }));
|
|
123
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"booking-guarantee-list.d.ts","sourceRoot":"","sources":["../../src/components/booking-guarantee-list.tsx"],"names":[],"mappings":"AA4BA,MAAM,WAAW,yBAAyB;IACxC,SAAS,EAAE,MAAM,CAAA;CAClB;AAED,wBAAgB,oBAAoB,CAAC,EAAE,SAAS,EAAE,EAAE,yBAAyB,2CAkK5E"}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { useBookingGuaranteeMutation, useBookingGuarantees, } from "@voyant-travel/finance-react";
|
|
4
|
+
import { AlertDialog, AlertDialogAction, AlertDialogCancel, AlertDialogContent, AlertDialogDescription, AlertDialogFooter, AlertDialogHeader, AlertDialogTitle, Button, } from "@voyant-travel/ui/components";
|
|
5
|
+
import { DataTable } from "@voyant-travel/ui/components/data-table";
|
|
6
|
+
import { Pencil, Plus, ShieldCheck, Trash2 } from "lucide-react";
|
|
7
|
+
import * as React from "react";
|
|
8
|
+
import { useBookingsUiI18nOrDefault, useBookingsUiMessagesOrDefault } from "../i18n/provider.js";
|
|
9
|
+
import { BookingGuaranteeDialog } from "./booking-guarantee-dialog.js";
|
|
10
|
+
import { IconActionButton } from "./icon-action-button.js";
|
|
11
|
+
import { StatusBadge } from "./status-badge.js";
|
|
12
|
+
export function BookingGuaranteeList({ bookingId }) {
|
|
13
|
+
const [dialogOpen, setDialogOpen] = React.useState(false);
|
|
14
|
+
const [editing, setEditing] = React.useState(undefined);
|
|
15
|
+
const [deleteTarget, setDeleteTarget] = React.useState(null);
|
|
16
|
+
const { data } = useBookingGuarantees(bookingId);
|
|
17
|
+
const { remove } = useBookingGuaranteeMutation(bookingId);
|
|
18
|
+
const { formatCurrency, formatDate } = useBookingsUiI18nOrDefault();
|
|
19
|
+
const messages = useBookingsUiMessagesOrDefault();
|
|
20
|
+
const t = messages.bookingGuaranteeList;
|
|
21
|
+
const deleteMessages = t.actions.deleteConfirm;
|
|
22
|
+
const guarantees = data?.data ?? [];
|
|
23
|
+
const handleConfirmDelete = async () => {
|
|
24
|
+
if (!deleteTarget)
|
|
25
|
+
return;
|
|
26
|
+
await remove.mutateAsync(deleteTarget.id);
|
|
27
|
+
setDeleteTarget(null);
|
|
28
|
+
};
|
|
29
|
+
const columns = React.useMemo(() => [
|
|
30
|
+
{
|
|
31
|
+
accessorKey: "guaranteeType",
|
|
32
|
+
header: t.columns.type,
|
|
33
|
+
cell: ({ row }) => messages.bookingGuaranteeDialog.guaranteeTypeLabels[row.original.guaranteeType],
|
|
34
|
+
},
|
|
35
|
+
{
|
|
36
|
+
accessorKey: "amountCents",
|
|
37
|
+
header: t.columns.amount,
|
|
38
|
+
cell: ({ row }) => (_jsx("span", { className: "font-mono", children: row.original.amountCents == null || !row.original.currency
|
|
39
|
+
? t.values.amountUnavailable
|
|
40
|
+
: formatCurrency(row.original.amountCents / 100, row.original.currency) })),
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
accessorKey: "status",
|
|
44
|
+
header: t.columns.status,
|
|
45
|
+
cell: ({ row }) => (_jsx(StatusBadge, { status: row.original.status, children: messages.bookingGuaranteeDialog.guaranteeStatusLabels[row.original.status] })),
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
accessorKey: "provider",
|
|
49
|
+
header: t.columns.provider,
|
|
50
|
+
cell: ({ row }) => row.original.provider ?? t.values.providerUnavailable,
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
accessorKey: "referenceNumber",
|
|
54
|
+
header: t.columns.reference,
|
|
55
|
+
cell: ({ row }) => (_jsx("span", { className: "block max-w-[180px] truncate font-mono text-xs", children: row.original.referenceNumber ?? t.values.referenceUnavailable })),
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
accessorKey: "expiresAt",
|
|
59
|
+
header: t.columns.expires,
|
|
60
|
+
cell: ({ row }) => row.original.expiresAt ? formatDate(row.original.expiresAt) : t.values.expiresUnavailable,
|
|
61
|
+
},
|
|
62
|
+
{
|
|
63
|
+
id: "actions",
|
|
64
|
+
header: "",
|
|
65
|
+
cell: ({ row }) => (_jsxs("div", { className: "flex items-center justify-end gap-1", children: [_jsx(IconActionButton, { label: t.actions.editGuarantee, icon: _jsx(Pencil, { className: "h-3.5 w-3.5" }), onClick: (e) => {
|
|
66
|
+
e.stopPropagation();
|
|
67
|
+
setEditing(row.original);
|
|
68
|
+
setDialogOpen(true);
|
|
69
|
+
} }), _jsx(IconActionButton, { label: t.actions.deleteGuarantee, icon: _jsx(Trash2, { className: "h-3.5 w-3.5" }), className: "text-muted-foreground hover:bg-destructive/10 hover:text-destructive", onClick: (e) => {
|
|
70
|
+
e.stopPropagation();
|
|
71
|
+
setDeleteTarget(row.original);
|
|
72
|
+
} })] })),
|
|
73
|
+
},
|
|
74
|
+
], [formatCurrency, formatDate, messages, t]);
|
|
75
|
+
return (_jsxs("div", { "data-slot": "booking-guarantee-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(ShieldCheck, { className: "h-4 w-4" }), t.title] }), _jsxs(Button, { variant: "outline", size: "sm", onClick: () => {
|
|
76
|
+
setEditing(undefined);
|
|
77
|
+
setDialogOpen(true);
|
|
78
|
+
}, children: [_jsx(Plus, { className: "mr-2 h-4 w-4" }), t.addGuarantee] })] }), _jsx(DataTable, { columns: columns, data: guarantees, emptyMessage: t.empty, showPagination: false }), _jsx(BookingGuaranteeDialog, { open: dialogOpen, onOpenChange: (nextOpen) => {
|
|
79
|
+
setDialogOpen(nextOpen);
|
|
80
|
+
if (!nextOpen)
|
|
81
|
+
setEditing(undefined);
|
|
82
|
+
}, bookingId: bookingId, guarantee: editing, onSuccess: () => setEditing(undefined) }), _jsx(AlertDialog, { open: Boolean(deleteTarget), onOpenChange: (next) => {
|
|
83
|
+
if (!next && !remove.isPending)
|
|
84
|
+
setDeleteTarget(null);
|
|
85
|
+
}, 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 })] })] }) })] }));
|
|
86
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { type BookingItemRecord } from "../index.js";
|
|
2
|
+
export interface BookingItemDialogProps {
|
|
3
|
+
open: boolean;
|
|
4
|
+
onOpenChange: (open: boolean) => void;
|
|
5
|
+
bookingId: string;
|
|
6
|
+
item?: BookingItemRecord;
|
|
7
|
+
onSuccess?: () => void;
|
|
8
|
+
}
|
|
9
|
+
export declare function BookingItemDialog({ open, onOpenChange, bookingId, item, onSuccess, }: BookingItemDialogProps): import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
//# sourceMappingURL=booking-item-dialog.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"booking-item-dialog.d.ts","sourceRoot":"","sources":["../../src/components/booking-item-dialog.tsx"],"names":[],"mappings":"AA4BA,OAAO,EAAE,KAAK,iBAAiB,EAA0B,MAAM,aAAa,CAAA;AAuC5E,MAAM,WAAW,sBAAsB;IACrC,IAAI,EAAE,OAAO,CAAA;IACb,YAAY,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAA;IACrC,SAAS,EAAE,MAAM,CAAA;IACjB,IAAI,CAAC,EAAE,iBAAiB,CAAA;IACxB,SAAS,CAAC,EAAE,MAAM,IAAI,CAAA;CACvB;AAED,wBAAgB,iBAAiB,CAAC,EAChC,IAAI,EACJ,YAAY,EACZ,SAAS,EACT,IAAI,EACJ,SAAS,GACV,EAAE,sBAAsB,2CA4SxB"}
|
|
@@ -0,0 +1,155 @@
|
|
|
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 { DatePicker } from "@voyant-travel/ui/components/date-picker";
|
|
7
|
+
import { zodResolver } from "@voyant-travel/ui/lib/zod-resolver";
|
|
8
|
+
import { Loader2 } from "lucide-react";
|
|
9
|
+
import { useEffect, useMemo } from "react";
|
|
10
|
+
import { useForm } from "react-hook-form";
|
|
11
|
+
import { z } from "zod/v4";
|
|
12
|
+
import { useBookingsUiMessagesOrDefault } from "../i18n/provider.js";
|
|
13
|
+
import { useBookingItemMutation } from "../index.js";
|
|
14
|
+
const itemTypes = [
|
|
15
|
+
"unit",
|
|
16
|
+
"extra",
|
|
17
|
+
"service",
|
|
18
|
+
"fee",
|
|
19
|
+
"tax",
|
|
20
|
+
"discount",
|
|
21
|
+
"adjustment",
|
|
22
|
+
"accommodation",
|
|
23
|
+
"transport",
|
|
24
|
+
"other",
|
|
25
|
+
];
|
|
26
|
+
const itemStatuses = ["draft", "on_hold", "confirmed", "cancelled", "expired", "fulfilled"];
|
|
27
|
+
const DEFAULT_CURRENCY = "EUR"; // i18n-literal-ok ISO default currency
|
|
28
|
+
function createBookingItemFormSchema(messages) {
|
|
29
|
+
return z.object({
|
|
30
|
+
title: z.string().min(1, messages.bookingItemDialog.validation.titleRequired),
|
|
31
|
+
itemType: z.enum(itemTypes).default("unit"),
|
|
32
|
+
status: z.enum(itemStatuses).default("draft"),
|
|
33
|
+
quantity: z.coerce.number().int().positive().default(1),
|
|
34
|
+
sellCurrency: z.string().min(3).max(3).default("EUR"),
|
|
35
|
+
unitSellAmountCents: z.coerce.number().int().optional().nullable(),
|
|
36
|
+
totalSellAmountCents: z.coerce.number().int().optional().nullable(),
|
|
37
|
+
costCurrency: z.string().min(3).max(3).optional().nullable(),
|
|
38
|
+
unitCostAmountCents: z.coerce.number().int().optional().nullable(),
|
|
39
|
+
totalCostAmountCents: z.coerce.number().int().optional().nullable(),
|
|
40
|
+
serviceDate: z.string().optional().nullable(),
|
|
41
|
+
description: z.string().optional().nullable(),
|
|
42
|
+
notes: z.string().optional().nullable(),
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
export function BookingItemDialog({ open, onOpenChange, bookingId, item, onSuccess, }) {
|
|
46
|
+
const isEditing = Boolean(item);
|
|
47
|
+
const { create, update } = useBookingItemMutation(bookingId);
|
|
48
|
+
const messages = useBookingsUiMessagesOrDefault();
|
|
49
|
+
const bookingItemFormSchema = createBookingItemFormSchema(messages);
|
|
50
|
+
const typeItems = useMemo(() => itemTypes.map((t) => ({
|
|
51
|
+
value: t,
|
|
52
|
+
label: messages.bookingItemDialog.itemTypeLabels[t],
|
|
53
|
+
})), [messages.bookingItemDialog.itemTypeLabels]);
|
|
54
|
+
const statusItems = useMemo(() => itemStatuses.map((s) => ({
|
|
55
|
+
value: s,
|
|
56
|
+
label: messages.bookingItemDialog.itemStatusLabels[s],
|
|
57
|
+
})), [messages.bookingItemDialog.itemStatusLabels]);
|
|
58
|
+
const form = useForm({
|
|
59
|
+
resolver: zodResolver(bookingItemFormSchema),
|
|
60
|
+
defaultValues: {
|
|
61
|
+
title: "",
|
|
62
|
+
itemType: "unit",
|
|
63
|
+
status: "draft",
|
|
64
|
+
quantity: 1,
|
|
65
|
+
sellCurrency: DEFAULT_CURRENCY,
|
|
66
|
+
unitSellAmountCents: null,
|
|
67
|
+
totalSellAmountCents: null,
|
|
68
|
+
costCurrency: null,
|
|
69
|
+
unitCostAmountCents: null,
|
|
70
|
+
totalCostAmountCents: null,
|
|
71
|
+
serviceDate: "",
|
|
72
|
+
description: "",
|
|
73
|
+
notes: "",
|
|
74
|
+
},
|
|
75
|
+
});
|
|
76
|
+
// `form` is intentionally omitted from deps — react-hook-form returns
|
|
77
|
+
// a fresh wrapper object on every render even though the underlying
|
|
78
|
+
// state lives in a ref. Including `form` here would re-run the effect
|
|
79
|
+
// on every render and re-trigger reset → re-render → loop. The methods
|
|
80
|
+
// we call (`reset`) are safe to call from a stale closure since they
|
|
81
|
+
// dispatch into the form's internal store.
|
|
82
|
+
// biome-ignore lint/correctness/useExhaustiveDependencies: see comment above -- owner: bookings-react; existing suppression is intentional pending typed cleanup.
|
|
83
|
+
useEffect(() => {
|
|
84
|
+
if (open && item) {
|
|
85
|
+
form.reset({
|
|
86
|
+
title: item.title,
|
|
87
|
+
itemType: item.itemType,
|
|
88
|
+
status: item.status,
|
|
89
|
+
quantity: item.quantity,
|
|
90
|
+
sellCurrency: item.sellCurrency,
|
|
91
|
+
unitSellAmountCents: item.unitSellAmountCents,
|
|
92
|
+
totalSellAmountCents: item.totalSellAmountCents,
|
|
93
|
+
costCurrency: item.costCurrency,
|
|
94
|
+
unitCostAmountCents: item.unitCostAmountCents,
|
|
95
|
+
totalCostAmountCents: item.totalCostAmountCents,
|
|
96
|
+
serviceDate: item.serviceDate ?? "",
|
|
97
|
+
description: item.description ?? "",
|
|
98
|
+
notes: item.notes ?? "",
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
else if (open) {
|
|
102
|
+
form.reset();
|
|
103
|
+
}
|
|
104
|
+
}, [open, item]);
|
|
105
|
+
const onSubmit = async (values) => {
|
|
106
|
+
const payload = {
|
|
107
|
+
title: values.title,
|
|
108
|
+
itemType: values.itemType,
|
|
109
|
+
status: values.status,
|
|
110
|
+
quantity: values.quantity,
|
|
111
|
+
sellCurrency: values.sellCurrency,
|
|
112
|
+
unitSellAmountCents: values.unitSellAmountCents ?? null,
|
|
113
|
+
totalSellAmountCents: values.totalSellAmountCents ?? null,
|
|
114
|
+
costCurrency: values.costCurrency || null,
|
|
115
|
+
unitCostAmountCents: values.unitCostAmountCents ?? null,
|
|
116
|
+
totalCostAmountCents: values.totalCostAmountCents ?? null,
|
|
117
|
+
serviceDate: values.serviceDate || null,
|
|
118
|
+
description: values.description || null,
|
|
119
|
+
notes: values.notes || null,
|
|
120
|
+
};
|
|
121
|
+
if (isEditing) {
|
|
122
|
+
await update.mutateAsync({ id: item.id, input: payload });
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
await create.mutateAsync(payload);
|
|
126
|
+
}
|
|
127
|
+
onOpenChange(false);
|
|
128
|
+
onSuccess?.();
|
|
129
|
+
};
|
|
130
|
+
const isSubmitting = create.isPending || update.isPending;
|
|
131
|
+
return (_jsx(Dialog, { open: open, onOpenChange: onOpenChange, children: _jsxs(DialogContent, { size: "lg", children: [_jsx(DialogHeader, { children: _jsx(DialogTitle, { children: isEditing
|
|
132
|
+
? messages.bookingItemDialog.titles.edit
|
|
133
|
+
: messages.bookingItemDialog.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: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingItemDialog.fields.title }), _jsx(Input, { ...form.register("title"), placeholder: messages.bookingItemDialog.placeholders.title }), form.formState.errors.title && (_jsx("p", { className: "text-xs text-destructive", children: form.formState.errors.title.message }))] }), _jsxs("div", { className: "grid grid-cols-3 gap-4", children: [_jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingItemDialog.fields.type }), _jsxs(Select, { items: typeItems, value: form.watch("itemType"), onValueChange: (v) => form.setValue("itemType", v), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsx(SelectContent, { children: itemTypes.map((t) => (_jsx(SelectItem, { value: t, children: messages.bookingItemDialog.itemTypeLabels[t] }, t))) })] })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingItemDialog.fields.status }), _jsxs(Select, { items: statusItems, value: form.watch("status"), onValueChange: (v) => form.setValue("status", v), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsx(SelectContent, { children: itemStatuses.map((s) => (_jsx(SelectItem, { value: s, children: messages.bookingItemDialog.itemStatusLabels[s] }, s))) })] })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingItemDialog.fields.quantity }), _jsx(Input, { ...form.register("quantity"), type: "number", min: 1 })] })] }), _jsxs("div", { className: "grid grid-cols-3 gap-4", children: [_jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingItemDialog.fields.sellCurrency }), _jsx(CurrencyCombobox, { value: form.watch("sellCurrency") || null, onChange: (next) => form.setValue("sellCurrency", next ?? DEFAULT_CURRENCY, {
|
|
134
|
+
shouldValidate: true,
|
|
135
|
+
shouldDirty: true,
|
|
136
|
+
}) })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingItemDialog.fields.unitSellAmountCents }), _jsx(CurrencyInput, { value: form.watch("unitSellAmountCents"), onChange: (next) => form.setValue("unitSellAmountCents", next, {
|
|
137
|
+
shouldDirty: true,
|
|
138
|
+
shouldValidate: true,
|
|
139
|
+
}), currency: form.watch("sellCurrency"), placeholder: messages.bookingItemDialog.placeholders.unitSellAmountCents })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingItemDialog.fields.totalSellAmountCents }), _jsx(CurrencyInput, { value: form.watch("totalSellAmountCents"), onChange: (next) => form.setValue("totalSellAmountCents", next, {
|
|
140
|
+
shouldDirty: true,
|
|
141
|
+
shouldValidate: true,
|
|
142
|
+
}), currency: form.watch("sellCurrency"), placeholder: messages.bookingItemDialog.placeholders.totalSellAmountCents })] })] }), _jsxs("div", { className: "grid grid-cols-3 gap-4", children: [_jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingItemDialog.fields.costCurrency }), _jsx(CurrencyCombobox, { value: form.watch("costCurrency") || null, onChange: (next) => form.setValue("costCurrency", next ?? DEFAULT_CURRENCY, {
|
|
143
|
+
shouldValidate: true,
|
|
144
|
+
shouldDirty: true,
|
|
145
|
+
}) })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingItemDialog.fields.unitCostAmountCents }), _jsx(CurrencyInput, { value: form.watch("unitCostAmountCents"), onChange: (next) => form.setValue("unitCostAmountCents", next, {
|
|
146
|
+
shouldDirty: true,
|
|
147
|
+
shouldValidate: true,
|
|
148
|
+
}), currency: form.watch("costCurrency") || form.watch("sellCurrency"), placeholder: messages.bookingItemDialog.placeholders.unitCostAmountCents })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingItemDialog.fields.totalCostAmountCents }), _jsx(CurrencyInput, { value: form.watch("totalCostAmountCents"), onChange: (next) => form.setValue("totalCostAmountCents", next, {
|
|
149
|
+
shouldDirty: true,
|
|
150
|
+
shouldValidate: true,
|
|
151
|
+
}), currency: form.watch("costCurrency") || form.watch("sellCurrency"), placeholder: messages.bookingItemDialog.placeholders.totalCostAmountCents })] })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingItemDialog.fields.serviceDate }), _jsx(DatePicker, { value: form.watch("serviceDate") || null, onChange: (next) => form.setValue("serviceDate", next ?? "", {
|
|
152
|
+
shouldValidate: true,
|
|
153
|
+
shouldDirty: true,
|
|
154
|
+
}), placeholder: messages.bookingItemDialog.placeholders.serviceDate, className: "w-full" })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingItemDialog.fields.description }), _jsx(Textarea, { ...form.register("description"), placeholder: messages.bookingItemDialog.placeholders.description })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.bookingItemDialog.fields.notes }), _jsx(Textarea, { ...form.register("notes"), placeholder: messages.bookingItemDialog.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 ? messages.common.saveChanges : messages.bookingItemDialog.actions.addItem] })] })] })] }) }));
|
|
155
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export type BookingItemResourceKind = "product" | "availabilitySlot";
|
|
2
|
+
export interface BookingItemListProps {
|
|
3
|
+
bookingId: string;
|
|
4
|
+
/**
|
|
5
|
+
* Open a linked resource (product / availability slot) in the host app.
|
|
6
|
+
* When omitted, the snapshot sheet renders the names as plain text
|
|
7
|
+
* instead of clickable links.
|
|
8
|
+
*/
|
|
9
|
+
onResourceOpen?: (kind: BookingItemResourceKind, id: string) => void;
|
|
10
|
+
}
|
|
11
|
+
export declare function BookingItemList({ bookingId, onResourceOpen }: BookingItemListProps): import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
//# sourceMappingURL=booking-item-list.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"booking-item-list.d.ts","sourceRoot":"","sources":["../../src/components/booking-item-list.tsx"],"names":[],"mappings":"AA8BA,MAAM,MAAM,uBAAuB,GAAG,SAAS,GAAG,kBAAkB,CAAA;AAEpE,MAAM,WAAW,oBAAoB;IACnC,SAAS,EAAE,MAAM,CAAA;IACjB;;;;OAIG;IACH,cAAc,CAAC,EAAE,CAAC,IAAI,EAAE,uBAAuB,EAAE,EAAE,EAAE,MAAM,KAAK,IAAI,CAAA;CACrE;AAED,wBAAgB,eAAe,CAAC,EAAE,SAAS,EAAE,cAAc,EAAE,EAAE,oBAAoB,2CA+NlF"}
|