@open-mercato/core 0.6.5-develop.4534.1.b459babe6d → 0.6.5-develop.4559.1.839e136509
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/.turbo/turbo-build.log +1 -1
- package/AGENTS.md +5 -0
- package/dist/generated/entities/role/index.js +3 -1
- package/dist/generated/entities/role/index.js.map +2 -2
- package/dist/generated/entities/user/index.js +3 -1
- package/dist/generated/entities/user/index.js.map +2 -2
- package/dist/generated/entity-fields-registry.js +2 -0
- package/dist/generated/entity-fields-registry.js.map +2 -2
- package/dist/helpers/integration/communicationChannelsFixtures.js.map +2 -2
- package/dist/helpers/integration/dbFixtures.js +2 -1
- package/dist/helpers/integration/dbFixtures.js.map +2 -2
- package/dist/helpers/integration/optimisticLockUi.js +104 -0
- package/dist/helpers/integration/optimisticLockUi.js.map +7 -0
- package/dist/helpers/integration/salesFixtures.js +17 -0
- package/dist/helpers/integration/salesFixtures.js.map +2 -2
- package/dist/modules/api_keys/backend/api-keys/page.js +9 -5
- package/dist/modules/api_keys/backend/api-keys/page.js.map +2 -2
- package/dist/modules/attachments/components/AttachmentPartitionSettings.js +17 -9
- package/dist/modules/attachments/components/AttachmentPartitionSettings.js.map +2 -2
- package/dist/modules/auth/api/roles/acl/route.js +32 -13
- package/dist/modules/auth/api/roles/acl/route.js.map +2 -2
- package/dist/modules/auth/api/roles/route.js +3 -1
- package/dist/modules/auth/api/roles/route.js.map +2 -2
- package/dist/modules/auth/api/sidebar/preferences/route.js +71 -3
- package/dist/modules/auth/api/sidebar/preferences/route.js.map +2 -2
- package/dist/modules/auth/api/users/acl/route.js +42 -19
- package/dist/modules/auth/api/users/acl/route.js.map +2 -2
- package/dist/modules/auth/api/users/route.js +3 -1
- package/dist/modules/auth/api/users/route.js.map +2 -2
- package/dist/modules/auth/backend/roles/[id]/edit/page.js +24 -4
- package/dist/modules/auth/backend/roles/[id]/edit/page.js.map +2 -2
- package/dist/modules/auth/backend/roles/page.js +8 -4
- package/dist/modules/auth/backend/roles/page.js.map +2 -2
- package/dist/modules/auth/backend/users/[id]/edit/page.js +27 -5
- package/dist/modules/auth/backend/users/[id]/edit/page.js.map +2 -2
- package/dist/modules/auth/backend/users/page.js +6 -2
- package/dist/modules/auth/backend/users/page.js.map +2 -2
- package/dist/modules/auth/components/AclEditor.js +3 -1
- package/dist/modules/auth/components/AclEditor.js.map +2 -2
- package/dist/modules/auth/data/entities.js +6 -0
- package/dist/modules/auth/data/entities.js.map +2 -2
- package/dist/modules/auth/services/sidebarPreferencesService.js +32 -4
- package/dist/modules/auth/services/sidebarPreferencesService.js.map +2 -2
- package/dist/modules/business_rules/api/rules/route.js +28 -0
- package/dist/modules/business_rules/api/rules/route.js.map +2 -2
- package/dist/modules/business_rules/api/sets/route.js +28 -0
- package/dist/modules/business_rules/api/sets/route.js.map +2 -2
- package/dist/modules/business_rules/backend/rules/[id]/page.js +11 -4
- package/dist/modules/business_rules/backend/rules/[id]/page.js.map +3 -3
- package/dist/modules/business_rules/backend/rules/page.js +20 -11
- package/dist/modules/business_rules/backend/rules/page.js.map +2 -2
- package/dist/modules/business_rules/backend/sets/[id]/page.js +11 -4
- package/dist/modules/business_rules/backend/sets/[id]/page.js.map +2 -2
- package/dist/modules/business_rules/backend/sets/page.js +20 -11
- package/dist/modules/business_rules/backend/sets/page.js.map +2 -2
- package/dist/modules/catalog/api/categories/route.js +2 -0
- package/dist/modules/catalog/api/categories/route.js.map +2 -2
- package/dist/modules/catalog/api/products/route.js +2 -1
- package/dist/modules/catalog/api/products/route.js.map +2 -2
- package/dist/modules/catalog/backend/catalog/categories/[id]/edit/page.js +2 -0
- package/dist/modules/catalog/backend/catalog/categories/[id]/edit/page.js.map +2 -2
- package/dist/modules/catalog/backend/catalog/products/[id]/page.js +94 -40
- package/dist/modules/catalog/backend/catalog/products/[id]/page.js.map +2 -2
- package/dist/modules/catalog/backend/catalog/products/[productId]/variants/[variantId]/page.js +37 -8
- package/dist/modules/catalog/backend/catalog/products/[productId]/variants/[variantId]/page.js.map +2 -2
- package/dist/modules/catalog/backend/catalog/products/optionSchemaClient.js.map +2 -2
- package/dist/modules/catalog/commands/variants.js +32 -31
- package/dist/modules/catalog/commands/variants.js.map +2 -2
- package/dist/modules/catalog/components/PriceKindSettings.js +12 -5
- package/dist/modules/catalog/components/PriceKindSettings.js.map +2 -2
- package/dist/modules/catalog/components/categories/CategoriesDataTable.js.map +2 -2
- package/dist/modules/catalog/components/products/ProductMediaManager.js.map +2 -2
- package/dist/modules/catalog/components/products/ProductsDataTable.js +5 -3
- package/dist/modules/catalog/components/products/ProductsDataTable.js.map +2 -2
- package/dist/modules/catalog/components/products/productForm.js.map +2 -2
- package/dist/modules/catalog/components/products/variantForm.js +2 -1
- package/dist/modules/catalog/components/products/variantForm.js.map +2 -2
- package/dist/modules/communication_channels/api/post/test-seed/route.js +23 -2
- package/dist/modules/communication_channels/api/post/test-seed/route.js.map +2 -2
- package/dist/modules/communication_channels/backend/profile/communication-channels/page.js +5 -0
- package/dist/modules/communication_channels/backend/profile/communication-channels/page.js.map +2 -2
- package/dist/modules/communication_channels/commands/set-primary-channel.js +2 -1
- package/dist/modules/communication_channels/commands/set-primary-channel.js.map +2 -2
- package/dist/modules/currencies/backend/currencies/[id]/page.js +6 -3
- package/dist/modules/currencies/backend/currencies/[id]/page.js.map +2 -2
- package/dist/modules/currencies/backend/currencies/page.js +18 -11
- package/dist/modules/currencies/backend/currencies/page.js.map +2 -2
- package/dist/modules/currencies/backend/exchange-rates/[id]/page.js +1 -0
- package/dist/modules/currencies/backend/exchange-rates/[id]/page.js.map +2 -2
- package/dist/modules/currencies/backend/exchange-rates/page.js +10 -6
- package/dist/modules/currencies/backend/exchange-rates/page.js.map +2 -2
- package/dist/modules/currencies/commands/currencies.js +7 -5
- package/dist/modules/currencies/commands/currencies.js.map +2 -2
- package/dist/modules/currencies/components/CurrencyFetchingConfig.js +26 -19
- package/dist/modules/currencies/components/CurrencyFetchingConfig.js.map +2 -2
- package/dist/modules/customer_accounts/api/admin/roles/[id].js +28 -5
- package/dist/modules/customer_accounts/api/admin/roles/[id].js.map +2 -2
- package/dist/modules/customer_accounts/api/admin/roles.js +4 -2
- package/dist/modules/customer_accounts/api/admin/roles.js.map +2 -2
- package/dist/modules/customer_accounts/api/admin/users/[id].js +28 -5
- package/dist/modules/customer_accounts/api/admin/users/[id].js.map +2 -2
- package/dist/modules/customer_accounts/api/admin/users.js +2 -0
- package/dist/modules/customer_accounts/api/admin/users.js.map +2 -2
- package/dist/modules/customer_accounts/backend/customer_accounts/roles/[id]/page.js +16 -8
- package/dist/modules/customer_accounts/backend/customer_accounts/roles/[id]/page.js.map +2 -2
- package/dist/modules/customer_accounts/backend/customer_accounts/roles/page.js +8 -4
- package/dist/modules/customer_accounts/backend/customer_accounts/roles/page.js.map +2 -2
- package/dist/modules/customer_accounts/backend/customer_accounts/settings/domain/page.js +8 -4
- package/dist/modules/customer_accounts/backend/customer_accounts/settings/domain/page.js.map +2 -2
- package/dist/modules/customer_accounts/backend/customer_accounts/users/[id]/page.js +29 -18
- package/dist/modules/customer_accounts/backend/customer_accounts/users/[id]/page.js.map +2 -2
- package/dist/modules/customer_accounts/backend/customer_accounts/users/page.js +18 -11
- package/dist/modules/customer_accounts/backend/customer_accounts/users/page.js.map +2 -2
- package/dist/modules/customers/api/companies/route.js +13 -2
- package/dist/modules/customers/api/companies/route.js.map +2 -2
- package/dist/modules/customers/api/deals/route.js +2 -0
- package/dist/modules/customers/api/deals/route.js.map +2 -2
- package/dist/modules/customers/api/people/route.js +11 -2
- package/dist/modules/customers/api/people/route.js.map +2 -2
- package/dist/modules/customers/api/todos/route.js +1 -0
- package/dist/modules/customers/api/todos/route.js.map +2 -2
- package/dist/modules/customers/backend/config/customers/deals/page.js.map +2 -2
- package/dist/modules/customers/backend/config/customers/pipeline-stages/page.js +34 -21
- package/dist/modules/customers/backend/config/customers/pipeline-stages/page.js.map +2 -2
- package/dist/modules/customers/backend/customers/companies/[id]/page.js +45 -27
- package/dist/modules/customers/backend/customers/companies/[id]/page.js.map +2 -2
- package/dist/modules/customers/backend/customers/companies/page.js.map +2 -2
- package/dist/modules/customers/backend/customers/companies-v2/[id]/page.js +22 -5
- package/dist/modules/customers/backend/customers/companies-v2/[id]/page.js.map +2 -2
- package/dist/modules/customers/backend/customers/deals/[id]/hooks/useDealFormHandlers.js +30 -8
- package/dist/modules/customers/backend/customers/deals/[id]/hooks/useDealFormHandlers.js.map +2 -2
- package/dist/modules/customers/backend/customers/deals/[id]/page.js +1 -0
- package/dist/modules/customers/backend/customers/deals/[id]/page.js.map +2 -2
- package/dist/modules/customers/backend/customers/deals/page.js +16 -6
- package/dist/modules/customers/backend/customers/deals/page.js.map +2 -2
- package/dist/modules/customers/backend/customers/deals/pipeline/page.js +62 -39
- package/dist/modules/customers/backend/customers/deals/pipeline/page.js.map +2 -2
- package/dist/modules/customers/backend/customers/people/[id]/page.js +41 -26
- package/dist/modules/customers/backend/customers/people/[id]/page.js.map +2 -2
- package/dist/modules/customers/backend/customers/people/page.js.map +2 -2
- package/dist/modules/customers/backend/customers/people-v2/[id]/page.js +50 -23
- package/dist/modules/customers/backend/customers/people-v2/[id]/page.js.map +2 -2
- package/dist/modules/customers/commands/addresses.js +16 -14
- package/dist/modules/customers/commands/addresses.js.map +2 -2
- package/dist/modules/customers/commands/companies.js +1 -1
- package/dist/modules/customers/commands/companies.js.map +2 -2
- package/dist/modules/customers/commands/interactions.js +41 -4
- package/dist/modules/customers/commands/interactions.js.map +2 -2
- package/dist/modules/customers/commands/people.js +1 -1
- package/dist/modules/customers/commands/people.js.map +2 -2
- package/dist/modules/customers/commands/personCompanyLinks.js +8 -5
- package/dist/modules/customers/commands/personCompanyLinks.js.map +2 -2
- package/dist/modules/customers/commands/pipeline-stages.js +13 -11
- package/dist/modules/customers/commands/pipeline-stages.js.map +3 -3
- package/dist/modules/customers/components/AddressFormatSettings.js.map +2 -2
- package/dist/modules/customers/components/DictionarySettings.js +20 -13
- package/dist/modules/customers/components/DictionarySettings.js.map +2 -2
- package/dist/modules/customers/components/DictionarySortSettings.js +4 -0
- package/dist/modules/customers/components/DictionarySortSettings.js.map +2 -2
- package/dist/modules/customers/components/PipelineSettings.js +38 -23
- package/dist/modules/customers/components/PipelineSettings.js.map +2 -2
- package/dist/modules/customers/components/detail/ActivityTimeline.js +1 -1
- package/dist/modules/customers/components/detail/ActivityTimeline.js.map +2 -2
- package/dist/modules/customers/components/detail/AddressesSection.js +4 -0
- package/dist/modules/customers/components/detail/AddressesSection.js.map +2 -2
- package/dist/modules/customers/components/detail/CompanyPeopleSection.js +28 -22
- package/dist/modules/customers/components/detail/CompanyPeopleSection.js.map +2 -2
- package/dist/modules/customers/components/detail/DealsSection.js +36 -24
- package/dist/modules/customers/components/detail/DealsSection.js.map +2 -2
- package/dist/modules/customers/components/detail/EmailCardActions.js +5 -0
- package/dist/modules/customers/components/detail/EmailCardActions.js.map +2 -2
- package/dist/modules/customers/components/detail/EntityTagsDialog.js +7 -0
- package/dist/modules/customers/components/detail/EntityTagsDialog.js.map +2 -2
- package/dist/modules/customers/components/detail/ManageTagsDialog.js +34 -22
- package/dist/modules/customers/components/detail/ManageTagsDialog.js.map +2 -2
- package/dist/modules/customers/components/detail/PersonCompaniesSection.js +41 -29
- package/dist/modules/customers/components/detail/PersonCompaniesSection.js.map +2 -2
- package/dist/modules/customers/components/detail/RoleAssignmentRow.js +14 -8
- package/dist/modules/customers/components/detail/RoleAssignmentRow.js.map +2 -2
- package/dist/modules/customers/components/detail/ScheduleActivityDialog.js +14 -6
- package/dist/modules/customers/components/detail/ScheduleActivityDialog.js.map +2 -2
- package/dist/modules/customers/components/detail/hooks/useInteractionMutations.js +29 -13
- package/dist/modules/customers/components/detail/hooks/useInteractionMutations.js.map +2 -2
- package/dist/modules/customers/components/detail/hooks/useInteractions.js +77 -35
- package/dist/modules/customers/components/detail/hooks/useInteractions.js.map +2 -2
- package/dist/modules/customers/components/detail/hooks/usePersonTasks.js +25 -17
- package/dist/modules/customers/components/detail/hooks/usePersonTasks.js.map +2 -2
- package/dist/modules/customers/components/detail/schedule/useScheduleFormState.js.map +2 -2
- package/dist/modules/customers/components/formConfig.js.map +2 -2
- package/dist/modules/customers/data/guards.js +66 -0
- package/dist/modules/customers/data/guards.js.map +7 -0
- package/dist/modules/customers/di.js +37 -0
- package/dist/modules/customers/di.js.map +2 -2
- package/dist/modules/customers/lib/todoCompatibility.js +11 -0
- package/dist/modules/customers/lib/todoCompatibility.js.map +2 -2
- package/dist/modules/dashboards/components/WidgetVisibilityEditor.js.map +2 -2
- package/dist/modules/data_sync/api/options.js +4 -4
- package/dist/modules/data_sync/api/options.js.map +2 -2
- package/dist/modules/data_sync/api/schedules/route.js +9 -1
- package/dist/modules/data_sync/api/schedules/route.js.map +2 -2
- package/dist/modules/data_sync/backend/data-sync/page.js +17 -8
- package/dist/modules/data_sync/backend/data-sync/page.js.map +2 -2
- package/dist/modules/data_sync/components/IntegrationScheduleTab.js +43 -22
- package/dist/modules/data_sync/components/IntegrationScheduleTab.js.map +2 -2
- package/dist/modules/data_sync/lib/sync-schedule-service.js +9 -0
- package/dist/modules/data_sync/lib/sync-schedule-service.js.map +2 -2
- package/dist/modules/dictionaries/api/[dictionaryId]/entries/[entryId]/route.js +8 -1
- package/dist/modules/dictionaries/api/[dictionaryId]/entries/[entryId]/route.js.map +2 -2
- package/dist/modules/dictionaries/api/[dictionaryId]/route.js +17 -1
- package/dist/modules/dictionaries/api/[dictionaryId]/route.js.map +2 -2
- package/dist/modules/dictionaries/components/DictionariesManager.js +31 -10
- package/dist/modules/dictionaries/components/DictionariesManager.js.map +2 -2
- package/dist/modules/dictionaries/components/DictionaryEntriesEditor.js +28 -15
- package/dist/modules/dictionaries/components/DictionaryEntriesEditor.js.map +2 -2
- package/dist/modules/directory/api/organizations/route.js +3 -0
- package/dist/modules/directory/api/organizations/route.js.map +2 -2
- package/dist/modules/directory/backend/directory/organizations/[id]/edit/page.js +2 -0
- package/dist/modules/directory/backend/directory/organizations/[id]/edit/page.js.map +2 -2
- package/dist/modules/directory/backend/directory/organizations/page.js +9 -5
- package/dist/modules/directory/backend/directory/organizations/page.js.map +2 -2
- package/dist/modules/directory/backend/directory/tenants/[id]/edit/page.js +7 -3
- package/dist/modules/directory/backend/directory/tenants/[id]/edit/page.js.map +2 -2
- package/dist/modules/directory/backend/directory/tenants/page.js +8 -4
- package/dist/modules/directory/backend/directory/tenants/page.js.map +2 -2
- package/dist/modules/directory/commands/organizations.js +7 -2
- package/dist/modules/directory/commands/organizations.js.map +2 -2
- package/dist/modules/entities/api/records.js +66 -0
- package/dist/modules/entities/api/records.js.map +2 -2
- package/dist/modules/entities/backend/entities/user/[entityId]/records/[recordId]/page.js +1 -0
- package/dist/modules/entities/backend/entities/user/[entityId]/records/[recordId]/page.js.map +2 -2
- package/dist/modules/entities/backend/entities/user/[entityId]/records/page.js +8 -4
- package/dist/modules/entities/backend/entities/user/[entityId]/records/page.js.map +2 -2
- package/dist/modules/entities/lib/helpers.js +17 -0
- package/dist/modules/entities/lib/helpers.js.map +2 -2
- package/dist/modules/feature_toggles/api/global/[id]/override/route.js +2 -1
- package/dist/modules/feature_toggles/api/global/[id]/override/route.js.map +2 -2
- package/dist/modules/feature_toggles/api/overrides/route.js +15 -0
- package/dist/modules/feature_toggles/api/overrides/route.js.map +2 -2
- package/dist/modules/feature_toggles/backend/feature-toggles/global/[id]/edit/page.js +15 -14
- package/dist/modules/feature_toggles/backend/feature-toggles/global/[id]/edit/page.js.map +2 -2
- package/dist/modules/feature_toggles/components/FeatureToggleOverrideCard.js +20 -12
- package/dist/modules/feature_toggles/components/FeatureToggleOverrideCard.js.map +2 -2
- package/dist/modules/feature_toggles/components/FeatureTogglesTable.js +6 -2
- package/dist/modules/feature_toggles/components/FeatureTogglesTable.js.map +2 -2
- package/dist/modules/feature_toggles/components/formConfig.js +2 -1
- package/dist/modules/feature_toggles/components/formConfig.js.map +2 -2
- package/dist/modules/feature_toggles/components/overrideFormConfig.js +5 -1
- package/dist/modules/feature_toggles/components/overrideFormConfig.js.map +2 -2
- package/dist/modules/feature_toggles/data/validators.js +7 -4
- package/dist/modules/feature_toggles/data/validators.js.map +2 -2
- package/dist/modules/inbox_ops/api/settings/route.js +17 -2
- package/dist/modules/inbox_ops/api/settings/route.js.map +2 -2
- package/dist/modules/inbox_ops/backend/inbox-ops/settings/page.js +13 -8
- package/dist/modules/inbox_ops/backend/inbox-ops/settings/page.js.map +2 -2
- package/dist/modules/inbox_ops/components/proposals/EditActionDialog.js +9 -4
- package/dist/modules/inbox_ops/components/proposals/EditActionDialog.js.map +2 -2
- package/dist/modules/integrations/backend/integrations/bundle/[id]/page.js +18 -11
- package/dist/modules/integrations/backend/integrations/bundle/[id]/page.js.map +2 -2
- package/dist/modules/integrations/backend/integrations/page.js +12 -8
- package/dist/modules/integrations/backend/integrations/page.js.map +2 -2
- package/dist/modules/messages/commands/messages.js +13 -10
- package/dist/modules/messages/commands/messages.js.map +2 -2
- package/dist/modules/perspectives/api/[tableId]/route.js +39 -30
- package/dist/modules/perspectives/api/[tableId]/route.js.map +2 -2
- package/dist/modules/perspectives/services/perspectiveService.js +7 -0
- package/dist/modules/perspectives/services/perspectiveService.js.map +2 -2
- package/dist/modules/planner/backend/planner/availability-rulesets/[id]/page.js +6 -14
- package/dist/modules/planner/backend/planner/availability-rulesets/[id]/page.js.map +3 -3
- package/dist/modules/planner/backend/planner/availability-rulesets/page.js +4 -2
- package/dist/modules/planner/backend/planner/availability-rulesets/page.js.map +2 -2
- package/dist/modules/planner/components/AvailabilityRuleSetForm.js +2 -0
- package/dist/modules/planner/components/AvailabilityRuleSetForm.js.map +2 -2
- package/dist/modules/planner/components/AvailabilityRulesEditor.js +36 -11
- package/dist/modules/planner/components/AvailabilityRulesEditor.js.map +2 -2
- package/dist/modules/planner/components/AvailabilitySchedule.js +9 -5
- package/dist/modules/planner/components/AvailabilitySchedule.js.map +2 -2
- package/dist/modules/query_index/lib/engine.js +19 -0
- package/dist/modules/query_index/lib/engine.js.map +2 -2
- package/dist/modules/resources/backend/resources/resource-types/[id]/edit/page.js +1 -0
- package/dist/modules/resources/backend/resources/resource-types/[id]/edit/page.js.map +2 -2
- package/dist/modules/resources/backend/resources/resource-types/page.js +4 -2
- package/dist/modules/resources/backend/resources/resource-types/page.js.map +2 -2
- package/dist/modules/resources/backend/resources/resources/[id]/page.js +14 -3
- package/dist/modules/resources/backend/resources/resources/[id]/page.js.map +2 -2
- package/dist/modules/resources/backend/resources/resources/page.js +8 -4
- package/dist/modules/resources/backend/resources/resources/page.js.map +2 -2
- package/dist/modules/resources/components/ResourceCrudForm.js +2 -0
- package/dist/modules/resources/components/ResourceCrudForm.js.map +2 -2
- package/dist/modules/resources/components/ResourceTypeCrudForm.js +1 -0
- package/dist/modules/resources/components/ResourceTypeCrudForm.js.map +2 -2
- package/dist/modules/sales/api/documents/factory.js +7 -2
- package/dist/modules/sales/api/documents/factory.js.map +2 -2
- package/dist/modules/sales/backend/sales/channels/[channelId]/edit/page.js +3 -1
- package/dist/modules/sales/backend/sales/channels/[channelId]/edit/page.js.map +2 -2
- package/dist/modules/sales/backend/sales/channels/offers/page.js +13 -4
- package/dist/modules/sales/backend/sales/channels/offers/page.js.map +2 -2
- package/dist/modules/sales/backend/sales/channels/page.js +16 -4
- package/dist/modules/sales/backend/sales/channels/page.js.map +2 -2
- package/dist/modules/sales/backend/sales/documents/[id]/page.js +68 -22
- package/dist/modules/sales/backend/sales/documents/[id]/page.js.map +2 -2
- package/dist/modules/sales/backend/sales/documents/create/page.js.map +2 -2
- package/dist/modules/sales/commands/documentAddresses.js +181 -2
- package/dist/modules/sales/commands/documentAddresses.js.map +2 -2
- package/dist/modules/sales/commands/documents.js +29 -1
- package/dist/modules/sales/commands/documents.js.map +2 -2
- package/dist/modules/sales/commands/returns.js +12 -2
- package/dist/modules/sales/commands/returns.js.map +2 -2
- package/dist/modules/sales/commands/shared.js +15 -0
- package/dist/modules/sales/commands/shared.js.map +2 -2
- package/dist/modules/sales/commands/shipments.js +4 -1
- package/dist/modules/sales/commands/shipments.js.map +2 -2
- package/dist/modules/sales/components/AdjustmentKindSettings.js +19 -11
- package/dist/modules/sales/components/AdjustmentKindSettings.js.map +2 -2
- package/dist/modules/sales/components/DocumentNumberSettings.js.map +2 -2
- package/dist/modules/sales/components/OrderEditingSettings.js.map +2 -2
- package/dist/modules/sales/components/PaymentMethodsSettings.js +12 -4
- package/dist/modules/sales/components/PaymentMethodsSettings.js.map +2 -2
- package/dist/modules/sales/components/ShippingMethodsSettings.js +12 -4
- package/dist/modules/sales/components/ShippingMethodsSettings.js.map +2 -2
- package/dist/modules/sales/components/StatusSettings.js +18 -11
- package/dist/modules/sales/components/StatusSettings.js.map +2 -2
- package/dist/modules/sales/components/TaxRatesSettings.js +12 -4
- package/dist/modules/sales/components/TaxRatesSettings.js.map +2 -2
- package/dist/modules/sales/components/channels/ChannelOfferForm.js +47 -16
- package/dist/modules/sales/components/channels/ChannelOfferForm.js.map +2 -2
- package/dist/modules/sales/components/channels/SalesChannelOffersPanel.js +8 -4
- package/dist/modules/sales/components/channels/SalesChannelOffersPanel.js.map +2 -2
- package/dist/modules/sales/components/documents/AddressesSection.js +44 -25
- package/dist/modules/sales/components/documents/AddressesSection.js.map +2 -2
- package/dist/modules/sales/components/documents/AdjustmentsSection.js +43 -23
- package/dist/modules/sales/components/documents/AdjustmentsSection.js.map +2 -2
- package/dist/modules/sales/components/documents/ItemsSection.js +22 -13
- package/dist/modules/sales/components/documents/ItemsSection.js.map +2 -2
- package/dist/modules/sales/components/documents/LineItemDialog.js +23 -10
- package/dist/modules/sales/components/documents/LineItemDialog.js.map +2 -2
- package/dist/modules/sales/components/documents/PaymentDialog.js +29 -14
- package/dist/modules/sales/components/documents/PaymentDialog.js.map +2 -2
- package/dist/modules/sales/components/documents/PaymentsSection.js +20 -10
- package/dist/modules/sales/components/documents/PaymentsSection.js.map +2 -2
- package/dist/modules/sales/components/documents/ReturnDialog.js +26 -17
- package/dist/modules/sales/components/documents/ReturnDialog.js.map +2 -2
- package/dist/modules/sales/components/documents/ReturnsSection.js +3 -1
- package/dist/modules/sales/components/documents/ReturnsSection.js.map +2 -2
- package/dist/modules/sales/components/documents/SalesDocumentsTable.js +10 -5
- package/dist/modules/sales/components/documents/SalesDocumentsTable.js.map +2 -2
- package/dist/modules/sales/components/documents/ShipmentDialog.js +21 -7
- package/dist/modules/sales/components/documents/ShipmentDialog.js.map +2 -2
- package/dist/modules/sales/components/documents/ShipmentsSection.js +19 -10
- package/dist/modules/sales/components/documents/ShipmentsSection.js.map +2 -2
- package/dist/modules/sales/components/documents/optimisticLock.js +27 -0
- package/dist/modules/sales/components/documents/optimisticLock.js.map +7 -0
- package/dist/modules/sales/di.js +18 -0
- package/dist/modules/sales/di.js.map +2 -2
- package/dist/modules/staff/api/job-histories.js +11 -2
- package/dist/modules/staff/api/job-histories.js.map +2 -2
- package/dist/modules/staff/api/timesheets/time-entries/route.js +11 -4
- package/dist/modules/staff/api/timesheets/time-entries/route.js.map +2 -2
- package/dist/modules/staff/backend/staff/leave-requests/[id]/page.js +13 -8
- package/dist/modules/staff/backend/staff/leave-requests/[id]/page.js.map +2 -2
- package/dist/modules/staff/backend/staff/my-leave-requests/[id]/page.js +2 -1
- package/dist/modules/staff/backend/staff/my-leave-requests/[id]/page.js.map +2 -2
- package/dist/modules/staff/backend/staff/team-members/[id]/page.js +7 -4
- package/dist/modules/staff/backend/staff/team-members/[id]/page.js.map +2 -2
- package/dist/modules/staff/backend/staff/team-members/page.js +4 -2
- package/dist/modules/staff/backend/staff/team-members/page.js.map +2 -2
- package/dist/modules/staff/backend/staff/team-roles/[id]/edit/page.js +1 -0
- package/dist/modules/staff/backend/staff/team-roles/[id]/edit/page.js.map +2 -2
- package/dist/modules/staff/backend/staff/team-roles/page.js +4 -2
- package/dist/modules/staff/backend/staff/team-roles/page.js.map +2 -2
- package/dist/modules/staff/backend/staff/teams/[id]/edit/page.js +5 -2
- package/dist/modules/staff/backend/staff/teams/[id]/edit/page.js.map +2 -2
- package/dist/modules/staff/backend/staff/teams/page.js +12 -3
- package/dist/modules/staff/backend/staff/teams/page.js.map +2 -2
- package/dist/modules/staff/backend/staff/timesheets/page.js +4 -1
- package/dist/modules/staff/backend/staff/timesheets/page.js.map +2 -2
- package/dist/modules/staff/backend/staff/timesheets/projects/[id]/page.js.map +2 -2
- package/dist/modules/staff/backend/staff/timesheets/projects/page.js +12 -3
- package/dist/modules/staff/backend/staff/timesheets/projects/page.js.map +2 -2
- package/dist/modules/staff/commands/job-histories.js +40 -3
- package/dist/modules/staff/commands/job-histories.js.map +2 -2
- package/dist/modules/staff/components/LeaveRequestForm.js +1 -0
- package/dist/modules/staff/components/LeaveRequestForm.js.map +2 -2
- package/dist/modules/staff/components/TeamForm.js +1 -0
- package/dist/modules/staff/components/TeamForm.js.map +2 -2
- package/dist/modules/staff/components/TeamMemberForm.js +1 -0
- package/dist/modules/staff/components/TeamMemberForm.js.map +2 -2
- package/dist/modules/staff/components/TeamRoleForm.js +1 -0
- package/dist/modules/staff/components/TeamRoleForm.js.map +2 -2
- package/dist/modules/staff/components/detail/JobHistorySection.js +20 -7
- package/dist/modules/staff/components/detail/JobHistorySection.js.map +2 -2
- package/dist/modules/staff/data/validators.js +7 -1
- package/dist/modules/staff/data/validators.js.map +2 -2
- package/dist/modules/staff/lib/leaveRequestHelpers.js +2 -1
- package/dist/modules/staff/lib/leaveRequestHelpers.js.map +2 -2
- package/dist/modules/translations/components/TranslationManager.js +12 -8
- package/dist/modules/translations/components/TranslationManager.js.map +2 -2
- package/dist/modules/workflows/api/definitions/[id]/route.js +106 -0
- package/dist/modules/workflows/api/definitions/[id]/route.js.map +2 -2
- package/dist/modules/workflows/backend/definitions/[id]/page.js +11 -3
- package/dist/modules/workflows/backend/definitions/[id]/page.js.map +2 -2
- package/dist/modules/workflows/backend/definitions/page.js +19 -8
- package/dist/modules/workflows/backend/definitions/page.js.map +2 -2
- package/dist/modules/workflows/backend/definitions/visual-editor/page.js +29 -16
- package/dist/modules/workflows/backend/definitions/visual-editor/page.js.map +2 -2
- package/dist/modules/workflows/components/formConfig.js +4 -1
- package/dist/modules/workflows/components/formConfig.js.map +2 -2
- package/dist/modules/workflows/di.js +12 -0
- package/dist/modules/workflows/di.js.map +2 -2
- package/generated/entities/role/index.ts +1 -0
- package/generated/entities/user/index.ts +1 -0
- package/generated/entity-fields-registry.ts +2 -0
- package/jest.setup.ts +17 -0
- package/package.json +8 -7
- package/src/helpers/integration/communicationChannelsFixtures.ts +6 -0
- package/src/helpers/integration/dbFixtures.ts +1 -1
- package/src/helpers/integration/optimisticLockUi.ts +172 -0
- package/src/helpers/integration/salesFixtures.ts +29 -0
- package/src/modules/api_keys/backend/api-keys/page.tsx +10 -5
- package/src/modules/attachments/components/AttachmentPartitionSettings.tsx +19 -9
- package/src/modules/auth/api/roles/acl/route.ts +37 -11
- package/src/modules/auth/api/roles/route.ts +2 -0
- package/src/modules/auth/api/sidebar/preferences/route.ts +73 -0
- package/src/modules/auth/api/users/acl/route.ts +46 -18
- package/src/modules/auth/api/users/route.ts +2 -0
- package/src/modules/auth/backend/roles/[id]/edit/page.tsx +29 -4
- package/src/modules/auth/backend/roles/page.tsx +9 -4
- package/src/modules/auth/backend/users/[id]/edit/page.tsx +37 -4
- package/src/modules/auth/backend/users/page.tsx +7 -2
- package/src/modules/auth/components/AclEditor.tsx +10 -1
- package/src/modules/auth/data/entities.ts +7 -1
- package/src/modules/auth/services/sidebarPreferencesService.ts +38 -4
- package/src/modules/business_rules/api/rules/route.ts +30 -0
- package/src/modules/business_rules/api/sets/route.ts +30 -0
- package/src/modules/business_rules/backend/rules/[id]/page.tsx +16 -4
- package/src/modules/business_rules/backend/rules/page.tsx +20 -11
- package/src/modules/business_rules/backend/sets/[id]/page.tsx +16 -4
- package/src/modules/business_rules/backend/sets/page.tsx +20 -11
- package/src/modules/catalog/api/categories/route.ts +3 -0
- package/src/modules/catalog/api/products/route.ts +4 -0
- package/src/modules/catalog/backend/catalog/categories/[id]/edit/page.tsx +5 -0
- package/src/modules/catalog/backend/catalog/products/[id]/page.tsx +112 -35
- package/src/modules/catalog/backend/catalog/products/[productId]/variants/[variantId]/page.tsx +56 -7
- package/src/modules/catalog/backend/catalog/products/optionSchemaClient.ts +2 -0
- package/src/modules/catalog/commands/variants.ts +32 -32
- package/src/modules/catalog/components/PriceKindSettings.tsx +20 -7
- package/src/modules/catalog/components/categories/CategoriesDataTable.tsx +1 -0
- package/src/modules/catalog/components/products/ProductMediaManager.tsx +2 -0
- package/src/modules/catalog/components/products/ProductsDataTable.tsx +8 -4
- package/src/modules/catalog/components/products/productForm.ts +3 -0
- package/src/modules/catalog/components/products/variantForm.ts +9 -0
- package/src/modules/communication_channels/api/post/test-seed/route.ts +28 -1
- package/src/modules/communication_channels/backend/profile/communication-channels/page.tsx +5 -0
- package/src/modules/communication_channels/commands/set-primary-channel.ts +10 -7
- package/src/modules/currencies/backend/currencies/[id]/page.tsx +13 -6
- package/src/modules/currencies/backend/currencies/page.tsx +18 -11
- package/src/modules/currencies/backend/exchange-rates/[id]/page.tsx +3 -0
- package/src/modules/currencies/backend/exchange-rates/page.tsx +10 -6
- package/src/modules/currencies/commands/currencies.ts +10 -5
- package/src/modules/currencies/components/CurrencyFetchingConfig.tsx +31 -21
- package/src/modules/customer_accounts/api/admin/roles/[id].ts +35 -5
- package/src/modules/customer_accounts/api/admin/roles.ts +2 -0
- package/src/modules/customer_accounts/api/admin/users/[id].ts +38 -5
- package/src/modules/customer_accounts/api/admin/users.ts +2 -0
- package/src/modules/customer_accounts/backend/customer_accounts/roles/[id]/page.tsx +34 -20
- package/src/modules/customer_accounts/backend/customer_accounts/roles/page.tsx +9 -4
- package/src/modules/customer_accounts/backend/customer_accounts/settings/domain/page.tsx +11 -4
- package/src/modules/customer_accounts/backend/customer_accounts/users/[id]/page.tsx +28 -17
- package/src/modules/customer_accounts/backend/customer_accounts/users/page.tsx +19 -11
- package/src/modules/customers/AGENTS.md +2 -2
- package/src/modules/customers/api/companies/route.ts +14 -1
- package/src/modules/customers/api/deals/route.ts +3 -0
- package/src/modules/customers/api/people/route.ts +12 -1
- package/src/modules/customers/api/todos/route.ts +1 -0
- package/src/modules/customers/backend/config/customers/deals/page.tsx +1 -0
- package/src/modules/customers/backend/config/customers/pipeline-stages/page.tsx +36 -21
- package/src/modules/customers/backend/customers/companies/[id]/page.tsx +52 -27
- package/src/modules/customers/backend/customers/companies/page.tsx +2 -0
- package/src/modules/customers/backend/customers/companies-v2/[id]/page.tsx +27 -5
- package/src/modules/customers/backend/customers/deals/[id]/hooks/useDealFormHandlers.ts +39 -7
- package/src/modules/customers/backend/customers/deals/[id]/page.tsx +1 -0
- package/src/modules/customers/backend/customers/deals/page.tsx +18 -6
- package/src/modules/customers/backend/customers/deals/pipeline/page.tsx +64 -39
- package/src/modules/customers/backend/customers/people/[id]/page.tsx +46 -26
- package/src/modules/customers/backend/customers/people/page.tsx +2 -0
- package/src/modules/customers/backend/customers/people-v2/[id]/page.tsx +84 -24
- package/src/modules/customers/commands/addresses.ts +16 -14
- package/src/modules/customers/commands/companies.ts +3 -1
- package/src/modules/customers/commands/interactions.ts +50 -4
- package/src/modules/customers/commands/people.ts +2 -1
- package/src/modules/customers/commands/personCompanyLinks.ts +8 -5
- package/src/modules/customers/commands/pipeline-stages.ts +16 -16
- package/src/modules/customers/components/AddressFormatSettings.tsx +1 -0
- package/src/modules/customers/components/DictionarySettings.tsx +18 -13
- package/src/modules/customers/components/DictionarySortSettings.tsx +4 -0
- package/src/modules/customers/components/PipelineSettings.tsx +42 -21
- package/src/modules/customers/components/detail/ActivityTimeline.tsx +3 -3
- package/src/modules/customers/components/detail/AddressesSection.tsx +4 -0
- package/src/modules/customers/components/detail/CompanyPeopleSection.tsx +2 -0
- package/src/modules/customers/components/detail/DealsSection.tsx +4 -0
- package/src/modules/customers/components/detail/EmailCardActions.tsx +5 -0
- package/src/modules/customers/components/detail/EntityTagsDialog.tsx +7 -0
- package/src/modules/customers/components/detail/ManageTagsDialog.tsx +4 -0
- package/src/modules/customers/components/detail/PersonCompaniesSection.tsx +4 -0
- package/src/modules/customers/components/detail/RoleAssignmentRow.tsx +2 -0
- package/src/modules/customers/components/detail/ScheduleActivityDialog.tsx +23 -7
- package/src/modules/customers/components/detail/hooks/useInteractionMutations.ts +25 -15
- package/src/modules/customers/components/detail/hooks/useInteractions.ts +76 -35
- package/src/modules/customers/components/detail/hooks/usePersonTasks.ts +30 -17
- package/src/modules/customers/components/detail/schedule/useScheduleFormState.ts +2 -0
- package/src/modules/customers/components/detail/types.ts +1 -0
- package/src/modules/customers/components/formConfig.tsx +2 -0
- package/src/modules/customers/data/guards.ts +67 -0
- package/src/modules/customers/di.ts +66 -0
- package/src/modules/customers/i18n/de.json +2 -0
- package/src/modules/customers/i18n/en.json +2 -0
- package/src/modules/customers/i18n/es.json +2 -0
- package/src/modules/customers/i18n/pl.json +2 -0
- package/src/modules/customers/lib/todoCompatibility.ts +14 -0
- package/src/modules/dashboards/components/WidgetVisibilityEditor.tsx +2 -0
- package/src/modules/data_sync/api/options.ts +7 -4
- package/src/modules/data_sync/api/schedules/route.ts +9 -1
- package/src/modules/data_sync/backend/data-sync/page.tsx +18 -5
- package/src/modules/data_sync/components/IntegrationScheduleTab.tsx +46 -19
- package/src/modules/data_sync/lib/sync-schedule-service.ts +11 -0
- package/src/modules/dictionaries/api/[dictionaryId]/entries/[entryId]/route.ts +8 -1
- package/src/modules/dictionaries/api/[dictionaryId]/route.ts +23 -0
- package/src/modules/dictionaries/components/DictionariesManager.tsx +32 -9
- package/src/modules/dictionaries/components/DictionaryEntriesEditor.tsx +30 -14
- package/src/modules/dictionaries/i18n/de.json +1 -0
- package/src/modules/dictionaries/i18n/en.json +1 -0
- package/src/modules/dictionaries/i18n/es.json +1 -0
- package/src/modules/dictionaries/i18n/pl.json +1 -0
- package/src/modules/directory/api/organizations/route.ts +3 -0
- package/src/modules/directory/backend/directory/organizations/[id]/edit/page.tsx +8 -0
- package/src/modules/directory/backend/directory/organizations/page.tsx +10 -5
- package/src/modules/directory/backend/directory/tenants/[id]/edit/page.tsx +16 -5
- package/src/modules/directory/backend/directory/tenants/page.tsx +8 -4
- package/src/modules/directory/commands/organizations.ts +7 -4
- package/src/modules/entities/api/records.ts +99 -0
- package/src/modules/entities/backend/entities/user/[entityId]/records/[recordId]/page.tsx +7 -0
- package/src/modules/entities/backend/entities/user/[entityId]/records/page.tsx +8 -4
- package/src/modules/entities/lib/helpers.ts +17 -0
- package/src/modules/feature_toggles/api/global/[id]/override/route.ts +1 -0
- package/src/modules/feature_toggles/api/overrides/route.ts +19 -0
- package/src/modules/feature_toggles/backend/feature-toggles/global/[id]/edit/page.tsx +19 -13
- package/src/modules/feature_toggles/components/FeatureToggleOverrideCard.tsx +22 -12
- package/src/modules/feature_toggles/components/FeatureTogglesTable.tsx +7 -2
- package/src/modules/feature_toggles/components/formConfig.tsx +2 -1
- package/src/modules/feature_toggles/components/overrideFormConfig.tsx +10 -1
- package/src/modules/feature_toggles/data/validators.ts +11 -3
- package/src/modules/inbox_ops/api/settings/route.ts +18 -0
- package/src/modules/inbox_ops/backend/inbox-ops/settings/page.tsx +15 -10
- package/src/modules/inbox_ops/components/proposals/EditActionDialog.tsx +9 -4
- package/src/modules/integrations/backend/integrations/bundle/[id]/page.tsx +20 -11
- package/src/modules/integrations/backend/integrations/page.tsx +13 -8
- package/src/modules/messages/commands/messages.ts +27 -15
- package/src/modules/perspectives/api/[tableId]/route.ts +11 -2
- package/src/modules/perspectives/services/perspectiveService.ts +13 -1
- package/src/modules/planner/backend/planner/availability-rulesets/[id]/page.tsx +16 -14
- package/src/modules/planner/backend/planner/availability-rulesets/page.tsx +6 -3
- package/src/modules/planner/components/AvailabilityRuleSetForm.tsx +3 -0
- package/src/modules/planner/components/AvailabilityRulesEditor.tsx +58 -15
- package/src/modules/planner/components/AvailabilitySchedule.tsx +22 -7
- package/src/modules/query_index/lib/engine.ts +34 -0
- package/src/modules/resources/backend/resources/resource-types/[id]/edit/page.tsx +7 -1
- package/src/modules/resources/backend/resources/resource-types/page.tsx +6 -3
- package/src/modules/resources/backend/resources/resources/[id]/page.tsx +23 -3
- package/src/modules/resources/backend/resources/resources/page.tsx +15 -4
- package/src/modules/resources/components/ResourceCrudForm.tsx +3 -0
- package/src/modules/resources/components/ResourceTypeCrudForm.tsx +2 -0
- package/src/modules/sales/api/documents/factory.ts +13 -1
- package/src/modules/sales/backend/sales/channels/[channelId]/edit/page.tsx +6 -0
- package/src/modules/sales/backend/sales/channels/offers/page.tsx +10 -4
- package/src/modules/sales/backend/sales/channels/page.tsx +19 -4
- package/src/modules/sales/backend/sales/documents/[id]/page.tsx +73 -20
- package/src/modules/sales/backend/sales/documents/create/page.tsx +2 -0
- package/src/modules/sales/commands/documentAddresses.ts +226 -4
- package/src/modules/sales/commands/documents.ts +28 -0
- package/src/modules/sales/commands/returns.ts +12 -3
- package/src/modules/sales/commands/shared.ts +36 -0
- package/src/modules/sales/commands/shipments.ts +17 -1
- package/src/modules/sales/components/AdjustmentKindSettings.tsx +20 -11
- package/src/modules/sales/components/DocumentNumberSettings.tsx +1 -0
- package/src/modules/sales/components/OrderEditingSettings.tsx +1 -0
- package/src/modules/sales/components/PaymentMethodsSettings.tsx +12 -4
- package/src/modules/sales/components/ShippingMethodsSettings.tsx +12 -4
- package/src/modules/sales/components/StatusSettings.tsx +20 -11
- package/src/modules/sales/components/TaxRatesSettings.tsx +12 -5
- package/src/modules/sales/components/channels/ChannelOfferForm.tsx +67 -14
- package/src/modules/sales/components/channels/SalesChannelOffersPanel.tsx +7 -4
- package/src/modules/sales/components/documents/AddressesSection.tsx +35 -25
- package/src/modules/sales/components/documents/AdjustmentsSection.tsx +50 -25
- package/src/modules/sales/components/documents/ItemsSection.tsx +24 -13
- package/src/modules/sales/components/documents/LineItemDialog.tsx +26 -9
- package/src/modules/sales/components/documents/PaymentDialog.tsx +33 -14
- package/src/modules/sales/components/documents/PaymentsSection.tsx +22 -10
- package/src/modules/sales/components/documents/ReturnDialog.tsx +28 -17
- package/src/modules/sales/components/documents/ReturnsSection.tsx +4 -1
- package/src/modules/sales/components/documents/SalesDocumentsTable.tsx +11 -4
- package/src/modules/sales/components/documents/ShipmentDialog.tsx +23 -8
- package/src/modules/sales/components/documents/ShipmentsSection.tsx +20 -10
- package/src/modules/sales/components/documents/optimisticLock.ts +34 -0
- package/src/modules/sales/components/documents/shipmentTypes.ts +1 -0
- package/src/modules/sales/di.ts +35 -0
- package/src/modules/sales/i18n/de.json +3 -0
- package/src/modules/sales/i18n/en.json +3 -0
- package/src/modules/sales/i18n/es.json +3 -0
- package/src/modules/sales/i18n/pl.json +3 -0
- package/src/modules/staff/api/job-histories.ts +12 -2
- package/src/modules/staff/api/timesheets/time-entries/route.ts +16 -4
- package/src/modules/staff/backend/staff/leave-requests/[id]/page.tsx +12 -7
- package/src/modules/staff/backend/staff/my-leave-requests/[id]/page.tsx +2 -0
- package/src/modules/staff/backend/staff/team-members/[id]/page.tsx +16 -5
- package/src/modules/staff/backend/staff/team-members/page.tsx +6 -2
- package/src/modules/staff/backend/staff/team-roles/[id]/edit/page.tsx +8 -0
- package/src/modules/staff/backend/staff/team-roles/page.tsx +6 -2
- package/src/modules/staff/backend/staff/teams/[id]/edit/page.tsx +13 -3
- package/src/modules/staff/backend/staff/teams/page.tsx +9 -3
- package/src/modules/staff/backend/staff/timesheets/page.tsx +10 -1
- package/src/modules/staff/backend/staff/timesheets/projects/[id]/page.tsx +4 -0
- package/src/modules/staff/backend/staff/timesheets/projects/page.tsx +9 -3
- package/src/modules/staff/commands/job-histories.ts +42 -3
- package/src/modules/staff/components/LeaveRequestForm.tsx +2 -0
- package/src/modules/staff/components/TeamForm.tsx +2 -0
- package/src/modules/staff/components/TeamMemberForm.tsx +2 -0
- package/src/modules/staff/components/TeamRoleForm.tsx +2 -0
- package/src/modules/staff/components/detail/JobHistorySection.tsx +28 -6
- package/src/modules/staff/data/validators.ts +6 -0
- package/src/modules/staff/i18n/de.json +1 -0
- package/src/modules/staff/i18n/en.json +1 -0
- package/src/modules/staff/i18n/es.json +1 -0
- package/src/modules/staff/i18n/pl.json +1 -0
- package/src/modules/staff/lib/leaveRequestHelpers.ts +4 -0
- package/src/modules/translations/components/TranslationManager.tsx +13 -8
- package/src/modules/workflows/api/definitions/[id]/route.ts +112 -0
- package/src/modules/workflows/backend/definitions/[id]/page.tsx +20 -4
- package/src/modules/workflows/backend/definitions/page.tsx +20 -9
- package/src/modules/workflows/backend/definitions/visual-editor/page.tsx +29 -16
- package/src/modules/workflows/components/formConfig.tsx +5 -0
- package/src/modules/workflows/di.ts +20 -0
- package/src/modules/workflows/i18n/de.json +1 -0
- package/src/modules/workflows/i18n/en.json +1 -0
- package/src/modules/workflows/i18n/es.json +1 -0
- package/src/modules/workflows/i18n/pl.json +1 -0
|
@@ -26,6 +26,7 @@ type ReturnRow = {
|
|
|
26
26
|
type SalesReturnsSectionProps = {
|
|
27
27
|
orderId: string
|
|
28
28
|
currencyCode?: string | null
|
|
29
|
+
documentUpdatedAt?: string | null
|
|
29
30
|
}
|
|
30
31
|
|
|
31
32
|
function formatDisplayDate(value: string | null | undefined): string | null {
|
|
@@ -35,7 +36,7 @@ function formatDisplayDate(value: string | null | undefined): string | null {
|
|
|
35
36
|
return new Intl.DateTimeFormat(undefined, { dateStyle: 'medium' }).format(date)
|
|
36
37
|
}
|
|
37
38
|
|
|
38
|
-
export function SalesReturnsSection({ orderId, currencyCode }: SalesReturnsSectionProps) {
|
|
39
|
+
export function SalesReturnsSection({ orderId, currencyCode, documentUpdatedAt }: SalesReturnsSectionProps) {
|
|
39
40
|
const t = useT()
|
|
40
41
|
const [returns, setReturns] = React.useState<ReturnRow[]>([])
|
|
41
42
|
const [lines, setLines] = React.useState<ReturnOrderLine[]>([])
|
|
@@ -208,6 +209,7 @@ export function SalesReturnsSection({ orderId, currencyCode }: SalesReturnsSecti
|
|
|
208
209
|
open={dialogOpen}
|
|
209
210
|
orderId={orderId}
|
|
210
211
|
lines={lines}
|
|
212
|
+
documentUpdatedAt={documentUpdatedAt}
|
|
211
213
|
onClose={() => setDialogOpen(false)}
|
|
212
214
|
onSaved={async () => {
|
|
213
215
|
emitSalesDocumentTotalsRefresh({ documentId: orderId, kind: 'order' })
|
|
@@ -258,6 +260,7 @@ export function SalesReturnsSection({ orderId, currencyCode }: SalesReturnsSecti
|
|
|
258
260
|
open={dialogOpen}
|
|
259
261
|
orderId={orderId}
|
|
260
262
|
lines={lines}
|
|
263
|
+
documentUpdatedAt={documentUpdatedAt}
|
|
261
264
|
onClose={() => setDialogOpen(false)}
|
|
262
265
|
onSaved={async () => {
|
|
263
266
|
emitSalesDocumentTotalsRefresh({ documentId: orderId, kind: 'order' })
|
|
@@ -9,7 +9,8 @@ import { DataTable, type DataTableExportFormat, withDataTableNamespaces } from '
|
|
|
9
9
|
import type { FilterDef, FilterValues } from '@open-mercato/ui/backend/FilterBar'
|
|
10
10
|
import { RowActions } from '@open-mercato/ui/backend/RowActions'
|
|
11
11
|
import { Button } from '@open-mercato/ui/primitives/button'
|
|
12
|
-
import { apiCall } from '@open-mercato/ui/backend/utils/apiCall'
|
|
12
|
+
import { apiCall, withScopedApiRequestHeaders } from '@open-mercato/ui/backend/utils/apiCall'
|
|
13
|
+
import { buildOptimisticLockHeader } from '@open-mercato/ui/backend/utils/optimisticLock'
|
|
13
14
|
import { buildCrudExportUrl, deleteCrud } from '@open-mercato/ui/backend/utils/crud'
|
|
14
15
|
import { flash } from '@open-mercato/ui/backend/FlashMessages'
|
|
15
16
|
import { useOrganizationScopeVersion } from '@open-mercato/shared/lib/frontend/useOrganizationScope'
|
|
@@ -76,6 +77,7 @@ type SalesDocumentRow = {
|
|
|
76
77
|
totalGross?: number | null
|
|
77
78
|
currency?: string | null
|
|
78
79
|
date?: string | null
|
|
80
|
+
updatedAt?: string | null
|
|
79
81
|
}
|
|
80
82
|
|
|
81
83
|
const PAGE_SIZE = 20
|
|
@@ -464,6 +466,7 @@ export function SalesDocumentsTable({ kind }: { kind: SalesDocumentKind }) {
|
|
|
464
466
|
totalGross,
|
|
465
467
|
currency: doc.currencyCode ?? null,
|
|
466
468
|
date,
|
|
469
|
+
updatedAt: doc.updatedAt ?? null,
|
|
467
470
|
}, item)
|
|
468
471
|
},
|
|
469
472
|
[kind]
|
|
@@ -540,9 +543,13 @@ export function SalesDocumentsTable({ kind }: { kind: SalesDocumentKind }) {
|
|
|
540
543
|
})
|
|
541
544
|
if (!confirmed) return
|
|
542
545
|
try {
|
|
543
|
-
const result = await
|
|
544
|
-
|
|
545
|
-
|
|
546
|
+
const result = await withScopedApiRequestHeaders(
|
|
547
|
+
buildOptimisticLockHeader(row.updatedAt),
|
|
548
|
+
() =>
|
|
549
|
+
deleteCrud(`sales/${resource}`, row.id, {
|
|
550
|
+
errorMessage: t('sales.documents.list.table.deleteError', 'Failed to delete document.'),
|
|
551
|
+
}),
|
|
552
|
+
)
|
|
546
553
|
if (result.ok) {
|
|
547
554
|
flash(
|
|
548
555
|
kind === 'order'
|
|
@@ -10,10 +10,12 @@ import { Label } from '@open-mercato/ui/primitives/label'
|
|
|
10
10
|
import { Switch } from '@open-mercato/ui/primitives/switch'
|
|
11
11
|
import { CrudForm, type CrudCustomFieldRenderProps, type CrudField, type CrudFormGroup } from '@open-mercato/ui/backend/CrudForm'
|
|
12
12
|
import { LookupSelect, type LookupSelectItem } from '@open-mercato/ui/backend/inputs'
|
|
13
|
-
import { apiCall } from '@open-mercato/ui/backend/utils/apiCall'
|
|
13
|
+
import { apiCall, withScopedApiRequestHeaders } from '@open-mercato/ui/backend/utils/apiCall'
|
|
14
|
+
import { buildOptimisticLockHeader } from '@open-mercato/ui/backend/utils/optimisticLock'
|
|
14
15
|
import { createCrud, updateCrud } from '@open-mercato/ui/backend/utils/crud'
|
|
15
16
|
import { collectCustomFieldValues } from '@open-mercato/ui/backend/utils/customFieldValues'
|
|
16
17
|
import { createCrudFormError } from '@open-mercato/ui/backend/utils/serverErrors'
|
|
18
|
+
import { handleSectionMutationError, rowOptimisticVersion } from './optimisticLock'
|
|
17
19
|
import { flash } from '@open-mercato/ui/backend/FlashMessages'
|
|
18
20
|
import { cn } from '@open-mercato/shared/lib/utils'
|
|
19
21
|
import { E } from '#generated/entities.ids.generated'
|
|
@@ -973,13 +975,25 @@ export function ShipmentDialog({
|
|
|
973
975
|
}
|
|
974
976
|
|
|
975
977
|
const action = shipment?.id ? updateCrud : createCrud
|
|
976
|
-
|
|
977
|
-
|
|
978
|
-
|
|
979
|
-
|
|
980
|
-
|
|
981
|
-
|
|
982
|
-
|
|
978
|
+
let result
|
|
979
|
+
try {
|
|
980
|
+
result = await withScopedApiRequestHeaders(
|
|
981
|
+
buildOptimisticLockHeader(shipment?.id ? rowOptimisticVersion(shipment) : undefined),
|
|
982
|
+
() =>
|
|
983
|
+
action(
|
|
984
|
+
'sales/shipments',
|
|
985
|
+
shipment?.id ? { id: shipment.id, ...payload } : payload,
|
|
986
|
+
{
|
|
987
|
+
errorMessage: t('sales.documents.shipments.errorSave', 'Failed to save shipment.'),
|
|
988
|
+
},
|
|
989
|
+
),
|
|
990
|
+
)
|
|
991
|
+
} catch (err) {
|
|
992
|
+
if (handleSectionMutationError(err, t, () => void onSaved())) {
|
|
993
|
+
return
|
|
994
|
+
}
|
|
995
|
+
throw err
|
|
996
|
+
}
|
|
983
997
|
if (result.ok) {
|
|
984
998
|
const shipmentId = ((result.result as any)?.id as string | undefined) ?? shipment?.id ?? null
|
|
985
999
|
const shouldAddShippingAdjustment =
|
|
@@ -1101,6 +1115,7 @@ export function ShipmentDialog({
|
|
|
1101
1115
|
orderId,
|
|
1102
1116
|
organizationId,
|
|
1103
1117
|
shipment?.id,
|
|
1118
|
+
shipment?.updatedAt,
|
|
1104
1119
|
addressOptions,
|
|
1105
1120
|
addressOptionsMap,
|
|
1106
1121
|
shippingMethods,
|
|
@@ -6,7 +6,8 @@ import { Button } from '@open-mercato/ui/primitives/button'
|
|
|
6
6
|
import { Badge } from '@open-mercato/ui/primitives/badge'
|
|
7
7
|
import { ErrorMessage, LoadingMessage, TabEmptyState } from '@open-mercato/ui/backend/detail'
|
|
8
8
|
import { flash } from '@open-mercato/ui/backend/FlashMessages'
|
|
9
|
-
import { apiCall } from '@open-mercato/ui/backend/utils/apiCall'
|
|
9
|
+
import { apiCall, withScopedApiRequestHeaders } from '@open-mercato/ui/backend/utils/apiCall'
|
|
10
|
+
import { buildOptimisticLockHeader } from '@open-mercato/ui/backend/utils/optimisticLock'
|
|
10
11
|
import { deleteCrud } from '@open-mercato/ui/backend/utils/crud'
|
|
11
12
|
import { useOrganizationScopeDetail } from '@open-mercato/shared/lib/frontend/useOrganizationScope'
|
|
12
13
|
import { useT } from '@open-mercato/shared/lib/i18n/context'
|
|
@@ -19,6 +20,7 @@ import type { SectionAction } from '@open-mercato/core/modules/customers/compone
|
|
|
19
20
|
import { generateTempId } from '@open-mercato/core/modules/customers/lib/detailHelpers'
|
|
20
21
|
import { formatAddressString, type AddressValue } from '@open-mercato/core/modules/customers/utils/addressFormat'
|
|
21
22
|
import { ShipmentDialog } from './ShipmentDialog'
|
|
23
|
+
import { handleSectionMutationError, readRowUpdatedAt, rowOptimisticVersion } from './optimisticLock'
|
|
22
24
|
import { extractCustomFieldValues } from './customFieldHelpers'
|
|
23
25
|
import type { OrderLine, ShipmentRow, ShipmentItem } from './shipmentTypes'
|
|
24
26
|
|
|
@@ -267,6 +269,7 @@ export function SalesShipmentsSection({
|
|
|
267
269
|
const customValues = extractCustomFieldValues(item as Record<string, unknown>)
|
|
268
270
|
return {
|
|
269
271
|
id,
|
|
272
|
+
updatedAt: readRowUpdatedAt(item),
|
|
270
273
|
shipmentNumber:
|
|
271
274
|
typeof (item as any).shipment_number === 'string'
|
|
272
275
|
? (item as any).shipment_number
|
|
@@ -397,20 +400,27 @@ export function SalesShipmentsSection({
|
|
|
397
400
|
})
|
|
398
401
|
if (!confirmed) return
|
|
399
402
|
try {
|
|
400
|
-
const result = await
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
403
|
+
const result = await withScopedApiRequestHeaders(
|
|
404
|
+
buildOptimisticLockHeader(rowOptimisticVersion(shipment)),
|
|
405
|
+
() =>
|
|
406
|
+
deleteCrud('sales/shipments', {
|
|
407
|
+
body: {
|
|
408
|
+
id: shipment.id,
|
|
409
|
+
orderId,
|
|
410
|
+
organizationId: resolvedOrganizationId,
|
|
411
|
+
tenantId: resolvedTenantId,
|
|
412
|
+
},
|
|
413
|
+
errorMessage: t('sales.documents.shipments.errorDelete', 'Failed to delete shipment.'),
|
|
414
|
+
})
|
|
415
|
+
)
|
|
409
416
|
if (result.ok) {
|
|
410
417
|
await loadShipments()
|
|
411
418
|
emitSalesDocumentTotalsRefresh({ documentId: orderId, kind: 'order' })
|
|
412
419
|
}
|
|
413
420
|
} catch (err) {
|
|
421
|
+
if (handleSectionMutationError(err, t, () => void loadShipments())) {
|
|
422
|
+
return
|
|
423
|
+
}
|
|
414
424
|
console.error('sales.shipments.delete', err)
|
|
415
425
|
flash(t('sales.documents.shipments.errorDelete', 'Failed to delete shipment.'), 'error')
|
|
416
426
|
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { surfaceRecordConflict } from '@open-mercato/ui/backend/conflicts'
|
|
2
|
+
|
|
3
|
+
type Translate = (key: string, fallback?: string) => string
|
|
4
|
+
|
|
5
|
+
export function rowOptimisticVersion(row: { updatedAt?: string | null } | null | undefined): string | undefined {
|
|
6
|
+
const value = row?.updatedAt
|
|
7
|
+
return typeof value === 'string' && value.length ? value : undefined
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Read a row's `updated_at` / `updatedAt` version from an untyped API record
|
|
12
|
+
* without `any`. Returns `null` when neither key holds a non-empty string.
|
|
13
|
+
*/
|
|
14
|
+
export function readRowUpdatedAt(source: unknown): string | null {
|
|
15
|
+
if (!source || typeof source !== 'object') return null
|
|
16
|
+
const record = source as Record<string, unknown>
|
|
17
|
+
const snake = record.updated_at
|
|
18
|
+
if (typeof snake === 'string' && snake.length) return snake
|
|
19
|
+
const camel = record.updatedAt
|
|
20
|
+
if (typeof camel === 'string' && camel.length) return camel
|
|
21
|
+
return null
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export function handleSectionMutationError(
|
|
25
|
+
err: unknown,
|
|
26
|
+
t: Translate,
|
|
27
|
+
refresh: () => void,
|
|
28
|
+
): boolean {
|
|
29
|
+
if (surfaceRecordConflict(err, t, { onRefresh: refresh })) {
|
|
30
|
+
refresh()
|
|
31
|
+
return true
|
|
32
|
+
}
|
|
33
|
+
return false
|
|
34
|
+
}
|
package/src/modules/sales/di.ts
CHANGED
|
@@ -2,6 +2,8 @@ import { asFunction, asValue } from 'awilix'
|
|
|
2
2
|
import type { EntityManager } from '@mikro-orm/postgresql'
|
|
3
3
|
import type { EventBus } from '@open-mercato/events'
|
|
4
4
|
import type { AppContainer } from '@open-mercato/shared/lib/di/container'
|
|
5
|
+
import type { OptimisticLockCurrentReader } from '@open-mercato/shared/lib/crud/optimistic-lock'
|
|
6
|
+
import { registerOptimisticLockReaders } from '@open-mercato/shared/lib/crud/optimistic-lock-store'
|
|
5
7
|
import { DefaultSalesCalculationService } from './services/salesCalculationService'
|
|
6
8
|
import { DefaultTaxCalculationService } from './services/taxCalculationService'
|
|
7
9
|
import { SalesDocumentNumberGenerator } from './services/salesDocumentNumberGenerator'
|
|
@@ -38,6 +40,34 @@ type AppCradle = AppContainer['cradle'] & {
|
|
|
38
40
|
eventBus?: EventBus | null
|
|
39
41
|
}
|
|
40
42
|
|
|
43
|
+
const RESOURCE_KIND_ORDER = 'sales.order'
|
|
44
|
+
|
|
45
|
+
const readSalesOrderUpdatedAt: OptimisticLockCurrentReader = async (
|
|
46
|
+
em: EntityManager,
|
|
47
|
+
{ resourceId, tenantId, organizationId },
|
|
48
|
+
) => {
|
|
49
|
+
const row = await em.findOne(
|
|
50
|
+
SalesOrder,
|
|
51
|
+
{
|
|
52
|
+
id: resourceId,
|
|
53
|
+
tenantId,
|
|
54
|
+
...(organizationId ? { organizationId } : {}),
|
|
55
|
+
deletedAt: null,
|
|
56
|
+
},
|
|
57
|
+
{ fields: ['updatedAt'] as const },
|
|
58
|
+
)
|
|
59
|
+
return row?.updatedAt instanceof Date ? row.updatedAt.toISOString() : null
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
// Hand-wired sales.order reader registered at module-load time so the
|
|
63
|
+
// `customer_entities`-style polymorphic-table override pattern stays
|
|
64
|
+
// observable for downstream modules. Functionally identical to the
|
|
65
|
+
// auto-registered generic reader; kept here as a reference example. The
|
|
66
|
+
// guard's mode check short-circuits when `OM_OPTIMISTIC_LOCK=off`.
|
|
67
|
+
registerOptimisticLockReaders({
|
|
68
|
+
[RESOURCE_KIND_ORDER]: readSalesOrderUpdatedAt,
|
|
69
|
+
})
|
|
70
|
+
|
|
41
71
|
export function register(container: AppContainer) {
|
|
42
72
|
container.register({
|
|
43
73
|
salesCalculationService: asFunction(({ eventBus }: AppCradle) => {
|
|
@@ -81,4 +111,9 @@ export function register(container: AppContainer) {
|
|
|
81
111
|
SalesPaymentMethod: asValue(SalesPaymentMethod),
|
|
82
112
|
SalesTaxRate: asValue(SalesTaxRate),
|
|
83
113
|
})
|
|
114
|
+
|
|
115
|
+
// `crudMutationGuardService` is registered platform-wide in the shared
|
|
116
|
+
// DI bootstrap (`packages/shared/src/lib/di/container.ts`). The
|
|
117
|
+
// hand-wired sales.order reader above already lives in the global store,
|
|
118
|
+
// so this module no longer needs its own DI binding.
|
|
84
119
|
}
|
|
@@ -15,6 +15,9 @@
|
|
|
15
15
|
"sales.audit.delivery-windows.create": "Create delivery window",
|
|
16
16
|
"sales.audit.delivery-windows.delete": "Delete delivery window",
|
|
17
17
|
"sales.audit.delivery-windows.update": "Update delivery window",
|
|
18
|
+
"sales.audit.document_addresses.create": "Dokumentadresse hinzufügen",
|
|
19
|
+
"sales.audit.document_addresses.delete": "Dokumentadresse entfernen",
|
|
20
|
+
"sales.audit.document_addresses.update": "Dokumentadresse aktualisieren",
|
|
18
21
|
"sales.audit.invoices.create": "Rechnung erstellen",
|
|
19
22
|
"sales.audit.invoices.delete": "Rechnung löschen",
|
|
20
23
|
"sales.audit.invoices.update": "Rechnung aktualisieren",
|
|
@@ -15,6 +15,9 @@
|
|
|
15
15
|
"sales.audit.delivery-windows.create": "Create delivery window",
|
|
16
16
|
"sales.audit.delivery-windows.delete": "Delete delivery window",
|
|
17
17
|
"sales.audit.delivery-windows.update": "Update delivery window",
|
|
18
|
+
"sales.audit.document_addresses.create": "Add document address",
|
|
19
|
+
"sales.audit.document_addresses.delete": "Remove document address",
|
|
20
|
+
"sales.audit.document_addresses.update": "Update document address",
|
|
18
21
|
"sales.audit.invoices.create": "Create invoice",
|
|
19
22
|
"sales.audit.invoices.delete": "Delete invoice",
|
|
20
23
|
"sales.audit.invoices.update": "Update invoice",
|
|
@@ -15,6 +15,9 @@
|
|
|
15
15
|
"sales.audit.delivery-windows.create": "Create delivery window",
|
|
16
16
|
"sales.audit.delivery-windows.delete": "Delete delivery window",
|
|
17
17
|
"sales.audit.delivery-windows.update": "Update delivery window",
|
|
18
|
+
"sales.audit.document_addresses.create": "Agregar dirección del documento",
|
|
19
|
+
"sales.audit.document_addresses.delete": "Eliminar dirección del documento",
|
|
20
|
+
"sales.audit.document_addresses.update": "Actualizar dirección del documento",
|
|
18
21
|
"sales.audit.invoices.create": "Crear factura",
|
|
19
22
|
"sales.audit.invoices.delete": "Eliminar factura",
|
|
20
23
|
"sales.audit.invoices.update": "Actualizar factura",
|
|
@@ -15,6 +15,9 @@
|
|
|
15
15
|
"sales.audit.delivery-windows.create": "Create delivery window",
|
|
16
16
|
"sales.audit.delivery-windows.delete": "Delete delivery window",
|
|
17
17
|
"sales.audit.delivery-windows.update": "Update delivery window",
|
|
18
|
+
"sales.audit.document_addresses.create": "Dodaj adres dokumentu",
|
|
19
|
+
"sales.audit.document_addresses.delete": "Usuń adres dokumentu",
|
|
20
|
+
"sales.audit.document_addresses.update": "Zaktualizuj adres dokumentu",
|
|
18
21
|
"sales.audit.invoices.create": "Utwórz fakturę",
|
|
19
22
|
"sales.audit.invoices.delete": "Usuń fakturę",
|
|
20
23
|
"sales.audit.invoices.update": "Zaktualizuj fakturę",
|
|
@@ -4,6 +4,7 @@ import { resolveTranslations } from '@open-mercato/shared/lib/i18n/server'
|
|
|
4
4
|
import { resolveCrudRecordId, parseScopedCommandInput } from '@open-mercato/shared/lib/api/scoped'
|
|
5
5
|
import { StaffTeamMemberJobHistory } from '../data/entities'
|
|
6
6
|
import {
|
|
7
|
+
optimisticUpdatedAtSchema,
|
|
7
8
|
staffTeamMemberJobHistoryCreateSchema,
|
|
8
9
|
staffTeamMemberJobHistoryUpdateSchema,
|
|
9
10
|
} from '../data/validators'
|
|
@@ -12,6 +13,11 @@ import { E } from '#generated/entities.ids.generated'
|
|
|
12
13
|
|
|
13
14
|
const rawBodySchema = z.object({}).passthrough()
|
|
14
15
|
|
|
16
|
+
const optimisticDeleteSchema = z.object({
|
|
17
|
+
id: z.string().uuid(),
|
|
18
|
+
updatedAt: optimisticUpdatedAtSchema.optional(),
|
|
19
|
+
})
|
|
20
|
+
|
|
15
21
|
const listSchema = z
|
|
16
22
|
.object({
|
|
17
23
|
page: z.coerce.number().min(1).default(1),
|
|
@@ -94,7 +100,11 @@ const crud = makeCrudRoute({
|
|
|
94
100
|
mapInput: async ({ parsed, ctx }) => {
|
|
95
101
|
const { translate } = await resolveTranslations()
|
|
96
102
|
const id = resolveCrudRecordId(parsed, ctx, translate)
|
|
97
|
-
|
|
103
|
+
const parsedBody = (parsed as { body?: Record<string, unknown> })?.body
|
|
104
|
+
return {
|
|
105
|
+
id,
|
|
106
|
+
updatedAt: typeof parsedBody?.updatedAt === 'string' ? parsedBody.updatedAt : undefined,
|
|
107
|
+
}
|
|
98
108
|
},
|
|
99
109
|
response: () => ({ ok: true }),
|
|
100
110
|
},
|
|
@@ -137,7 +147,7 @@ export const openApi = createStaffCrudOpenApi({
|
|
|
137
147
|
description: 'Updates a team member job history entry.',
|
|
138
148
|
},
|
|
139
149
|
del: {
|
|
140
|
-
schema:
|
|
150
|
+
schema: optimisticDeleteSchema,
|
|
141
151
|
responseSchema: defaultOkResponseSchema,
|
|
142
152
|
description: 'Deletes a team member job history entry.',
|
|
143
153
|
},
|
|
@@ -37,13 +37,25 @@ export const metadata = routeMetadata
|
|
|
37
37
|
|
|
38
38
|
const rawBodySchema = z.object({}).passthrough()
|
|
39
39
|
|
|
40
|
+
const isParseableDateFilter = (value: string): boolean => {
|
|
41
|
+
const trimmed = value.trim()
|
|
42
|
+
if (trimmed.length === 0) return true
|
|
43
|
+
if (!/^\d{4}-\d{2}-\d{2}([T ].*)?$/.test(trimmed)) return false
|
|
44
|
+
return !Number.isNaN(new Date(trimmed).getTime())
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
const dateFilterSchema = z
|
|
48
|
+
.string()
|
|
49
|
+
.refine(isParseableDateFilter, { message: 'Invalid date' })
|
|
50
|
+
.optional()
|
|
51
|
+
|
|
40
52
|
const listSchema = z
|
|
41
53
|
.object({
|
|
42
54
|
page: z.coerce.number().min(1).default(1),
|
|
43
55
|
pageSize: z.coerce.number().min(1).max(100).default(50),
|
|
44
56
|
staffMemberId: z.string().uuid().optional(),
|
|
45
|
-
from:
|
|
46
|
-
to:
|
|
57
|
+
from: dateFilterSchema,
|
|
58
|
+
to: dateFilterSchema,
|
|
47
59
|
projectId: z.string().uuid().optional(),
|
|
48
60
|
ids: z.string().optional(),
|
|
49
61
|
sortField: z.string().optional(),
|
|
@@ -102,10 +114,10 @@ const crud = makeCrudRoute({
|
|
|
102
114
|
if (typeof query.staffMemberId === 'string' && query.staffMemberId.length > 0) {
|
|
103
115
|
filters[F.staff_member_id] = query.staffMemberId
|
|
104
116
|
}
|
|
105
|
-
if (typeof query.from === 'string' && query.from.length > 0) {
|
|
117
|
+
if (typeof query.from === 'string' && query.from.length > 0 && isParseableDateFilter(query.from)) {
|
|
106
118
|
filters[F.date] = { ...((filters[F.date] as Record<string, unknown>) ?? {}), $gte: query.from }
|
|
107
119
|
}
|
|
108
|
-
if (typeof query.to === 'string' && query.to.length > 0) {
|
|
120
|
+
if (typeof query.to === 'string' && query.to.length > 0 && isParseableDateFilter(query.to)) {
|
|
109
121
|
filters[F.date] = { ...((filters[F.date] as Record<string, unknown>) ?? {}), $lte: query.to }
|
|
110
122
|
}
|
|
111
123
|
if (typeof query.projectId === 'string' && query.projectId.length > 0) {
|
|
@@ -8,7 +8,8 @@ import { Button } from '@open-mercato/ui/primitives/button'
|
|
|
8
8
|
import { Textarea } from '@open-mercato/ui/primitives/textarea'
|
|
9
9
|
import { LoadingMessage, ErrorMessage, RecordNotFoundState } from '@open-mercato/ui/backend/detail'
|
|
10
10
|
import { SendObjectMessageDialog } from '@open-mercato/ui/backend/messages'
|
|
11
|
-
import { apiCallOrThrow, readApiResultOrThrow } from '@open-mercato/ui/backend/utils/apiCall'
|
|
11
|
+
import { apiCallOrThrow, readApiResultOrThrow, withScopedApiRequestHeaders } from '@open-mercato/ui/backend/utils/apiCall'
|
|
12
|
+
import { buildOptimisticLockHeader } from '@open-mercato/ui/backend/utils/optimisticLock'
|
|
12
13
|
import { updateCrud } from '@open-mercato/ui/backend/utils/crud'
|
|
13
14
|
import { flash } from '@open-mercato/ui/backend/FlashMessages'
|
|
14
15
|
import { useT } from '@open-mercato/shared/lib/i18n/context'
|
|
@@ -89,6 +90,7 @@ export default function StaffLeaveRequestDetailPage({ params }: { params?: { id?
|
|
|
89
90
|
unavailabilityReasonEntryId: record?.unavailabilityReasonEntryId ?? null,
|
|
90
91
|
unavailabilityReasonValue: record?.unavailabilityReasonValue ?? null,
|
|
91
92
|
note: record?.note ?? null,
|
|
93
|
+
updatedAt: record?.updatedAt ?? null,
|
|
92
94
|
}), [record, memberLabel])
|
|
93
95
|
|
|
94
96
|
const handleSubmit = React.useCallback(async (values: LeaveRequestFormValues) => {
|
|
@@ -104,11 +106,14 @@ const handleSubmit = React.useCallback(async (values: LeaveRequestFormValues) =>
|
|
|
104
106
|
const handleDecision = React.useCallback(async (action: 'accept' | 'reject') => {
|
|
105
107
|
if (!record?.id) return
|
|
106
108
|
const endpoint = action === 'accept' ? '/api/staff/leave-requests/accept' : '/api/staff/leave-requests/reject'
|
|
107
|
-
await
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
109
|
+
await withScopedApiRequestHeaders(
|
|
110
|
+
buildOptimisticLockHeader(record.updatedAt),
|
|
111
|
+
() => apiCallOrThrow(endpoint, {
|
|
112
|
+
method: 'POST',
|
|
113
|
+
headers: { 'content-type': 'application/json' },
|
|
114
|
+
body: JSON.stringify({ id: record.id, decisionComment: decisionComment || null }),
|
|
115
|
+
}),
|
|
116
|
+
)
|
|
112
117
|
flash(
|
|
113
118
|
action === 'accept'
|
|
114
119
|
? t('staff.leaveRequests.messages.accepted', 'Leave request approved.')
|
|
@@ -116,7 +121,7 @@ const handleSubmit = React.useCallback(async (values: LeaveRequestFormValues) =>
|
|
|
116
121
|
'success',
|
|
117
122
|
)
|
|
118
123
|
router.refresh()
|
|
119
|
-
}, [decisionComment, record?.id, router, t])
|
|
124
|
+
}, [decisionComment, record?.id, record?.updatedAt, router, t])
|
|
120
125
|
|
|
121
126
|
if (isLoading) {
|
|
122
127
|
return (
|
|
@@ -74,6 +74,7 @@ export default function StaffMyLeaveRequestDetailPage({ params }: { params?: { i
|
|
|
74
74
|
|
|
75
75
|
const status = record?.status ?? 'pending'
|
|
76
76
|
const memberLabel = record?.member?.displayName ?? null
|
|
77
|
+
// optimistic-lock: LeaveRequestForm forwards optimisticLockUpdatedAt from initialValues.updatedAt (wrapper auto-derives the header on save).
|
|
77
78
|
const initialValues = React.useMemo<LeaveRequestFormValues>(() => ({
|
|
78
79
|
id: record?.id,
|
|
79
80
|
memberId: record?.memberId ?? null,
|
|
@@ -84,6 +85,7 @@ export default function StaffMyLeaveRequestDetailPage({ params }: { params?: { i
|
|
|
84
85
|
unavailabilityReasonEntryId: record?.unavailabilityReasonEntryId ?? null,
|
|
85
86
|
unavailabilityReasonValue: record?.unavailabilityReasonValue ?? null,
|
|
86
87
|
note: record?.note ?? null,
|
|
88
|
+
updatedAt: record?.updatedAt ?? null,
|
|
87
89
|
}), [record, memberLabel])
|
|
88
90
|
const dateSummary = formatDateRange(record?.startDate, record?.endDate)
|
|
89
91
|
const handleSubmit = React.useCallback(async (values: LeaveRequestFormValues) => {
|
|
@@ -5,9 +5,10 @@ import Link from 'next/link'
|
|
|
5
5
|
import { useRouter, useSearchParams } from 'next/navigation'
|
|
6
6
|
import { Page, PageBody } from '@open-mercato/ui/backend/Page'
|
|
7
7
|
import { Button } from '@open-mercato/ui/primitives/button'
|
|
8
|
-
import { readApiResultOrThrow } from '@open-mercato/ui/backend/utils/apiCall'
|
|
8
|
+
import { readApiResultOrThrow, withScopedApiRequestHeaders } from '@open-mercato/ui/backend/utils/apiCall'
|
|
9
9
|
import { extractCustomFieldEntries } from '@open-mercato/shared/lib/crud/custom-fields-client'
|
|
10
10
|
import { updateCrud, deleteCrud } from '@open-mercato/ui/backend/utils/crud'
|
|
11
|
+
import { buildOptimisticLockHeader } from '@open-mercato/ui/backend/utils/optimisticLock'
|
|
11
12
|
import { flash } from '@open-mercato/ui/backend/FlashMessages'
|
|
12
13
|
import { useT } from '@open-mercato/shared/lib/i18n/context'
|
|
13
14
|
import { createTranslatorWithFallback } from '@open-mercato/shared/lib/i18n/translate'
|
|
@@ -54,6 +55,8 @@ type TeamMemberRecord = {
|
|
|
54
55
|
is_active?: boolean
|
|
55
56
|
availabilityRuleSetId?: string | null
|
|
56
57
|
availability_rule_set_id?: string | null
|
|
58
|
+
updatedAt?: string | null
|
|
59
|
+
updated_at?: string | null
|
|
57
60
|
user?: { id?: string; email?: string | null } | null
|
|
58
61
|
team?: { id?: string; name?: string | null } | null
|
|
59
62
|
customFields?: Record<string, unknown> | null
|
|
@@ -226,6 +229,11 @@ export default function StaffTeamMemberDetailPage({ params }: { params?: { id?:
|
|
|
226
229
|
roleIds: normalizedRoleIds,
|
|
227
230
|
tags: normalizeStringList(record.tags),
|
|
228
231
|
isActive: record.isActive ?? record.is_active ?? true,
|
|
232
|
+
updatedAt: typeof record.updatedAt === 'string'
|
|
233
|
+
? record.updatedAt
|
|
234
|
+
: typeof record.updated_at === 'string'
|
|
235
|
+
? record.updated_at
|
|
236
|
+
: null,
|
|
229
237
|
...customFields,
|
|
230
238
|
})
|
|
231
239
|
setMemberRecord(record)
|
|
@@ -289,12 +297,15 @@ export default function StaffTeamMemberDetailPage({ params }: { params?: { id?:
|
|
|
289
297
|
|
|
290
298
|
const handleRulesetChange = React.useCallback(async (nextId: string | null) => {
|
|
291
299
|
if (!memberId) return
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
300
|
+
const headers = buildOptimisticLockHeader(initialValues?.updatedAt)
|
|
301
|
+
await withScopedApiRequestHeaders(headers, () => (
|
|
302
|
+
updateCrud('staff/team-members', { id: memberId, availabilityRuleSetId: nextId }, {
|
|
303
|
+
errorMessage: t('staff.teamMembers.availability.ruleset.updateError', 'Failed to update schedule.'),
|
|
304
|
+
})
|
|
305
|
+
))
|
|
295
306
|
setAvailabilityRuleSetId(nextId)
|
|
296
307
|
flash(t('staff.teamMembers.availability.ruleset.updateSuccess', 'Schedule updated.'), 'success')
|
|
297
|
-
}, [memberId, t])
|
|
308
|
+
}, [initialValues?.updatedAt, memberId, t])
|
|
298
309
|
|
|
299
310
|
const panelTabs = React.useMemo(() => ([
|
|
300
311
|
{ id: 'details' as const, label: t('staff.teamMembers.detail.tabs.details', 'Details') },
|
|
@@ -9,8 +9,9 @@ import { DataTable, withDataTableNamespaces } from '@open-mercato/ui/backend/Dat
|
|
|
9
9
|
import { RowActions } from '@open-mercato/ui/backend/RowActions'
|
|
10
10
|
import { Button } from '@open-mercato/ui/primitives/button'
|
|
11
11
|
import { BooleanIcon } from '@open-mercato/ui/backend/ValueIcons'
|
|
12
|
-
import { readApiResultOrThrow, apiCall } from '@open-mercato/ui/backend/utils/apiCall'
|
|
12
|
+
import { readApiResultOrThrow, apiCall, withScopedApiRequestHeaders } from '@open-mercato/ui/backend/utils/apiCall'
|
|
13
13
|
import { deleteCrud } from '@open-mercato/ui/backend/utils/crud'
|
|
14
|
+
import { buildOptimisticLockHeader } from '@open-mercato/ui/backend/utils/optimisticLock'
|
|
14
15
|
import { flash } from '@open-mercato/ui/backend/FlashMessages'
|
|
15
16
|
import { useConfirmDialog } from '@open-mercato/ui/backend/confirm-dialog'
|
|
16
17
|
import type { FilterDef, FilterValues } from '@open-mercato/ui/backend/FilterBar'
|
|
@@ -391,7 +392,10 @@ export default function StaffTeamMembersPage() {
|
|
|
391
392
|
})
|
|
392
393
|
if (!confirmed) return
|
|
393
394
|
try {
|
|
394
|
-
|
|
395
|
+
const headers = buildOptimisticLockHeader(entry.updatedAt)
|
|
396
|
+
await withScopedApiRequestHeaders(headers, () => (
|
|
397
|
+
deleteCrud('staff/team-members', entry.id, { errorMessage: labels.errors.delete })
|
|
398
|
+
))
|
|
395
399
|
flash(labels.messages.deleted, 'success')
|
|
396
400
|
handleRefresh()
|
|
397
401
|
} catch (error) {
|
|
@@ -23,6 +23,8 @@ type TeamRoleRecord = {
|
|
|
23
23
|
appearanceColor?: string | null
|
|
24
24
|
appearance_icon?: string | null
|
|
25
25
|
appearance_color?: string | null
|
|
26
|
+
updatedAt?: string | null
|
|
27
|
+
updated_at?: string | null
|
|
26
28
|
} & Record<string, unknown>
|
|
27
29
|
|
|
28
30
|
type TeamRoleResponse = {
|
|
@@ -38,6 +40,7 @@ export default function StaffTeamRoleEditPage({ params }: { params?: { id?: stri
|
|
|
38
40
|
const t = useT()
|
|
39
41
|
const router = useRouter()
|
|
40
42
|
const scopeVersion = useOrganizationScopeVersion()
|
|
43
|
+
// optimistic-lock: TeamRoleForm forwards optimisticLockUpdatedAt from initialValues.updatedAt (wrapper auto-derives the header on save + delete).
|
|
41
44
|
const [initialValues, setInitialValues] = React.useState<TeamRoleFormValues | null>(null)
|
|
42
45
|
const [error, setError] = React.useState<string | null>(null)
|
|
43
46
|
const [isNotFound, setIsNotFound] = React.useState(false)
|
|
@@ -86,6 +89,11 @@ export default function StaffTeamRoleEditPage({ params }: { params?: { id?: stri
|
|
|
86
89
|
name: record.name ?? '',
|
|
87
90
|
description: record.description ?? '',
|
|
88
91
|
appearance: { icon: appearanceIcon, color: appearanceColor },
|
|
92
|
+
updatedAt: typeof record.updatedAt === 'string'
|
|
93
|
+
? record.updatedAt
|
|
94
|
+
: typeof record.updated_at === 'string'
|
|
95
|
+
? record.updated_at
|
|
96
|
+
: null,
|
|
89
97
|
...customFields,
|
|
90
98
|
})
|
|
91
99
|
}
|
|
@@ -9,8 +9,9 @@ import { DataTable, withDataTableNamespaces } from '@open-mercato/ui/backend/Dat
|
|
|
9
9
|
import { RowActions } from '@open-mercato/ui/backend/RowActions'
|
|
10
10
|
import { MarkdownPreview } from '@open-mercato/ui/backend/markdown/MarkdownContent'
|
|
11
11
|
import { Button } from '@open-mercato/ui/primitives/button'
|
|
12
|
-
import { readApiResultOrThrow, apiCall } from '@open-mercato/ui/backend/utils/apiCall'
|
|
12
|
+
import { readApiResultOrThrow, apiCall, withScopedApiRequestHeaders } from '@open-mercato/ui/backend/utils/apiCall'
|
|
13
13
|
import { deleteCrud } from '@open-mercato/ui/backend/utils/crud'
|
|
14
|
+
import { buildOptimisticLockHeader } from '@open-mercato/ui/backend/utils/optimisticLock'
|
|
14
15
|
import { flash } from '@open-mercato/ui/backend/FlashMessages'
|
|
15
16
|
import { useConfirmDialog } from '@open-mercato/ui/backend/confirm-dialog'
|
|
16
17
|
import { Pencil, Users } from 'lucide-react'
|
|
@@ -277,7 +278,10 @@ export default function StaffTeamRolesPage() {
|
|
|
277
278
|
})
|
|
278
279
|
if (!confirmed) return
|
|
279
280
|
try {
|
|
280
|
-
|
|
281
|
+
const headers = buildOptimisticLockHeader(entry.updatedAt)
|
|
282
|
+
await withScopedApiRequestHeaders(headers, () => (
|
|
283
|
+
deleteCrud('staff/team-roles', entry.id, { errorMessage: labels.errors.delete })
|
|
284
|
+
))
|
|
281
285
|
flash(labels.messages.deleted, 'success')
|
|
282
286
|
handleRefresh()
|
|
283
287
|
} catch (error) {
|