@voyant-travel/operations-react 0.0.0
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 +11 -0
- package/dist/admin.d.ts +59 -0
- package/dist/admin.d.ts.map +1 -0
- package/dist/admin.js +165 -0
- package/dist/availability/admin/availability-index-host.d.ts +12 -0
- package/dist/availability/admin/availability-index-host.d.ts.map +1 -0
- package/dist/availability/admin/availability-index-host.js +125 -0
- package/dist/availability/admin/availability-page-data.d.ts +9 -0
- package/dist/availability/admin/availability-page-data.d.ts.map +1 -0
- package/dist/availability/admin/availability-page-data.js +25 -0
- package/dist/availability/admin/index.d.ts +70 -0
- package/dist/availability/admin/index.d.ts.map +1 -0
- package/dist/availability/admin/index.js +140 -0
- package/dist/availability/admin/option-resource-template-seat-map.d.ts +10 -0
- package/dist/availability/admin/option-resource-template-seat-map.d.ts.map +1 -0
- package/dist/availability/admin/option-resource-template-seat-map.js +36 -0
- package/dist/availability/admin/option-resource-templates-panel.d.ts +22 -0
- package/dist/availability/admin/option-resource-templates-panel.d.ts.map +1 -0
- package/dist/availability/admin/option-resource-templates-panel.js +221 -0
- package/dist/availability/admin/pages/availability-rule-detail-page.d.ts +9 -0
- package/dist/availability/admin/pages/availability-rule-detail-page.d.ts.map +1 -0
- package/dist/availability/admin/pages/availability-rule-detail-page.js +11 -0
- package/dist/availability/admin/pages/availability-slot-detail-page.d.ts +9 -0
- package/dist/availability/admin/pages/availability-slot-detail-page.d.ts.map +1 -0
- package/dist/availability/admin/pages/availability-slot-detail-page.js +11 -0
- package/dist/availability/admin/pages/availability-start-time-detail-page.d.ts +9 -0
- package/dist/availability/admin/pages/availability-start-time-detail-page.d.ts.map +1 -0
- package/dist/availability/admin/pages/availability-start-time-detail-page.js +11 -0
- package/dist/availability/admin/rule-detail-host.d.ts +14 -0
- package/dist/availability/admin/rule-detail-host.d.ts.map +1 -0
- package/dist/availability/admin/rule-detail-host.js +27 -0
- package/dist/availability/admin/slot-detail-host.d.ts +29 -0
- package/dist/availability/admin/slot-detail-host.d.ts.map +1 -0
- package/dist/availability/admin/slot-detail-host.js +110 -0
- package/dist/availability/admin/start-time-detail-host.d.ts +15 -0
- package/dist/availability/admin/start-time-detail-host.d.ts.map +1 -0
- package/dist/availability/admin/start-time-detail-host.js +37 -0
- package/dist/availability/allocation/components/seat-map-builder.d.ts +25 -0
- package/dist/availability/allocation/components/seat-map-builder.d.ts.map +1 -0
- package/dist/availability/allocation/components/seat-map-builder.js +133 -0
- package/dist/availability/allocation/components/slot-allocation-add-resource-dialog.d.ts +29 -0
- package/dist/availability/allocation/components/slot-allocation-add-resource-dialog.d.ts.map +1 -0
- package/dist/availability/allocation/components/slot-allocation-add-resource-dialog.js +19 -0
- package/dist/availability/allocation/components/slot-allocation-model.d.ts +111 -0
- package/dist/availability/allocation/components/slot-allocation-model.d.ts.map +1 -0
- package/dist/availability/allocation/components/slot-allocation-model.js +237 -0
- package/dist/availability/allocation/components/slot-allocation-page-panels.d.ts +17 -0
- package/dist/availability/allocation/components/slot-allocation-page-panels.d.ts.map +1 -0
- package/dist/availability/allocation/components/slot-allocation-page-panels.js +27 -0
- package/dist/availability/allocation/components/slot-allocation-page.d.ts +51 -0
- package/dist/availability/allocation/components/slot-allocation-page.d.ts.map +1 -0
- package/dist/availability/allocation/components/slot-allocation-page.js +217 -0
- package/dist/availability/allocation/components/slot-allocation-resource-view-rows.d.ts +28 -0
- package/dist/availability/allocation/components/slot-allocation-resource-view-rows.d.ts.map +1 -0
- package/dist/availability/allocation/components/slot-allocation-resource-view-rows.js +90 -0
- package/dist/availability/allocation/components/slot-allocation-resource-view.d.ts +34 -0
- package/dist/availability/allocation/components/slot-allocation-resource-view.d.ts.map +1 -0
- package/dist/availability/allocation/components/slot-allocation-resource-view.js +35 -0
- package/dist/availability/allocation/components/slot-allocation-seat-view.d.ts +17 -0
- package/dist/availability/allocation/components/slot-allocation-seat-view.d.ts.map +1 -0
- package/dist/availability/allocation/components/slot-allocation-seat-view.js +97 -0
- package/dist/availability/allocation/components/slot-allocation-shared.d.ts +54 -0
- package/dist/availability/allocation/components/slot-allocation-shared.d.ts.map +1 -0
- package/dist/availability/allocation/components/slot-allocation-shared.js +106 -0
- package/dist/availability/allocation/i18n/index.d.ts +2 -0
- package/dist/availability/allocation/i18n/index.d.ts.map +1 -0
- package/dist/availability/allocation/i18n/index.js +1 -0
- package/dist/availability/allocation/i18n/provider.d.ts +692 -0
- package/dist/availability/allocation/i18n/provider.d.ts.map +1 -0
- package/dist/availability/allocation/i18n/provider.js +320 -0
- package/dist/availability/allocation/index.d.ts +4 -0
- package/dist/availability/allocation/index.d.ts.map +1 -0
- package/dist/availability/allocation/index.js +3 -0
- package/dist/availability/client.d.ts +14 -0
- package/dist/availability/client.d.ts.map +1 -0
- package/dist/availability/client.js +59 -0
- package/dist/availability/components/availability-columns.d.ts +42 -0
- package/dist/availability/components/availability-columns.d.ts.map +1 -0
- package/dist/availability/components/availability-columns.js +182 -0
- package/dist/availability/components/availability-dialogs/closeout-dialog.d.ts +13 -0
- package/dist/availability/components/availability-dialogs/closeout-dialog.d.ts.map +1 -0
- package/dist/availability/components/availability-dialogs/closeout-dialog.js +60 -0
- package/dist/availability/components/availability-dialogs/pickup-point-dialog.d.ts +12 -0
- package/dist/availability/components/availability-dialogs/pickup-point-dialog.d.ts.map +1 -0
- package/dist/availability/components/availability-dialogs/pickup-point-dialog.js +58 -0
- package/dist/availability/components/availability-dialogs/rule-dialog.d.ts +12 -0
- package/dist/availability/components/availability-dialogs/rule-dialog.d.ts.map +1 -0
- package/dist/availability/components/availability-dialogs/rule-dialog.js +76 -0
- package/dist/availability/components/availability-dialogs/shared.d.ts +213 -0
- package/dist/availability/components/availability-dialogs/shared.d.ts.map +1 -0
- package/dist/availability/components/availability-dialogs/shared.js +16 -0
- package/dist/availability/components/availability-dialogs/slot-dialog.d.ts +14 -0
- package/dist/availability/components/availability-dialogs/slot-dialog.d.ts.map +1 -0
- package/dist/availability/components/availability-dialogs/slot-dialog.js +138 -0
- package/dist/availability/components/availability-dialogs/start-time-dialog.d.ts +12 -0
- package/dist/availability/components/availability-dialogs/start-time-dialog.d.ts.map +1 -0
- package/dist/availability/components/availability-dialogs/start-time-dialog.js +62 -0
- package/dist/availability/components/availability-dialogs.d.ts +7 -0
- package/dist/availability/components/availability-dialogs.d.ts.map +1 -0
- package/dist/availability/components/availability-dialogs.js +6 -0
- package/dist/availability/components/availability-overview.d.ts +54 -0
- package/dist/availability/components/availability-overview.d.ts.map +1 -0
- package/dist/availability/components/availability-overview.js +50 -0
- package/dist/availability/components/availability-page.d.ts +32 -0
- package/dist/availability/components/availability-page.d.ts.map +1 -0
- package/dist/availability/components/availability-page.js +128 -0
- package/dist/availability/components/availability-rule-detail-page.d.ts +251 -0
- package/dist/availability/components/availability-rule-detail-page.d.ts.map +1 -0
- package/dist/availability/components/availability-rule-detail-page.js +74 -0
- package/dist/availability/components/availability-section-header.d.ts +8 -0
- package/dist/availability/components/availability-section-header.d.ts.map +1 -0
- package/dist/availability/components/availability-section-header.js +7 -0
- package/dist/availability/components/availability-skeletons.d.ts +6 -0
- package/dist/availability/components/availability-skeletons.d.ts.map +1 -0
- package/dist/availability/components/availability-skeletons.js +34 -0
- package/dist/availability/components/availability-slot-detail-activity.d.ts +30 -0
- package/dist/availability/components/availability-slot-detail-activity.d.ts.map +1 -0
- package/dist/availability/components/availability-slot-detail-activity.js +82 -0
- package/dist/availability/components/availability-slot-detail-financials.d.ts +27 -0
- package/dist/availability/components/availability-slot-detail-financials.d.ts.map +1 -0
- package/dist/availability/components/availability-slot-detail-financials.js +92 -0
- package/dist/availability/components/availability-slot-detail-meta.d.ts +38 -0
- package/dist/availability/components/availability-slot-detail-meta.d.ts.map +1 -0
- package/dist/availability/components/availability-slot-detail-meta.js +68 -0
- package/dist/availability/components/availability-slot-detail-page.d.ts +963 -0
- package/dist/availability/components/availability-slot-detail-page.d.ts.map +1 -0
- package/dist/availability/components/availability-slot-detail-page.js +159 -0
- package/dist/availability/components/availability-start-time-detail-page.d.ts +246 -0
- package/dist/availability/components/availability-start-time-detail-page.d.ts.map +1 -0
- package/dist/availability/components/availability-start-time-detail-page.js +83 -0
- package/dist/availability/components/availability-tabs/other-tabs.d.ts +58 -0
- package/dist/availability/components/availability-tabs/other-tabs.d.ts.map +1 -0
- package/dist/availability/components/availability-tabs/other-tabs.js +127 -0
- package/dist/availability/components/availability-tabs/shared.d.ts +80 -0
- package/dist/availability/components/availability-tabs/shared.d.ts.map +1 -0
- package/dist/availability/components/availability-tabs/shared.js +6 -0
- package/dist/availability/components/availability-tabs/slots-tab.d.ts +23 -0
- package/dist/availability/components/availability-tabs/slots-tab.d.ts.map +1 -0
- package/dist/availability/components/availability-tabs/slots-tab.js +69 -0
- package/dist/availability/components/availability-tabs.d.ts +4 -0
- package/dist/availability/components/availability-tabs.d.ts.map +1 -0
- package/dist/availability/components/availability-tabs.js +3 -0
- package/dist/availability/components/slot-status-tone.d.ts +15 -0
- package/dist/availability/components/slot-status-tone.d.ts.map +1 -0
- package/dist/availability/components/slot-status-tone.js +18 -0
- package/dist/availability/constants.d.ts +26 -0
- package/dist/availability/constants.d.ts.map +1 -0
- package/dist/availability/constants.js +23 -0
- package/dist/availability/form-resolver.d.ts +4 -0
- package/dist/availability/form-resolver.d.ts.map +1 -0
- package/dist/availability/form-resolver.js +40 -0
- package/dist/availability/hooks/index.d.ts +25 -0
- package/dist/availability/hooks/index.d.ts.map +1 -0
- package/dist/availability/hooks/index.js +15 -0
- package/dist/availability/hooks/use-availability-batch-mutations.d.ts +193 -0
- package/dist/availability/hooks/use-availability-batch-mutations.d.ts.map +1 -0
- package/dist/availability/hooks/use-availability-batch-mutations.js +53 -0
- package/dist/availability/hooks/use-availability-closeout-mutation.d.ts +34 -0
- package/dist/availability/hooks/use-availability-closeout-mutation.d.ts.map +1 -0
- package/dist/availability/hooks/use-availability-closeout-mutation.js +38 -0
- package/dist/availability/hooks/use-availability-overview.d.ts +46 -0
- package/dist/availability/hooks/use-availability-overview.d.ts.map +1 -0
- package/dist/availability/hooks/use-availability-overview.js +9 -0
- package/dist/availability/hooks/use-availability-pickup-point-mutation.d.ts +35 -0
- package/dist/availability/hooks/use-availability-pickup-point-mutation.d.ts.map +1 -0
- package/dist/availability/hooks/use-availability-pickup-point-mutation.js +38 -0
- package/dist/availability/hooks/use-availability-rule-mutation.d.ts +52 -0
- package/dist/availability/hooks/use-availability-rule-mutation.d.ts.map +1 -0
- package/dist/availability/hooks/use-availability-rule-mutation.js +41 -0
- package/dist/availability/hooks/use-availability-slot-mutation.d.ts +77 -0
- package/dist/availability/hooks/use-availability-slot-mutation.d.ts.map +1 -0
- package/dist/availability/hooks/use-availability-slot-mutation.js +41 -0
- package/dist/availability/hooks/use-availability-start-time-mutation.d.ts +43 -0
- package/dist/availability/hooks/use-availability-start-time-mutation.d.ts.map +1 -0
- package/dist/availability/hooks/use-availability-start-time-mutation.js +41 -0
- package/dist/availability/hooks/use-closeouts.d.ts +19 -0
- package/dist/availability/hooks/use-closeouts.d.ts.map +1 -0
- package/dist/availability/hooks/use-closeouts.js +9 -0
- package/dist/availability/hooks/use-pickup-points.d.ts +19 -0
- package/dist/availability/hooks/use-pickup-points.d.ts.map +1 -0
- package/dist/availability/hooks/use-pickup-points.js +9 -0
- package/dist/availability/hooks/use-products.d.ts +20 -0
- package/dist/availability/hooks/use-products.d.ts.map +1 -0
- package/dist/availability/hooks/use-products.js +9 -0
- package/dist/availability/hooks/use-rules.d.ts +25 -0
- package/dist/availability/hooks/use-rules.d.ts.map +1 -0
- package/dist/availability/hooks/use-rules.js +9 -0
- package/dist/availability/hooks/use-slot-allocation.d.ts +306 -0
- package/dist/availability/hooks/use-slot-allocation.d.ts.map +1 -0
- package/dist/availability/hooks/use-slot-allocation.js +211 -0
- package/dist/availability/hooks/use-slot-unit-availability.d.ts +25 -0
- package/dist/availability/hooks/use-slot-unit-availability.d.ts.map +1 -0
- package/dist/availability/hooks/use-slot-unit-availability.js +21 -0
- package/dist/availability/hooks/use-slots.d.ts +32 -0
- package/dist/availability/hooks/use-slots.d.ts.map +1 -0
- package/dist/availability/hooks/use-slots.js +9 -0
- package/dist/availability/hooks/use-start-times.d.ts +22 -0
- package/dist/availability/hooks/use-start-times.d.ts.map +1 -0
- package/dist/availability/hooks/use-start-times.js +9 -0
- package/dist/availability/i18n/index.d.ts +2 -0
- package/dist/availability/i18n/index.d.ts.map +1 -0
- package/dist/availability/i18n/index.js +1 -0
- package/dist/availability/i18n/provider.d.ts +2003 -0
- package/dist/availability/i18n/provider.d.ts.map +1 -0
- package/dist/availability/i18n/provider.js +102 -0
- package/dist/availability/index.d.ts +10 -0
- package/dist/availability/index.d.ts.map +1 -0
- package/dist/availability/index.js +9 -0
- package/dist/availability/provider.d.ts +2 -0
- package/dist/availability/provider.d.ts.map +1 -0
- package/dist/availability/provider.js +1 -0
- package/dist/availability/query-keys.d.ts +69 -0
- package/dist/availability/query-keys.d.ts.map +1 -0
- package/dist/availability/query-keys.js +29 -0
- package/dist/availability/query-options.d.ts +1549 -0
- package/dist/availability/query-options.d.ts.map +1 -0
- package/dist/availability/query-options.js +258 -0
- package/dist/availability/schemas.d.ts +974 -0
- package/dist/availability/schemas.d.ts.map +1 -0
- package/dist/availability/schemas.js +329 -0
- package/dist/availability/ui.d.ts +14 -0
- package/dist/availability/ui.d.ts.map +1 -0
- package/dist/availability/ui.js +13 -0
- package/dist/availability/utils.d.ts +10 -0
- package/dist/availability/utils.d.ts.map +1 -0
- package/dist/availability/utils.js +32 -0
- package/dist/ground/client.d.ts +14 -0
- package/dist/ground/client.d.ts.map +1 -0
- package/dist/ground/client.js +58 -0
- package/dist/ground/hooks/index.d.ts +7 -0
- package/dist/ground/hooks/index.d.ts.map +1 -0
- package/dist/ground/hooks/index.js +6 -0
- package/dist/ground/hooks/use-ground-driver-mutation.d.ts +48 -0
- package/dist/ground/hooks/use-ground-driver-mutation.d.ts.map +1 -0
- package/dist/ground/hooks/use-ground-driver-mutation.js +40 -0
- package/dist/ground/hooks/use-ground-drivers.d.ts +23 -0
- package/dist/ground/hooks/use-ground-drivers.d.ts.map +1 -0
- package/dist/ground/hooks/use-ground-drivers.js +12 -0
- package/dist/ground/hooks/use-ground-operator-mutation.d.ts +42 -0
- package/dist/ground/hooks/use-ground-operator-mutation.d.ts.map +1 -0
- package/dist/ground/hooks/use-ground-operator-mutation.js +40 -0
- package/dist/ground/hooks/use-ground-operators.d.ts +21 -0
- package/dist/ground/hooks/use-ground-operators.d.ts.map +1 -0
- package/dist/ground/hooks/use-ground-operators.js +12 -0
- package/dist/ground/hooks/use-ground-vehicle-mutation.d.ts +60 -0
- package/dist/ground/hooks/use-ground-vehicle-mutation.d.ts.map +1 -0
- package/dist/ground/hooks/use-ground-vehicle-mutation.js +40 -0
- package/dist/ground/hooks/use-ground-vehicles.d.ts +27 -0
- package/dist/ground/hooks/use-ground-vehicles.d.ts.map +1 -0
- package/dist/ground/hooks/use-ground-vehicles.js +12 -0
- package/dist/ground/index.d.ts +7 -0
- package/dist/ground/index.d.ts.map +1 -0
- package/dist/ground/index.js +6 -0
- package/dist/ground/provider.d.ts +2 -0
- package/dist/ground/provider.d.ts.map +1 -0
- package/dist/ground/provider.js +1 -0
- package/dist/ground/query-keys.d.ts +35 -0
- package/dist/ground/query-keys.d.ts.map +1 -0
- package/dist/ground/query-keys.js +12 -0
- package/dist/ground/query-options.d.ts +417 -0
- package/dist/ground/query-options.d.ts.map +1 -0
- package/dist/ground/query-options.js +63 -0
- package/dist/ground/schemas.d.ts +212 -0
- package/dist/ground/schemas.d.ts.map +1 -0
- package/dist/ground/schemas.js +45 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +4 -0
- package/dist/places/client.d.ts +14 -0
- package/dist/places/client.d.ts.map +1 -0
- package/dist/places/client.js +58 -0
- package/dist/places/components/facility-badge.d.ts +13 -0
- package/dist/places/components/facility-badge.d.ts.map +1 -0
- package/dist/places/components/facility-badge.js +22 -0
- package/dist/places/components/facility-combobox.d.ts +16 -0
- package/dist/places/components/facility-combobox.d.ts.map +1 -0
- package/dist/places/components/facility-combobox.js +61 -0
- package/dist/places/components/place-badge.d.ts +2 -0
- package/dist/places/components/place-badge.d.ts.map +1 -0
- package/dist/places/components/place-badge.js +1 -0
- package/dist/places/components/place-combobox.d.ts +2 -0
- package/dist/places/components/place-combobox.d.ts.map +1 -0
- package/dist/places/components/place-combobox.js +1 -0
- package/dist/places/hooks/index.d.ts +23 -0
- package/dist/places/hooks/index.d.ts.map +1 -0
- package/dist/places/hooks/index.js +22 -0
- package/dist/places/hooks/use-facilities.d.ts +31 -0
- package/dist/places/hooks/use-facilities.d.ts.map +1 -0
- package/dist/places/hooks/use-facilities.js +12 -0
- package/dist/places/hooks/use-facility-feature-mutation.d.ts +37 -0
- package/dist/places/hooks/use-facility-feature-mutation.d.ts.map +1 -0
- package/dist/places/hooks/use-facility-feature-mutation.js +38 -0
- package/dist/places/hooks/use-facility-features.d.ts +21 -0
- package/dist/places/hooks/use-facility-features.d.ts.map +1 -0
- package/dist/places/hooks/use-facility-features.js +12 -0
- package/dist/places/hooks/use-facility-mutation.d.ts +74 -0
- package/dist/places/hooks/use-facility-mutation.d.ts.map +1 -0
- package/dist/places/hooks/use-facility-mutation.js +45 -0
- package/dist/places/hooks/use-facility-operation-schedule-mutation.d.ts +37 -0
- package/dist/places/hooks/use-facility-operation-schedule-mutation.d.ts.map +1 -0
- package/dist/places/hooks/use-facility-operation-schedule-mutation.js +44 -0
- package/dist/places/hooks/use-facility-operation-schedules.d.ts +21 -0
- package/dist/places/hooks/use-facility-operation-schedules.d.ts.map +1 -0
- package/dist/places/hooks/use-facility-operation-schedules.js +12 -0
- package/dist/places/hooks/use-facility.d.ts +25 -0
- package/dist/places/hooks/use-facility.d.ts.map +1 -0
- package/dist/places/hooks/use-facility.js +12 -0
- package/dist/places/hooks/use-properties.d.ts +23 -0
- package/dist/places/hooks/use-properties.d.ts.map +1 -0
- package/dist/places/hooks/use-properties.js +12 -0
- package/dist/places/hooks/use-property-group-member-mutation.d.ts +41 -0
- package/dist/places/hooks/use-property-group-member-mutation.d.ts.map +1 -0
- package/dist/places/hooks/use-property-group-member-mutation.js +38 -0
- package/dist/places/hooks/use-property-group-members.d.ts +20 -0
- package/dist/places/hooks/use-property-group-members.d.ts.map +1 -0
- package/dist/places/hooks/use-property-group-members.js +12 -0
- package/dist/places/hooks/use-property-group-mutation.d.ts +50 -0
- package/dist/places/hooks/use-property-group-mutation.d.ts.map +1 -0
- package/dist/places/hooks/use-property-group-mutation.js +39 -0
- package/dist/places/hooks/use-property-group.d.ts +17 -0
- package/dist/places/hooks/use-property-group.d.ts.map +1 -0
- package/dist/places/hooks/use-property-group.js +12 -0
- package/dist/places/hooks/use-property-groups.d.ts +23 -0
- package/dist/places/hooks/use-property-groups.d.ts.map +1 -0
- package/dist/places/hooks/use-property-groups.js +12 -0
- package/dist/places/hooks/use-property-mutation.d.ts +50 -0
- package/dist/places/hooks/use-property-mutation.d.ts.map +1 -0
- package/dist/places/hooks/use-property-mutation.js +40 -0
- package/dist/places/hooks/use-property.d.ts +17 -0
- package/dist/places/hooks/use-property.d.ts.map +1 -0
- package/dist/places/hooks/use-property.js +12 -0
- package/dist/places/i18n/en.d.ts +14 -0
- package/dist/places/i18n/en.d.ts.map +1 -0
- package/dist/places/i18n/en.js +13 -0
- package/dist/places/i18n/index.d.ts +5 -0
- package/dist/places/i18n/index.d.ts.map +1 -0
- package/dist/places/i18n/index.js +3 -0
- package/dist/places/i18n/messages.d.ts +15 -0
- package/dist/places/i18n/messages.d.ts.map +1 -0
- package/dist/places/i18n/messages.js +1 -0
- package/dist/places/i18n/provider.d.ts +50 -0
- package/dist/places/i18n/provider.d.ts.map +1 -0
- package/dist/places/i18n/provider.js +44 -0
- package/dist/places/i18n/ro.d.ts +14 -0
- package/dist/places/i18n/ro.d.ts.map +1 -0
- package/dist/places/i18n/ro.js +13 -0
- package/dist/places/index.d.ts +7 -0
- package/dist/places/index.d.ts.map +1 -0
- package/dist/places/index.js +6 -0
- package/dist/places/provider.d.ts +2 -0
- package/dist/places/provider.d.ts.map +1 -0
- package/dist/places/provider.js +1 -0
- package/dist/places/query-keys.d.ts +92 -0
- package/dist/places/query-keys.d.ts.map +1 -0
- package/dist/places/query-keys.js +22 -0
- package/dist/places/query-options.d.ts +814 -0
- package/dist/places/query-options.d.ts.map +1 -0
- package/dist/places/query-options.js +132 -0
- package/dist/places/schemas.d.ts +464 -0
- package/dist/places/schemas.d.ts.map +1 -0
- package/dist/places/schemas.js +84 -0
- package/dist/places/ui.d.ts +4 -0
- package/dist/places/ui.d.ts.map +1 -0
- package/dist/places/ui.js +3 -0
- package/dist/resources/admin/detail-hosts.d.ts +30 -0
- package/dist/resources/admin/detail-hosts.d.ts.map +1 -0
- package/dist/resources/admin/detail-hosts.js +50 -0
- package/dist/resources/admin/index.d.ts +89 -0
- package/dist/resources/admin/index.d.ts.map +1 -0
- package/dist/resources/admin/index.js +148 -0
- package/dist/resources/admin/pages/resource-allocation-detail-page.d.ts +9 -0
- package/dist/resources/admin/pages/resource-allocation-detail-page.d.ts.map +1 -0
- package/dist/resources/admin/pages/resource-allocation-detail-page.js +11 -0
- package/dist/resources/admin/pages/resource-assignment-detail-page.d.ts +9 -0
- package/dist/resources/admin/pages/resource-assignment-detail-page.d.ts.map +1 -0
- package/dist/resources/admin/pages/resource-assignment-detail-page.js +11 -0
- package/dist/resources/admin/pages/resource-detail-page.d.ts +9 -0
- package/dist/resources/admin/pages/resource-detail-page.d.ts.map +1 -0
- package/dist/resources/admin/pages/resource-detail-page.js +11 -0
- package/dist/resources/admin/pages/resource-pool-detail-page.d.ts +9 -0
- package/dist/resources/admin/pages/resource-pool-detail-page.d.ts.map +1 -0
- package/dist/resources/admin/pages/resource-pool-detail-page.js +11 -0
- package/dist/resources/admin/resources-admin-api.d.ts +22 -0
- package/dist/resources/admin/resources-admin-api.d.ts.map +1 -0
- package/dist/resources/admin/resources-admin-api.js +28 -0
- package/dist/resources/admin/resources-dialog-allocation.d.ts +12 -0
- package/dist/resources/admin/resources-dialog-allocation.d.ts.map +1 -0
- package/dist/resources/admin/resources-dialog-allocation.js +77 -0
- package/dist/resources/admin/resources-dialogs-core.d.ts +16 -0
- package/dist/resources/admin/resources-dialogs-core.d.ts.map +1 -0
- package/dist/resources/admin/resources-dialogs-core.js +133 -0
- package/dist/resources/admin/resources-dialogs-ops.d.ts +19 -0
- package/dist/resources/admin/resources-dialogs-ops.d.ts.map +1 -0
- package/dist/resources/admin/resources-dialogs-ops.js +137 -0
- package/dist/resources/admin/resources-dialogs.d.ts +28 -0
- package/dist/resources/admin/resources-dialogs.d.ts.map +1 -0
- package/dist/resources/admin/resources-dialogs.js +23 -0
- package/dist/resources/admin/resources-host.d.ts +11 -0
- package/dist/resources/admin/resources-host.d.ts.map +1 -0
- package/dist/resources/admin/resources-host.js +159 -0
- package/dist/resources/admin/resources-page-data.d.ts +61 -0
- package/dist/resources/admin/resources-page-data.d.ts.map +1 -0
- package/dist/resources/admin/resources-page-data.js +39 -0
- package/dist/resources/admin/resources-page-skeleton.d.ts +5 -0
- package/dist/resources/admin/resources-page-skeleton.d.ts.map +1 -0
- package/dist/resources/admin/resources-page-skeleton.js +22 -0
- package/dist/resources/client.d.ts +14 -0
- package/dist/resources/client.d.ts.map +1 -0
- package/dist/resources/client.js +59 -0
- package/dist/resources/components/resource-allocation-detail-page.d.ts +16 -0
- package/dist/resources/components/resource-allocation-detail-page.d.ts.map +1 -0
- package/dist/resources/components/resource-allocation-detail-page.js +48 -0
- package/dist/resources/components/resource-assignment-detail-page.d.ts +16 -0
- package/dist/resources/components/resource-assignment-detail-page.d.ts.map +1 -0
- package/dist/resources/components/resource-assignment-detail-page.js +50 -0
- package/dist/resources/components/resource-detail-data.d.ts +34 -0
- package/dist/resources/components/resource-detail-data.d.ts.map +1 -0
- package/dist/resources/components/resource-detail-data.js +90 -0
- package/dist/resources/components/resource-detail-page.d.ts +24 -0
- package/dist/resources/components/resource-detail-page.d.ts.map +1 -0
- package/dist/resources/components/resource-detail-page.js +80 -0
- package/dist/resources/components/resource-detail-shared.d.ts +37 -0
- package/dist/resources/components/resource-detail-shared.d.ts.map +1 -0
- package/dist/resources/components/resource-detail-shared.js +51 -0
- package/dist/resources/components/resource-detail-skeletons.d.ts +14 -0
- package/dist/resources/components/resource-detail-skeletons.d.ts.map +1 -0
- package/dist/resources/components/resource-detail-skeletons.js +24 -0
- package/dist/resources/components/resource-pool-detail-page.d.ts +22 -0
- package/dist/resources/components/resource-pool-detail-page.d.ts.map +1 -0
- package/dist/resources/components/resource-pool-detail-page.js +68 -0
- package/dist/resources/components/resources-overview.d.ts +28 -0
- package/dist/resources/components/resources-overview.d.ts.map +1 -0
- package/dist/resources/components/resources-overview.js +32 -0
- package/dist/resources/components/resources-page-filters.d.ts +22 -0
- package/dist/resources/components/resources-page-filters.d.ts.map +1 -0
- package/dist/resources/components/resources-page-filters.js +40 -0
- package/dist/resources/components/resources-page.d.ts +77 -0
- package/dist/resources/components/resources-page.d.ts.map +1 -0
- package/dist/resources/components/resources-page.js +140 -0
- package/dist/resources/components/resources-section-header.d.ts +7 -0
- package/dist/resources/components/resources-section-header.d.ts.map +1 -0
- package/dist/resources/components/resources-section-header.js +6 -0
- package/dist/resources/components/resources-tabs-primary.d.ts +58 -0
- package/dist/resources/components/resources-tabs-primary.d.ts.map +1 -0
- package/dist/resources/components/resources-tabs-primary.js +201 -0
- package/dist/resources/components/resources-tabs-secondary.d.ts +46 -0
- package/dist/resources/components/resources-tabs-secondary.d.ts.map +1 -0
- package/dist/resources/components/resources-tabs-secondary.js +143 -0
- package/dist/resources/constants.d.ts +44 -0
- package/dist/resources/constants.d.ts.map +1 -0
- package/dist/resources/constants.js +20 -0
- package/dist/resources/hooks/index.d.ts +31 -0
- package/dist/resources/hooks/index.d.ts.map +1 -0
- package/dist/resources/hooks/index.js +15 -0
- package/dist/resources/hooks/use-allocation.d.ts +16 -0
- package/dist/resources/hooks/use-allocation.d.ts.map +1 -0
- package/dist/resources/hooks/use-allocation.js +12 -0
- package/dist/resources/hooks/use-allocations.d.ts +20 -0
- package/dist/resources/hooks/use-allocations.d.ts.map +1 -0
- package/dist/resources/hooks/use-allocations.js +12 -0
- package/dist/resources/hooks/use-assignment.d.ts +17 -0
- package/dist/resources/hooks/use-assignment.d.ts.map +1 -0
- package/dist/resources/hooks/use-assignment.js +12 -0
- package/dist/resources/hooks/use-assignments.d.ts +21 -0
- package/dist/resources/hooks/use-assignments.d.ts.map +1 -0
- package/dist/resources/hooks/use-assignments.js +12 -0
- package/dist/resources/hooks/use-bookings.d.ts +14 -0
- package/dist/resources/hooks/use-bookings.d.ts.map +1 -0
- package/dist/resources/hooks/use-bookings.js +12 -0
- package/dist/resources/hooks/use-closeouts.d.ts +19 -0
- package/dist/resources/hooks/use-closeouts.d.ts.map +1 -0
- package/dist/resources/hooks/use-closeouts.js +12 -0
- package/dist/resources/hooks/use-pool.d.ts +15 -0
- package/dist/resources/hooks/use-pool.d.ts.map +1 -0
- package/dist/resources/hooks/use-pool.js +12 -0
- package/dist/resources/hooks/use-pools.d.ts +19 -0
- package/dist/resources/hooks/use-pools.d.ts.map +1 -0
- package/dist/resources/hooks/use-pools.js +12 -0
- package/dist/resources/hooks/use-products.d.ts +14 -0
- package/dist/resources/hooks/use-products.d.ts.map +1 -0
- package/dist/resources/hooks/use-products.js +12 -0
- package/dist/resources/hooks/use-resource.d.ts +16 -0
- package/dist/resources/hooks/use-resource.d.ts.map +1 -0
- package/dist/resources/hooks/use-resource.js +12 -0
- package/dist/resources/hooks/use-resources.d.ts +20 -0
- package/dist/resources/hooks/use-resources.d.ts.map +1 -0
- package/dist/resources/hooks/use-resources.js +12 -0
- package/dist/resources/hooks/use-rules.d.ts +15 -0
- package/dist/resources/hooks/use-rules.d.ts.map +1 -0
- package/dist/resources/hooks/use-rules.js +12 -0
- package/dist/resources/hooks/use-slots.d.ts +16 -0
- package/dist/resources/hooks/use-slots.d.ts.map +1 -0
- package/dist/resources/hooks/use-slots.js +12 -0
- package/dist/resources/hooks/use-start-times.d.ts +16 -0
- package/dist/resources/hooks/use-start-times.d.ts.map +1 -0
- package/dist/resources/hooks/use-start-times.js +12 -0
- package/dist/resources/hooks/use-suppliers.d.ts +14 -0
- package/dist/resources/hooks/use-suppliers.d.ts.map +1 -0
- package/dist/resources/hooks/use-suppliers.js +12 -0
- package/dist/resources/i18n/en.d.ts +3 -0
- package/dist/resources/i18n/en.d.ts.map +1 -0
- package/dist/resources/i18n/en.js +363 -0
- package/dist/resources/i18n/index.d.ts +5 -0
- package/dist/resources/i18n/index.d.ts.map +1 -0
- package/dist/resources/i18n/index.js +3 -0
- package/dist/resources/i18n/messages.d.ts +298 -0
- package/dist/resources/i18n/messages.d.ts.map +1 -0
- package/dist/resources/i18n/messages.js +1 -0
- package/dist/resources/i18n/provider.d.ts +26 -0
- package/dist/resources/i18n/provider.d.ts.map +1 -0
- package/dist/resources/i18n/provider.js +44 -0
- package/dist/resources/i18n/ro.d.ts +3 -0
- package/dist/resources/i18n/ro.d.ts.map +1 -0
- package/dist/resources/i18n/ro.js +363 -0
- package/dist/resources/i18n/utils.d.ts +18 -0
- package/dist/resources/i18n/utils.d.ts.map +1 -0
- package/dist/resources/i18n/utils.js +30 -0
- package/dist/resources/index.d.ts +9 -0
- package/dist/resources/index.d.ts.map +1 -0
- package/dist/resources/index.js +8 -0
- package/dist/resources/provider.d.ts +2 -0
- package/dist/resources/provider.d.ts.map +1 -0
- package/dist/resources/provider.js +1 -0
- package/dist/resources/query-keys.d.ts +73 -0
- package/dist/resources/query-keys.d.ts.map +1 -0
- package/dist/resources/query-keys.js +29 -0
- package/dist/resources/query-options.d.ts +801 -0
- package/dist/resources/query-options.d.ts.map +1 -0
- package/dist/resources/query-options.js +237 -0
- package/dist/resources/schemas.d.ts +452 -0
- package/dist/resources/schemas.d.ts.map +1 -0
- package/dist/resources/schemas.js +126 -0
- package/dist/resources/ui.d.ts +13 -0
- package/dist/resources/ui.d.ts.map +1 -0
- package/dist/resources/ui.js +12 -0
- package/dist/resources/utils.d.ts +14 -0
- package/dist/resources/utils.d.ts.map +1 -0
- package/dist/resources/utils.js +33 -0
- package/package.json +325 -0
- package/src/availability/styles.css +12 -0
- package/src/places/styles.css +11 -0
- package/src/resources/styles.css +11 -0
- package/src/styles.css +3 -0
|
@@ -0,0 +1,251 @@
|
|
|
1
|
+
import type { QueryClient } from "@tanstack/react-query";
|
|
2
|
+
import { type VoyantAvailabilityContextValue } from "../index.js";
|
|
3
|
+
export interface AvailabilityRuleDetailPageProps {
|
|
4
|
+
id: string;
|
|
5
|
+
className?: string;
|
|
6
|
+
onBack?: () => void;
|
|
7
|
+
onDeleted?: () => void;
|
|
8
|
+
onOpenProduct?: (productId: string) => void;
|
|
9
|
+
onOpenSlot?: (slotId: string) => void;
|
|
10
|
+
confirmAction?: (message: string) => boolean;
|
|
11
|
+
}
|
|
12
|
+
export declare function getAvailabilityRuleDetailQueryOptions(client: VoyantAvailabilityContextValue, id: string | null | undefined): import("@tanstack/react-query").OmitKeyof<import("@tanstack/react-query").UseQueryOptions<{
|
|
13
|
+
data: {
|
|
14
|
+
id: string;
|
|
15
|
+
productId: string;
|
|
16
|
+
optionId: string | null;
|
|
17
|
+
facilityId: string | null;
|
|
18
|
+
timezone: string;
|
|
19
|
+
recurrenceRule: string;
|
|
20
|
+
maxCapacity: number;
|
|
21
|
+
maxPickupCapacity: number | null;
|
|
22
|
+
minTotalPax: number | null;
|
|
23
|
+
cutoffMinutes: number | null;
|
|
24
|
+
earlyBookingLimitMinutes: number | null;
|
|
25
|
+
active: boolean;
|
|
26
|
+
productName?: string | null | undefined;
|
|
27
|
+
};
|
|
28
|
+
}, Error, {
|
|
29
|
+
data: {
|
|
30
|
+
id: string;
|
|
31
|
+
productId: string;
|
|
32
|
+
optionId: string | null;
|
|
33
|
+
facilityId: string | null;
|
|
34
|
+
timezone: string;
|
|
35
|
+
recurrenceRule: string;
|
|
36
|
+
maxCapacity: number;
|
|
37
|
+
maxPickupCapacity: number | null;
|
|
38
|
+
minTotalPax: number | null;
|
|
39
|
+
cutoffMinutes: number | null;
|
|
40
|
+
earlyBookingLimitMinutes: number | null;
|
|
41
|
+
active: boolean;
|
|
42
|
+
productName?: string | null | undefined;
|
|
43
|
+
};
|
|
44
|
+
}, readonly ["voyant", "availability", "rules", "detail", string]>, "queryFn"> & {
|
|
45
|
+
queryFn?: import("@tanstack/react-query").QueryFunction<{
|
|
46
|
+
data: {
|
|
47
|
+
id: string;
|
|
48
|
+
productId: string;
|
|
49
|
+
optionId: string | null;
|
|
50
|
+
facilityId: string | null;
|
|
51
|
+
timezone: string;
|
|
52
|
+
recurrenceRule: string;
|
|
53
|
+
maxCapacity: number;
|
|
54
|
+
maxPickupCapacity: number | null;
|
|
55
|
+
minTotalPax: number | null;
|
|
56
|
+
cutoffMinutes: number | null;
|
|
57
|
+
earlyBookingLimitMinutes: number | null;
|
|
58
|
+
active: boolean;
|
|
59
|
+
productName?: string | null | undefined;
|
|
60
|
+
};
|
|
61
|
+
}, readonly ["voyant", "availability", "rules", "detail", string], never> | undefined;
|
|
62
|
+
} & {
|
|
63
|
+
queryKey: readonly ["voyant", "availability", "rules", "detail", string] & {
|
|
64
|
+
[dataTagSymbol]: {
|
|
65
|
+
data: {
|
|
66
|
+
id: string;
|
|
67
|
+
productId: string;
|
|
68
|
+
optionId: string | null;
|
|
69
|
+
facilityId: string | null;
|
|
70
|
+
timezone: string;
|
|
71
|
+
recurrenceRule: string;
|
|
72
|
+
maxCapacity: number;
|
|
73
|
+
maxPickupCapacity: number | null;
|
|
74
|
+
minTotalPax: number | null;
|
|
75
|
+
cutoffMinutes: number | null;
|
|
76
|
+
earlyBookingLimitMinutes: number | null;
|
|
77
|
+
active: boolean;
|
|
78
|
+
productName?: string | null | undefined;
|
|
79
|
+
};
|
|
80
|
+
};
|
|
81
|
+
[dataTagErrorSymbol]: Error;
|
|
82
|
+
};
|
|
83
|
+
};
|
|
84
|
+
export declare function getAvailabilityRuleSlotsQueryOptions(client: VoyantAvailabilityContextValue, id: string | null | undefined): import("@tanstack/react-query").OmitKeyof<import("@tanstack/react-query").UseQueryOptions<{
|
|
85
|
+
data: {
|
|
86
|
+
id: string;
|
|
87
|
+
productId: string;
|
|
88
|
+
itineraryId: string | null;
|
|
89
|
+
optionId: string | null;
|
|
90
|
+
facilityId: string | null;
|
|
91
|
+
availabilityRuleId: string | null;
|
|
92
|
+
startTimeId: string | null;
|
|
93
|
+
dateLocal: string;
|
|
94
|
+
startsAt: string;
|
|
95
|
+
endsAt: string | null;
|
|
96
|
+
timezone: string;
|
|
97
|
+
status: "cancelled" | "open" | "closed" | "sold_out";
|
|
98
|
+
unlimited: boolean;
|
|
99
|
+
initialPax: number | null;
|
|
100
|
+
remainingPax: number | null;
|
|
101
|
+
nights: number | null;
|
|
102
|
+
days: number | null;
|
|
103
|
+
notes: string | null;
|
|
104
|
+
productName?: string | null | undefined;
|
|
105
|
+
endDateLocal?: string | null | undefined;
|
|
106
|
+
}[];
|
|
107
|
+
total: number;
|
|
108
|
+
limit: number;
|
|
109
|
+
offset: number;
|
|
110
|
+
}, Error, {
|
|
111
|
+
data: {
|
|
112
|
+
id: string;
|
|
113
|
+
productId: string;
|
|
114
|
+
itineraryId: string | null;
|
|
115
|
+
optionId: string | null;
|
|
116
|
+
facilityId: string | null;
|
|
117
|
+
availabilityRuleId: string | null;
|
|
118
|
+
startTimeId: string | null;
|
|
119
|
+
dateLocal: string;
|
|
120
|
+
startsAt: string;
|
|
121
|
+
endsAt: string | null;
|
|
122
|
+
timezone: string;
|
|
123
|
+
status: "cancelled" | "open" | "closed" | "sold_out";
|
|
124
|
+
unlimited: boolean;
|
|
125
|
+
initialPax: number | null;
|
|
126
|
+
remainingPax: number | null;
|
|
127
|
+
nights: number | null;
|
|
128
|
+
days: number | null;
|
|
129
|
+
notes: string | null;
|
|
130
|
+
productName?: string | null | undefined;
|
|
131
|
+
endDateLocal?: string | null | undefined;
|
|
132
|
+
}[];
|
|
133
|
+
total: number;
|
|
134
|
+
limit: number;
|
|
135
|
+
offset: number;
|
|
136
|
+
}, readonly ["voyant", "availability", "slots", "list", import("../query-keys.js").AvailabilitySlotsListFilters]>, "queryFn"> & {
|
|
137
|
+
queryFn?: import("@tanstack/react-query").QueryFunction<{
|
|
138
|
+
data: {
|
|
139
|
+
id: string;
|
|
140
|
+
productId: string;
|
|
141
|
+
itineraryId: string | null;
|
|
142
|
+
optionId: string | null;
|
|
143
|
+
facilityId: string | null;
|
|
144
|
+
availabilityRuleId: string | null;
|
|
145
|
+
startTimeId: string | null;
|
|
146
|
+
dateLocal: string;
|
|
147
|
+
startsAt: string;
|
|
148
|
+
endsAt: string | null;
|
|
149
|
+
timezone: string;
|
|
150
|
+
status: "cancelled" | "open" | "closed" | "sold_out";
|
|
151
|
+
unlimited: boolean;
|
|
152
|
+
initialPax: number | null;
|
|
153
|
+
remainingPax: number | null;
|
|
154
|
+
nights: number | null;
|
|
155
|
+
days: number | null;
|
|
156
|
+
notes: string | null;
|
|
157
|
+
productName?: string | null | undefined;
|
|
158
|
+
endDateLocal?: string | null | undefined;
|
|
159
|
+
}[];
|
|
160
|
+
total: number;
|
|
161
|
+
limit: number;
|
|
162
|
+
offset: number;
|
|
163
|
+
}, readonly ["voyant", "availability", "slots", "list", import("../query-keys.js").AvailabilitySlotsListFilters], never> | undefined;
|
|
164
|
+
} & {
|
|
165
|
+
queryKey: readonly ["voyant", "availability", "slots", "list", import("../query-keys.js").AvailabilitySlotsListFilters] & {
|
|
166
|
+
[dataTagSymbol]: {
|
|
167
|
+
data: {
|
|
168
|
+
id: string;
|
|
169
|
+
productId: string;
|
|
170
|
+
itineraryId: string | null;
|
|
171
|
+
optionId: string | null;
|
|
172
|
+
facilityId: string | null;
|
|
173
|
+
availabilityRuleId: string | null;
|
|
174
|
+
startTimeId: string | null;
|
|
175
|
+
dateLocal: string;
|
|
176
|
+
startsAt: string;
|
|
177
|
+
endsAt: string | null;
|
|
178
|
+
timezone: string;
|
|
179
|
+
status: "cancelled" | "open" | "closed" | "sold_out";
|
|
180
|
+
unlimited: boolean;
|
|
181
|
+
initialPax: number | null;
|
|
182
|
+
remainingPax: number | null;
|
|
183
|
+
nights: number | null;
|
|
184
|
+
days: number | null;
|
|
185
|
+
notes: string | null;
|
|
186
|
+
productName?: string | null | undefined;
|
|
187
|
+
endDateLocal?: string | null | undefined;
|
|
188
|
+
}[];
|
|
189
|
+
total: number;
|
|
190
|
+
limit: number;
|
|
191
|
+
offset: number;
|
|
192
|
+
};
|
|
193
|
+
[dataTagErrorSymbol]: Error;
|
|
194
|
+
};
|
|
195
|
+
};
|
|
196
|
+
export declare function loadAvailabilityRuleDetailPage(queryClient: QueryClient, client: VoyantAvailabilityContextValue, id: string): Promise<[{
|
|
197
|
+
data: {
|
|
198
|
+
id: string;
|
|
199
|
+
productId: string;
|
|
200
|
+
optionId: string | null;
|
|
201
|
+
facilityId: string | null;
|
|
202
|
+
timezone: string;
|
|
203
|
+
recurrenceRule: string;
|
|
204
|
+
maxCapacity: number;
|
|
205
|
+
maxPickupCapacity: number | null;
|
|
206
|
+
minTotalPax: number | null;
|
|
207
|
+
cutoffMinutes: number | null;
|
|
208
|
+
earlyBookingLimitMinutes: number | null;
|
|
209
|
+
active: boolean;
|
|
210
|
+
productName?: string | null | undefined;
|
|
211
|
+
};
|
|
212
|
+
}, {
|
|
213
|
+
data: {
|
|
214
|
+
id: string;
|
|
215
|
+
productId: string;
|
|
216
|
+
itineraryId: string | null;
|
|
217
|
+
optionId: string | null;
|
|
218
|
+
facilityId: string | null;
|
|
219
|
+
availabilityRuleId: string | null;
|
|
220
|
+
startTimeId: string | null;
|
|
221
|
+
dateLocal: string;
|
|
222
|
+
startsAt: string;
|
|
223
|
+
endsAt: string | null;
|
|
224
|
+
timezone: string;
|
|
225
|
+
status: "cancelled" | "open" | "closed" | "sold_out";
|
|
226
|
+
unlimited: boolean;
|
|
227
|
+
initialPax: number | null;
|
|
228
|
+
remainingPax: number | null;
|
|
229
|
+
nights: number | null;
|
|
230
|
+
days: number | null;
|
|
231
|
+
notes: string | null;
|
|
232
|
+
productName?: string | null | undefined;
|
|
233
|
+
endDateLocal?: string | null | undefined;
|
|
234
|
+
}[];
|
|
235
|
+
total: number;
|
|
236
|
+
limit: number;
|
|
237
|
+
offset: number;
|
|
238
|
+
}, {
|
|
239
|
+
data: {
|
|
240
|
+
id: string;
|
|
241
|
+
name: string;
|
|
242
|
+
sellCurrency: string | null;
|
|
243
|
+
productType: {
|
|
244
|
+
id: string;
|
|
245
|
+
name: string;
|
|
246
|
+
code: string | null;
|
|
247
|
+
} | null;
|
|
248
|
+
};
|
|
249
|
+
}]>;
|
|
250
|
+
export declare function AvailabilityRuleDetailPage({ id, className, onBack, onDeleted, onOpenProduct, onOpenSlot, confirmAction, }: AvailabilityRuleDetailPageProps): import("react/jsx-runtime").JSX.Element;
|
|
251
|
+
//# sourceMappingURL=availability-rule-detail-page.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"availability-rule-detail-page.d.ts","sourceRoot":"","sources":["../../../src/availability/components/availability-rule-detail-page.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAA;AAaxD,OAAO,EAWL,KAAK,8BAA8B,EACpC,MAAM,aAAa,CAAA;AAIpB,MAAM,WAAW,+BAA+B;IAC9C,EAAE,EAAE,MAAM,CAAA;IACV,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,MAAM,CAAC,EAAE,MAAM,IAAI,CAAA;IACnB,SAAS,CAAC,EAAE,MAAM,IAAI,CAAA;IACtB,aAAa,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAA;IAC3C,UAAU,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAA;IACrC,aAAa,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,OAAO,CAAA;CAC7C;AAED,wBAAgB,qCAAqC,CACnD,MAAM,EAAE,8BAA8B,EACtC,EAAE,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAa9B;AAED,wBAAgB,oCAAoC,CAClD,MAAM,EAAE,8BAA8B,EACtC,EAAE,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAG9B;AAED,wBAAsB,8BAA8B,CAClD,WAAW,EAAE,WAAW,EACxB,MAAM,EAAE,8BAA8B,EACtC,EAAE,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAWX;AAED,wBAAgB,0BAA0B,CAAC,EACzC,EAAE,EACF,SAAS,EACT,MAAM,EACN,SAAS,EACT,aAAa,EACb,UAAU,EACV,aAAkE,GACnE,EAAE,+BAA+B,2CAsIjC"}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { queryOptions, useQuery } from "@tanstack/react-query";
|
|
4
|
+
import { Badge, Button, Card, CardContent, CardHeader, CardTitle, cn, } from "@voyant-travel/ui/components";
|
|
5
|
+
import { ArrowLeft, CalendarDays, Package, Trash2 } from "lucide-react";
|
|
6
|
+
import { useAvailabilityUiMessagesOrDefault } from "../i18n/index.js";
|
|
7
|
+
import { availabilityQueryKeys, availabilityRuleSingleResponse, fetchWithValidation, getProductQueryOptions, getSlotsQueryOptions, slotLocalStart, useAvailabilityRuleMutation, useVoyantAvailabilityContext, } from "../index.js";
|
|
8
|
+
import { getSlotStatusLabel } from "./availability-columns.js";
|
|
9
|
+
import { AvailabilityRuleDetailSkeleton } from "./availability-skeletons.js";
|
|
10
|
+
export function getAvailabilityRuleDetailQueryOptions(client, id) {
|
|
11
|
+
return queryOptions({
|
|
12
|
+
queryKey: availabilityQueryKeys.ruleDetail(id ?? ""),
|
|
13
|
+
queryFn: async () => {
|
|
14
|
+
if (!id)
|
|
15
|
+
throw new Error("getAvailabilityRuleDetailQueryOptions requires an id");
|
|
16
|
+
return fetchWithValidation(`/v1/operations/availability/rules/${id}`, availabilityRuleSingleResponse, client);
|
|
17
|
+
},
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
export function getAvailabilityRuleSlotsQueryOptions(client, id) {
|
|
21
|
+
return getSlotsQueryOptions(client, { availabilityRuleId: id ?? undefined, limit: 25, offset: 0 });
|
|
22
|
+
}
|
|
23
|
+
export async function loadAvailabilityRuleDetailPage(queryClient, client, id) {
|
|
24
|
+
const ruleData = await queryClient.ensureQueryData(getAvailabilityRuleDetailQueryOptions(client, id));
|
|
25
|
+
return Promise.all([
|
|
26
|
+
Promise.resolve(ruleData),
|
|
27
|
+
queryClient.ensureQueryData(getAvailabilityRuleSlotsQueryOptions(client, id)),
|
|
28
|
+
queryClient.ensureQueryData(getProductQueryOptions(client, ruleData.data.productId)),
|
|
29
|
+
]);
|
|
30
|
+
}
|
|
31
|
+
export function AvailabilityRuleDetailPage({ id, className, onBack, onDeleted, onOpenProduct, onOpenSlot, confirmAction = (message) => globalThis.confirm?.(message) ?? true, }) {
|
|
32
|
+
const client = useVoyantAvailabilityContext();
|
|
33
|
+
const messages = useAvailabilityUiMessagesOrDefault();
|
|
34
|
+
const detailMessages = messages.details;
|
|
35
|
+
const noValue = detailMessages.noValue;
|
|
36
|
+
const ruleMutation = useAvailabilityRuleMutation();
|
|
37
|
+
const { data: ruleData, isPending } = useQuery(getAvailabilityRuleDetailQueryOptions(client, id));
|
|
38
|
+
const rule = ruleData?.data;
|
|
39
|
+
const productQuery = useQuery({
|
|
40
|
+
...getProductQueryOptions(client, rule?.productId ?? ""),
|
|
41
|
+
enabled: Boolean(rule?.productId),
|
|
42
|
+
});
|
|
43
|
+
const slotsQuery = useQuery(getAvailabilityRuleSlotsQueryOptions(client, id));
|
|
44
|
+
if (isPending) {
|
|
45
|
+
return _jsx(AvailabilityRuleDetailSkeleton, {});
|
|
46
|
+
}
|
|
47
|
+
if (!rule) {
|
|
48
|
+
return (_jsx(DetailEmptyState, { message: detailMessages.rule.notFound, backLabel: detailMessages.backToAvailability, onBack: onBack }));
|
|
49
|
+
}
|
|
50
|
+
async function deleteRule(currentRule) {
|
|
51
|
+
if (!confirmAction(detailMessages.rule.deleteConfirm))
|
|
52
|
+
return;
|
|
53
|
+
await ruleMutation.remove.mutateAsync(currentRule.id);
|
|
54
|
+
if (onDeleted)
|
|
55
|
+
onDeleted();
|
|
56
|
+
else
|
|
57
|
+
onBack?.();
|
|
58
|
+
}
|
|
59
|
+
return (_jsxs("div", { className: cn("flex flex-col gap-6 p-6", className), children: [_jsxs("div", { className: "flex flex-col gap-4 md:flex-row md:items-start md:justify-between", children: [_jsxs("div", { className: "flex items-start gap-4", children: [onBack ? (_jsx(Button, { variant: "ghost", size: "icon", onClick: onBack, "aria-label": detailMessages.backToAvailability, children: _jsx(ArrowLeft, { "data-icon": true, "aria-hidden": "true" }) })) : null, _jsxs("div", { className: "flex-1", children: [_jsx("h1", { className: "text-2xl font-bold tracking-tight", children: detailMessages.rule.pageTitle }), _jsxs("div", { className: "mt-1 flex flex-wrap items-center gap-2", children: [_jsx(Badge, { variant: rule.active ? "default" : "secondary", children: rule.active ? messages.statusActive : messages.statusInactive }), _jsx(Badge, { variant: "outline", children: rule.timezone })] })] })] }), _jsxs("div", { className: "flex flex-wrap items-center gap-2", children: [onOpenProduct ? (_jsxs(Button, { variant: "outline", onClick: () => onOpenProduct(rule.productId), children: [_jsx(Package, { "data-icon": "inline-start", "aria-hidden": "true" }), detailMessages.openProduct] })) : null, _jsxs(Button, { variant: "destructive", onClick: () => void deleteRule(rule), disabled: ruleMutation.remove.isPending, children: [_jsx(Trash2, { "data-icon": "inline-start", "aria-hidden": "true" }), detailMessages.delete] })] })] }), _jsxs("div", { className: "grid gap-6 md:grid-cols-2", children: [_jsxs(Card, { children: [_jsx(CardHeader, { children: _jsx(CardTitle, { children: detailMessages.rule.detailsTitle }) }), _jsxs(CardContent, { className: "flex flex-col gap-3 text-sm", children: [_jsx(DetailLine, { label: messages.productLabel, children: productQuery.data?.data.name ?? rule.productId }), _jsxs("div", { children: [_jsxs("span", { className: "text-muted-foreground", children: [messages.recurrenceLabel, ":"] }), _jsx("pre", { className: "mt-1 overflow-x-auto rounded-md bg-muted p-3 font-mono text-xs", children: rule.recurrenceRule })] })] })] }), _jsxs(Card, { children: [_jsx(CardHeader, { children: _jsx(CardTitle, { children: detailMessages.rule.capacityPolicyTitle }) }), _jsxs(CardContent, { className: "flex flex-col gap-3 text-sm", children: [_jsx(DetailLine, { label: messages.maxPaxLabel, children: rule.maxCapacity }), _jsx(DetailLine, { label: detailMessages.rule.maxPickupCapacityLabel, children: rule.maxPickupCapacity ?? noValue }), _jsx(DetailLine, { label: detailMessages.rule.minTotalPaxLabel, children: rule.minTotalPax ?? noValue }), _jsx(DetailLine, { label: detailMessages.rule.cutoffMinutesLabel, children: rule.cutoffMinutes ?? noValue }), _jsx(DetailLine, { label: detailMessages.rule.earlyBookingLimitLabel, children: rule.earlyBookingLimitMinutes ?? noValue })] })] })] }), _jsxs(Card, { children: [_jsxs(CardHeader, { className: "flex flex-row items-center gap-2", children: [_jsx(CalendarDays, { className: "size-4", "aria-hidden": "true" }), _jsx(CardTitle, { children: detailMessages.rule.generatedSlotsTitle })] }), _jsx(CardContent, { className: "flex flex-col gap-3 text-sm", children: (slotsQuery.data?.data.length ?? 0) === 0 ? (_jsx("p", { className: "text-muted-foreground", children: detailMessages.rule.generatedSlotsEmpty })) : (slotsQuery.data?.data.map((slot) => (_jsx(SlotButton, { slot: slot, onOpenSlot: onOpenSlot }, slot.id)))) })] })] }));
|
|
60
|
+
}
|
|
61
|
+
function SlotButton({ slot, onOpenSlot, }) {
|
|
62
|
+
const messages = useAvailabilityUiMessagesOrDefault();
|
|
63
|
+
const noValue = messages.details.noValue;
|
|
64
|
+
return (_jsxs("button", { type: "button", className: "block w-full rounded-md border p-3 text-left hover:bg-muted/40", onClick: () => onOpenSlot?.(slot.id), children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(Badge, { variant: "outline", children: getSlotStatusLabel(slot.status, messages) }), _jsx("span", { children: formatSlotLocalDateTime(slotLocalStart(slot)) })] }), _jsxs("div", { className: "mt-2 text-muted-foreground", children: [messages.remainingPaxLabel, ": ", slot.remainingPax ?? noValue] })] }));
|
|
65
|
+
}
|
|
66
|
+
function formatSlotLocalDateTime(value) {
|
|
67
|
+
return `${value.date} ${value.time}`;
|
|
68
|
+
}
|
|
69
|
+
function DetailLine({ label, children }) {
|
|
70
|
+
return (_jsxs("div", { children: [_jsxs("span", { className: "text-muted-foreground", children: [label, ":"] }), " ", _jsx("span", { children: children })] }));
|
|
71
|
+
}
|
|
72
|
+
function DetailEmptyState({ message, backLabel, onBack, }) {
|
|
73
|
+
return (_jsxs("div", { className: "flex flex-col items-center justify-center gap-4 py-12", children: [_jsx("p", { className: "text-muted-foreground", children: message }), onBack ? (_jsx(Button, { variant: "outline", onClick: onBack, children: backLabel })) : null] }));
|
|
74
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export interface AvailabilitySectionHeaderProps {
|
|
2
|
+
actionLabel: string;
|
|
3
|
+
description: string;
|
|
4
|
+
onAction: () => void;
|
|
5
|
+
title: string;
|
|
6
|
+
}
|
|
7
|
+
export declare function AvailabilitySectionHeader({ actionLabel, description, onAction, title, }: AvailabilitySectionHeaderProps): import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
//# sourceMappingURL=availability-section-header.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"availability-section-header.d.ts","sourceRoot":"","sources":["../../../src/availability/components/availability-section-header.tsx"],"names":[],"mappings":"AAKA,MAAM,WAAW,8BAA8B;IAC7C,WAAW,EAAE,MAAM,CAAA;IACnB,WAAW,EAAE,MAAM,CAAA;IACnB,QAAQ,EAAE,MAAM,IAAI,CAAA;IACpB,KAAK,EAAE,MAAM,CAAA;CACd;AAED,wBAAgB,yBAAyB,CAAC,EACxC,WAAW,EACX,WAAW,EACX,QAAQ,EACR,KAAK,GACN,EAAE,8BAA8B,2CAahC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { Button } from "@voyant-travel/ui/components";
|
|
4
|
+
import { Plus } from "lucide-react";
|
|
5
|
+
export function AvailabilitySectionHeader({ actionLabel, description, onAction, title, }) {
|
|
6
|
+
return (_jsxs("div", { className: "flex items-center justify-between gap-4", children: [_jsxs("div", { children: [_jsx("h2", { className: "text-lg font-semibold", children: title }), _jsx("p", { className: "text-sm text-muted-foreground", children: description })] }), _jsxs(Button, { onClick: onAction, children: [_jsx(Plus, { className: "mr-2 h-4 w-4" }), actionLabel] })] }));
|
|
7
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export declare function AvailabilityBodySkeleton(): import("react/jsx-runtime").JSX.Element;
|
|
2
|
+
export declare function AvailabilityPageSkeleton(): import("react/jsx-runtime").JSX.Element;
|
|
3
|
+
export declare function AvailabilityRuleDetailSkeleton(): import("react/jsx-runtime").JSX.Element;
|
|
4
|
+
export declare function AvailabilityStartTimeDetailSkeleton(): import("react/jsx-runtime").JSX.Element;
|
|
5
|
+
export declare function AvailabilitySlotDetailSkeleton(): import("react/jsx-runtime").JSX.Element;
|
|
6
|
+
//# sourceMappingURL=availability-skeletons.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"availability-skeletons.d.ts","sourceRoot":"","sources":["../../../src/availability/components/availability-skeletons.tsx"],"names":[],"mappings":"AAYA,wBAAgB,wBAAwB,4CAsEvC;AAED,wBAAgB,wBAAwB,4CAUvC;AAED,wBAAgB,8BAA8B,4CAmE7C;AAED,wBAAgB,mCAAmC,4CAqDlD;AAED,wBAAgB,8BAA8B,4CA6D7C"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Card, CardContent, CardHeader } from "@voyant-travel/ui/components/card";
|
|
3
|
+
import { Skeleton } from "@voyant-travel/ui/components/skeleton";
|
|
4
|
+
import { Table, TableBody, TableCell, TableHead, TableHeader, TableRow, } from "@voyant-travel/ui/components/table";
|
|
5
|
+
import { useAvailabilityUiMessagesOrDefault } from "../i18n/index.js";
|
|
6
|
+
export function AvailabilityBodySkeleton() {
|
|
7
|
+
const messages = useAvailabilityUiMessagesOrDefault().page.skeleton;
|
|
8
|
+
return (_jsxs("div", { className: "flex flex-col gap-6", children: [_jsxs("div", { className: "flex items-center gap-3", children: [_jsx(Skeleton, { className: "h-9 w-full max-w-sm" }), _jsx(Skeleton, { className: "h-9 w-44" })] }), _jsx("div", { className: "grid gap-4 md:grid-cols-2 lg:grid-cols-4", children: Array.from({ length: 4 }).map((_, i) => (_jsxs(Card, { children: [_jsx(CardHeader, { className: "pb-2", children: _jsx(Skeleton, { className: "h-3.5 w-28" }) }), _jsxs(CardContent, { className: "space-y-2", children: [_jsx(Skeleton, { className: "h-7 w-20" }), _jsx(Skeleton, { className: "h-3 w-40" })] })] }, i))) }), _jsxs(Card, { children: [_jsx(CardHeader, { children: _jsx(Skeleton, { className: "h-5 w-52" }) }), _jsx(CardContent, { className: "space-y-2", children: Array.from({ length: 3 }).map((_, i) => (_jsxs("div", { className: "flex items-center justify-between rounded-md border px-3 py-2", children: [_jsx(Skeleton, { className: "h-4 w-48" }), _jsx(Skeleton, { className: "h-4 w-32" })] }, i))) })] }), _jsxs("div", { className: "flex items-center gap-1 border-b", children: [_jsx(Skeleton, { className: "h-9 w-20" }), _jsx(Skeleton, { className: "h-9 w-20" }), _jsx(Skeleton, { className: "h-9 w-28" }), _jsx(Skeleton, { className: "h-9 w-24" }), _jsx(Skeleton, { className: "h-9 w-32" })] }), _jsx("div", { className: "rounded-md border", children: _jsxs(Table, { children: [_jsx(TableHeader, { children: _jsxs(TableRow, { children: [_jsx(TableHead, { children: messages.date }), _jsx(TableHead, { children: messages.product }), _jsx(TableHead, { children: messages.status }), _jsx(TableHead, { children: messages.remaining }), _jsx(TableHead, { children: messages.capacity })] }) }), _jsx(SkeletonTableRows, { rows: 6, columns: 5, columnWidths: ["w-24", "w-40", "w-16", "w-16", "w-16"] })] }) })] }));
|
|
9
|
+
}
|
|
10
|
+
export function AvailabilityPageSkeleton() {
|
|
11
|
+
return (_jsxs("div", { className: "flex flex-col gap-6 p-6", children: [_jsxs("div", { className: "space-y-2", children: [_jsx(Skeleton, { className: "h-7 w-40" }), _jsx(Skeleton, { className: "h-4 w-96" })] }), _jsx(AvailabilityBodySkeleton, {})] }));
|
|
12
|
+
}
|
|
13
|
+
export function AvailabilityRuleDetailSkeleton() {
|
|
14
|
+
return (_jsxs("div", { className: "flex flex-col gap-6 p-6", children: [_jsxs("div", { className: "flex items-center gap-4", children: [_jsx(Skeleton, { className: "h-9 w-9 rounded-md" }), _jsxs("div", { className: "flex-1 space-y-2", children: [_jsx(Skeleton, { className: "h-7 w-48" }), _jsxs("div", { className: "flex gap-2", children: [_jsx(Skeleton, { className: "h-5 w-14 rounded-full" }), _jsx(Skeleton, { className: "h-5 w-24 rounded" })] })] }), _jsx(Skeleton, { className: "h-9 w-32" }), _jsx(Skeleton, { className: "h-9 w-24" })] }), _jsxs("div", { className: "grid gap-6 md:grid-cols-2", children: [_jsxs(Card, { children: [_jsx(CardHeader, { children: _jsx(Skeleton, { className: "h-5 w-24" }) }), _jsxs(CardContent, { className: "grid gap-3", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(Skeleton, { className: "h-3.5 w-20" }), _jsx(Skeleton, { className: "h-3.5 w-40" })] }), _jsx(Skeleton, { className: "h-3.5 w-24" }), _jsx(Skeleton, { className: "h-24 w-full rounded-md" })] })] }), _jsxs(Card, { children: [_jsx(CardHeader, { children: _jsx(Skeleton, { className: "h-5 w-32" }) }), _jsx(CardContent, { className: "grid gap-3", children: Array.from({ length: 5 }).map((_, i) => (_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(Skeleton, { className: "h-3.5 w-32" }), _jsx(Skeleton, { className: "h-3.5 w-16" })] }, i))) })] })] }), _jsxs(Card, { children: [_jsxs(CardHeader, { className: "flex flex-row items-center gap-2", children: [_jsx(Skeleton, { className: "h-4 w-4" }), _jsx(Skeleton, { className: "h-5 w-36" })] }), _jsx(CardContent, { className: "space-y-2", children: Array.from({ length: 4 }).map((_, i) => (_jsxs("div", { className: "flex items-center justify-between rounded-md border px-3 py-2", children: [_jsx(Skeleton, { className: "h-4 w-48" }), _jsx(Skeleton, { className: "h-5 w-16 rounded-full" })] }, i))) })] })] }));
|
|
15
|
+
}
|
|
16
|
+
export function AvailabilityStartTimeDetailSkeleton() {
|
|
17
|
+
return (_jsxs("div", { className: "flex flex-col gap-6 p-6", children: [_jsxs("div", { className: "flex items-center gap-4", children: [_jsx(Skeleton, { className: "h-9 w-9 rounded-md" }), _jsxs("div", { className: "flex-1 space-y-2", children: [_jsx(Skeleton, { className: "h-7 w-56" }), _jsxs("div", { className: "flex gap-2", children: [_jsx(Skeleton, { className: "h-5 w-16 rounded" }), _jsx(Skeleton, { className: "h-5 w-14 rounded-full" })] })] }), _jsx(Skeleton, { className: "h-9 w-32" }), _jsx(Skeleton, { className: "h-9 w-24" })] }), _jsxs("div", { className: "grid gap-6 md:grid-cols-2", children: [_jsxs(Card, { children: [_jsx(CardHeader, { children: _jsx(Skeleton, { className: "h-5 w-40" }) }), _jsx(CardContent, { className: "grid gap-3", children: Array.from({ length: 6 }).map((_, i) => (_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(Skeleton, { className: "h-3.5 w-24" }), _jsx(Skeleton, { className: "h-3.5 w-32" })] }, i))) })] }), _jsxs(Card, { children: [_jsxs(CardHeader, { className: "flex flex-row items-center gap-2", children: [_jsx(Skeleton, { className: "h-4 w-4" }), _jsx(Skeleton, { className: "h-5 w-36" })] }), _jsx(CardContent, { className: "space-y-3", children: Array.from({ length: 3 }).map((_, i) => (_jsxs("div", { className: "rounded-md border p-3 space-y-1.5", children: [_jsx(Skeleton, { className: "h-4 w-48" }), _jsx(Skeleton, { className: "h-3 w-32" })] }, i))) })] })] })] }));
|
|
18
|
+
}
|
|
19
|
+
export function AvailabilitySlotDetailSkeleton() {
|
|
20
|
+
return (_jsxs("div", { className: "flex flex-col gap-6 p-6", children: [_jsxs("div", { className: "flex items-center gap-4", children: [_jsx(Skeleton, { className: "h-9 w-9 rounded-md" }), _jsxs("div", { className: "flex-1 space-y-2", children: [_jsx(Skeleton, { className: "h-7 w-72" }), _jsxs("div", { className: "flex gap-2", children: [_jsx(Skeleton, { className: "h-5 w-16 rounded-full" }), _jsx(Skeleton, { className: "h-5 w-24 rounded" })] })] }), _jsx(Skeleton, { className: "h-9 w-32" }), _jsx(Skeleton, { className: "h-9 w-24" })] }), _jsxs("div", { className: "grid gap-6 md:grid-cols-2", children: [_jsx(PairListCard, { titleWidth: "w-24", rows: 7 }), _jsx(PairListCard, { titleWidth: "w-28", rows: 7 })] }), _jsxs(Card, { children: [_jsxs(CardHeader, { className: "flex flex-row items-center gap-2", children: [_jsx(Skeleton, { className: "h-4 w-4" }), _jsx(Skeleton, { className: "h-5 w-36" })] }), _jsx(CardContent, { className: "space-y-3", children: Array.from({ length: 3 }).map((_, i) => (_jsxs("div", { className: "rounded-md border p-3 space-y-1.5", children: [_jsx(Skeleton, { className: "h-4 w-40" }), _jsx(Skeleton, { className: "h-3 w-56" }), _jsx(Skeleton, { className: "h-3 w-44" })] }, i))) })] }), _jsxs(Card, { children: [_jsxs(CardHeader, { className: "flex flex-row items-center gap-2", children: [_jsx(Skeleton, { className: "h-4 w-4" }), _jsx(Skeleton, { className: "h-5 w-44" })] }), _jsx(CardContent, { className: "space-y-2", children: Array.from({ length: 2 }).map((_, i) => (_jsxs("div", { className: "flex items-center justify-between rounded-md border px-3 py-2", children: [_jsx(Skeleton, { className: "h-4 w-48" }), _jsx(Skeleton, { className: "h-5 w-16 rounded-full" })] }, i))) })] })] }));
|
|
21
|
+
}
|
|
22
|
+
function PairListCard({ titleWidth, rows }) {
|
|
23
|
+
return (_jsxs(Card, { children: [_jsx(CardHeader, { children: _jsx(Skeleton, { className: `h-5 ${titleWidth}` }) }), _jsx(CardContent, { className: "grid gap-3", children: Array.from({ length: rows }).map((_, i) => (_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(Skeleton, { className: "h-3.5 w-28" }), _jsx(Skeleton, { className: "h-3.5 w-32" })] }, i))) })] }));
|
|
24
|
+
}
|
|
25
|
+
function SkeletonTableRows({ rows = 6, columns = 4, columnWidths, }) {
|
|
26
|
+
return (_jsx(TableBody, { children: Array.from({ length: rows }).map((_, r) => (_jsx(TableRow
|
|
27
|
+
// biome-ignore lint/suspicious/noArrayIndexKey: stable placeholders -- owner: availability-react; existing suppression is intentional pending typed cleanup.
|
|
28
|
+
, { children: Array.from({ length: columns }).map((__, c) => {
|
|
29
|
+
const width = columnWidths?.[c] ?? (c === 0 ? "w-2/3" : c === columns - 1 ? "w-16" : "w-1/2");
|
|
30
|
+
return (_jsx(TableCell
|
|
31
|
+
// biome-ignore lint/suspicious/noArrayIndexKey: stable placeholders -- owner: availability-react; existing suppression is intentional pending typed cleanup.
|
|
32
|
+
, { children: _jsx(Skeleton, { className: `h-4 ${width}` }) }, c));
|
|
33
|
+
}) }, r))) }));
|
|
34
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { AllocationAuditLogEntry, AllocationManifestBooking, AvailabilitySlotAssignmentRow } from "../index.js";
|
|
2
|
+
export declare function ActivityTimeline({ assignments, auditEntries, resourceById, bookingById, travelerById, formatDateTime: formatDateTimeFn, i18n, }: {
|
|
3
|
+
assignments: AvailabilitySlotAssignmentRow[];
|
|
4
|
+
auditEntries: AllocationAuditLogEntry[];
|
|
5
|
+
resourceById: Map<string, {
|
|
6
|
+
id: string;
|
|
7
|
+
name: string;
|
|
8
|
+
}>;
|
|
9
|
+
bookingById: Map<string, AllocationManifestBooking>;
|
|
10
|
+
travelerById: Map<string, {
|
|
11
|
+
fullName: string;
|
|
12
|
+
bookingNumber: string;
|
|
13
|
+
bookingId: string;
|
|
14
|
+
}>;
|
|
15
|
+
formatDateTime: (value: string | Date) => string;
|
|
16
|
+
i18n: {
|
|
17
|
+
title: string;
|
|
18
|
+
empty: string;
|
|
19
|
+
filterAll: string;
|
|
20
|
+
filterAudit: string;
|
|
21
|
+
filterAssignments: string;
|
|
22
|
+
byActor: string;
|
|
23
|
+
unassignedResource: string;
|
|
24
|
+
bookingLabel: string;
|
|
25
|
+
auditActionLabels: Record<string, string>;
|
|
26
|
+
ongoing: string;
|
|
27
|
+
noValue: string;
|
|
28
|
+
};
|
|
29
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
30
|
+
//# sourceMappingURL=availability-slot-detail-activity.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"availability-slot-detail-activity.d.ts","sourceRoot":"","sources":["../../../src/availability/components/availability-slot-detail-activity.tsx"],"names":[],"mappings":"AAeA,OAAO,KAAK,EACV,uBAAuB,EACvB,yBAAyB,EACzB,6BAA6B,EAC9B,MAAM,aAAa,CAAA;AAsCpB,wBAAgB,gBAAgB,CAAC,EAC/B,WAAW,EACX,YAAY,EACZ,YAAY,EACZ,WAAW,EACX,YAAY,EACZ,cAAc,EAAE,gBAAgB,EAChC,IAAI,GACL,EAAE;IACD,WAAW,EAAE,6BAA6B,EAAE,CAAA;IAC5C,YAAY,EAAE,uBAAuB,EAAE,CAAA;IACvC,YAAY,EAAE,GAAG,CAAC,MAAM,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC,CAAA;IACvD,WAAW,EAAE,GAAG,CAAC,MAAM,EAAE,yBAAyB,CAAC,CAAA;IACnD,YAAY,EAAE,GAAG,CAAC,MAAM,EAAE;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,aAAa,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAA;KAAE,CAAC,CAAA;IACzF,cAAc,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,KAAK,MAAM,CAAA;IAChD,IAAI,EAAE;QACJ,KAAK,EAAE,MAAM,CAAA;QACb,KAAK,EAAE,MAAM,CAAA;QACb,SAAS,EAAE,MAAM,CAAA;QACjB,WAAW,EAAE,MAAM,CAAA;QACnB,iBAAiB,EAAE,MAAM,CAAA;QACzB,OAAO,EAAE,MAAM,CAAA;QACf,kBAAkB,EAAE,MAAM,CAAA;QAC1B,YAAY,EAAE,MAAM,CAAA;QACpB,iBAAiB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;QACzC,OAAO,EAAE,MAAM,CAAA;QACf,OAAO,EAAE,MAAM,CAAA;KAChB,CAAA;CACF,2CAwGA"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { Badge, Button } from "@voyant-travel/ui/components";
|
|
4
|
+
import { Activity, History, Pencil, Plus, Sparkles, Trash2, UserMinus, UserPlus, Wrench, } from "lucide-react";
|
|
5
|
+
import { useState } from "react";
|
|
6
|
+
const AUDIT_ACTION_ICONS = {
|
|
7
|
+
"resource.create": Plus,
|
|
8
|
+
"resource.update": Pencil,
|
|
9
|
+
"resource.delete": Trash2,
|
|
10
|
+
"traveler.assign": UserPlus,
|
|
11
|
+
"traveler.unassign": UserMinus,
|
|
12
|
+
"resources.materialize": Sparkles,
|
|
13
|
+
"auto-allocate": Sparkles,
|
|
14
|
+
};
|
|
15
|
+
function humanizeAction(action, labels) {
|
|
16
|
+
return labels[action] ?? action.replace(/[._-]/g, " ").replace(/\b\w/g, (c) => c.toUpperCase());
|
|
17
|
+
}
|
|
18
|
+
export function ActivityTimeline({ assignments, auditEntries, resourceById, bookingById, travelerById, formatDateTime: formatDateTimeFn, i18n, }) {
|
|
19
|
+
const [filter, setFilter] = useState("all");
|
|
20
|
+
const resourceLabel = (id) => (id ? resourceById.get(id)?.name : null) ?? id ?? i18n.unassignedResource;
|
|
21
|
+
const events = [];
|
|
22
|
+
const nowIso = new Date().toISOString();
|
|
23
|
+
for (const assignment of assignments) {
|
|
24
|
+
const resource = resourceLabel(assignment.resourceId);
|
|
25
|
+
const booking = bookingById.get(assignment.bookingId ?? "");
|
|
26
|
+
// Active assignments don't carry a released timestamp. Sort them
|
|
27
|
+
// alongside current activity using `now`, and flag the entry so
|
|
28
|
+
// the row meta line renders "ongoing" instead of formatting the
|
|
29
|
+
// sentinel time.
|
|
30
|
+
const isOngoing = assignment.releasedAt == null;
|
|
31
|
+
events.push({
|
|
32
|
+
id: `assignment:${assignment.id}`,
|
|
33
|
+
source: "assignment",
|
|
34
|
+
icon: Wrench,
|
|
35
|
+
title: resource,
|
|
36
|
+
badge: assignment.status,
|
|
37
|
+
description: (_jsxs("span", { children: [i18n.bookingLabel, ": ", booking?.bookingNumber ?? assignment.bookingId ?? i18n.noValue, assignment.notes ? ` · ${assignment.notes}` : null] })),
|
|
38
|
+
timestamp: assignment.releasedAt ?? nowIso,
|
|
39
|
+
isOngoing,
|
|
40
|
+
actorId: assignment.assignedBy,
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
for (const entry of auditEntries) {
|
|
44
|
+
const resource = entry.resourceId ? resourceLabel(entry.resourceId) : null;
|
|
45
|
+
const traveler = entry.travelerId ? travelerById.get(entry.travelerId) : null;
|
|
46
|
+
const detailParts = [];
|
|
47
|
+
if (traveler)
|
|
48
|
+
detailParts.push(traveler.fullName);
|
|
49
|
+
if (resource)
|
|
50
|
+
detailParts.push(resource);
|
|
51
|
+
events.push({
|
|
52
|
+
id: `audit:${entry.id}`,
|
|
53
|
+
source: "audit",
|
|
54
|
+
icon: AUDIT_ACTION_ICONS[entry.action] ?? History,
|
|
55
|
+
title: humanizeAction(entry.action, i18n.auditActionLabels),
|
|
56
|
+
description: detailParts.length > 0 ? detailParts.join(" → ") : null,
|
|
57
|
+
timestamp: entry.createdAt,
|
|
58
|
+
actorId: entry.actorId,
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
events.sort((a, b) => new Date(b.timestamp).getTime() - new Date(a.timestamp).getTime());
|
|
62
|
+
const visible = filter === "all" ? events : events.filter((e) => e.source === filter);
|
|
63
|
+
const hasAssignments = assignments.length > 0;
|
|
64
|
+
const hasAudit = auditEntries.length > 0;
|
|
65
|
+
const filters = [
|
|
66
|
+
{ id: "all", label: i18n.filterAll, show: true },
|
|
67
|
+
{ id: "assignment", label: i18n.filterAssignments, show: hasAssignments },
|
|
68
|
+
{ id: "audit", label: i18n.filterAudit, show: hasAudit },
|
|
69
|
+
];
|
|
70
|
+
return (_jsxs("div", { "data-slot": "slot-activity-timeline", className: "flex flex-col gap-3", children: [_jsxs("div", { className: "flex flex-wrap items-center justify-between gap-3", children: [_jsxs("h2", { className: "flex items-center gap-2 text-base font-semibold", children: [_jsx(Activity, { className: "h-4 w-4 text-muted-foreground", "aria-hidden": "true" }), i18n.title] }), events.length > 0 && hasAssignments && hasAudit ? (_jsx("div", { className: "flex flex-wrap items-center gap-1", children: filters
|
|
71
|
+
.filter((f) => f.show)
|
|
72
|
+
.map((f) => (_jsx(Button, { variant: filter === f.id ? "default" : "ghost", size: "sm", className: "h-7 capitalize", onClick: () => setFilter(f.id), children: f.label }, f.id))) })) : null] }), visible.length === 0 ? (_jsx("div", { className: "rounded-md border bg-background p-6 text-center", children: _jsx("p", { className: "text-sm text-muted-foreground", children: i18n.empty }) })) : (_jsx("div", { className: "flex flex-col gap-2", children: visible.map((event) => (_jsx(ActivityTimelineItem, { event: event, formatDateTime: formatDateTimeFn, byActor: i18n.byActor, ongoingLabel: i18n.ongoing }, event.id))) }))] }));
|
|
73
|
+
}
|
|
74
|
+
function ActivityTimelineItem({ event, formatDateTime: formatDateTimeFn, byActor, ongoingLabel, }) {
|
|
75
|
+
const Icon = event.icon;
|
|
76
|
+
const timestamp = event.isOngoing ? ongoingLabel : formatDateTimeFn(event.timestamp);
|
|
77
|
+
const actor = event.actorId && event.actorId !== "system" ? event.actorId : null;
|
|
78
|
+
const meta = actor
|
|
79
|
+
? byActor.replace("{actor}", actor).replace("{timestamp}", timestamp)
|
|
80
|
+
: timestamp;
|
|
81
|
+
return (_jsxs("div", { className: "flex items-start gap-3 rounded-md border p-3", children: [_jsx(Icon, { className: "mt-0.5 h-4 w-4 shrink-0 text-muted-foreground", "aria-hidden": true }), _jsxs("div", { className: "min-w-0 flex-1", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx("p", { className: "text-sm font-medium capitalize", children: event.title }), event.badge ? (_jsx(Badge, { variant: "outline", className: "text-xs capitalize", children: event.badge })) : null] }), event.description ? (_jsx("p", { className: "mt-0.5 text-xs text-muted-foreground", children: event.description })) : null, _jsx("p", { className: "mt-0.5 text-xs text-muted-foreground", children: meta })] })] }));
|
|
82
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import type { AllocationManifestBooking, AvailabilitySlotRow } from "../index.js";
|
|
2
|
+
export declare function KpiStrip({ slot, rollup, formatCurrency, i18nLabels, }: {
|
|
3
|
+
slot: AvailabilitySlotRow;
|
|
4
|
+
rollup: SlotFinancialRollup;
|
|
5
|
+
formatCurrency: (value: number, currency: string) => string;
|
|
6
|
+
i18nLabels: {
|
|
7
|
+
pax: string;
|
|
8
|
+
total: string;
|
|
9
|
+
paid: string;
|
|
10
|
+
outstanding: string;
|
|
11
|
+
mixedHint: string;
|
|
12
|
+
noValue: string;
|
|
13
|
+
};
|
|
14
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
15
|
+
interface CurrencyTotals {
|
|
16
|
+
currency: string;
|
|
17
|
+
sellCents: number;
|
|
18
|
+
paidCents: number;
|
|
19
|
+
outstandingCents: number;
|
|
20
|
+
}
|
|
21
|
+
export interface SlotFinancialRollup {
|
|
22
|
+
primaryCurrency: string | null;
|
|
23
|
+
entries: CurrencyTotals[];
|
|
24
|
+
}
|
|
25
|
+
export declare function aggregateSlotFinancials(bookings: ReadonlyArray<AllocationManifestBooking>, productCurrency: string | null): SlotFinancialRollup;
|
|
26
|
+
export {};
|
|
27
|
+
//# sourceMappingURL=availability-slot-detail-financials.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"availability-slot-detail-financials.d.ts","sourceRoot":"","sources":["../../../src/availability/components/availability-slot-detail-financials.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,yBAAyB,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAA;AAEjF,wBAAgB,QAAQ,CAAC,EACvB,IAAI,EACJ,MAAM,EACN,cAAc,EACd,UAAU,GACX,EAAE;IACD,IAAI,EAAE,mBAAmB,CAAA;IACzB,MAAM,EAAE,mBAAmB,CAAA;IAC3B,cAAc,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,KAAK,MAAM,CAAA;IAC3D,UAAU,EAAE;QACV,GAAG,EAAE,MAAM,CAAA;QACX,KAAK,EAAE,MAAM,CAAA;QACb,IAAI,EAAE,MAAM,CAAA;QACZ,WAAW,EAAE,MAAM,CAAA;QACnB,SAAS,EAAE,MAAM,CAAA;QACjB,OAAO,EAAE,MAAM,CAAA;KAChB,CAAA;CACF,2CAoDA;AA+CD,UAAU,cAAc;IACtB,QAAQ,EAAE,MAAM,CAAA;IAChB,SAAS,EAAE,MAAM,CAAA;IACjB,SAAS,EAAE,MAAM,CAAA;IACjB,gBAAgB,EAAE,MAAM,CAAA;CACzB;AAED,MAAM,WAAW,mBAAmB;IAClC,eAAe,EAAE,MAAM,GAAG,IAAI,CAAA;IAC9B,OAAO,EAAE,cAAc,EAAE,CAAA;CAC1B;AAUD,wBAAgB,uBAAuB,CACrC,QAAQ,EAAE,aAAa,CAAC,yBAAyB,CAAC,EAClD,eAAe,EAAE,MAAM,GAAG,IAAI,GAC7B,mBAAmB,CA6BrB"}
|