@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,77 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { useOperatorAdminMessages } from "@voyant-travel/admin";
|
|
4
|
+
import { Button, Dialog, DialogBody, DialogContent, DialogFooter, DialogHeader, DialogTitle, Input, Label, Select, SelectContent, SelectItem, SelectTrigger, SelectValue, } from "@voyant-travel/ui/components";
|
|
5
|
+
import { zodResolver } from "@voyant-travel/ui/lib/zod-resolver";
|
|
6
|
+
import { Loader2 } from "lucide-react";
|
|
7
|
+
import { useEffect } from "react";
|
|
8
|
+
import { useForm } from "react-hook-form";
|
|
9
|
+
import { z } from "zod/v4";
|
|
10
|
+
import { allocationModeOptions, NONE_VALUE, useVoyantResourcesContext, } from "../index.js";
|
|
11
|
+
import { sendResourcesMutation } from "./resources-admin-api.js";
|
|
12
|
+
const getAllocationFormSchema = (messages) => z.object({
|
|
13
|
+
poolId: z.string().min(1, messages.resources.dialogs.allocation.validationPoolRequired),
|
|
14
|
+
productId: z.string().min(1, messages.resources.dialogs.allocation.validationProductRequired),
|
|
15
|
+
availabilityRuleId: z.string().optional(),
|
|
16
|
+
startTimeId: z.string().optional(),
|
|
17
|
+
quantityRequired: z.coerce.number().int().min(1),
|
|
18
|
+
allocationMode: z.enum(["shared", "exclusive"]),
|
|
19
|
+
priority: z.coerce.number().int(),
|
|
20
|
+
});
|
|
21
|
+
export function ResourceAllocationDialog({ open, onOpenChange, allocation, pools, products, rules, startTimes, onSuccess, }) {
|
|
22
|
+
const client = useVoyantResourcesContext();
|
|
23
|
+
const messages = useOperatorAdminMessages();
|
|
24
|
+
const dialogMessages = messages.resources.dialogs.allocation;
|
|
25
|
+
const allocationFormSchema = getAllocationFormSchema(messages);
|
|
26
|
+
const form = useForm({
|
|
27
|
+
resolver: zodResolver(allocationFormSchema),
|
|
28
|
+
defaultValues: {
|
|
29
|
+
poolId: "",
|
|
30
|
+
productId: "",
|
|
31
|
+
availabilityRuleId: NONE_VALUE,
|
|
32
|
+
startTimeId: NONE_VALUE,
|
|
33
|
+
quantityRequired: 1,
|
|
34
|
+
allocationMode: "shared",
|
|
35
|
+
priority: 0,
|
|
36
|
+
},
|
|
37
|
+
});
|
|
38
|
+
useEffect(() => {
|
|
39
|
+
if (open && allocation) {
|
|
40
|
+
form.reset({
|
|
41
|
+
poolId: allocation.poolId,
|
|
42
|
+
productId: allocation.productId,
|
|
43
|
+
availabilityRuleId: allocation.availabilityRuleId ?? NONE_VALUE,
|
|
44
|
+
startTimeId: allocation.startTimeId ?? NONE_VALUE,
|
|
45
|
+
quantityRequired: allocation.quantityRequired,
|
|
46
|
+
allocationMode: allocation.allocationMode,
|
|
47
|
+
priority: allocation.priority,
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
else if (open) {
|
|
51
|
+
form.reset();
|
|
52
|
+
}
|
|
53
|
+
}, [allocation, form, open]);
|
|
54
|
+
const selectedProductId = form.watch("productId");
|
|
55
|
+
const filteredRules = rules.filter((rule) => rule.productId === selectedProductId);
|
|
56
|
+
const filteredStartTimes = startTimes.filter((startTime) => startTime.productId === selectedProductId);
|
|
57
|
+
const isEditing = Boolean(allocation);
|
|
58
|
+
const onSubmit = async (values) => {
|
|
59
|
+
const payload = {
|
|
60
|
+
poolId: values.poolId,
|
|
61
|
+
productId: values.productId,
|
|
62
|
+
availabilityRuleId: values.availabilityRuleId === NONE_VALUE ? null : values.availabilityRuleId,
|
|
63
|
+
startTimeId: values.startTimeId === NONE_VALUE ? null : values.startTimeId,
|
|
64
|
+
quantityRequired: values.quantityRequired,
|
|
65
|
+
allocationMode: values.allocationMode,
|
|
66
|
+
priority: values.priority,
|
|
67
|
+
};
|
|
68
|
+
if (isEditing) {
|
|
69
|
+
await sendResourcesMutation(client, "PATCH", `/v1/operations/allocations/${allocation?.id}`, payload);
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
await sendResourcesMutation(client, "POST", "/v1/operations/allocations", payload);
|
|
73
|
+
}
|
|
74
|
+
onSuccess();
|
|
75
|
+
};
|
|
76
|
+
return (_jsx(Dialog, { open: open, onOpenChange: onOpenChange, children: _jsxs(DialogContent, { children: [_jsx(DialogHeader, { children: _jsx(DialogTitle, { children: isEditing ? dialogMessages.editTitle : dialogMessages.newTitle }) }), _jsxs("form", { onSubmit: form.handleSubmit(onSubmit), children: [_jsxs(DialogBody, { className: "grid gap-4", children: [_jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.poolLabel }), _jsxs(Select, { items: pools.map((pool) => ({ label: pool.name, value: pool.id })), value: form.watch("poolId"), onValueChange: (value) => form.setValue("poolId", value ?? ""), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, { placeholder: dialogMessages.selectPoolPlaceholder }) }), _jsx(SelectContent, { children: pools.map((pool) => (_jsx(SelectItem, { value: pool.id, children: pool.name }, pool.id))) })] })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.productLabel }), _jsxs(Select, { items: products.map((product) => ({ label: product.name, value: product.id })), value: form.watch("productId"), onValueChange: (value) => form.setValue("productId", value ?? ""), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, { placeholder: dialogMessages.selectProductPlaceholder }) }), _jsx(SelectContent, { children: products.map((product) => (_jsx(SelectItem, { value: product.id, children: product.name }, product.id))) })] })] }), _jsxs("div", { className: "grid grid-cols-2 gap-4", children: [_jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.ruleLabel }), _jsxs(Select, { value: form.watch("availabilityRuleId"), onValueChange: (value) => form.setValue("availabilityRuleId", value ?? NONE_VALUE), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsxs(SelectContent, { children: [_jsx(SelectItem, { value: NONE_VALUE, children: dialogMessages.noRule }), filteredRules.map((rule) => (_jsx(SelectItem, { value: rule.id, children: rule.recurrenceRule }, rule.id)))] })] })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.startTimeLabel }), _jsxs(Select, { value: form.watch("startTimeId"), onValueChange: (value) => form.setValue("startTimeId", value ?? NONE_VALUE), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsxs(SelectContent, { children: [_jsx(SelectItem, { value: NONE_VALUE, children: dialogMessages.noStartTime }), filteredStartTimes.map((startTime) => (_jsx(SelectItem, { value: startTime.id, children: startTime.label ?? startTime.startTimeLocal }, startTime.id)))] })] })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.quantityRequiredLabel }), _jsx(Input, { ...form.register("quantityRequired"), type: "number", min: 1 })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.priorityLabel }), _jsx(Input, { ...form.register("priority"), type: "number" })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.allocationModeLabel }), _jsxs(Select, { items: allocationModeOptions, value: form.watch("allocationMode"), onValueChange: (value) => form.setValue("allocationMode", value), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsx(SelectContent, { children: allocationModeOptions.map((option) => (_jsx(SelectItem, { value: option.value, children: messages.resources.allocationModeLabels[option.value] }, option.value))) })] })] })] })] }), _jsxs(DialogFooter, { children: [_jsx(Button, { type: "button", variant: "ghost", onClick: () => onOpenChange(false), children: dialogMessages.cancel }), _jsxs(Button, { type: "submit", disabled: form.formState.isSubmitting, children: [form.formState.isSubmitting && _jsx(Loader2, { className: "mr-2 h-4 w-4 animate-spin" }), isEditing ? dialogMessages.save : dialogMessages.create] })] })] })] }) }));
|
|
77
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { type ProductOption, type ResourcePoolRow, type ResourceRow, type SupplierOption } from "../index.js";
|
|
2
|
+
export declare function ResourceDialog({ open, onOpenChange, resource, suppliers, onSuccess, }: {
|
|
3
|
+
open: boolean;
|
|
4
|
+
onOpenChange: (open: boolean) => void;
|
|
5
|
+
resource?: ResourceRow;
|
|
6
|
+
suppliers: SupplierOption[];
|
|
7
|
+
onSuccess: () => void;
|
|
8
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
export declare function ResourcePoolDialog({ open, onOpenChange, pool, products, onSuccess, }: {
|
|
10
|
+
open: boolean;
|
|
11
|
+
onOpenChange: (open: boolean) => void;
|
|
12
|
+
pool?: ResourcePoolRow;
|
|
13
|
+
products: ProductOption[];
|
|
14
|
+
onSuccess: () => void;
|
|
15
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
16
|
+
//# sourceMappingURL=resources-dialogs-core.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resources-dialogs-core.d.ts","sourceRoot":"","sources":["../../../src/resources/admin/resources-dialogs-core.tsx"],"names":[],"mappings":"AA0BA,OAAO,EAIL,KAAK,aAAa,EAClB,KAAK,eAAe,EACpB,KAAK,WAAW,EAEhB,KAAK,cAAc,EAEpB,MAAM,aAAa,CAAA;AAepB,wBAAgB,cAAc,CAAC,EAC7B,IAAI,EACJ,YAAY,EACZ,QAAQ,EACR,SAAS,EACT,SAAS,GACV,EAAE;IACD,IAAI,EAAE,OAAO,CAAA;IACb,YAAY,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAA;IACrC,QAAQ,CAAC,EAAE,WAAW,CAAA;IACtB,SAAS,EAAE,cAAc,EAAE,CAAA;IAC3B,SAAS,EAAE,MAAM,IAAI,CAAA;CACtB,2CAsJA;AAYD,wBAAgB,kBAAkB,CAAC,EACjC,IAAI,EACJ,YAAY,EACZ,IAAI,EACJ,QAAQ,EACR,SAAS,GACV,EAAE;IACD,IAAI,EAAE,OAAO,CAAA;IACb,YAAY,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAA;IACrC,IAAI,CAAC,EAAE,eAAe,CAAA;IACtB,QAAQ,EAAE,aAAa,EAAE,CAAA;IACzB,SAAS,EAAE,MAAM,IAAI,CAAA;CACtB,2CA0IA"}
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { useOperatorAdminMessages } from "@voyant-travel/admin";
|
|
4
|
+
import { Button, Dialog, DialogBody, DialogContent, DialogFooter, DialogHeader, DialogTitle, Input, Label, Select, SelectContent, SelectItem, SelectTrigger, SelectValue, Switch, Textarea, } from "@voyant-travel/ui/components";
|
|
5
|
+
import { zodResolver } from "@voyant-travel/ui/lib/zod-resolver";
|
|
6
|
+
import { Loader2 } from "lucide-react";
|
|
7
|
+
import { useEffect } from "react";
|
|
8
|
+
import { useForm } from "react-hook-form";
|
|
9
|
+
import { z } from "zod/v4";
|
|
10
|
+
import { NONE_VALUE, nullableNumber, nullableString, resourceKindOptions, useVoyantResourcesContext, } from "../index.js";
|
|
11
|
+
import { sendResourcesMutation } from "./resources-admin-api.js";
|
|
12
|
+
const getResourceFormSchema = (messages) => z.object({
|
|
13
|
+
supplierId: z.string().optional(),
|
|
14
|
+
kind: z.enum(["guide", "vehicle", "room", "boat", "equipment", "other"]),
|
|
15
|
+
name: z.string().min(1, messages.resources.dialogs.resource.validationNameRequired),
|
|
16
|
+
code: z.string().optional(),
|
|
17
|
+
capacity: z.string().optional(),
|
|
18
|
+
active: z.boolean(),
|
|
19
|
+
notes: z.string().optional(),
|
|
20
|
+
});
|
|
21
|
+
export function ResourceDialog({ open, onOpenChange, resource, suppliers, onSuccess, }) {
|
|
22
|
+
const client = useVoyantResourcesContext();
|
|
23
|
+
const messages = useOperatorAdminMessages();
|
|
24
|
+
const dialogMessages = messages.resources.dialogs.resource;
|
|
25
|
+
const resourceFormSchema = getResourceFormSchema(messages);
|
|
26
|
+
const form = useForm({
|
|
27
|
+
resolver: zodResolver(resourceFormSchema),
|
|
28
|
+
defaultValues: {
|
|
29
|
+
supplierId: NONE_VALUE,
|
|
30
|
+
kind: "guide",
|
|
31
|
+
name: "",
|
|
32
|
+
code: "",
|
|
33
|
+
capacity: "",
|
|
34
|
+
active: true,
|
|
35
|
+
notes: "",
|
|
36
|
+
},
|
|
37
|
+
});
|
|
38
|
+
useEffect(() => {
|
|
39
|
+
if (open && resource) {
|
|
40
|
+
form.reset({
|
|
41
|
+
supplierId: resource.supplierId ?? NONE_VALUE,
|
|
42
|
+
kind: resource.kind,
|
|
43
|
+
name: resource.name,
|
|
44
|
+
code: resource.code ?? "",
|
|
45
|
+
capacity: resource.capacity?.toString() ?? "",
|
|
46
|
+
active: resource.active,
|
|
47
|
+
notes: resource.notes ?? "",
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
else if (open) {
|
|
51
|
+
form.reset();
|
|
52
|
+
}
|
|
53
|
+
}, [form, open, resource]);
|
|
54
|
+
const isEditing = Boolean(resource);
|
|
55
|
+
const onSubmit = async (values) => {
|
|
56
|
+
const payload = {
|
|
57
|
+
supplierId: values.supplierId === NONE_VALUE ? null : values.supplierId,
|
|
58
|
+
kind: values.kind,
|
|
59
|
+
name: values.name,
|
|
60
|
+
code: nullableString(values.code),
|
|
61
|
+
capacity: nullableNumber(values.capacity),
|
|
62
|
+
active: values.active,
|
|
63
|
+
notes: nullableString(values.notes),
|
|
64
|
+
};
|
|
65
|
+
if (isEditing) {
|
|
66
|
+
await sendResourcesMutation(client, "PATCH", `/v1/operations/resources/${resource?.id}`, payload);
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
await sendResourcesMutation(client, "POST", "/v1/operations/resources", payload);
|
|
70
|
+
}
|
|
71
|
+
onSuccess();
|
|
72
|
+
};
|
|
73
|
+
return (_jsx(Dialog, { open: open, onOpenChange: onOpenChange, children: _jsxs(DialogContent, { children: [_jsx(DialogHeader, { children: _jsx(DialogTitle, { children: isEditing ? dialogMessages.editTitle : dialogMessages.newTitle }) }), _jsxs("form", { onSubmit: form.handleSubmit(onSubmit), children: [_jsxs(DialogBody, { className: "grid gap-4", children: [_jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.supplierLabel }), _jsxs(Select, { value: form.watch("supplierId"), onValueChange: (value) => form.setValue("supplierId", value ?? NONE_VALUE), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsxs(SelectContent, { children: [_jsx(SelectItem, { value: NONE_VALUE, children: dialogMessages.noSupplier }), suppliers.map((supplier) => (_jsx(SelectItem, { value: supplier.id, children: supplier.name }, supplier.id)))] })] })] }), _jsxs("div", { className: "grid grid-cols-2 gap-4", children: [_jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.kindLabel }), _jsxs(Select, { items: resourceKindOptions, value: form.watch("kind"), onValueChange: (value) => form.setValue("kind", value), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsx(SelectContent, { children: resourceKindOptions.map((option) => (_jsx(SelectItem, { value: option.value, children: messages.resources.kindLabels[option.value] }, option.value))) })] })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.nameLabel }), _jsx(Input, { ...form.register("name"), placeholder: dialogMessages.namePlaceholder })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.codeLabel }), _jsx(Input, { ...form.register("code"), placeholder: dialogMessages.codePlaceholder })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.capacityLabel }), _jsx(Input, { ...form.register("capacity"), type: "number", min: 0 })] })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.notesLabel }), _jsx(Textarea, { ...form.register("notes"), placeholder: dialogMessages.notesPlaceholder })] }), _jsxs("div", { className: "flex items-center justify-between rounded-md border px-3 py-2", children: [_jsxs("div", { children: [_jsx("p", { className: "text-sm font-medium", children: dialogMessages.activeTitle }), _jsx("p", { className: "text-xs text-muted-foreground", children: dialogMessages.activeDescription })] }), _jsx(Switch, { checked: form.watch("active"), onCheckedChange: (checked) => form.setValue("active", checked) })] })] }), _jsxs(DialogFooter, { children: [_jsx(Button, { type: "button", variant: "ghost", onClick: () => onOpenChange(false), children: dialogMessages.cancel }), _jsxs(Button, { type: "submit", disabled: form.formState.isSubmitting, children: [form.formState.isSubmitting && _jsx(Loader2, { className: "mr-2 h-4 w-4 animate-spin" }), isEditing ? dialogMessages.save : dialogMessages.create] })] })] })] }) }));
|
|
74
|
+
}
|
|
75
|
+
const getPoolFormSchema = (messages) => z.object({
|
|
76
|
+
productId: z.string().optional(),
|
|
77
|
+
kind: z.enum(["guide", "vehicle", "room", "boat", "equipment", "other"]),
|
|
78
|
+
name: z.string().min(1, messages.resources.dialogs.pool.validationNameRequired),
|
|
79
|
+
sharedCapacity: z.string().optional(),
|
|
80
|
+
active: z.boolean(),
|
|
81
|
+
notes: z.string().optional(),
|
|
82
|
+
});
|
|
83
|
+
export function ResourcePoolDialog({ open, onOpenChange, pool, products, onSuccess, }) {
|
|
84
|
+
const client = useVoyantResourcesContext();
|
|
85
|
+
const messages = useOperatorAdminMessages();
|
|
86
|
+
const dialogMessages = messages.resources.dialogs.pool;
|
|
87
|
+
const poolFormSchema = getPoolFormSchema(messages);
|
|
88
|
+
const form = useForm({
|
|
89
|
+
resolver: zodResolver(poolFormSchema),
|
|
90
|
+
defaultValues: {
|
|
91
|
+
productId: NONE_VALUE,
|
|
92
|
+
kind: "guide",
|
|
93
|
+
name: "",
|
|
94
|
+
sharedCapacity: "",
|
|
95
|
+
active: true,
|
|
96
|
+
notes: "",
|
|
97
|
+
},
|
|
98
|
+
});
|
|
99
|
+
useEffect(() => {
|
|
100
|
+
if (open && pool) {
|
|
101
|
+
form.reset({
|
|
102
|
+
productId: pool.productId ?? NONE_VALUE,
|
|
103
|
+
kind: pool.kind,
|
|
104
|
+
name: pool.name,
|
|
105
|
+
sharedCapacity: pool.sharedCapacity?.toString() ?? "",
|
|
106
|
+
active: pool.active,
|
|
107
|
+
notes: pool.notes ?? "",
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
else if (open) {
|
|
111
|
+
form.reset();
|
|
112
|
+
}
|
|
113
|
+
}, [form, open, pool]);
|
|
114
|
+
const isEditing = Boolean(pool);
|
|
115
|
+
const onSubmit = async (values) => {
|
|
116
|
+
const payload = {
|
|
117
|
+
productId: values.productId === NONE_VALUE ? null : values.productId,
|
|
118
|
+
kind: values.kind,
|
|
119
|
+
name: values.name,
|
|
120
|
+
sharedCapacity: nullableNumber(values.sharedCapacity),
|
|
121
|
+
active: values.active,
|
|
122
|
+
notes: nullableString(values.notes),
|
|
123
|
+
};
|
|
124
|
+
if (isEditing) {
|
|
125
|
+
await sendResourcesMutation(client, "PATCH", `/v1/operations/pools/${pool?.id}`, payload);
|
|
126
|
+
}
|
|
127
|
+
else {
|
|
128
|
+
await sendResourcesMutation(client, "POST", "/v1/operations/pools", payload);
|
|
129
|
+
}
|
|
130
|
+
onSuccess();
|
|
131
|
+
};
|
|
132
|
+
return (_jsx(Dialog, { open: open, onOpenChange: onOpenChange, children: _jsxs(DialogContent, { children: [_jsx(DialogHeader, { children: _jsx(DialogTitle, { children: isEditing ? dialogMessages.editTitle : dialogMessages.newTitle }) }), _jsxs("form", { onSubmit: form.handleSubmit(onSubmit), children: [_jsxs(DialogBody, { className: "grid gap-4", children: [_jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.productLabel }), _jsxs(Select, { value: form.watch("productId"), onValueChange: (value) => form.setValue("productId", value ?? NONE_VALUE), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsxs(SelectContent, { children: [_jsx(SelectItem, { value: NONE_VALUE, children: dialogMessages.noProduct }), products.map((product) => (_jsx(SelectItem, { value: product.id, children: product.name }, product.id)))] })] })] }), _jsxs("div", { className: "grid grid-cols-2 gap-4", children: [_jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.kindLabel }), _jsxs(Select, { items: resourceKindOptions, value: form.watch("kind"), onValueChange: (value) => form.setValue("kind", value), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsx(SelectContent, { children: resourceKindOptions.map((option) => (_jsx(SelectItem, { value: option.value, children: messages.resources.kindLabels[option.value] }, option.value))) })] })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.nameLabel }), _jsx(Input, { ...form.register("name"), placeholder: dialogMessages.namePlaceholder })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.sharedCapacityLabel }), _jsx(Input, { ...form.register("sharedCapacity"), type: "number", min: 0 })] })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.notesLabel }), _jsx(Textarea, { ...form.register("notes"), placeholder: dialogMessages.notesPlaceholder })] }), _jsxs("div", { className: "flex items-center justify-between rounded-md border px-3 py-2", children: [_jsxs("div", { children: [_jsx("p", { className: "text-sm font-medium", children: dialogMessages.activeTitle }), _jsx("p", { className: "text-xs text-muted-foreground", children: dialogMessages.activeDescription })] }), _jsx(Switch, { checked: form.watch("active"), onCheckedChange: (checked) => form.setValue("active", checked) })] })] }), _jsxs(DialogFooter, { children: [_jsx(Button, { type: "button", variant: "ghost", onClick: () => onOpenChange(false), children: dialogMessages.cancel }), _jsxs(Button, { type: "submit", disabled: form.formState.isSubmitting, children: [form.formState.isSubmitting && _jsx(Loader2, { className: "mr-2 h-4 w-4 animate-spin" }), isEditing ? dialogMessages.save : dialogMessages.create] })] })] })] }) }));
|
|
133
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { type BookingOption, type ResourceCloseoutRow, type ResourcePoolRow, type ResourceRow, type ResourceSlotAssignmentRow, type SlotOption } from "../index.js";
|
|
2
|
+
export declare function ResourceSlotAssignmentDialog({ open, onOpenChange, assignment, slots, pools, resources, bookings, onSuccess, }: {
|
|
3
|
+
open: boolean;
|
|
4
|
+
onOpenChange: (open: boolean) => void;
|
|
5
|
+
assignment?: ResourceSlotAssignmentRow;
|
|
6
|
+
slots: SlotOption[];
|
|
7
|
+
pools: ResourcePoolRow[];
|
|
8
|
+
resources: ResourceRow[];
|
|
9
|
+
bookings: BookingOption[];
|
|
10
|
+
onSuccess: () => void;
|
|
11
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
export declare function ResourceCloseoutDialog({ open, onOpenChange, closeout, resources, onSuccess, }: {
|
|
13
|
+
open: boolean;
|
|
14
|
+
onOpenChange: (open: boolean) => void;
|
|
15
|
+
closeout?: ResourceCloseoutRow;
|
|
16
|
+
resources: ResourceRow[];
|
|
17
|
+
onSuccess: () => void;
|
|
18
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
19
|
+
//# sourceMappingURL=resources-dialogs-ops.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resources-dialogs-ops.d.ts","sourceRoot":"","sources":["../../../src/resources/admin/resources-dialogs-ops.tsx"],"names":[],"mappings":"AAyBA,OAAO,EAEL,KAAK,aAAa,EAGlB,KAAK,mBAAmB,EACxB,KAAK,eAAe,EACpB,KAAK,WAAW,EAChB,KAAK,yBAAyB,EAC9B,KAAK,UAAU,EAKhB,MAAM,aAAa,CAAA;AAgBpB,wBAAgB,4BAA4B,CAAC,EAC3C,IAAI,EACJ,YAAY,EACZ,UAAU,EACV,KAAK,EACL,KAAK,EACL,SAAS,EACT,QAAQ,EACR,SAAS,GACV,EAAE;IACD,IAAI,EAAE,OAAO,CAAA;IACb,YAAY,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAA;IACrC,UAAU,CAAC,EAAE,yBAAyB,CAAA;IACtC,KAAK,EAAE,UAAU,EAAE,CAAA;IACnB,KAAK,EAAE,eAAe,EAAE,CAAA;IACxB,SAAS,EAAE,WAAW,EAAE,CAAA;IACxB,QAAQ,EAAE,aAAa,EAAE,CAAA;IACzB,SAAS,EAAE,MAAM,IAAI,CAAA;CACtB,2CAyMA;AAYD,wBAAgB,sBAAsB,CAAC,EACrC,IAAI,EACJ,YAAY,EACZ,QAAQ,EACR,SAAS,EACT,SAAS,GACV,EAAE;IACD,IAAI,EAAE,OAAO,CAAA;IACb,YAAY,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAA;IACrC,QAAQ,CAAC,EAAE,mBAAmB,CAAA;IAC9B,SAAS,EAAE,WAAW,EAAE,CAAA;IACxB,SAAS,EAAE,MAAM,IAAI,CAAA;CACtB,2CAgIA"}
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { useOperatorAdminMessages } from "@voyant-travel/admin";
|
|
4
|
+
import { Button, Dialog, DialogBody, DialogContent, DialogFooter, DialogHeader, DialogTitle, Input, Label, Select, SelectContent, SelectItem, SelectTrigger, SelectValue, Textarea, } from "@voyant-travel/ui/components";
|
|
5
|
+
import { zodResolver } from "@voyant-travel/ui/lib/zod-resolver";
|
|
6
|
+
import { Loader2 } from "lucide-react";
|
|
7
|
+
import { useEffect } from "react";
|
|
8
|
+
import { useForm } from "react-hook-form";
|
|
9
|
+
import { z } from "zod/v4";
|
|
10
|
+
import { assignmentStatusOptions, NONE_VALUE, nullableString, slotLabel, toIsoDateTime, toLocalDateTimeInput, useVoyantResourcesContext, } from "../index.js";
|
|
11
|
+
import { sendResourcesMutation } from "./resources-admin-api.js";
|
|
12
|
+
const getAssignmentFormSchema = (messages) => z.object({
|
|
13
|
+
slotId: z.string().min(1, messages.resources.dialogs.assignment.validationSlotRequired),
|
|
14
|
+
poolId: z.string().optional(),
|
|
15
|
+
resourceId: z.string().optional(),
|
|
16
|
+
bookingId: z.string().optional(),
|
|
17
|
+
status: z.enum(["reserved", "assigned", "released", "cancelled", "completed"]),
|
|
18
|
+
assignedBy: z.string().optional(),
|
|
19
|
+
releasedAt: z.string().optional(),
|
|
20
|
+
notes: z.string().optional(),
|
|
21
|
+
});
|
|
22
|
+
export function ResourceSlotAssignmentDialog({ open, onOpenChange, assignment, slots, pools, resources, bookings, onSuccess, }) {
|
|
23
|
+
const client = useVoyantResourcesContext();
|
|
24
|
+
const messages = useOperatorAdminMessages();
|
|
25
|
+
const dialogMessages = messages.resources.dialogs.assignment;
|
|
26
|
+
const assignmentFormSchema = getAssignmentFormSchema(messages);
|
|
27
|
+
const form = useForm({
|
|
28
|
+
resolver: zodResolver(assignmentFormSchema),
|
|
29
|
+
defaultValues: {
|
|
30
|
+
slotId: "",
|
|
31
|
+
poolId: NONE_VALUE,
|
|
32
|
+
resourceId: NONE_VALUE,
|
|
33
|
+
bookingId: NONE_VALUE,
|
|
34
|
+
status: "reserved",
|
|
35
|
+
assignedBy: "",
|
|
36
|
+
releasedAt: "",
|
|
37
|
+
notes: "",
|
|
38
|
+
},
|
|
39
|
+
});
|
|
40
|
+
useEffect(() => {
|
|
41
|
+
if (open && assignment) {
|
|
42
|
+
form.reset({
|
|
43
|
+
slotId: assignment.slotId,
|
|
44
|
+
poolId: assignment.poolId ?? NONE_VALUE,
|
|
45
|
+
resourceId: assignment.resourceId ?? NONE_VALUE,
|
|
46
|
+
bookingId: assignment.bookingId ?? NONE_VALUE,
|
|
47
|
+
status: assignment.status,
|
|
48
|
+
assignedBy: assignment.assignedBy ?? "",
|
|
49
|
+
releasedAt: toLocalDateTimeInput(assignment.releasedAt),
|
|
50
|
+
notes: assignment.notes ?? "",
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
else if (open) {
|
|
54
|
+
form.reset();
|
|
55
|
+
}
|
|
56
|
+
}, [assignment, form, open]);
|
|
57
|
+
const isEditing = Boolean(assignment);
|
|
58
|
+
const onSubmit = async (values) => {
|
|
59
|
+
const payload = {
|
|
60
|
+
slotId: values.slotId,
|
|
61
|
+
poolId: values.poolId === NONE_VALUE ? null : values.poolId,
|
|
62
|
+
resourceId: values.resourceId === NONE_VALUE ? null : values.resourceId,
|
|
63
|
+
bookingId: values.bookingId === NONE_VALUE ? null : values.bookingId,
|
|
64
|
+
status: values.status,
|
|
65
|
+
assignedBy: nullableString(values.assignedBy),
|
|
66
|
+
releasedAt: toIsoDateTime(values.releasedAt),
|
|
67
|
+
notes: nullableString(values.notes),
|
|
68
|
+
};
|
|
69
|
+
if (isEditing) {
|
|
70
|
+
await sendResourcesMutation(client, "PATCH", `/v1/operations/slot-assignments/${assignment?.id}`, payload);
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
await sendResourcesMutation(client, "POST", "/v1/operations/slot-assignments", payload);
|
|
74
|
+
}
|
|
75
|
+
onSuccess();
|
|
76
|
+
};
|
|
77
|
+
return (_jsx(Dialog, { open: open, onOpenChange: onOpenChange, children: _jsxs(DialogContent, { size: "lg", children: [_jsx(DialogHeader, { children: _jsx(DialogTitle, { children: isEditing ? dialogMessages.editTitle : dialogMessages.newTitle }) }), _jsxs("form", { onSubmit: form.handleSubmit(onSubmit), children: [_jsxs(DialogBody, { className: "grid gap-4", children: [_jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.slotLabel }), _jsxs(Select, { items: slots.map((slot) => ({ label: slotLabel(slot), value: slot.id })), value: form.watch("slotId"), onValueChange: (value) => form.setValue("slotId", value ?? ""), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, { placeholder: dialogMessages.selectSlotPlaceholder }) }), _jsx(SelectContent, { children: slots.map((slot) => (_jsx(SelectItem, { value: slot.id, children: slotLabel(slot) }, slot.id))) })] })] }), _jsxs("div", { className: "grid grid-cols-2 gap-4", children: [_jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.poolLabel }), _jsxs(Select, { value: form.watch("poolId"), onValueChange: (value) => form.setValue("poolId", value ?? NONE_VALUE), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsxs(SelectContent, { children: [_jsx(SelectItem, { value: NONE_VALUE, children: dialogMessages.noPool }), pools.map((pool) => (_jsx(SelectItem, { value: pool.id, children: pool.name }, pool.id)))] })] })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.resourceLabel }), _jsxs(Select, { value: form.watch("resourceId"), onValueChange: (value) => form.setValue("resourceId", value ?? NONE_VALUE), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsxs(SelectContent, { children: [_jsx(SelectItem, { value: NONE_VALUE, children: dialogMessages.noResource }), resources.map((resource) => (_jsx(SelectItem, { value: resource.id, children: resource.name }, resource.id)))] })] })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.bookingLabel }), _jsxs(Select, { value: form.watch("bookingId"), onValueChange: (value) => form.setValue("bookingId", value ?? NONE_VALUE), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsxs(SelectContent, { children: [_jsx(SelectItem, { value: NONE_VALUE, children: dialogMessages.noBooking }), bookings.map((booking) => (_jsx(SelectItem, { value: booking.id, children: booking.bookingNumber }, booking.id)))] })] })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.statusLabel }), _jsxs(Select, { items: assignmentStatusOptions, value: form.watch("status"), onValueChange: (value) => form.setValue("status", value), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsx(SelectContent, { children: assignmentStatusOptions.map((option) => (_jsx(SelectItem, { value: option.value, children: messages.resources.assignmentStatusLabels[option.value] }, option.value))) })] })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.assignedByLabel }), _jsx(Input, { ...form.register("assignedBy"), placeholder: dialogMessages.assignedByPlaceholder })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.releasedAtLabel }), _jsx(Input, { ...form.register("releasedAt"), type: "datetime-local" })] })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.notesLabel }), _jsx(Textarea, { ...form.register("notes"), placeholder: dialogMessages.notesPlaceholder })] })] }), _jsxs(DialogFooter, { children: [_jsx(Button, { type: "button", variant: "ghost", onClick: () => onOpenChange(false), children: dialogMessages.cancel }), _jsxs(Button, { type: "submit", disabled: form.formState.isSubmitting, children: [form.formState.isSubmitting && _jsx(Loader2, { className: "mr-2 h-4 w-4 animate-spin" }), isEditing ? dialogMessages.save : dialogMessages.create] })] })] })] }) }));
|
|
78
|
+
}
|
|
79
|
+
const getCloseoutFormSchema = (messages) => z.object({
|
|
80
|
+
resourceId: z.string().min(1, messages.resources.dialogs.closeout.validationResourceRequired),
|
|
81
|
+
dateLocal: z.string().min(1, messages.resources.dialogs.closeout.validationDateRequired),
|
|
82
|
+
startsAt: z.string().optional(),
|
|
83
|
+
endsAt: z.string().optional(),
|
|
84
|
+
reason: z.string().optional(),
|
|
85
|
+
createdBy: z.string().optional(),
|
|
86
|
+
});
|
|
87
|
+
export function ResourceCloseoutDialog({ open, onOpenChange, closeout, resources, onSuccess, }) {
|
|
88
|
+
const client = useVoyantResourcesContext();
|
|
89
|
+
const messages = useOperatorAdminMessages();
|
|
90
|
+
const dialogMessages = messages.resources.dialogs.closeout;
|
|
91
|
+
const closeoutFormSchema = getCloseoutFormSchema(messages);
|
|
92
|
+
const form = useForm({
|
|
93
|
+
resolver: zodResolver(closeoutFormSchema),
|
|
94
|
+
defaultValues: {
|
|
95
|
+
resourceId: "",
|
|
96
|
+
dateLocal: "",
|
|
97
|
+
startsAt: "",
|
|
98
|
+
endsAt: "",
|
|
99
|
+
reason: "",
|
|
100
|
+
createdBy: "",
|
|
101
|
+
},
|
|
102
|
+
});
|
|
103
|
+
useEffect(() => {
|
|
104
|
+
if (open && closeout) {
|
|
105
|
+
form.reset({
|
|
106
|
+
resourceId: closeout.resourceId,
|
|
107
|
+
dateLocal: closeout.dateLocal,
|
|
108
|
+
startsAt: toLocalDateTimeInput(closeout.startsAt),
|
|
109
|
+
endsAt: toLocalDateTimeInput(closeout.endsAt),
|
|
110
|
+
reason: closeout.reason ?? "",
|
|
111
|
+
createdBy: closeout.createdBy ?? "",
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
else if (open) {
|
|
115
|
+
form.reset();
|
|
116
|
+
}
|
|
117
|
+
}, [closeout, form, open]);
|
|
118
|
+
const isEditing = Boolean(closeout);
|
|
119
|
+
const onSubmit = async (values) => {
|
|
120
|
+
const payload = {
|
|
121
|
+
resourceId: values.resourceId,
|
|
122
|
+
dateLocal: values.dateLocal,
|
|
123
|
+
startsAt: toIsoDateTime(values.startsAt),
|
|
124
|
+
endsAt: toIsoDateTime(values.endsAt),
|
|
125
|
+
reason: nullableString(values.reason),
|
|
126
|
+
createdBy: nullableString(values.createdBy),
|
|
127
|
+
};
|
|
128
|
+
if (isEditing) {
|
|
129
|
+
await sendResourcesMutation(client, "PATCH", `/v1/operations/closeouts/${closeout?.id}`, payload);
|
|
130
|
+
}
|
|
131
|
+
else {
|
|
132
|
+
await sendResourcesMutation(client, "POST", "/v1/operations/closeouts", payload);
|
|
133
|
+
}
|
|
134
|
+
onSuccess();
|
|
135
|
+
};
|
|
136
|
+
return (_jsx(Dialog, { open: open, onOpenChange: onOpenChange, children: _jsxs(DialogContent, { children: [_jsx(DialogHeader, { children: _jsx(DialogTitle, { children: isEditing ? dialogMessages.editTitle : dialogMessages.newTitle }) }), _jsxs("form", { onSubmit: form.handleSubmit(onSubmit), children: [_jsxs(DialogBody, { className: "grid gap-4", children: [_jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.resourceLabel }), _jsxs(Select, { items: resources.map((resource) => ({ label: resource.name, value: resource.id })), value: form.watch("resourceId"), onValueChange: (value) => form.setValue("resourceId", value ?? ""), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, { placeholder: dialogMessages.selectResourcePlaceholder }) }), _jsx(SelectContent, { children: resources.map((resource) => (_jsx(SelectItem, { value: resource.id, children: resource.name }, resource.id))) })] })] }), _jsxs("div", { className: "grid grid-cols-2 gap-4", children: [_jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.dateLabel }), _jsx(Input, { ...form.register("dateLocal"), type: "date" })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.startsAtLabel }), _jsx(Input, { ...form.register("startsAt"), type: "datetime-local" })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.endsAtLabel }), _jsx(Input, { ...form.register("endsAt"), type: "datetime-local" })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.createdByLabel }), _jsx(Input, { ...form.register("createdBy"), placeholder: dialogMessages.createdByPlaceholder })] })] }), _jsxs("div", { className: "grid gap-2", children: [_jsx(Label, { children: dialogMessages.reasonLabel }), _jsx(Textarea, { ...form.register("reason"), placeholder: dialogMessages.reasonPlaceholder })] })] }), _jsxs(DialogFooter, { children: [_jsx(Button, { type: "button", variant: "ghost", onClick: () => onOpenChange(false), children: dialogMessages.cancel }), _jsxs(Button, { type: "submit", disabled: form.formState.isSubmitting, children: [form.formState.isSubmitting && _jsx(Loader2, { className: "mr-2 h-4 w-4 animate-spin" }), isEditing ? dialogMessages.save : dialogMessages.create] })] })] })] }) }));
|
|
137
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import type { BookingOption, ProductOption, ResourceAllocationRow, ResourceCloseoutRow, ResourcePoolRow, ResourceRow, ResourceSlotAssignmentRow, RuleOption, SlotOption, StartTimeOption, SupplierOption } from "../index.js";
|
|
2
|
+
export declare function ResourcesDialogs({ resourceDialogOpen, setResourceDialogOpen, editingResource, poolDialogOpen, setPoolDialogOpen, editingPool, allocationDialogOpen, setAllocationDialogOpen, editingAllocation, assignmentDialogOpen, setAssignmentDialogOpen, editingAssignment, closeoutDialogOpen, setCloseoutDialogOpen, editingCloseout, suppliers, products, rules, startTimes, resources, pools, slots, bookings, refreshAll, }: {
|
|
3
|
+
resourceDialogOpen: boolean;
|
|
4
|
+
setResourceDialogOpen: (open: boolean) => void;
|
|
5
|
+
editingResource: ResourceRow | undefined;
|
|
6
|
+
poolDialogOpen: boolean;
|
|
7
|
+
setPoolDialogOpen: (open: boolean) => void;
|
|
8
|
+
editingPool: ResourcePoolRow | undefined;
|
|
9
|
+
allocationDialogOpen: boolean;
|
|
10
|
+
setAllocationDialogOpen: (open: boolean) => void;
|
|
11
|
+
editingAllocation: ResourceAllocationRow | undefined;
|
|
12
|
+
assignmentDialogOpen: boolean;
|
|
13
|
+
setAssignmentDialogOpen: (open: boolean) => void;
|
|
14
|
+
editingAssignment: ResourceSlotAssignmentRow | undefined;
|
|
15
|
+
closeoutDialogOpen: boolean;
|
|
16
|
+
setCloseoutDialogOpen: (open: boolean) => void;
|
|
17
|
+
editingCloseout: ResourceCloseoutRow | undefined;
|
|
18
|
+
suppliers: SupplierOption[];
|
|
19
|
+
products: ProductOption[];
|
|
20
|
+
rules: RuleOption[];
|
|
21
|
+
startTimes: StartTimeOption[];
|
|
22
|
+
resources: ResourceRow[];
|
|
23
|
+
pools: ResourcePoolRow[];
|
|
24
|
+
slots: SlotOption[];
|
|
25
|
+
bookings: BookingOption[];
|
|
26
|
+
refreshAll: () => Promise<void>;
|
|
27
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
28
|
+
//# sourceMappingURL=resources-dialogs.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resources-dialogs.d.ts","sourceRoot":"","sources":["../../../src/resources/admin/resources-dialogs.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,aAAa,EACb,aAAa,EACb,qBAAqB,EACrB,mBAAmB,EACnB,eAAe,EACf,WAAW,EACX,yBAAyB,EACzB,UAAU,EACV,UAAU,EACV,eAAe,EACf,cAAc,EACf,MAAM,aAAa,CAAA;AAMpB,wBAAgB,gBAAgB,CAAC,EAC/B,kBAAkB,EAClB,qBAAqB,EACrB,eAAe,EACf,cAAc,EACd,iBAAiB,EACjB,WAAW,EACX,oBAAoB,EACpB,uBAAuB,EACvB,iBAAiB,EACjB,oBAAoB,EACpB,uBAAuB,EACvB,iBAAiB,EACjB,kBAAkB,EAClB,qBAAqB,EACrB,eAAe,EACf,SAAS,EACT,QAAQ,EACR,KAAK,EACL,UAAU,EACV,SAAS,EACT,KAAK,EACL,KAAK,EACL,QAAQ,EACR,UAAU,GACX,EAAE;IACD,kBAAkB,EAAE,OAAO,CAAA;IAC3B,qBAAqB,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAA;IAC9C,eAAe,EAAE,WAAW,GAAG,SAAS,CAAA;IACxC,cAAc,EAAE,OAAO,CAAA;IACvB,iBAAiB,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAA;IAC1C,WAAW,EAAE,eAAe,GAAG,SAAS,CAAA;IACxC,oBAAoB,EAAE,OAAO,CAAA;IAC7B,uBAAuB,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAA;IAChD,iBAAiB,EAAE,qBAAqB,GAAG,SAAS,CAAA;IACpD,oBAAoB,EAAE,OAAO,CAAA;IAC7B,uBAAuB,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAA;IAChD,iBAAiB,EAAE,yBAAyB,GAAG,SAAS,CAAA;IACxD,kBAAkB,EAAE,OAAO,CAAA;IAC3B,qBAAqB,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAA;IAC9C,eAAe,EAAE,mBAAmB,GAAG,SAAS,CAAA;IAChD,SAAS,EAAE,cAAc,EAAE,CAAA;IAC3B,QAAQ,EAAE,aAAa,EAAE,CAAA;IACzB,KAAK,EAAE,UAAU,EAAE,CAAA;IACnB,UAAU,EAAE,eAAe,EAAE,CAAA;IAC7B,SAAS,EAAE,WAAW,EAAE,CAAA;IACxB,KAAK,EAAE,eAAe,EAAE,CAAA;IACxB,KAAK,EAAE,UAAU,EAAE,CAAA;IACnB,QAAQ,EAAE,aAAa,EAAE,CAAA;IACzB,UAAU,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;CAChC,2CA6DA"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { ResourceAllocationDialog } from "./resources-dialog-allocation.js";
|
|
4
|
+
import { ResourceDialog, ResourcePoolDialog } from "./resources-dialogs-core.js";
|
|
5
|
+
import { ResourceCloseoutDialog, ResourceSlotAssignmentDialog } from "./resources-dialogs-ops.js";
|
|
6
|
+
export function ResourcesDialogs({ resourceDialogOpen, setResourceDialogOpen, editingResource, poolDialogOpen, setPoolDialogOpen, editingPool, allocationDialogOpen, setAllocationDialogOpen, editingAllocation, assignmentDialogOpen, setAssignmentDialogOpen, editingAssignment, closeoutDialogOpen, setCloseoutDialogOpen, editingCloseout, suppliers, products, rules, startTimes, resources, pools, slots, bookings, refreshAll, }) {
|
|
7
|
+
return (_jsxs(_Fragment, { children: [_jsx(ResourceDialog, { open: resourceDialogOpen, onOpenChange: setResourceDialogOpen, resource: editingResource, suppliers: suppliers, onSuccess: () => {
|
|
8
|
+
setResourceDialogOpen(false);
|
|
9
|
+
void refreshAll();
|
|
10
|
+
} }), _jsx(ResourcePoolDialog, { open: poolDialogOpen, onOpenChange: setPoolDialogOpen, pool: editingPool, products: products, onSuccess: () => {
|
|
11
|
+
setPoolDialogOpen(false);
|
|
12
|
+
void refreshAll();
|
|
13
|
+
} }), _jsx(ResourceAllocationDialog, { open: allocationDialogOpen, onOpenChange: setAllocationDialogOpen, allocation: editingAllocation, pools: pools, products: products, rules: rules, startTimes: startTimes, onSuccess: () => {
|
|
14
|
+
setAllocationDialogOpen(false);
|
|
15
|
+
void refreshAll();
|
|
16
|
+
} }), _jsx(ResourceSlotAssignmentDialog, { open: assignmentDialogOpen, onOpenChange: setAssignmentDialogOpen, assignment: editingAssignment, slots: slots, pools: pools, resources: resources, bookings: bookings, onSuccess: () => {
|
|
17
|
+
setAssignmentDialogOpen(false);
|
|
18
|
+
void refreshAll();
|
|
19
|
+
} }), _jsx(ResourceCloseoutDialog, { open: closeoutDialogOpen, onOpenChange: setCloseoutDialogOpen, closeout: editingCloseout, resources: resources, onSuccess: () => {
|
|
20
|
+
setCloseoutDialogOpen(false);
|
|
21
|
+
void refreshAll();
|
|
22
|
+
} })] }));
|
|
23
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Packaged admin host for the resources tab dashboard (packaged-admin RFC
|
|
3
|
+
* Phase 3). Zero-prop: list/filter state stays component-local (no URL
|
|
4
|
+
* search contract), opening a row resolves through the resource semantic
|
|
5
|
+
* destinations, and the create/edit dialogs are the packaged operator-grade
|
|
6
|
+
* {@link ResourcesDialogs} bound to the shared resources provider context.
|
|
7
|
+
* Bulk mutations post the module's `batch-update`/`batch-delete` endpoints
|
|
8
|
+
* through the same context client and refresh via query invalidation.
|
|
9
|
+
*/
|
|
10
|
+
export declare function ResourcesHost(): import("react/jsx-runtime").JSX.Element;
|
|
11
|
+
//# sourceMappingURL=resources-host.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resources-host.d.ts","sourceRoot":"","sources":["../../../src/resources/admin/resources-host.tsx"],"names":[],"mappings":"AAsCA;;;;;;;;GAQG;AACH,wBAAgB,aAAa,4CA0N5B"}
|