@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 @@
|
|
|
1
|
+
{"version":3,"file":"traveler-dialog.d.ts","sourceRoot":"","sources":["../../src/components/traveler-dialog.tsx"],"names":[],"mappings":"AAoCA,OAAO,EACL,KAAK,qBAAqB,EAG3B,MAAM,aAAa,CAAA;AAoCpB,MAAM,WAAW,mBAAmB;IAClC,IAAI,EAAE,OAAO,CAAA;IACb,YAAY,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAA;IACrC,SAAS,EAAE,MAAM,CAAA;IACjB,QAAQ,CAAC,EAAE,qBAAqB,CAAA;IAChC,SAAS,CAAC,EAAE,MAAM,IAAI,CAAA;CACvB;AAED,wBAAgB,cAAc,CAAC,EAC7B,IAAI,EACJ,YAAY,EACZ,SAAS,EACT,QAAQ,EACR,SAAS,GACV,EAAE,mBAAmB,2CA0brB"}
|
|
@@ -0,0 +1,256 @@
|
|
|
1
|
+
// agent-quality: file-size exception -- owner: bookings-react; existing UI surface stays co-located until a dedicated split preserves behavior and tests.
|
|
2
|
+
"use client";
|
|
3
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
4
|
+
import { usePersonDocumentMutation, usePersonDocuments, usePersonMutation, usePersonTravelSnapshot, } from "@voyant-travel/relationships-react";
|
|
5
|
+
import { Button, Dialog, DialogBody, DialogContent, DialogFooter, DialogHeader, DialogTitle, Input, Label, Select, SelectContent, SelectItem, SelectTrigger, SelectValue, Textarea, } from "@voyant-travel/ui/components";
|
|
6
|
+
import { CountryCombobox } from "@voyant-travel/ui/components/country-combobox";
|
|
7
|
+
import { DatePicker } from "@voyant-travel/ui/components/date-picker";
|
|
8
|
+
import { PhoneInput } from "@voyant-travel/ui/components/phone-input";
|
|
9
|
+
import { zodResolver } from "@voyant-travel/ui/lib/zod-resolver";
|
|
10
|
+
import { Loader2, Sparkles, Upload } from "lucide-react";
|
|
11
|
+
import { useEffect, useState } from "react";
|
|
12
|
+
import { useForm } from "react-hook-form";
|
|
13
|
+
import { z } from "zod/v4";
|
|
14
|
+
import { useBookingsUiMessagesOrDefault } from "../i18n/provider.js";
|
|
15
|
+
import { useRevealTraveler, useTravelerWithTravelDetailsMutation, } from "../index.js";
|
|
16
|
+
const identityDocumentTypes = ["passport", "id_card", "driver_license", "visa", "other"];
|
|
17
|
+
function createTravelerFormSchema(messages) {
|
|
18
|
+
return z.object({
|
|
19
|
+
firstName: z.string().min(1, messages.travelerDialog.validation.firstNameRequired),
|
|
20
|
+
lastName: z.string().min(1, messages.travelerDialog.validation.lastNameRequired),
|
|
21
|
+
email: z.string().email().optional().or(z.literal("")).nullable(),
|
|
22
|
+
phone: z.string().optional().nullable(),
|
|
23
|
+
specialRequests: z.string().optional().nullable(),
|
|
24
|
+
documentType: z.enum(identityDocumentTypes).default("passport"),
|
|
25
|
+
documentNumber: z.string().optional().nullable(),
|
|
26
|
+
documentExpiry: z.string().optional().nullable(),
|
|
27
|
+
documentIssuingCountry: z.string().optional().nullable(),
|
|
28
|
+
documentIssuingAuthority: z.string().optional().nullable(),
|
|
29
|
+
dateOfBirth: z.string().optional().nullable(),
|
|
30
|
+
dietaryRequirements: z.string().optional().nullable(),
|
|
31
|
+
accessibilityNeeds: z.string().optional().nullable(),
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
const EMPTY_PII_FORM = {
|
|
35
|
+
documentType: "passport",
|
|
36
|
+
documentNumber: "",
|
|
37
|
+
documentExpiry: "",
|
|
38
|
+
documentIssuingCountry: "",
|
|
39
|
+
documentIssuingAuthority: "",
|
|
40
|
+
dateOfBirth: "",
|
|
41
|
+
dietaryRequirements: "",
|
|
42
|
+
accessibilityNeeds: "",
|
|
43
|
+
};
|
|
44
|
+
export function TravelerDialog({ open, onOpenChange, bookingId, traveler, onSuccess, }) {
|
|
45
|
+
const isEditing = Boolean(traveler);
|
|
46
|
+
const personId = traveler?.personId ?? null;
|
|
47
|
+
const messages = useBookingsUiMessagesOrDefault();
|
|
48
|
+
const travelerFormSchema = createTravelerFormSchema(messages);
|
|
49
|
+
const travelerMutation = useTravelerWithTravelDetailsMutation(bookingId);
|
|
50
|
+
const personMutation = usePersonMutation();
|
|
51
|
+
const documentMutation = usePersonDocumentMutation(personId ?? undefined);
|
|
52
|
+
const reveal = useRevealTraveler(bookingId, traveler?.id ?? null, {
|
|
53
|
+
enabled: Boolean(open && isEditing && traveler?.id),
|
|
54
|
+
});
|
|
55
|
+
const snapshotQuery = usePersonTravelSnapshot(personId ?? undefined, {
|
|
56
|
+
enabled: open && Boolean(personId),
|
|
57
|
+
});
|
|
58
|
+
const documentsQuery = usePersonDocuments(personId ?? undefined, {
|
|
59
|
+
enabled: open && Boolean(personId),
|
|
60
|
+
});
|
|
61
|
+
const snapshot = snapshotQuery.data?.data ?? null;
|
|
62
|
+
const revealedTravelDetails = reveal.data?.data.travelDetails ?? null;
|
|
63
|
+
const form = useForm({
|
|
64
|
+
resolver: zodResolver(travelerFormSchema),
|
|
65
|
+
defaultValues: {
|
|
66
|
+
firstName: "",
|
|
67
|
+
lastName: "",
|
|
68
|
+
email: "",
|
|
69
|
+
phone: "",
|
|
70
|
+
specialRequests: "",
|
|
71
|
+
...EMPTY_PII_FORM,
|
|
72
|
+
},
|
|
73
|
+
});
|
|
74
|
+
const [savedToProfileMessage, setSavedToProfileMessage] = useState(false);
|
|
75
|
+
const [prefilledNotice, setPrefilledNotice] = useState(false);
|
|
76
|
+
useEffect(() => {
|
|
77
|
+
setSavedToProfileMessage(false);
|
|
78
|
+
setPrefilledNotice(false);
|
|
79
|
+
if (!open)
|
|
80
|
+
return;
|
|
81
|
+
if (traveler) {
|
|
82
|
+
form.reset({
|
|
83
|
+
firstName: traveler.firstName,
|
|
84
|
+
lastName: traveler.lastName,
|
|
85
|
+
email: traveler.email ?? "",
|
|
86
|
+
phone: traveler.phone ?? "",
|
|
87
|
+
specialRequests: traveler.specialRequests ?? "",
|
|
88
|
+
documentType: revealedTravelDetails?.documentType ?? "passport",
|
|
89
|
+
documentNumber: revealedTravelDetails?.documentNumber ?? "",
|
|
90
|
+
documentExpiry: revealedTravelDetails?.documentExpiry ?? "",
|
|
91
|
+
documentIssuingCountry: revealedTravelDetails?.documentIssuingCountry ?? "",
|
|
92
|
+
documentIssuingAuthority: revealedTravelDetails?.documentIssuingAuthority ?? "",
|
|
93
|
+
dateOfBirth: revealedTravelDetails?.dateOfBirth ?? "",
|
|
94
|
+
dietaryRequirements: revealedTravelDetails?.dietaryRequirements ?? "",
|
|
95
|
+
accessibilityNeeds: revealedTravelDetails?.accessibilityNeeds ?? "",
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
form.reset({
|
|
100
|
+
firstName: "",
|
|
101
|
+
lastName: "",
|
|
102
|
+
email: "",
|
|
103
|
+
phone: "",
|
|
104
|
+
specialRequests: "",
|
|
105
|
+
...EMPTY_PII_FORM,
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
}, [form, open, traveler, revealedTravelDetails]);
|
|
109
|
+
const prefillFromProfile = () => {
|
|
110
|
+
if (!snapshot)
|
|
111
|
+
return;
|
|
112
|
+
form.setValue("documentType", snapshot.documentType ?? "passport");
|
|
113
|
+
form.setValue("documentNumber", snapshot.documentNumber ?? "");
|
|
114
|
+
form.setValue("documentExpiry", snapshot.documentExpiry ?? "");
|
|
115
|
+
form.setValue("documentIssuingCountry", snapshot.documentIssuingCountry ?? "");
|
|
116
|
+
form.setValue("documentIssuingAuthority", snapshot.documentIssuingAuthority ?? "");
|
|
117
|
+
form.setValue("dateOfBirth", snapshot.dateOfBirth ?? "");
|
|
118
|
+
form.setValue("dietaryRequirements", snapshot.dietaryRequirements ?? "");
|
|
119
|
+
form.setValue("accessibilityNeeds", snapshot.accessibilityNeeds ?? "");
|
|
120
|
+
setPrefilledNotice(true);
|
|
121
|
+
setSavedToProfileMessage(false);
|
|
122
|
+
};
|
|
123
|
+
const onSubmit = async (values) => {
|
|
124
|
+
const trimOrNull = (value) => {
|
|
125
|
+
if (value === null || value === undefined)
|
|
126
|
+
return null;
|
|
127
|
+
const trimmed = value.trim();
|
|
128
|
+
return trimmed === "" ? null : trimmed;
|
|
129
|
+
};
|
|
130
|
+
const payload = {
|
|
131
|
+
firstName: values.firstName,
|
|
132
|
+
lastName: values.lastName,
|
|
133
|
+
email: values.email || null,
|
|
134
|
+
phone: values.phone || null,
|
|
135
|
+
specialRequests: values.specialRequests || null,
|
|
136
|
+
isPrimary: traveler?.isPrimary ?? false,
|
|
137
|
+
participantType: "traveler",
|
|
138
|
+
documentType: values.documentType,
|
|
139
|
+
documentNumber: trimOrNull(values.documentNumber),
|
|
140
|
+
documentExpiry: trimOrNull(values.documentExpiry),
|
|
141
|
+
documentIssuingCountry: trimOrNull(values.documentIssuingCountry),
|
|
142
|
+
documentIssuingAuthority: trimOrNull(values.documentIssuingAuthority),
|
|
143
|
+
dateOfBirth: trimOrNull(values.dateOfBirth),
|
|
144
|
+
dietaryRequirements: trimOrNull(values.dietaryRequirements),
|
|
145
|
+
accessibilityNeeds: trimOrNull(values.accessibilityNeeds),
|
|
146
|
+
};
|
|
147
|
+
if (isEditing) {
|
|
148
|
+
await travelerMutation.update.mutateAsync({ travelerId: traveler.id, input: payload });
|
|
149
|
+
}
|
|
150
|
+
else {
|
|
151
|
+
await travelerMutation.create.mutateAsync(payload);
|
|
152
|
+
}
|
|
153
|
+
onOpenChange(false);
|
|
154
|
+
onSuccess?.();
|
|
155
|
+
};
|
|
156
|
+
/**
|
|
157
|
+
* Pushes diverging dietary / accessibility / document values from
|
|
158
|
+
* the form back to the linked person record. Dietary + accessibility
|
|
159
|
+
* land on `crm.people` via the profile-pii endpoint. Document
|
|
160
|
+
* diffs update the existing primary document of the selected type if
|
|
161
|
+
* there is one, otherwise create a new primary document.
|
|
162
|
+
*/
|
|
163
|
+
const saveBackToProfile = async () => {
|
|
164
|
+
if (!personId)
|
|
165
|
+
return;
|
|
166
|
+
const values = form.getValues();
|
|
167
|
+
const trim = (value) => {
|
|
168
|
+
if (value === null || value === undefined)
|
|
169
|
+
return null;
|
|
170
|
+
const trimmed = value.trim();
|
|
171
|
+
return trimmed === "" ? null : trimmed;
|
|
172
|
+
};
|
|
173
|
+
const formDietary = trim(values.dietaryRequirements);
|
|
174
|
+
const formAccessibility = trim(values.accessibilityNeeds);
|
|
175
|
+
const formDocumentType = values.documentType ?? "passport";
|
|
176
|
+
const formDocumentNumber = trim(values.documentNumber);
|
|
177
|
+
const formDocumentExpiry = trim(values.documentExpiry);
|
|
178
|
+
const formDocumentCountry = trim(values.documentIssuingCountry);
|
|
179
|
+
const formDocumentAuthority = trim(values.documentIssuingAuthority);
|
|
180
|
+
const piiUpdate = {};
|
|
181
|
+
if (formDietary !== (snapshot?.dietaryRequirements ?? null)) {
|
|
182
|
+
piiUpdate.dietary = formDietary;
|
|
183
|
+
}
|
|
184
|
+
if (formAccessibility !== (snapshot?.accessibilityNeeds ?? null)) {
|
|
185
|
+
piiUpdate.accessibility = formAccessibility;
|
|
186
|
+
}
|
|
187
|
+
if (Object.keys(piiUpdate).length > 0) {
|
|
188
|
+
await personMutation.updateProfilePii.mutateAsync({ personId, input: piiUpdate });
|
|
189
|
+
}
|
|
190
|
+
const documentDiverged = formDocumentType !== (snapshot?.documentType ?? "passport") ||
|
|
191
|
+
formDocumentNumber !== (snapshot?.documentNumber ?? null) ||
|
|
192
|
+
formDocumentExpiry !== (snapshot?.documentExpiry ?? null) ||
|
|
193
|
+
formDocumentCountry !== (snapshot?.documentIssuingCountry ?? null) ||
|
|
194
|
+
formDocumentAuthority !== (snapshot?.documentIssuingAuthority ?? null);
|
|
195
|
+
if (documentDiverged) {
|
|
196
|
+
const documentPayload = {
|
|
197
|
+
type: formDocumentType,
|
|
198
|
+
number: formDocumentNumber,
|
|
199
|
+
issuingCountry: formDocumentCountry,
|
|
200
|
+
issuingAuthority: formDocumentAuthority,
|
|
201
|
+
expiryDate: formDocumentExpiry,
|
|
202
|
+
isPrimary: true,
|
|
203
|
+
};
|
|
204
|
+
const primaryDocument = documentsQuery.data?.data.find((row) => row.type === formDocumentType && row.isPrimary) ??
|
|
205
|
+
null;
|
|
206
|
+
if (primaryDocument) {
|
|
207
|
+
await documentMutation.updateFromPlaintext.mutateAsync({
|
|
208
|
+
id: primaryDocument.id,
|
|
209
|
+
input: documentPayload,
|
|
210
|
+
});
|
|
211
|
+
}
|
|
212
|
+
else {
|
|
213
|
+
await documentMutation.createFromPlaintext.mutateAsync(documentPayload);
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
setSavedToProfileMessage(true);
|
|
217
|
+
setPrefilledNotice(false);
|
|
218
|
+
};
|
|
219
|
+
const isSubmitting = travelerMutation.create.isPending || travelerMutation.update.isPending;
|
|
220
|
+
const isSavingProfile = personMutation.updateProfilePii.isPending ||
|
|
221
|
+
documentMutation.updateFromPlaintext.isPending ||
|
|
222
|
+
documentMutation.createFromPlaintext.isPending;
|
|
223
|
+
const watched = form.watch();
|
|
224
|
+
const hasDivergence = Boolean(personId) &&
|
|
225
|
+
snapshot &&
|
|
226
|
+
[
|
|
227
|
+
["dietaryRequirements", "dietaryRequirements"],
|
|
228
|
+
["accessibilityNeeds", "accessibilityNeeds"],
|
|
229
|
+
["documentType", "documentType"],
|
|
230
|
+
["documentNumber", "documentNumber"],
|
|
231
|
+
["documentExpiry", "documentExpiry"],
|
|
232
|
+
["documentIssuingCountry", "documentIssuingCountry"],
|
|
233
|
+
["documentIssuingAuthority", "documentIssuingAuthority"],
|
|
234
|
+
].some(([formKey, snapKey]) => {
|
|
235
|
+
const formValue = watched[formKey] ?? "";
|
|
236
|
+
const snapValue = snapshot[snapKey] ?? "";
|
|
237
|
+
return String(formValue ?? "").trim() !== String(snapValue ?? "").trim();
|
|
238
|
+
});
|
|
239
|
+
return (_jsx(Dialog, { open: open, onOpenChange: onOpenChange, children: _jsxs(DialogContent, { size: "lg", children: [_jsx(DialogHeader, { children: _jsx(DialogTitle, { children: isEditing
|
|
240
|
+
? messages.travelerDialog.titles.edit
|
|
241
|
+
: messages.travelerDialog.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.travelerDialog.fields.firstName }), _jsx(Input, { ...form.register("firstName"), placeholder: messages.travelerDialog.placeholders.firstName }), form.formState.errors.firstName && (_jsx("p", { className: "text-xs text-destructive", children: form.formState.errors.firstName.message }))] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.travelerDialog.fields.lastName }), _jsx(Input, { ...form.register("lastName"), placeholder: messages.travelerDialog.placeholders.lastName }), form.formState.errors.lastName && (_jsx("p", { className: "text-xs text-destructive", children: form.formState.errors.lastName.message }))] })] }), _jsxs("div", { className: "grid grid-cols-2 gap-4", children: [_jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.travelerDialog.fields.email }), _jsx(Input, { ...form.register("email"), type: "email", placeholder: messages.travelerDialog.placeholders.email })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.travelerDialog.fields.phone }), _jsx(PhoneInput, { value: form.watch("phone") ?? "", onChange: (next) => form.setValue("phone", next, { shouldDirty: true }) })] })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.travelerDialog.fields.specialRequests }), _jsx(Textarea, { ...form.register("specialRequests"), placeholder: messages.travelerDialog.placeholders.specialRequests })] }), _jsxs("div", { className: "flex flex-col gap-3 border-t pt-4", children: [_jsxs("div", { className: "flex items-center justify-between gap-2", children: [_jsx("h3", { className: "text-sm font-semibold", children: messages.travelerDialog.fields.travelDetailsHeading }), personId ? (_jsxs(Button, { type: "button", variant: "ghost", size: "sm", disabled: !snapshot || snapshotQuery.isLoading, onClick: prefillFromProfile, children: [_jsx(Sparkles, { className: "mr-2 h-3.5 w-3.5" }), messages.travelerDialog.actions.prefillFromProfile] })) : null] }), prefilledNotice ? (_jsx("p", { className: "text-xs text-muted-foreground", children: messages.travelerDialog.hints.prefilledFromProfile })) : null, _jsxs("div", { className: "grid grid-cols-2 gap-4", children: [_jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.travelerDialog.fields.documentType }), _jsxs(Select, { value: form.watch("documentType") ?? "passport", onValueChange: (nextValue) => form.setValue("documentType", nextValue, {
|
|
242
|
+
shouldDirty: true,
|
|
243
|
+
shouldValidate: true,
|
|
244
|
+
}), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsx(SelectContent, { children: identityDocumentTypes.map((type) => (_jsx(SelectItem, { value: type, children: messages.travelerDialog.documentTypeLabels[type] }, type))) })] })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.travelerDialog.fields.documentNumber }), _jsx(Input, { ...form.register("documentNumber"), placeholder: messages.travelerDialog.placeholders.documentNumber })] })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.travelerDialog.fields.documentExpiry }), _jsx(DatePicker, { value: form.watch("documentExpiry") || null, onChange: (nextValue) => form.setValue("documentExpiry", nextValue ?? "", {
|
|
245
|
+
shouldDirty: true,
|
|
246
|
+
shouldValidate: true,
|
|
247
|
+
}), placeholder: messages.travelerDialog.placeholders.documentExpiry })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.travelerDialog.fields.documentIssuingCountry }), _jsx(CountryCombobox, { value: form.watch("documentIssuingCountry") || null, onChange: (next) => form.setValue("documentIssuingCountry", next ?? "", {
|
|
248
|
+
shouldDirty: true,
|
|
249
|
+
shouldValidate: true,
|
|
250
|
+
}) })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.travelerDialog.fields.documentIssuingAuthority }), _jsx(Input, { ...form.register("documentIssuingAuthority"), placeholder: messages.travelerDialog.placeholders.documentIssuingAuthority })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.travelerDialog.fields.dateOfBirth }), _jsx(DatePicker, { value: form.watch("dateOfBirth") || null, onChange: (nextValue) => form.setValue("dateOfBirth", nextValue ?? "", {
|
|
251
|
+
shouldDirty: true,
|
|
252
|
+
shouldValidate: true,
|
|
253
|
+
}), placeholder: messages.travelerDialog.placeholders.dateOfBirth })] }), _jsxs("div", { className: "grid grid-cols-2 gap-4", children: [_jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.travelerDialog.fields.dietaryRequirements }), _jsx(Textarea, { ...form.register("dietaryRequirements"), placeholder: messages.travelerDialog.placeholders.dietaryRequirements })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: messages.travelerDialog.fields.accessibilityNeeds }), _jsx(Textarea, { ...form.register("accessibilityNeeds"), placeholder: messages.travelerDialog.placeholders.accessibilityNeeds })] })] }), personId && hasDivergence ? (_jsxs("div", { className: "flex items-center justify-between gap-2 rounded-md border bg-muted/40 px-3 py-2", children: [_jsx("p", { className: "text-xs text-muted-foreground", children: savedToProfileMessage ? messages.travelerDialog.hints.savedToProfile : null }), _jsxs(Button, { type: "button", variant: "outline", size: "sm", disabled: isSavingProfile, onClick: saveBackToProfile, children: [isSavingProfile ? (_jsx(Loader2, { className: "mr-2 h-3.5 w-3.5 animate-spin" })) : (_jsx(Upload, { className: "mr-2 h-3.5 w-3.5" })), messages.travelerDialog.actions.saveToProfile] })] })) : 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: isSubmitting, children: [isSubmitting && _jsx(Loader2, { className: "mr-2 h-4 w-4 animate-spin" }), isEditing
|
|
254
|
+
? messages.common.saveChanges
|
|
255
|
+
: messages.travelerDialog.actions.addTraveler] })] })] })] }) }));
|
|
256
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"traveler-list.d.ts","sourceRoot":"","sources":["../../src/components/traveler-list.tsx"],"names":[],"mappings":"AAuCA,MAAM,WAAW,iBAAiB;IAChC,SAAS,EAAE,MAAM,CAAA;IACjB,UAAU,CAAC,EAAE,OAAO,CAAA;CACrB;AAED,wBAAgB,YAAY,CAAC,EAAE,SAAS,EAAE,UAAkB,EAAE,EAAE,iBAAiB,2CA2RhF"}
|
|
@@ -0,0 +1,295 @@
|
|
|
1
|
+
// agent-quality: file-size exception -- owner: bookings-react; existing UI surface stays co-located until a dedicated split preserves behavior and tests.
|
|
2
|
+
"use client";
|
|
3
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
4
|
+
import { usePerson } from "@voyant-travel/relationships-react";
|
|
5
|
+
import { AlertDialog, AlertDialogAction, AlertDialogCancel, AlertDialogContent, AlertDialogDescription, AlertDialogFooter, AlertDialogHeader, AlertDialogTitle, Button, } from "@voyant-travel/ui/components";
|
|
6
|
+
import { DataTable } from "@voyant-travel/ui/components/data-table";
|
|
7
|
+
import { Sheet, SheetContent, SheetDescription, SheetHeader, SheetTitle, } from "@voyant-travel/ui/components/sheet";
|
|
8
|
+
import { Eye, EyeOff, Loader2, Pencil, Plus, Trash2, Users } from "lucide-react";
|
|
9
|
+
import * as React from "react";
|
|
10
|
+
import { formatMessage, useBookingsUiMessagesOrDefault } from "../i18n/provider.js";
|
|
11
|
+
import { useBookingTravelerDocuments, useRevealTraveler, useTravelerMutation, useTravelers, } from "../index.js";
|
|
12
|
+
import { IconActionButton } from "./icon-action-button.js";
|
|
13
|
+
import { TravelerDialog } from "./traveler-dialog.js";
|
|
14
|
+
export function TravelerList({ bookingId, autoReveal = false }) {
|
|
15
|
+
const [dialogOpen, setDialogOpen] = React.useState(false);
|
|
16
|
+
const [editing, setEditing] = React.useState(undefined);
|
|
17
|
+
const [viewingId, setViewingId] = React.useState(null);
|
|
18
|
+
const [deleteTarget, setDeleteTarget] = React.useState(null);
|
|
19
|
+
const [revealedIds, setRevealedIds] = React.useState(new Set());
|
|
20
|
+
const { data } = useTravelers(bookingId);
|
|
21
|
+
const documentsQuery = useBookingTravelerDocuments(bookingId);
|
|
22
|
+
const { remove } = useTravelerMutation(bookingId);
|
|
23
|
+
const messages = useBookingsUiMessagesOrDefault();
|
|
24
|
+
const travelers = data?.data ?? [];
|
|
25
|
+
const documentsByTraveler = React.useMemo(() => {
|
|
26
|
+
const grouped = new Map();
|
|
27
|
+
for (const document of documentsQuery.data?.data ?? []) {
|
|
28
|
+
if (!document.travelerId)
|
|
29
|
+
continue;
|
|
30
|
+
const bucket = grouped.get(document.travelerId) ?? [];
|
|
31
|
+
bucket.push(document);
|
|
32
|
+
grouped.set(document.travelerId, bucket);
|
|
33
|
+
}
|
|
34
|
+
return grouped;
|
|
35
|
+
}, [documentsQuery.data?.data]);
|
|
36
|
+
// Detect whether the list endpoint already returned unmasked data
|
|
37
|
+
// (caller has bookings-pii:* scope or similar). If so, don't show
|
|
38
|
+
// the reveal button — there's nothing to unmask.
|
|
39
|
+
const allAlreadyRevealed = React.useMemo(() => {
|
|
40
|
+
if (travelers.length === 0)
|
|
41
|
+
return true;
|
|
42
|
+
return travelers.every((t) => !looksRedacted(t));
|
|
43
|
+
}, [travelers]);
|
|
44
|
+
const toggleReveal = React.useCallback((travelerId) => {
|
|
45
|
+
setRevealedIds((prev) => {
|
|
46
|
+
const next = new Set(prev);
|
|
47
|
+
if (next.has(travelerId))
|
|
48
|
+
next.delete(travelerId);
|
|
49
|
+
else
|
|
50
|
+
next.add(travelerId);
|
|
51
|
+
return next;
|
|
52
|
+
});
|
|
53
|
+
}, []);
|
|
54
|
+
const isRevealed = React.useCallback((travelerId) => autoReveal || revealedIds.has(travelerId), [autoReveal, revealedIds]);
|
|
55
|
+
const deleteMessages = messages.travelerList.actions.deleteConfirm;
|
|
56
|
+
const handleConfirmDelete = async () => {
|
|
57
|
+
if (!deleteTarget)
|
|
58
|
+
return;
|
|
59
|
+
await remove.mutateAsync(deleteTarget.id);
|
|
60
|
+
setDeleteTarget(null);
|
|
61
|
+
};
|
|
62
|
+
const columns = React.useMemo(() => [
|
|
63
|
+
{
|
|
64
|
+
accessorKey: "firstName",
|
|
65
|
+
header: messages.travelerList.columns.name,
|
|
66
|
+
cell: ({ row }) => (_jsx(TravelerNameCell, { bookingId: bookingId, traveler: row.original, revealed: isRevealed(row.original.id) })),
|
|
67
|
+
},
|
|
68
|
+
{
|
|
69
|
+
accessorKey: "email",
|
|
70
|
+
header: messages.travelerList.columns.email,
|
|
71
|
+
cell: ({ row }) => (_jsx(TravelerContactCell, { bookingId: bookingId, traveler: row.original, revealed: isRevealed(row.original.id), field: "email" })),
|
|
72
|
+
},
|
|
73
|
+
{
|
|
74
|
+
accessorKey: "phone",
|
|
75
|
+
header: messages.travelerList.columns.phone,
|
|
76
|
+
cell: ({ row }) => (_jsx(TravelerContactCell, { bookingId: bookingId, traveler: row.original, revealed: isRevealed(row.original.id), field: "phone" })),
|
|
77
|
+
},
|
|
78
|
+
{
|
|
79
|
+
id: "role",
|
|
80
|
+
header: messages.travelerList.columns.role,
|
|
81
|
+
cell: ({ row }) => _jsx(RolePills, { traveler: row.original }),
|
|
82
|
+
},
|
|
83
|
+
{
|
|
84
|
+
id: "dobAge",
|
|
85
|
+
header: messages.travelerList.columns.dobAge,
|
|
86
|
+
cell: ({ row }) => (_jsx(TravelerDobCell, { bookingId: bookingId, traveler: row.original, revealed: isRevealed(row.original.id) })),
|
|
87
|
+
},
|
|
88
|
+
{
|
|
89
|
+
id: "documents",
|
|
90
|
+
header: messages.travelerList.columns.documents,
|
|
91
|
+
cell: ({ row }) => {
|
|
92
|
+
const documents = documentsByTraveler.get(row.original.id) ?? [];
|
|
93
|
+
if (documents.length === 0) {
|
|
94
|
+
return (_jsx("span", { className: "text-muted-foreground text-xs", children: messages.travelerList.values.documentsUnavailable }));
|
|
95
|
+
}
|
|
96
|
+
return (_jsxs("div", { className: "flex flex-wrap gap-1.5", children: [documents.slice(0, 2).map((document) => (_jsx(MiniPill, { children: document.type.replaceAll("_", " ") }, document.id))), documents.length > 2 ? _jsxs(MiniPill, { children: ["+", documents.length - 2] }) : null] }));
|
|
97
|
+
},
|
|
98
|
+
},
|
|
99
|
+
{
|
|
100
|
+
id: "actions",
|
|
101
|
+
header: "",
|
|
102
|
+
cell: ({ row }) => {
|
|
103
|
+
const traveler = row.original;
|
|
104
|
+
const revealed = isRevealed(traveler.id);
|
|
105
|
+
const showRevealToggle = !autoReveal && !allAlreadyRevealed;
|
|
106
|
+
return (_jsxs("div", { className: "flex items-center justify-end gap-1", children: [showRevealToggle ? (_jsx(IconActionButton, { label: revealed
|
|
107
|
+
? messages.travelerList.actions.hideContactDetails
|
|
108
|
+
: messages.travelerList.actions.revealContactDetails, icon: revealed ? _jsx(EyeOff, { className: "h-3.5 w-3.5" }) : _jsx(Eye, { className: "h-3.5 w-3.5" }), onClick: (e) => {
|
|
109
|
+
e.stopPropagation();
|
|
110
|
+
toggleReveal(traveler.id);
|
|
111
|
+
} })) : null, _jsx(IconActionButton, { label: messages.travelerList.actions.viewTraveler, icon: _jsx(Eye, { className: "h-3.5 w-3.5" }), onClick: (e) => {
|
|
112
|
+
e.stopPropagation();
|
|
113
|
+
setViewingId(traveler.id);
|
|
114
|
+
} }), _jsx(IconActionButton, { label: messages.travelerList.actions.editTraveler, icon: _jsx(Pencil, { className: "h-3.5 w-3.5" }), onClick: (e) => {
|
|
115
|
+
e.stopPropagation();
|
|
116
|
+
setEditing(traveler);
|
|
117
|
+
setDialogOpen(true);
|
|
118
|
+
} }), _jsx(IconActionButton, { label: messages.travelerList.actions.deleteTraveler, icon: _jsx(Trash2, { className: "h-3.5 w-3.5" }), className: "text-muted-foreground hover:bg-destructive/10 hover:text-destructive", onClick: (e) => {
|
|
119
|
+
e.stopPropagation();
|
|
120
|
+
setDeleteTarget(traveler);
|
|
121
|
+
} })] }));
|
|
122
|
+
},
|
|
123
|
+
},
|
|
124
|
+
], [
|
|
125
|
+
allAlreadyRevealed,
|
|
126
|
+
autoReveal,
|
|
127
|
+
bookingId,
|
|
128
|
+
documentsByTraveler,
|
|
129
|
+
isRevealed,
|
|
130
|
+
messages,
|
|
131
|
+
toggleReveal,
|
|
132
|
+
]);
|
|
133
|
+
const viewingTraveler = viewingId ? (travelers.find((t) => t.id === viewingId) ?? null) : null;
|
|
134
|
+
return (_jsxs("div", { "data-slot": "traveler-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(Users, { className: "h-4 w-4" }), messages.travelerList.title] }), _jsxs(Button, { variant: "outline", size: "sm", onClick: () => {
|
|
135
|
+
setEditing(undefined);
|
|
136
|
+
setDialogOpen(true);
|
|
137
|
+
}, children: [_jsx(Plus, { className: "mr-2 h-4 w-4" }), messages.travelerList.addTraveler] })] }), _jsx(DataTable, { columns: columns, data: travelers, emptyMessage: messages.travelerList.empty, showPagination: false }), _jsx(TravelerDialog, { open: dialogOpen, onOpenChange: (nextOpen) => {
|
|
138
|
+
setDialogOpen(nextOpen);
|
|
139
|
+
if (!nextOpen)
|
|
140
|
+
setEditing(undefined);
|
|
141
|
+
}, bookingId: bookingId, traveler: editing, onSuccess: () => setEditing(undefined) }), _jsx(Sheet, { open: Boolean(viewingTraveler), onOpenChange: (next) => {
|
|
142
|
+
if (!next)
|
|
143
|
+
setViewingId(null);
|
|
144
|
+
}, children: _jsxs(SheetContent, { side: "right", className: "sm:max-w-2xl", children: [_jsxs(SheetHeader, { children: [_jsx(SheetTitle, { children: messages.travelerList.snapshot.title }), _jsx(SheetDescription, { children: messages.travelerList.snapshot.subtitle })] }), viewingTraveler ? (_jsx(TravelerSnapshotBody, { bookingId: bookingId, traveler: viewingTraveler, documents: documentsByTraveler.get(viewingTraveler.id) ?? [] })) : null] }) }), _jsx(AlertDialog, { open: Boolean(deleteTarget), onOpenChange: (next) => {
|
|
145
|
+
if (!next && !remove.isPending)
|
|
146
|
+
setDeleteTarget(null);
|
|
147
|
+
}, 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 })] })] }) })] }));
|
|
148
|
+
}
|
|
149
|
+
function useRevealed(bookingId, traveler, revealed) {
|
|
150
|
+
const reveal = useRevealTraveler(bookingId, traveler.id, { enabled: revealed });
|
|
151
|
+
const revealedTraveler = reveal.data?.data;
|
|
152
|
+
const display = revealed && revealedTraveler ? revealedTraveler : traveler;
|
|
153
|
+
const travelDetails = revealed && revealedTraveler ? revealedTraveler.travelDetails : null;
|
|
154
|
+
return {
|
|
155
|
+
display,
|
|
156
|
+
travelDetails,
|
|
157
|
+
loading: revealed && reveal.isLoading,
|
|
158
|
+
error: revealed ? reveal.error : null,
|
|
159
|
+
};
|
|
160
|
+
}
|
|
161
|
+
function TravelerNameCell({ bookingId, traveler, revealed, }) {
|
|
162
|
+
const { display, loading } = useRevealed(bookingId, traveler, revealed);
|
|
163
|
+
if (loading)
|
|
164
|
+
return _jsx(RowLoading, {});
|
|
165
|
+
return _jsx("span", { children: `${display.firstName ?? ""} ${display.lastName ?? ""}`.trim() || "—" });
|
|
166
|
+
}
|
|
167
|
+
function TravelerContactCell({ bookingId, traveler, revealed, field, }) {
|
|
168
|
+
const { display, loading } = useRevealed(bookingId, traveler, revealed);
|
|
169
|
+
const person = usePerson(traveler.personId ?? undefined, {
|
|
170
|
+
enabled: Boolean(traveler.personId),
|
|
171
|
+
}).data;
|
|
172
|
+
const messages = useBookingsUiMessagesOrDefault();
|
|
173
|
+
if (loading)
|
|
174
|
+
return _jsx(RowLoading, {});
|
|
175
|
+
const value = display[field] ?? person?.[field] ?? null;
|
|
176
|
+
if (!value) {
|
|
177
|
+
return (_jsx("span", { className: "text-muted-foreground", children: field === "email"
|
|
178
|
+
? messages.travelerList.values.emailUnavailable
|
|
179
|
+
: messages.travelerList.values.phoneUnavailable }));
|
|
180
|
+
}
|
|
181
|
+
return _jsx(_Fragment, { children: value });
|
|
182
|
+
}
|
|
183
|
+
function TravelerDobCell({ bookingId, traveler, revealed, }) {
|
|
184
|
+
const { travelDetails, loading } = useRevealed(bookingId, traveler, revealed);
|
|
185
|
+
const person = usePerson(traveler.personId ?? undefined, {
|
|
186
|
+
enabled: Boolean(traveler.personId),
|
|
187
|
+
}).data;
|
|
188
|
+
const messages = useBookingsUiMessagesOrDefault();
|
|
189
|
+
if (loading)
|
|
190
|
+
return _jsx(RowLoading, {});
|
|
191
|
+
const dob = travelDetails?.dateOfBirth ?? person?.dateOfBirth ?? null;
|
|
192
|
+
return _jsx(_Fragment, { children: formatDobAge(dob, messages.travelerList.values.fieldUnavailable) });
|
|
193
|
+
}
|
|
194
|
+
function RolePills({ traveler }) {
|
|
195
|
+
const messages = useBookingsUiMessagesOrDefault();
|
|
196
|
+
const pills = [];
|
|
197
|
+
if (traveler.isPrimary)
|
|
198
|
+
pills.push(messages.travelerList.roles.primary);
|
|
199
|
+
if (traveler.travelerCategory)
|
|
200
|
+
pills.push(traveler.travelerCategory);
|
|
201
|
+
if (pills.length === 0)
|
|
202
|
+
return _jsx("span", { className: "text-muted-foreground text-xs", children: "\u2014" });
|
|
203
|
+
return (_jsx("div", { className: "flex flex-wrap gap-1.5", children: pills.map((label) => (_jsx(MiniPill, { children: label }, label))) }));
|
|
204
|
+
}
|
|
205
|
+
function TravelerSnapshotBody({ bookingId, traveler, documents, }) {
|
|
206
|
+
const messages = useBookingsUiMessagesOrDefault();
|
|
207
|
+
const labels = messages.travelerList.snapshot;
|
|
208
|
+
const empty = labels.empty;
|
|
209
|
+
const { display, travelDetails, loading } = useRevealed(bookingId, traveler, true);
|
|
210
|
+
const person = usePerson(traveler.personId ?? undefined, {
|
|
211
|
+
enabled: Boolean(traveler.personId),
|
|
212
|
+
}).data;
|
|
213
|
+
const fullName = `${display.firstName ?? ""} ${display.lastName ?? ""}`.trim() || empty;
|
|
214
|
+
const email = display.email ?? person?.email ?? empty;
|
|
215
|
+
const phone = display.phone ?? person?.phone ?? empty;
|
|
216
|
+
const dob = travelDetails?.dateOfBirth ?? person?.dateOfBirth ?? null;
|
|
217
|
+
const documentTypeLabels = messages.travelerDialog.documentTypeLabels;
|
|
218
|
+
const documentValue = travelDetails?.documentNumber && travelDetails?.documentType
|
|
219
|
+
? `${documentTypeLabels[travelDetails.documentType]} · ${travelDetails.documentNumber}`
|
|
220
|
+
: empty;
|
|
221
|
+
const roles = [];
|
|
222
|
+
if (display.isPrimary)
|
|
223
|
+
roles.push(messages.travelerList.roles.primary);
|
|
224
|
+
if (travelDetails?.isLeadTraveler)
|
|
225
|
+
roles.push(messages.travelerList.roles.lead);
|
|
226
|
+
if (display.travelerCategory)
|
|
227
|
+
roles.push(display.travelerCategory);
|
|
228
|
+
return (_jsxs("div", { className: "flex-1 overflow-y-auto px-4 pb-4", children: [loading ? (_jsx("div", { className: "py-4", children: _jsx(RowLoading, {}) })) : null, _jsxs(SnapshotSection, { title: labels.sectionContact, children: [_jsx(SnapshotRow, { label: labels.nameLabel, value: fullName }), _jsx(SnapshotRow, { label: labels.emailLabel, value: email }), _jsx(SnapshotRow, { label: labels.phoneLabel, value: phone }), _jsx(SnapshotRow, { label: labels.languageLabel, value: display.preferredLanguage || empty }), _jsx(SnapshotRow, { label: labels.roleLabel, value: roles.length > 0 ? (_jsx("div", { className: "flex flex-wrap gap-1.5", children: roles.map((label) => (_jsx(MiniPill, { children: label }, label))) })) : (empty) })] }), _jsxs(SnapshotSection, { title: labels.sectionTravel, children: [_jsx(SnapshotRow, { label: labels.dobLabel, value: formatDobAge(dob, empty) }), _jsx(SnapshotRow, { label: labels.nationalityLabel, value: travelDetails?.nationality || empty }), _jsx(SnapshotRow, { label: labels.documentLabel, value: documentValue }), _jsx(SnapshotRow, { label: labels.documentExpiryLabel, value: formatDateValue(travelDetails?.documentExpiry) ?? empty }), _jsx(SnapshotRow, { label: labels.dietaryLabel, value: travelDetails?.dietaryRequirements || empty, multiline: true }), _jsx(SnapshotRow, { label: labels.accessibilityLabel, value: travelDetails?.accessibilityNeeds || empty, multiline: true }), _jsx(SnapshotRow, { label: labels.specialRequestsLabel, value: display.specialRequests || empty, multiline: true }), _jsx(SnapshotRow, { label: labels.notesLabel, value: display.notes || empty, multiline: true })] }), _jsx(SnapshotSection, { title: labels.sectionDocuments, children: documents.length === 0 ? (_jsx("div", { className: "px-3 py-3 text-sm text-muted-foreground", children: labels.noDocuments })) : (documents.map((document) => (_jsx(SnapshotRow, { label: formatMessage(messages.travelerList.context.documentLabel, {
|
|
229
|
+
type: document.type.replaceAll("_", " "),
|
|
230
|
+
}), value: document.fileName }, document.id)))) }), _jsxs(SnapshotSection, { title: labels.sectionMeta, children: [_jsx(SnapshotRow, { label: labels.createdAtLabel, value: formatTimestamp(traveler.createdAt) ?? empty }), _jsx(SnapshotRow, { label: labels.updatedAtLabel, value: formatTimestamp(traveler.updatedAt) ?? empty })] })] }));
|
|
231
|
+
}
|
|
232
|
+
function SnapshotSection({ title, children }) {
|
|
233
|
+
return (_jsxs("section", { className: "mb-6", children: [_jsx("h3", { className: "mb-2 text-xs font-medium uppercase tracking-wide text-muted-foreground", children: title }), _jsx("dl", { className: "divide-y divide-border rounded-md border", children: children })] }));
|
|
234
|
+
}
|
|
235
|
+
function SnapshotRow({ label, value, multiline, }) {
|
|
236
|
+
return (_jsxs("div", { className: "grid grid-cols-[10rem_1fr] items-baseline gap-3 px-3 py-2 text-sm", children: [_jsx("dt", { className: "text-xs text-muted-foreground", children: label }), _jsx("dd", { className: multiline ? "whitespace-pre-wrap text-sm" : "truncate text-sm", children: value })] }));
|
|
237
|
+
}
|
|
238
|
+
function RowLoading() {
|
|
239
|
+
const messages = useBookingsUiMessagesOrDefault();
|
|
240
|
+
return (_jsxs("span", { className: "inline-flex items-center gap-1.5 text-muted-foreground", children: [_jsx(Loader2, { className: "h-3 w-3 animate-spin" }), _jsx("span", { className: "text-xs", children: messages.travelerList.loading.decrypting })] }));
|
|
241
|
+
}
|
|
242
|
+
function MiniPill({ children }) {
|
|
243
|
+
return (_jsx("span", { className: "inline-flex h-5 items-center rounded-full border px-2 text-[11px] capitalize text-muted-foreground", children: children }));
|
|
244
|
+
}
|
|
245
|
+
function formatTimestamp(iso) {
|
|
246
|
+
if (!iso)
|
|
247
|
+
return null;
|
|
248
|
+
const d = new Date(iso);
|
|
249
|
+
if (!Number.isFinite(d.getTime()))
|
|
250
|
+
return null;
|
|
251
|
+
try {
|
|
252
|
+
return d.toLocaleString(undefined, {
|
|
253
|
+
day: "numeric",
|
|
254
|
+
month: "short",
|
|
255
|
+
year: "numeric",
|
|
256
|
+
hour: "2-digit",
|
|
257
|
+
minute: "2-digit",
|
|
258
|
+
});
|
|
259
|
+
}
|
|
260
|
+
catch {
|
|
261
|
+
return d.toISOString();
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
function formatDobAge(value, unavailable) {
|
|
265
|
+
if (!value)
|
|
266
|
+
return unavailable;
|
|
267
|
+
const date = new Date(value);
|
|
268
|
+
if (Number.isNaN(date.getTime()))
|
|
269
|
+
return value;
|
|
270
|
+
const today = new Date();
|
|
271
|
+
let age = today.getFullYear() - date.getFullYear();
|
|
272
|
+
const birthdayPassed = today.getMonth() > date.getMonth() ||
|
|
273
|
+
(today.getMonth() === date.getMonth() && today.getDate() >= date.getDate());
|
|
274
|
+
if (!birthdayPassed)
|
|
275
|
+
age -= 1;
|
|
276
|
+
return `${formatDateValue(value)} · ${age}`;
|
|
277
|
+
}
|
|
278
|
+
function formatDateValue(value) {
|
|
279
|
+
if (!value)
|
|
280
|
+
return null;
|
|
281
|
+
const date = new Date(value);
|
|
282
|
+
if (Number.isNaN(date.getTime()))
|
|
283
|
+
return value;
|
|
284
|
+
return date.toLocaleDateString(undefined, { month: "short", day: "numeric", year: "numeric" });
|
|
285
|
+
}
|
|
286
|
+
/**
|
|
287
|
+
* Heuristic check for redaction markers used by `redactTravelerIdentity`
|
|
288
|
+
* on the API. We can't import the redactor from `@voyant-travel/bookings`
|
|
289
|
+
* at the UI layer (would pull in a server dep), so probe for the
|
|
290
|
+
* canonical patterns the redactor produces (`***`, `*@`, `***1234`).
|
|
291
|
+
*/
|
|
292
|
+
function looksRedacted(traveler) {
|
|
293
|
+
const fields = [traveler.firstName, traveler.lastName, traveler.email, traveler.phone];
|
|
294
|
+
return fields.some((v) => typeof v === "string" && (v === "***" || /\*\*\*/.test(v) || /\*+@/.test(v)));
|
|
295
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { type PersonRecord, type PersonRelationshipRecord } from "@voyant-travel/relationships-react";
|
|
2
|
+
import type { RoomGroup, TravelerEntry, TravelerPricingCategoryOption, TravelerRole, TravelersSectionProps } from "./travelers-section.js";
|
|
3
|
+
export declare function TravelerPersonPicker({ personId, labels, pinnedPeople, onSelect, onClear, }: {
|
|
4
|
+
personId: string | null;
|
|
5
|
+
labels: NonNullable<TravelersSectionProps["labels"]>;
|
|
6
|
+
pinnedPeople?: PersonRecord[];
|
|
7
|
+
onSelect: (person: PersonRecord) => void;
|
|
8
|
+
onClear: () => void;
|
|
9
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
export declare function createTravelerFromPerson(person: PersonRecord, role: TravelerRole): TravelerEntry;
|
|
11
|
+
/**
|
|
12
|
+
* Dynamic category-button group. Reads the product's actual
|
|
13
|
+
* person-typed option_units (Adult/Child/Senior, Adult/Child/Infant,
|
|
14
|
+
* Adult/Senior, etc) from `roomGroups` and renders one button per
|
|
15
|
+
* unit in the traveler's currently-assigned option.
|
|
16
|
+
*
|
|
17
|
+
* Falls back to the old static Adult/Child/Infant buttons when the
|
|
18
|
+
* parent hasn't wired `roomGroups` (during the brief window before a
|
|
19
|
+
* product is selected, or in legacy callers that don't pass the prop).
|
|
20
|
+
*/
|
|
21
|
+
export declare function TravelerCategoryButtons({ traveler, roomGroups, fallbackLabels, onPickUnit, }: {
|
|
22
|
+
traveler: TravelerEntry;
|
|
23
|
+
roomGroups?: RoomGroup[];
|
|
24
|
+
fallbackLabels: {
|
|
25
|
+
category: string;
|
|
26
|
+
adult: string;
|
|
27
|
+
child: string;
|
|
28
|
+
infant: string;
|
|
29
|
+
};
|
|
30
|
+
/**
|
|
31
|
+
* Called when the operator clicks a category button. `source`
|
|
32
|
+
* signals whether the click selected a real unit (`"manual"` —
|
|
33
|
+
* dynamic per-product button) or merely chose a role with no
|
|
34
|
+
* actual unit pick (`"auto"` — static fallback before units load).
|
|
35
|
+
* The wrapping handler uses `source` to decide whether to freeze
|
|
36
|
+
* the current `pricingUnitId` as a manual choice.
|
|
37
|
+
*/
|
|
38
|
+
onPickUnit: (unitId: string | null, nextRole: TravelerRole, source: "manual" | "auto") => void;
|
|
39
|
+
}): import("react/jsx-runtime").JSX.Element | null;
|
|
40
|
+
export declare function TravelerPricingCategorySelect({ traveler, categories, label, onPickCategory, }: {
|
|
41
|
+
traveler: TravelerEntry;
|
|
42
|
+
categories: TravelerPricingCategoryOption[];
|
|
43
|
+
label: string;
|
|
44
|
+
onPickCategory: (category: TravelerPricingCategoryOption) => void;
|
|
45
|
+
}): import("react/jsx-runtime").JSX.Element | null;
|
|
46
|
+
export declare function RelatedPersonChip({ personId, kind, addLabel, onAdd, }: {
|
|
47
|
+
personId: string;
|
|
48
|
+
kind: PersonRelationshipRecord["kind"];
|
|
49
|
+
addLabel: string;
|
|
50
|
+
onAdd: (person: PersonRecord) => void;
|
|
51
|
+
}): import("react/jsx-runtime").JSX.Element | null;
|
|
52
|
+
//# sourceMappingURL=travelers-section-controls.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"travelers-section-controls.d.ts","sourceRoot":"","sources":["../../src/components/travelers-section-controls.tsx"],"names":[],"mappings":"AAEA,OAAO,EACL,KAAK,YAAY,EACjB,KAAK,wBAAwB,EAG9B,MAAM,oCAAoC,CAAA;AAkC3C,OAAO,KAAK,EACV,SAAS,EACT,aAAa,EACb,6BAA6B,EAC7B,YAAY,EACZ,qBAAqB,EACtB,MAAM,wBAAwB,CAAA;AAW/B,wBAAgB,oBAAoB,CAAC,EACnC,QAAQ,EACR,MAAM,EACN,YAAiB,EACjB,QAAQ,EACR,OAAO,GACR,EAAE;IACD,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,MAAM,EAAE,WAAW,CAAC,qBAAqB,CAAC,QAAQ,CAAC,CAAC,CAAA;IACpD,YAAY,CAAC,EAAE,YAAY,EAAE,CAAA;IAC7B,QAAQ,EAAE,CAAC,MAAM,EAAE,YAAY,KAAK,IAAI,CAAA;IACxC,OAAO,EAAE,MAAM,IAAI,CAAA;CACpB,2CAuIA;AAED,wBAAgB,wBAAwB,CAAC,MAAM,EAAE,YAAY,EAAE,IAAI,EAAE,YAAY,GAAG,aAAa,CAwBhG;AAaD;;;;;;;;;GASG;AACH,wBAAgB,uBAAuB,CAAC,EACtC,QAAQ,EACR,UAAU,EACV,cAAc,EACd,UAAU,GACX,EAAE;IACD,QAAQ,EAAE,aAAa,CAAA;IACvB,UAAU,CAAC,EAAE,SAAS,EAAE,CAAA;IACxB,cAAc,EAAE;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAA;IAClF;;;;;;;OAOG;IACH,UAAU,EAAE,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,EAAE,QAAQ,GAAG,MAAM,KAAK,IAAI,CAAA;CAC/F,kDAsGA;AAED,wBAAgB,6BAA6B,CAAC,EAC5C,QAAQ,EACR,UAAU,EACV,KAAK,EACL,cAAc,GACf,EAAE;IACD,QAAQ,EAAE,aAAa,CAAA;IACvB,UAAU,EAAE,6BAA6B,EAAE,CAAA;IAC3C,KAAK,EAAE,MAAM,CAAA;IACb,cAAc,EAAE,CAAC,QAAQ,EAAE,6BAA6B,KAAK,IAAI,CAAA;CAClE,kDA+CA;AAED,wBAAgB,iBAAiB,CAAC,EAChC,QAAQ,EACR,IAAI,EACJ,QAAQ,EACR,KAAK,GACN,EAAE;IACD,QAAQ,EAAE,MAAM,CAAA;IAChB,IAAI,EAAE,wBAAwB,CAAC,MAAM,CAAC,CAAA;IACtC,QAAQ,EAAE,MAAM,CAAA;IAChB,KAAK,EAAE,CAAC,MAAM,EAAE,YAAY,KAAK,IAAI,CAAA;CACtC,kDAwBA"}
|