@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.
Files changed (644) hide show
  1. package/.turbo/turbo-build.log +1 -1
  2. package/AGENTS.md +5 -0
  3. package/dist/generated/entities/role/index.js +3 -1
  4. package/dist/generated/entities/role/index.js.map +2 -2
  5. package/dist/generated/entities/user/index.js +3 -1
  6. package/dist/generated/entities/user/index.js.map +2 -2
  7. package/dist/generated/entity-fields-registry.js +2 -0
  8. package/dist/generated/entity-fields-registry.js.map +2 -2
  9. package/dist/helpers/integration/communicationChannelsFixtures.js.map +2 -2
  10. package/dist/helpers/integration/dbFixtures.js +2 -1
  11. package/dist/helpers/integration/dbFixtures.js.map +2 -2
  12. package/dist/helpers/integration/optimisticLockUi.js +104 -0
  13. package/dist/helpers/integration/optimisticLockUi.js.map +7 -0
  14. package/dist/helpers/integration/salesFixtures.js +17 -0
  15. package/dist/helpers/integration/salesFixtures.js.map +2 -2
  16. package/dist/modules/api_keys/backend/api-keys/page.js +9 -5
  17. package/dist/modules/api_keys/backend/api-keys/page.js.map +2 -2
  18. package/dist/modules/attachments/components/AttachmentPartitionSettings.js +17 -9
  19. package/dist/modules/attachments/components/AttachmentPartitionSettings.js.map +2 -2
  20. package/dist/modules/auth/api/roles/acl/route.js +32 -13
  21. package/dist/modules/auth/api/roles/acl/route.js.map +2 -2
  22. package/dist/modules/auth/api/roles/route.js +3 -1
  23. package/dist/modules/auth/api/roles/route.js.map +2 -2
  24. package/dist/modules/auth/api/sidebar/preferences/route.js +71 -3
  25. package/dist/modules/auth/api/sidebar/preferences/route.js.map +2 -2
  26. package/dist/modules/auth/api/users/acl/route.js +42 -19
  27. package/dist/modules/auth/api/users/acl/route.js.map +2 -2
  28. package/dist/modules/auth/api/users/route.js +3 -1
  29. package/dist/modules/auth/api/users/route.js.map +2 -2
  30. package/dist/modules/auth/backend/roles/[id]/edit/page.js +24 -4
  31. package/dist/modules/auth/backend/roles/[id]/edit/page.js.map +2 -2
  32. package/dist/modules/auth/backend/roles/page.js +8 -4
  33. package/dist/modules/auth/backend/roles/page.js.map +2 -2
  34. package/dist/modules/auth/backend/users/[id]/edit/page.js +27 -5
  35. package/dist/modules/auth/backend/users/[id]/edit/page.js.map +2 -2
  36. package/dist/modules/auth/backend/users/page.js +6 -2
  37. package/dist/modules/auth/backend/users/page.js.map +2 -2
  38. package/dist/modules/auth/components/AclEditor.js +3 -1
  39. package/dist/modules/auth/components/AclEditor.js.map +2 -2
  40. package/dist/modules/auth/data/entities.js +6 -0
  41. package/dist/modules/auth/data/entities.js.map +2 -2
  42. package/dist/modules/auth/services/sidebarPreferencesService.js +32 -4
  43. package/dist/modules/auth/services/sidebarPreferencesService.js.map +2 -2
  44. package/dist/modules/business_rules/api/rules/route.js +28 -0
  45. package/dist/modules/business_rules/api/rules/route.js.map +2 -2
  46. package/dist/modules/business_rules/api/sets/route.js +28 -0
  47. package/dist/modules/business_rules/api/sets/route.js.map +2 -2
  48. package/dist/modules/business_rules/backend/rules/[id]/page.js +11 -4
  49. package/dist/modules/business_rules/backend/rules/[id]/page.js.map +3 -3
  50. package/dist/modules/business_rules/backend/rules/page.js +20 -11
  51. package/dist/modules/business_rules/backend/rules/page.js.map +2 -2
  52. package/dist/modules/business_rules/backend/sets/[id]/page.js +11 -4
  53. package/dist/modules/business_rules/backend/sets/[id]/page.js.map +2 -2
  54. package/dist/modules/business_rules/backend/sets/page.js +20 -11
  55. package/dist/modules/business_rules/backend/sets/page.js.map +2 -2
  56. package/dist/modules/catalog/api/categories/route.js +2 -0
  57. package/dist/modules/catalog/api/categories/route.js.map +2 -2
  58. package/dist/modules/catalog/api/products/route.js +2 -1
  59. package/dist/modules/catalog/api/products/route.js.map +2 -2
  60. package/dist/modules/catalog/backend/catalog/categories/[id]/edit/page.js +2 -0
  61. package/dist/modules/catalog/backend/catalog/categories/[id]/edit/page.js.map +2 -2
  62. package/dist/modules/catalog/backend/catalog/products/[id]/page.js +94 -40
  63. package/dist/modules/catalog/backend/catalog/products/[id]/page.js.map +2 -2
  64. package/dist/modules/catalog/backend/catalog/products/[productId]/variants/[variantId]/page.js +37 -8
  65. package/dist/modules/catalog/backend/catalog/products/[productId]/variants/[variantId]/page.js.map +2 -2
  66. package/dist/modules/catalog/backend/catalog/products/optionSchemaClient.js.map +2 -2
  67. package/dist/modules/catalog/commands/variants.js +32 -31
  68. package/dist/modules/catalog/commands/variants.js.map +2 -2
  69. package/dist/modules/catalog/components/PriceKindSettings.js +12 -5
  70. package/dist/modules/catalog/components/PriceKindSettings.js.map +2 -2
  71. package/dist/modules/catalog/components/categories/CategoriesDataTable.js.map +2 -2
  72. package/dist/modules/catalog/components/products/ProductMediaManager.js.map +2 -2
  73. package/dist/modules/catalog/components/products/ProductsDataTable.js +5 -3
  74. package/dist/modules/catalog/components/products/ProductsDataTable.js.map +2 -2
  75. package/dist/modules/catalog/components/products/productForm.js.map +2 -2
  76. package/dist/modules/catalog/components/products/variantForm.js +2 -1
  77. package/dist/modules/catalog/components/products/variantForm.js.map +2 -2
  78. package/dist/modules/communication_channels/api/post/test-seed/route.js +23 -2
  79. package/dist/modules/communication_channels/api/post/test-seed/route.js.map +2 -2
  80. package/dist/modules/communication_channels/backend/profile/communication-channels/page.js +5 -0
  81. package/dist/modules/communication_channels/backend/profile/communication-channels/page.js.map +2 -2
  82. package/dist/modules/communication_channels/commands/set-primary-channel.js +2 -1
  83. package/dist/modules/communication_channels/commands/set-primary-channel.js.map +2 -2
  84. package/dist/modules/currencies/backend/currencies/[id]/page.js +6 -3
  85. package/dist/modules/currencies/backend/currencies/[id]/page.js.map +2 -2
  86. package/dist/modules/currencies/backend/currencies/page.js +18 -11
  87. package/dist/modules/currencies/backend/currencies/page.js.map +2 -2
  88. package/dist/modules/currencies/backend/exchange-rates/[id]/page.js +1 -0
  89. package/dist/modules/currencies/backend/exchange-rates/[id]/page.js.map +2 -2
  90. package/dist/modules/currencies/backend/exchange-rates/page.js +10 -6
  91. package/dist/modules/currencies/backend/exchange-rates/page.js.map +2 -2
  92. package/dist/modules/currencies/commands/currencies.js +7 -5
  93. package/dist/modules/currencies/commands/currencies.js.map +2 -2
  94. package/dist/modules/currencies/components/CurrencyFetchingConfig.js +26 -19
  95. package/dist/modules/currencies/components/CurrencyFetchingConfig.js.map +2 -2
  96. package/dist/modules/customer_accounts/api/admin/roles/[id].js +28 -5
  97. package/dist/modules/customer_accounts/api/admin/roles/[id].js.map +2 -2
  98. package/dist/modules/customer_accounts/api/admin/roles.js +4 -2
  99. package/dist/modules/customer_accounts/api/admin/roles.js.map +2 -2
  100. package/dist/modules/customer_accounts/api/admin/users/[id].js +28 -5
  101. package/dist/modules/customer_accounts/api/admin/users/[id].js.map +2 -2
  102. package/dist/modules/customer_accounts/api/admin/users.js +2 -0
  103. package/dist/modules/customer_accounts/api/admin/users.js.map +2 -2
  104. package/dist/modules/customer_accounts/backend/customer_accounts/roles/[id]/page.js +16 -8
  105. package/dist/modules/customer_accounts/backend/customer_accounts/roles/[id]/page.js.map +2 -2
  106. package/dist/modules/customer_accounts/backend/customer_accounts/roles/page.js +8 -4
  107. package/dist/modules/customer_accounts/backend/customer_accounts/roles/page.js.map +2 -2
  108. package/dist/modules/customer_accounts/backend/customer_accounts/settings/domain/page.js +8 -4
  109. package/dist/modules/customer_accounts/backend/customer_accounts/settings/domain/page.js.map +2 -2
  110. package/dist/modules/customer_accounts/backend/customer_accounts/users/[id]/page.js +29 -18
  111. package/dist/modules/customer_accounts/backend/customer_accounts/users/[id]/page.js.map +2 -2
  112. package/dist/modules/customer_accounts/backend/customer_accounts/users/page.js +18 -11
  113. package/dist/modules/customer_accounts/backend/customer_accounts/users/page.js.map +2 -2
  114. package/dist/modules/customers/api/companies/route.js +13 -2
  115. package/dist/modules/customers/api/companies/route.js.map +2 -2
  116. package/dist/modules/customers/api/deals/route.js +2 -0
  117. package/dist/modules/customers/api/deals/route.js.map +2 -2
  118. package/dist/modules/customers/api/people/route.js +11 -2
  119. package/dist/modules/customers/api/people/route.js.map +2 -2
  120. package/dist/modules/customers/api/todos/route.js +1 -0
  121. package/dist/modules/customers/api/todos/route.js.map +2 -2
  122. package/dist/modules/customers/backend/config/customers/deals/page.js.map +2 -2
  123. package/dist/modules/customers/backend/config/customers/pipeline-stages/page.js +34 -21
  124. package/dist/modules/customers/backend/config/customers/pipeline-stages/page.js.map +2 -2
  125. package/dist/modules/customers/backend/customers/companies/[id]/page.js +45 -27
  126. package/dist/modules/customers/backend/customers/companies/[id]/page.js.map +2 -2
  127. package/dist/modules/customers/backend/customers/companies/page.js.map +2 -2
  128. package/dist/modules/customers/backend/customers/companies-v2/[id]/page.js +22 -5
  129. package/dist/modules/customers/backend/customers/companies-v2/[id]/page.js.map +2 -2
  130. package/dist/modules/customers/backend/customers/deals/[id]/hooks/useDealFormHandlers.js +30 -8
  131. package/dist/modules/customers/backend/customers/deals/[id]/hooks/useDealFormHandlers.js.map +2 -2
  132. package/dist/modules/customers/backend/customers/deals/[id]/page.js +1 -0
  133. package/dist/modules/customers/backend/customers/deals/[id]/page.js.map +2 -2
  134. package/dist/modules/customers/backend/customers/deals/page.js +16 -6
  135. package/dist/modules/customers/backend/customers/deals/page.js.map +2 -2
  136. package/dist/modules/customers/backend/customers/deals/pipeline/page.js +62 -39
  137. package/dist/modules/customers/backend/customers/deals/pipeline/page.js.map +2 -2
  138. package/dist/modules/customers/backend/customers/people/[id]/page.js +41 -26
  139. package/dist/modules/customers/backend/customers/people/[id]/page.js.map +2 -2
  140. package/dist/modules/customers/backend/customers/people/page.js.map +2 -2
  141. package/dist/modules/customers/backend/customers/people-v2/[id]/page.js +50 -23
  142. package/dist/modules/customers/backend/customers/people-v2/[id]/page.js.map +2 -2
  143. package/dist/modules/customers/commands/addresses.js +16 -14
  144. package/dist/modules/customers/commands/addresses.js.map +2 -2
  145. package/dist/modules/customers/commands/companies.js +1 -1
  146. package/dist/modules/customers/commands/companies.js.map +2 -2
  147. package/dist/modules/customers/commands/interactions.js +41 -4
  148. package/dist/modules/customers/commands/interactions.js.map +2 -2
  149. package/dist/modules/customers/commands/people.js +1 -1
  150. package/dist/modules/customers/commands/people.js.map +2 -2
  151. package/dist/modules/customers/commands/personCompanyLinks.js +8 -5
  152. package/dist/modules/customers/commands/personCompanyLinks.js.map +2 -2
  153. package/dist/modules/customers/commands/pipeline-stages.js +13 -11
  154. package/dist/modules/customers/commands/pipeline-stages.js.map +3 -3
  155. package/dist/modules/customers/components/AddressFormatSettings.js.map +2 -2
  156. package/dist/modules/customers/components/DictionarySettings.js +20 -13
  157. package/dist/modules/customers/components/DictionarySettings.js.map +2 -2
  158. package/dist/modules/customers/components/DictionarySortSettings.js +4 -0
  159. package/dist/modules/customers/components/DictionarySortSettings.js.map +2 -2
  160. package/dist/modules/customers/components/PipelineSettings.js +38 -23
  161. package/dist/modules/customers/components/PipelineSettings.js.map +2 -2
  162. package/dist/modules/customers/components/detail/ActivityTimeline.js +1 -1
  163. package/dist/modules/customers/components/detail/ActivityTimeline.js.map +2 -2
  164. package/dist/modules/customers/components/detail/AddressesSection.js +4 -0
  165. package/dist/modules/customers/components/detail/AddressesSection.js.map +2 -2
  166. package/dist/modules/customers/components/detail/CompanyPeopleSection.js +28 -22
  167. package/dist/modules/customers/components/detail/CompanyPeopleSection.js.map +2 -2
  168. package/dist/modules/customers/components/detail/DealsSection.js +36 -24
  169. package/dist/modules/customers/components/detail/DealsSection.js.map +2 -2
  170. package/dist/modules/customers/components/detail/EmailCardActions.js +5 -0
  171. package/dist/modules/customers/components/detail/EmailCardActions.js.map +2 -2
  172. package/dist/modules/customers/components/detail/EntityTagsDialog.js +7 -0
  173. package/dist/modules/customers/components/detail/EntityTagsDialog.js.map +2 -2
  174. package/dist/modules/customers/components/detail/ManageTagsDialog.js +34 -22
  175. package/dist/modules/customers/components/detail/ManageTagsDialog.js.map +2 -2
  176. package/dist/modules/customers/components/detail/PersonCompaniesSection.js +41 -29
  177. package/dist/modules/customers/components/detail/PersonCompaniesSection.js.map +2 -2
  178. package/dist/modules/customers/components/detail/RoleAssignmentRow.js +14 -8
  179. package/dist/modules/customers/components/detail/RoleAssignmentRow.js.map +2 -2
  180. package/dist/modules/customers/components/detail/ScheduleActivityDialog.js +14 -6
  181. package/dist/modules/customers/components/detail/ScheduleActivityDialog.js.map +2 -2
  182. package/dist/modules/customers/components/detail/hooks/useInteractionMutations.js +29 -13
  183. package/dist/modules/customers/components/detail/hooks/useInteractionMutations.js.map +2 -2
  184. package/dist/modules/customers/components/detail/hooks/useInteractions.js +77 -35
  185. package/dist/modules/customers/components/detail/hooks/useInteractions.js.map +2 -2
  186. package/dist/modules/customers/components/detail/hooks/usePersonTasks.js +25 -17
  187. package/dist/modules/customers/components/detail/hooks/usePersonTasks.js.map +2 -2
  188. package/dist/modules/customers/components/detail/schedule/useScheduleFormState.js.map +2 -2
  189. package/dist/modules/customers/components/formConfig.js.map +2 -2
  190. package/dist/modules/customers/data/guards.js +66 -0
  191. package/dist/modules/customers/data/guards.js.map +7 -0
  192. package/dist/modules/customers/di.js +37 -0
  193. package/dist/modules/customers/di.js.map +2 -2
  194. package/dist/modules/customers/lib/todoCompatibility.js +11 -0
  195. package/dist/modules/customers/lib/todoCompatibility.js.map +2 -2
  196. package/dist/modules/dashboards/components/WidgetVisibilityEditor.js.map +2 -2
  197. package/dist/modules/data_sync/api/options.js +4 -4
  198. package/dist/modules/data_sync/api/options.js.map +2 -2
  199. package/dist/modules/data_sync/api/schedules/route.js +9 -1
  200. package/dist/modules/data_sync/api/schedules/route.js.map +2 -2
  201. package/dist/modules/data_sync/backend/data-sync/page.js +17 -8
  202. package/dist/modules/data_sync/backend/data-sync/page.js.map +2 -2
  203. package/dist/modules/data_sync/components/IntegrationScheduleTab.js +43 -22
  204. package/dist/modules/data_sync/components/IntegrationScheduleTab.js.map +2 -2
  205. package/dist/modules/data_sync/lib/sync-schedule-service.js +9 -0
  206. package/dist/modules/data_sync/lib/sync-schedule-service.js.map +2 -2
  207. package/dist/modules/dictionaries/api/[dictionaryId]/entries/[entryId]/route.js +8 -1
  208. package/dist/modules/dictionaries/api/[dictionaryId]/entries/[entryId]/route.js.map +2 -2
  209. package/dist/modules/dictionaries/api/[dictionaryId]/route.js +17 -1
  210. package/dist/modules/dictionaries/api/[dictionaryId]/route.js.map +2 -2
  211. package/dist/modules/dictionaries/components/DictionariesManager.js +31 -10
  212. package/dist/modules/dictionaries/components/DictionariesManager.js.map +2 -2
  213. package/dist/modules/dictionaries/components/DictionaryEntriesEditor.js +28 -15
  214. package/dist/modules/dictionaries/components/DictionaryEntriesEditor.js.map +2 -2
  215. package/dist/modules/directory/api/organizations/route.js +3 -0
  216. package/dist/modules/directory/api/organizations/route.js.map +2 -2
  217. package/dist/modules/directory/backend/directory/organizations/[id]/edit/page.js +2 -0
  218. package/dist/modules/directory/backend/directory/organizations/[id]/edit/page.js.map +2 -2
  219. package/dist/modules/directory/backend/directory/organizations/page.js +9 -5
  220. package/dist/modules/directory/backend/directory/organizations/page.js.map +2 -2
  221. package/dist/modules/directory/backend/directory/tenants/[id]/edit/page.js +7 -3
  222. package/dist/modules/directory/backend/directory/tenants/[id]/edit/page.js.map +2 -2
  223. package/dist/modules/directory/backend/directory/tenants/page.js +8 -4
  224. package/dist/modules/directory/backend/directory/tenants/page.js.map +2 -2
  225. package/dist/modules/directory/commands/organizations.js +7 -2
  226. package/dist/modules/directory/commands/organizations.js.map +2 -2
  227. package/dist/modules/entities/api/records.js +66 -0
  228. package/dist/modules/entities/api/records.js.map +2 -2
  229. package/dist/modules/entities/backend/entities/user/[entityId]/records/[recordId]/page.js +1 -0
  230. package/dist/modules/entities/backend/entities/user/[entityId]/records/[recordId]/page.js.map +2 -2
  231. package/dist/modules/entities/backend/entities/user/[entityId]/records/page.js +8 -4
  232. package/dist/modules/entities/backend/entities/user/[entityId]/records/page.js.map +2 -2
  233. package/dist/modules/entities/lib/helpers.js +17 -0
  234. package/dist/modules/entities/lib/helpers.js.map +2 -2
  235. package/dist/modules/feature_toggles/api/global/[id]/override/route.js +2 -1
  236. package/dist/modules/feature_toggles/api/global/[id]/override/route.js.map +2 -2
  237. package/dist/modules/feature_toggles/api/overrides/route.js +15 -0
  238. package/dist/modules/feature_toggles/api/overrides/route.js.map +2 -2
  239. package/dist/modules/feature_toggles/backend/feature-toggles/global/[id]/edit/page.js +15 -14
  240. package/dist/modules/feature_toggles/backend/feature-toggles/global/[id]/edit/page.js.map +2 -2
  241. package/dist/modules/feature_toggles/components/FeatureToggleOverrideCard.js +20 -12
  242. package/dist/modules/feature_toggles/components/FeatureToggleOverrideCard.js.map +2 -2
  243. package/dist/modules/feature_toggles/components/FeatureTogglesTable.js +6 -2
  244. package/dist/modules/feature_toggles/components/FeatureTogglesTable.js.map +2 -2
  245. package/dist/modules/feature_toggles/components/formConfig.js +2 -1
  246. package/dist/modules/feature_toggles/components/formConfig.js.map +2 -2
  247. package/dist/modules/feature_toggles/components/overrideFormConfig.js +5 -1
  248. package/dist/modules/feature_toggles/components/overrideFormConfig.js.map +2 -2
  249. package/dist/modules/feature_toggles/data/validators.js +7 -4
  250. package/dist/modules/feature_toggles/data/validators.js.map +2 -2
  251. package/dist/modules/inbox_ops/api/settings/route.js +17 -2
  252. package/dist/modules/inbox_ops/api/settings/route.js.map +2 -2
  253. package/dist/modules/inbox_ops/backend/inbox-ops/settings/page.js +13 -8
  254. package/dist/modules/inbox_ops/backend/inbox-ops/settings/page.js.map +2 -2
  255. package/dist/modules/inbox_ops/components/proposals/EditActionDialog.js +9 -4
  256. package/dist/modules/inbox_ops/components/proposals/EditActionDialog.js.map +2 -2
  257. package/dist/modules/integrations/backend/integrations/bundle/[id]/page.js +18 -11
  258. package/dist/modules/integrations/backend/integrations/bundle/[id]/page.js.map +2 -2
  259. package/dist/modules/integrations/backend/integrations/page.js +12 -8
  260. package/dist/modules/integrations/backend/integrations/page.js.map +2 -2
  261. package/dist/modules/messages/commands/messages.js +13 -10
  262. package/dist/modules/messages/commands/messages.js.map +2 -2
  263. package/dist/modules/perspectives/api/[tableId]/route.js +39 -30
  264. package/dist/modules/perspectives/api/[tableId]/route.js.map +2 -2
  265. package/dist/modules/perspectives/services/perspectiveService.js +7 -0
  266. package/dist/modules/perspectives/services/perspectiveService.js.map +2 -2
  267. package/dist/modules/planner/backend/planner/availability-rulesets/[id]/page.js +6 -14
  268. package/dist/modules/planner/backend/planner/availability-rulesets/[id]/page.js.map +3 -3
  269. package/dist/modules/planner/backend/planner/availability-rulesets/page.js +4 -2
  270. package/dist/modules/planner/backend/planner/availability-rulesets/page.js.map +2 -2
  271. package/dist/modules/planner/components/AvailabilityRuleSetForm.js +2 -0
  272. package/dist/modules/planner/components/AvailabilityRuleSetForm.js.map +2 -2
  273. package/dist/modules/planner/components/AvailabilityRulesEditor.js +36 -11
  274. package/dist/modules/planner/components/AvailabilityRulesEditor.js.map +2 -2
  275. package/dist/modules/planner/components/AvailabilitySchedule.js +9 -5
  276. package/dist/modules/planner/components/AvailabilitySchedule.js.map +2 -2
  277. package/dist/modules/query_index/lib/engine.js +19 -0
  278. package/dist/modules/query_index/lib/engine.js.map +2 -2
  279. package/dist/modules/resources/backend/resources/resource-types/[id]/edit/page.js +1 -0
  280. package/dist/modules/resources/backend/resources/resource-types/[id]/edit/page.js.map +2 -2
  281. package/dist/modules/resources/backend/resources/resource-types/page.js +4 -2
  282. package/dist/modules/resources/backend/resources/resource-types/page.js.map +2 -2
  283. package/dist/modules/resources/backend/resources/resources/[id]/page.js +14 -3
  284. package/dist/modules/resources/backend/resources/resources/[id]/page.js.map +2 -2
  285. package/dist/modules/resources/backend/resources/resources/page.js +8 -4
  286. package/dist/modules/resources/backend/resources/resources/page.js.map +2 -2
  287. package/dist/modules/resources/components/ResourceCrudForm.js +2 -0
  288. package/dist/modules/resources/components/ResourceCrudForm.js.map +2 -2
  289. package/dist/modules/resources/components/ResourceTypeCrudForm.js +1 -0
  290. package/dist/modules/resources/components/ResourceTypeCrudForm.js.map +2 -2
  291. package/dist/modules/sales/api/documents/factory.js +7 -2
  292. package/dist/modules/sales/api/documents/factory.js.map +2 -2
  293. package/dist/modules/sales/backend/sales/channels/[channelId]/edit/page.js +3 -1
  294. package/dist/modules/sales/backend/sales/channels/[channelId]/edit/page.js.map +2 -2
  295. package/dist/modules/sales/backend/sales/channels/offers/page.js +13 -4
  296. package/dist/modules/sales/backend/sales/channels/offers/page.js.map +2 -2
  297. package/dist/modules/sales/backend/sales/channels/page.js +16 -4
  298. package/dist/modules/sales/backend/sales/channels/page.js.map +2 -2
  299. package/dist/modules/sales/backend/sales/documents/[id]/page.js +68 -22
  300. package/dist/modules/sales/backend/sales/documents/[id]/page.js.map +2 -2
  301. package/dist/modules/sales/backend/sales/documents/create/page.js.map +2 -2
  302. package/dist/modules/sales/commands/documentAddresses.js +181 -2
  303. package/dist/modules/sales/commands/documentAddresses.js.map +2 -2
  304. package/dist/modules/sales/commands/documents.js +29 -1
  305. package/dist/modules/sales/commands/documents.js.map +2 -2
  306. package/dist/modules/sales/commands/returns.js +12 -2
  307. package/dist/modules/sales/commands/returns.js.map +2 -2
  308. package/dist/modules/sales/commands/shared.js +15 -0
  309. package/dist/modules/sales/commands/shared.js.map +2 -2
  310. package/dist/modules/sales/commands/shipments.js +4 -1
  311. package/dist/modules/sales/commands/shipments.js.map +2 -2
  312. package/dist/modules/sales/components/AdjustmentKindSettings.js +19 -11
  313. package/dist/modules/sales/components/AdjustmentKindSettings.js.map +2 -2
  314. package/dist/modules/sales/components/DocumentNumberSettings.js.map +2 -2
  315. package/dist/modules/sales/components/OrderEditingSettings.js.map +2 -2
  316. package/dist/modules/sales/components/PaymentMethodsSettings.js +12 -4
  317. package/dist/modules/sales/components/PaymentMethodsSettings.js.map +2 -2
  318. package/dist/modules/sales/components/ShippingMethodsSettings.js +12 -4
  319. package/dist/modules/sales/components/ShippingMethodsSettings.js.map +2 -2
  320. package/dist/modules/sales/components/StatusSettings.js +18 -11
  321. package/dist/modules/sales/components/StatusSettings.js.map +2 -2
  322. package/dist/modules/sales/components/TaxRatesSettings.js +12 -4
  323. package/dist/modules/sales/components/TaxRatesSettings.js.map +2 -2
  324. package/dist/modules/sales/components/channels/ChannelOfferForm.js +47 -16
  325. package/dist/modules/sales/components/channels/ChannelOfferForm.js.map +2 -2
  326. package/dist/modules/sales/components/channels/SalesChannelOffersPanel.js +8 -4
  327. package/dist/modules/sales/components/channels/SalesChannelOffersPanel.js.map +2 -2
  328. package/dist/modules/sales/components/documents/AddressesSection.js +44 -25
  329. package/dist/modules/sales/components/documents/AddressesSection.js.map +2 -2
  330. package/dist/modules/sales/components/documents/AdjustmentsSection.js +43 -23
  331. package/dist/modules/sales/components/documents/AdjustmentsSection.js.map +2 -2
  332. package/dist/modules/sales/components/documents/ItemsSection.js +22 -13
  333. package/dist/modules/sales/components/documents/ItemsSection.js.map +2 -2
  334. package/dist/modules/sales/components/documents/LineItemDialog.js +23 -10
  335. package/dist/modules/sales/components/documents/LineItemDialog.js.map +2 -2
  336. package/dist/modules/sales/components/documents/PaymentDialog.js +29 -14
  337. package/dist/modules/sales/components/documents/PaymentDialog.js.map +2 -2
  338. package/dist/modules/sales/components/documents/PaymentsSection.js +20 -10
  339. package/dist/modules/sales/components/documents/PaymentsSection.js.map +2 -2
  340. package/dist/modules/sales/components/documents/ReturnDialog.js +26 -17
  341. package/dist/modules/sales/components/documents/ReturnDialog.js.map +2 -2
  342. package/dist/modules/sales/components/documents/ReturnsSection.js +3 -1
  343. package/dist/modules/sales/components/documents/ReturnsSection.js.map +2 -2
  344. package/dist/modules/sales/components/documents/SalesDocumentsTable.js +10 -5
  345. package/dist/modules/sales/components/documents/SalesDocumentsTable.js.map +2 -2
  346. package/dist/modules/sales/components/documents/ShipmentDialog.js +21 -7
  347. package/dist/modules/sales/components/documents/ShipmentDialog.js.map +2 -2
  348. package/dist/modules/sales/components/documents/ShipmentsSection.js +19 -10
  349. package/dist/modules/sales/components/documents/ShipmentsSection.js.map +2 -2
  350. package/dist/modules/sales/components/documents/optimisticLock.js +27 -0
  351. package/dist/modules/sales/components/documents/optimisticLock.js.map +7 -0
  352. package/dist/modules/sales/di.js +18 -0
  353. package/dist/modules/sales/di.js.map +2 -2
  354. package/dist/modules/staff/api/job-histories.js +11 -2
  355. package/dist/modules/staff/api/job-histories.js.map +2 -2
  356. package/dist/modules/staff/api/timesheets/time-entries/route.js +11 -4
  357. package/dist/modules/staff/api/timesheets/time-entries/route.js.map +2 -2
  358. package/dist/modules/staff/backend/staff/leave-requests/[id]/page.js +13 -8
  359. package/dist/modules/staff/backend/staff/leave-requests/[id]/page.js.map +2 -2
  360. package/dist/modules/staff/backend/staff/my-leave-requests/[id]/page.js +2 -1
  361. package/dist/modules/staff/backend/staff/my-leave-requests/[id]/page.js.map +2 -2
  362. package/dist/modules/staff/backend/staff/team-members/[id]/page.js +7 -4
  363. package/dist/modules/staff/backend/staff/team-members/[id]/page.js.map +2 -2
  364. package/dist/modules/staff/backend/staff/team-members/page.js +4 -2
  365. package/dist/modules/staff/backend/staff/team-members/page.js.map +2 -2
  366. package/dist/modules/staff/backend/staff/team-roles/[id]/edit/page.js +1 -0
  367. package/dist/modules/staff/backend/staff/team-roles/[id]/edit/page.js.map +2 -2
  368. package/dist/modules/staff/backend/staff/team-roles/page.js +4 -2
  369. package/dist/modules/staff/backend/staff/team-roles/page.js.map +2 -2
  370. package/dist/modules/staff/backend/staff/teams/[id]/edit/page.js +5 -2
  371. package/dist/modules/staff/backend/staff/teams/[id]/edit/page.js.map +2 -2
  372. package/dist/modules/staff/backend/staff/teams/page.js +12 -3
  373. package/dist/modules/staff/backend/staff/teams/page.js.map +2 -2
  374. package/dist/modules/staff/backend/staff/timesheets/page.js +4 -1
  375. package/dist/modules/staff/backend/staff/timesheets/page.js.map +2 -2
  376. package/dist/modules/staff/backend/staff/timesheets/projects/[id]/page.js.map +2 -2
  377. package/dist/modules/staff/backend/staff/timesheets/projects/page.js +12 -3
  378. package/dist/modules/staff/backend/staff/timesheets/projects/page.js.map +2 -2
  379. package/dist/modules/staff/commands/job-histories.js +40 -3
  380. package/dist/modules/staff/commands/job-histories.js.map +2 -2
  381. package/dist/modules/staff/components/LeaveRequestForm.js +1 -0
  382. package/dist/modules/staff/components/LeaveRequestForm.js.map +2 -2
  383. package/dist/modules/staff/components/TeamForm.js +1 -0
  384. package/dist/modules/staff/components/TeamForm.js.map +2 -2
  385. package/dist/modules/staff/components/TeamMemberForm.js +1 -0
  386. package/dist/modules/staff/components/TeamMemberForm.js.map +2 -2
  387. package/dist/modules/staff/components/TeamRoleForm.js +1 -0
  388. package/dist/modules/staff/components/TeamRoleForm.js.map +2 -2
  389. package/dist/modules/staff/components/detail/JobHistorySection.js +20 -7
  390. package/dist/modules/staff/components/detail/JobHistorySection.js.map +2 -2
  391. package/dist/modules/staff/data/validators.js +7 -1
  392. package/dist/modules/staff/data/validators.js.map +2 -2
  393. package/dist/modules/staff/lib/leaveRequestHelpers.js +2 -1
  394. package/dist/modules/staff/lib/leaveRequestHelpers.js.map +2 -2
  395. package/dist/modules/translations/components/TranslationManager.js +12 -8
  396. package/dist/modules/translations/components/TranslationManager.js.map +2 -2
  397. package/dist/modules/workflows/api/definitions/[id]/route.js +106 -0
  398. package/dist/modules/workflows/api/definitions/[id]/route.js.map +2 -2
  399. package/dist/modules/workflows/backend/definitions/[id]/page.js +11 -3
  400. package/dist/modules/workflows/backend/definitions/[id]/page.js.map +2 -2
  401. package/dist/modules/workflows/backend/definitions/page.js +19 -8
  402. package/dist/modules/workflows/backend/definitions/page.js.map +2 -2
  403. package/dist/modules/workflows/backend/definitions/visual-editor/page.js +29 -16
  404. package/dist/modules/workflows/backend/definitions/visual-editor/page.js.map +2 -2
  405. package/dist/modules/workflows/components/formConfig.js +4 -1
  406. package/dist/modules/workflows/components/formConfig.js.map +2 -2
  407. package/dist/modules/workflows/di.js +12 -0
  408. package/dist/modules/workflows/di.js.map +2 -2
  409. package/generated/entities/role/index.ts +1 -0
  410. package/generated/entities/user/index.ts +1 -0
  411. package/generated/entity-fields-registry.ts +2 -0
  412. package/jest.setup.ts +17 -0
  413. package/package.json +8 -7
  414. package/src/helpers/integration/communicationChannelsFixtures.ts +6 -0
  415. package/src/helpers/integration/dbFixtures.ts +1 -1
  416. package/src/helpers/integration/optimisticLockUi.ts +172 -0
  417. package/src/helpers/integration/salesFixtures.ts +29 -0
  418. package/src/modules/api_keys/backend/api-keys/page.tsx +10 -5
  419. package/src/modules/attachments/components/AttachmentPartitionSettings.tsx +19 -9
  420. package/src/modules/auth/api/roles/acl/route.ts +37 -11
  421. package/src/modules/auth/api/roles/route.ts +2 -0
  422. package/src/modules/auth/api/sidebar/preferences/route.ts +73 -0
  423. package/src/modules/auth/api/users/acl/route.ts +46 -18
  424. package/src/modules/auth/api/users/route.ts +2 -0
  425. package/src/modules/auth/backend/roles/[id]/edit/page.tsx +29 -4
  426. package/src/modules/auth/backend/roles/page.tsx +9 -4
  427. package/src/modules/auth/backend/users/[id]/edit/page.tsx +37 -4
  428. package/src/modules/auth/backend/users/page.tsx +7 -2
  429. package/src/modules/auth/components/AclEditor.tsx +10 -1
  430. package/src/modules/auth/data/entities.ts +7 -1
  431. package/src/modules/auth/services/sidebarPreferencesService.ts +38 -4
  432. package/src/modules/business_rules/api/rules/route.ts +30 -0
  433. package/src/modules/business_rules/api/sets/route.ts +30 -0
  434. package/src/modules/business_rules/backend/rules/[id]/page.tsx +16 -4
  435. package/src/modules/business_rules/backend/rules/page.tsx +20 -11
  436. package/src/modules/business_rules/backend/sets/[id]/page.tsx +16 -4
  437. package/src/modules/business_rules/backend/sets/page.tsx +20 -11
  438. package/src/modules/catalog/api/categories/route.ts +3 -0
  439. package/src/modules/catalog/api/products/route.ts +4 -0
  440. package/src/modules/catalog/backend/catalog/categories/[id]/edit/page.tsx +5 -0
  441. package/src/modules/catalog/backend/catalog/products/[id]/page.tsx +112 -35
  442. package/src/modules/catalog/backend/catalog/products/[productId]/variants/[variantId]/page.tsx +56 -7
  443. package/src/modules/catalog/backend/catalog/products/optionSchemaClient.ts +2 -0
  444. package/src/modules/catalog/commands/variants.ts +32 -32
  445. package/src/modules/catalog/components/PriceKindSettings.tsx +20 -7
  446. package/src/modules/catalog/components/categories/CategoriesDataTable.tsx +1 -0
  447. package/src/modules/catalog/components/products/ProductMediaManager.tsx +2 -0
  448. package/src/modules/catalog/components/products/ProductsDataTable.tsx +8 -4
  449. package/src/modules/catalog/components/products/productForm.ts +3 -0
  450. package/src/modules/catalog/components/products/variantForm.ts +9 -0
  451. package/src/modules/communication_channels/api/post/test-seed/route.ts +28 -1
  452. package/src/modules/communication_channels/backend/profile/communication-channels/page.tsx +5 -0
  453. package/src/modules/communication_channels/commands/set-primary-channel.ts +10 -7
  454. package/src/modules/currencies/backend/currencies/[id]/page.tsx +13 -6
  455. package/src/modules/currencies/backend/currencies/page.tsx +18 -11
  456. package/src/modules/currencies/backend/exchange-rates/[id]/page.tsx +3 -0
  457. package/src/modules/currencies/backend/exchange-rates/page.tsx +10 -6
  458. package/src/modules/currencies/commands/currencies.ts +10 -5
  459. package/src/modules/currencies/components/CurrencyFetchingConfig.tsx +31 -21
  460. package/src/modules/customer_accounts/api/admin/roles/[id].ts +35 -5
  461. package/src/modules/customer_accounts/api/admin/roles.ts +2 -0
  462. package/src/modules/customer_accounts/api/admin/users/[id].ts +38 -5
  463. package/src/modules/customer_accounts/api/admin/users.ts +2 -0
  464. package/src/modules/customer_accounts/backend/customer_accounts/roles/[id]/page.tsx +34 -20
  465. package/src/modules/customer_accounts/backend/customer_accounts/roles/page.tsx +9 -4
  466. package/src/modules/customer_accounts/backend/customer_accounts/settings/domain/page.tsx +11 -4
  467. package/src/modules/customer_accounts/backend/customer_accounts/users/[id]/page.tsx +28 -17
  468. package/src/modules/customer_accounts/backend/customer_accounts/users/page.tsx +19 -11
  469. package/src/modules/customers/AGENTS.md +2 -2
  470. package/src/modules/customers/api/companies/route.ts +14 -1
  471. package/src/modules/customers/api/deals/route.ts +3 -0
  472. package/src/modules/customers/api/people/route.ts +12 -1
  473. package/src/modules/customers/api/todos/route.ts +1 -0
  474. package/src/modules/customers/backend/config/customers/deals/page.tsx +1 -0
  475. package/src/modules/customers/backend/config/customers/pipeline-stages/page.tsx +36 -21
  476. package/src/modules/customers/backend/customers/companies/[id]/page.tsx +52 -27
  477. package/src/modules/customers/backend/customers/companies/page.tsx +2 -0
  478. package/src/modules/customers/backend/customers/companies-v2/[id]/page.tsx +27 -5
  479. package/src/modules/customers/backend/customers/deals/[id]/hooks/useDealFormHandlers.ts +39 -7
  480. package/src/modules/customers/backend/customers/deals/[id]/page.tsx +1 -0
  481. package/src/modules/customers/backend/customers/deals/page.tsx +18 -6
  482. package/src/modules/customers/backend/customers/deals/pipeline/page.tsx +64 -39
  483. package/src/modules/customers/backend/customers/people/[id]/page.tsx +46 -26
  484. package/src/modules/customers/backend/customers/people/page.tsx +2 -0
  485. package/src/modules/customers/backend/customers/people-v2/[id]/page.tsx +84 -24
  486. package/src/modules/customers/commands/addresses.ts +16 -14
  487. package/src/modules/customers/commands/companies.ts +3 -1
  488. package/src/modules/customers/commands/interactions.ts +50 -4
  489. package/src/modules/customers/commands/people.ts +2 -1
  490. package/src/modules/customers/commands/personCompanyLinks.ts +8 -5
  491. package/src/modules/customers/commands/pipeline-stages.ts +16 -16
  492. package/src/modules/customers/components/AddressFormatSettings.tsx +1 -0
  493. package/src/modules/customers/components/DictionarySettings.tsx +18 -13
  494. package/src/modules/customers/components/DictionarySortSettings.tsx +4 -0
  495. package/src/modules/customers/components/PipelineSettings.tsx +42 -21
  496. package/src/modules/customers/components/detail/ActivityTimeline.tsx +3 -3
  497. package/src/modules/customers/components/detail/AddressesSection.tsx +4 -0
  498. package/src/modules/customers/components/detail/CompanyPeopleSection.tsx +2 -0
  499. package/src/modules/customers/components/detail/DealsSection.tsx +4 -0
  500. package/src/modules/customers/components/detail/EmailCardActions.tsx +5 -0
  501. package/src/modules/customers/components/detail/EntityTagsDialog.tsx +7 -0
  502. package/src/modules/customers/components/detail/ManageTagsDialog.tsx +4 -0
  503. package/src/modules/customers/components/detail/PersonCompaniesSection.tsx +4 -0
  504. package/src/modules/customers/components/detail/RoleAssignmentRow.tsx +2 -0
  505. package/src/modules/customers/components/detail/ScheduleActivityDialog.tsx +23 -7
  506. package/src/modules/customers/components/detail/hooks/useInteractionMutations.ts +25 -15
  507. package/src/modules/customers/components/detail/hooks/useInteractions.ts +76 -35
  508. package/src/modules/customers/components/detail/hooks/usePersonTasks.ts +30 -17
  509. package/src/modules/customers/components/detail/schedule/useScheduleFormState.ts +2 -0
  510. package/src/modules/customers/components/detail/types.ts +1 -0
  511. package/src/modules/customers/components/formConfig.tsx +2 -0
  512. package/src/modules/customers/data/guards.ts +67 -0
  513. package/src/modules/customers/di.ts +66 -0
  514. package/src/modules/customers/i18n/de.json +2 -0
  515. package/src/modules/customers/i18n/en.json +2 -0
  516. package/src/modules/customers/i18n/es.json +2 -0
  517. package/src/modules/customers/i18n/pl.json +2 -0
  518. package/src/modules/customers/lib/todoCompatibility.ts +14 -0
  519. package/src/modules/dashboards/components/WidgetVisibilityEditor.tsx +2 -0
  520. package/src/modules/data_sync/api/options.ts +7 -4
  521. package/src/modules/data_sync/api/schedules/route.ts +9 -1
  522. package/src/modules/data_sync/backend/data-sync/page.tsx +18 -5
  523. package/src/modules/data_sync/components/IntegrationScheduleTab.tsx +46 -19
  524. package/src/modules/data_sync/lib/sync-schedule-service.ts +11 -0
  525. package/src/modules/dictionaries/api/[dictionaryId]/entries/[entryId]/route.ts +8 -1
  526. package/src/modules/dictionaries/api/[dictionaryId]/route.ts +23 -0
  527. package/src/modules/dictionaries/components/DictionariesManager.tsx +32 -9
  528. package/src/modules/dictionaries/components/DictionaryEntriesEditor.tsx +30 -14
  529. package/src/modules/dictionaries/i18n/de.json +1 -0
  530. package/src/modules/dictionaries/i18n/en.json +1 -0
  531. package/src/modules/dictionaries/i18n/es.json +1 -0
  532. package/src/modules/dictionaries/i18n/pl.json +1 -0
  533. package/src/modules/directory/api/organizations/route.ts +3 -0
  534. package/src/modules/directory/backend/directory/organizations/[id]/edit/page.tsx +8 -0
  535. package/src/modules/directory/backend/directory/organizations/page.tsx +10 -5
  536. package/src/modules/directory/backend/directory/tenants/[id]/edit/page.tsx +16 -5
  537. package/src/modules/directory/backend/directory/tenants/page.tsx +8 -4
  538. package/src/modules/directory/commands/organizations.ts +7 -4
  539. package/src/modules/entities/api/records.ts +99 -0
  540. package/src/modules/entities/backend/entities/user/[entityId]/records/[recordId]/page.tsx +7 -0
  541. package/src/modules/entities/backend/entities/user/[entityId]/records/page.tsx +8 -4
  542. package/src/modules/entities/lib/helpers.ts +17 -0
  543. package/src/modules/feature_toggles/api/global/[id]/override/route.ts +1 -0
  544. package/src/modules/feature_toggles/api/overrides/route.ts +19 -0
  545. package/src/modules/feature_toggles/backend/feature-toggles/global/[id]/edit/page.tsx +19 -13
  546. package/src/modules/feature_toggles/components/FeatureToggleOverrideCard.tsx +22 -12
  547. package/src/modules/feature_toggles/components/FeatureTogglesTable.tsx +7 -2
  548. package/src/modules/feature_toggles/components/formConfig.tsx +2 -1
  549. package/src/modules/feature_toggles/components/overrideFormConfig.tsx +10 -1
  550. package/src/modules/feature_toggles/data/validators.ts +11 -3
  551. package/src/modules/inbox_ops/api/settings/route.ts +18 -0
  552. package/src/modules/inbox_ops/backend/inbox-ops/settings/page.tsx +15 -10
  553. package/src/modules/inbox_ops/components/proposals/EditActionDialog.tsx +9 -4
  554. package/src/modules/integrations/backend/integrations/bundle/[id]/page.tsx +20 -11
  555. package/src/modules/integrations/backend/integrations/page.tsx +13 -8
  556. package/src/modules/messages/commands/messages.ts +27 -15
  557. package/src/modules/perspectives/api/[tableId]/route.ts +11 -2
  558. package/src/modules/perspectives/services/perspectiveService.ts +13 -1
  559. package/src/modules/planner/backend/planner/availability-rulesets/[id]/page.tsx +16 -14
  560. package/src/modules/planner/backend/planner/availability-rulesets/page.tsx +6 -3
  561. package/src/modules/planner/components/AvailabilityRuleSetForm.tsx +3 -0
  562. package/src/modules/planner/components/AvailabilityRulesEditor.tsx +58 -15
  563. package/src/modules/planner/components/AvailabilitySchedule.tsx +22 -7
  564. package/src/modules/query_index/lib/engine.ts +34 -0
  565. package/src/modules/resources/backend/resources/resource-types/[id]/edit/page.tsx +7 -1
  566. package/src/modules/resources/backend/resources/resource-types/page.tsx +6 -3
  567. package/src/modules/resources/backend/resources/resources/[id]/page.tsx +23 -3
  568. package/src/modules/resources/backend/resources/resources/page.tsx +15 -4
  569. package/src/modules/resources/components/ResourceCrudForm.tsx +3 -0
  570. package/src/modules/resources/components/ResourceTypeCrudForm.tsx +2 -0
  571. package/src/modules/sales/api/documents/factory.ts +13 -1
  572. package/src/modules/sales/backend/sales/channels/[channelId]/edit/page.tsx +6 -0
  573. package/src/modules/sales/backend/sales/channels/offers/page.tsx +10 -4
  574. package/src/modules/sales/backend/sales/channels/page.tsx +19 -4
  575. package/src/modules/sales/backend/sales/documents/[id]/page.tsx +73 -20
  576. package/src/modules/sales/backend/sales/documents/create/page.tsx +2 -0
  577. package/src/modules/sales/commands/documentAddresses.ts +226 -4
  578. package/src/modules/sales/commands/documents.ts +28 -0
  579. package/src/modules/sales/commands/returns.ts +12 -3
  580. package/src/modules/sales/commands/shared.ts +36 -0
  581. package/src/modules/sales/commands/shipments.ts +17 -1
  582. package/src/modules/sales/components/AdjustmentKindSettings.tsx +20 -11
  583. package/src/modules/sales/components/DocumentNumberSettings.tsx +1 -0
  584. package/src/modules/sales/components/OrderEditingSettings.tsx +1 -0
  585. package/src/modules/sales/components/PaymentMethodsSettings.tsx +12 -4
  586. package/src/modules/sales/components/ShippingMethodsSettings.tsx +12 -4
  587. package/src/modules/sales/components/StatusSettings.tsx +20 -11
  588. package/src/modules/sales/components/TaxRatesSettings.tsx +12 -5
  589. package/src/modules/sales/components/channels/ChannelOfferForm.tsx +67 -14
  590. package/src/modules/sales/components/channels/SalesChannelOffersPanel.tsx +7 -4
  591. package/src/modules/sales/components/documents/AddressesSection.tsx +35 -25
  592. package/src/modules/sales/components/documents/AdjustmentsSection.tsx +50 -25
  593. package/src/modules/sales/components/documents/ItemsSection.tsx +24 -13
  594. package/src/modules/sales/components/documents/LineItemDialog.tsx +26 -9
  595. package/src/modules/sales/components/documents/PaymentDialog.tsx +33 -14
  596. package/src/modules/sales/components/documents/PaymentsSection.tsx +22 -10
  597. package/src/modules/sales/components/documents/ReturnDialog.tsx +28 -17
  598. package/src/modules/sales/components/documents/ReturnsSection.tsx +4 -1
  599. package/src/modules/sales/components/documents/SalesDocumentsTable.tsx +11 -4
  600. package/src/modules/sales/components/documents/ShipmentDialog.tsx +23 -8
  601. package/src/modules/sales/components/documents/ShipmentsSection.tsx +20 -10
  602. package/src/modules/sales/components/documents/optimisticLock.ts +34 -0
  603. package/src/modules/sales/components/documents/shipmentTypes.ts +1 -0
  604. package/src/modules/sales/di.ts +35 -0
  605. package/src/modules/sales/i18n/de.json +3 -0
  606. package/src/modules/sales/i18n/en.json +3 -0
  607. package/src/modules/sales/i18n/es.json +3 -0
  608. package/src/modules/sales/i18n/pl.json +3 -0
  609. package/src/modules/staff/api/job-histories.ts +12 -2
  610. package/src/modules/staff/api/timesheets/time-entries/route.ts +16 -4
  611. package/src/modules/staff/backend/staff/leave-requests/[id]/page.tsx +12 -7
  612. package/src/modules/staff/backend/staff/my-leave-requests/[id]/page.tsx +2 -0
  613. package/src/modules/staff/backend/staff/team-members/[id]/page.tsx +16 -5
  614. package/src/modules/staff/backend/staff/team-members/page.tsx +6 -2
  615. package/src/modules/staff/backend/staff/team-roles/[id]/edit/page.tsx +8 -0
  616. package/src/modules/staff/backend/staff/team-roles/page.tsx +6 -2
  617. package/src/modules/staff/backend/staff/teams/[id]/edit/page.tsx +13 -3
  618. package/src/modules/staff/backend/staff/teams/page.tsx +9 -3
  619. package/src/modules/staff/backend/staff/timesheets/page.tsx +10 -1
  620. package/src/modules/staff/backend/staff/timesheets/projects/[id]/page.tsx +4 -0
  621. package/src/modules/staff/backend/staff/timesheets/projects/page.tsx +9 -3
  622. package/src/modules/staff/commands/job-histories.ts +42 -3
  623. package/src/modules/staff/components/LeaveRequestForm.tsx +2 -0
  624. package/src/modules/staff/components/TeamForm.tsx +2 -0
  625. package/src/modules/staff/components/TeamMemberForm.tsx +2 -0
  626. package/src/modules/staff/components/TeamRoleForm.tsx +2 -0
  627. package/src/modules/staff/components/detail/JobHistorySection.tsx +28 -6
  628. package/src/modules/staff/data/validators.ts +6 -0
  629. package/src/modules/staff/i18n/de.json +1 -0
  630. package/src/modules/staff/i18n/en.json +1 -0
  631. package/src/modules/staff/i18n/es.json +1 -0
  632. package/src/modules/staff/i18n/pl.json +1 -0
  633. package/src/modules/staff/lib/leaveRequestHelpers.ts +4 -0
  634. package/src/modules/translations/components/TranslationManager.tsx +13 -8
  635. package/src/modules/workflows/api/definitions/[id]/route.ts +112 -0
  636. package/src/modules/workflows/backend/definitions/[id]/page.tsx +20 -4
  637. package/src/modules/workflows/backend/definitions/page.tsx +20 -9
  638. package/src/modules/workflows/backend/definitions/visual-editor/page.tsx +29 -16
  639. package/src/modules/workflows/components/formConfig.tsx +5 -0
  640. package/src/modules/workflows/di.ts +20 -0
  641. package/src/modules/workflows/i18n/de.json +1 -0
  642. package/src/modules/workflows/i18n/en.json +1 -0
  643. package/src/modules/workflows/i18n/es.json +1 -0
  644. package/src/modules/workflows/i18n/pl.json +1 -0
@@ -9,7 +9,8 @@ import { RowActions } from '@open-mercato/ui/backend/RowActions'
9
9
  import { Button } from '@open-mercato/ui/primitives/button'
10
10
  import { BooleanIcon } from '@open-mercato/ui/backend/ValueIcons'
11
11
  import { flash } from '@open-mercato/ui/backend/FlashMessages'
12
- import { readApiResultOrThrow } from '@open-mercato/ui/backend/utils/apiCall'
12
+ import { readApiResultOrThrow, withScopedApiRequestHeaders } from '@open-mercato/ui/backend/utils/apiCall'
13
+ import { buildOptimisticLockHeader } from '@open-mercato/ui/backend/utils/optimisticLock'
13
14
  import { deleteCrud } from '@open-mercato/ui/backend/utils/crud'
14
15
  import { useT } from '@open-mercato/shared/lib/i18n/context'
15
16
  import { mapOfferRow, renderOfferPriceSummary, type OfferRow } from './offerTableUtils'
@@ -123,9 +124,11 @@ export function SalesChannelOffersPanel({ channelId, channelName }: { channelId:
123
124
 
124
125
  const handleDelete = React.useCallback(async (row: OfferRow) => {
125
126
  try {
126
- await deleteCrud('catalog/offers', row.id, {
127
- errorMessage: t('sales.channels.offers.errors.delete', 'Failed to delete offer.'),
128
- })
127
+ await withScopedApiRequestHeaders(buildOptimisticLockHeader(row.updatedAt), () =>
128
+ deleteCrud('catalog/offers', row.id, {
129
+ errorMessage: t('sales.channels.offers.errors.delete', 'Failed to delete offer.'),
130
+ }),
131
+ )
129
132
  flash(t('sales.channels.offers.messages.deleted', 'Offer deleted.'), 'success')
130
133
  setReloadToken((token) => token + 1)
131
134
  } catch (err) {
@@ -4,7 +4,8 @@
4
4
 
5
5
  import * as React from 'react'
6
6
  import { flash } from '@open-mercato/ui/backend/FlashMessages'
7
- import { apiCall, apiCallOrThrow } from '@open-mercato/ui/backend/utils/apiCall'
7
+ import { apiCall, apiCallOrThrow, withScopedApiRequestHeaders } from '@open-mercato/ui/backend/utils/apiCall'
8
+ import { buildOptimisticLockHeader } from '@open-mercato/ui/backend/utils/optimisticLock'
8
9
  import { createCrud } from '@open-mercato/ui/backend/utils/crud'
9
10
  import { useGuardedMutation } from '@open-mercato/ui/backend/injection/useGuardedMutation'
10
11
  import { ErrorMessage, LoadingMessage, TabEmptyState } from '@open-mercato/ui/backend/detail'
@@ -691,14 +692,17 @@ export function SalesDocumentAddressesSection({
691
692
  }
692
693
  await runGuardedMutation(
693
694
  () =>
694
- apiCallOrThrow(
695
- '/api/sales/document-addresses',
696
- {
697
- method: 'PUT',
698
- headers: { 'Content-Type': 'application/json' },
699
- body: JSON.stringify(payload),
700
- },
701
- { errorMessage: t('sales.documents.detail.addresses.saveError', 'Failed to update addresses.') },
695
+ // TODO(#2373-C): thread document updatedAt
696
+ withScopedApiRequestHeaders(buildOptimisticLockHeader(undefined), () =>
697
+ apiCallOrThrow(
698
+ '/api/sales/document-addresses',
699
+ {
700
+ method: 'PUT',
701
+ headers: { 'Content-Type': 'application/json' },
702
+ body: JSON.stringify(payload),
703
+ },
704
+ { errorMessage: t('sales.documents.detail.addresses.saveError', 'Failed to update addresses.') },
705
+ ),
702
706
  ),
703
707
  payload,
704
708
  )
@@ -750,14 +754,17 @@ export function SalesDocumentAddressesSection({
750
754
  const payload = { id, documentId, documentKind: kind }
751
755
  await runGuardedMutation(
752
756
  () =>
753
- apiCallOrThrow(
754
- '/api/sales/document-addresses',
755
- {
756
- method: 'DELETE',
757
- headers: { 'Content-Type': 'application/json' },
758
- body: JSON.stringify(payload),
759
- },
760
- { errorMessage: t('sales.documents.detail.addresses.deleteError', 'Failed to remove address.') },
757
+ // TODO(#2373-C): thread document updatedAt
758
+ withScopedApiRequestHeaders(buildOptimisticLockHeader(undefined), () =>
759
+ apiCallOrThrow(
760
+ '/api/sales/document-addresses',
761
+ {
762
+ method: 'DELETE',
763
+ headers: { 'Content-Type': 'application/json' },
764
+ body: JSON.stringify(payload),
765
+ },
766
+ { errorMessage: t('sales.documents.detail.addresses.deleteError', 'Failed to remove address.') },
767
+ ),
761
768
  ),
762
769
  payload,
763
770
  )
@@ -849,14 +856,17 @@ export function SalesDocumentAddressesSection({
849
856
  const endpoint = kind === 'order' ? '/api/sales/orders' : '/api/sales/quotes'
850
857
  const call = await runGuardedMutation(
851
858
  () =>
852
- apiCallOrThrow<Record<string, unknown>>(
853
- endpoint,
854
- {
855
- method: 'PUT',
856
- headers: { 'Content-Type': 'application/json' },
857
- body: JSON.stringify(payload),
858
- },
859
- { errorMessage: t('sales.documents.detail.updateError', 'Failed to update document.') },
859
+ // TODO(#2373-C): thread document updatedAt
860
+ withScopedApiRequestHeaders(buildOptimisticLockHeader(undefined), () =>
861
+ apiCallOrThrow<Record<string, unknown>>(
862
+ endpoint,
863
+ {
864
+ method: 'PUT',
865
+ headers: { 'Content-Type': 'application/json' },
866
+ body: JSON.stringify(payload),
867
+ },
868
+ { errorMessage: t('sales.documents.detail.updateError', 'Failed to update document.') },
869
+ ),
860
870
  ),
861
871
  payload,
862
872
  )
@@ -8,9 +8,11 @@ import { Badge } from '@open-mercato/ui/primitives/badge'
8
8
  import { DataTable } from '@open-mercato/ui/backend/DataTable'
9
9
  import { ErrorMessage, LoadingMessage, TabEmptyState } from '@open-mercato/ui/backend/detail'
10
10
  import { flash } from '@open-mercato/ui/backend/FlashMessages'
11
- import { apiCall } from '@open-mercato/ui/backend/utils/apiCall'
11
+ import { apiCall, withScopedApiRequestHeaders } from '@open-mercato/ui/backend/utils/apiCall'
12
+ import { buildOptimisticLockHeader } from '@open-mercato/ui/backend/utils/optimisticLock'
12
13
  import { createCrud, deleteCrud, updateCrud } from '@open-mercato/ui/backend/utils/crud'
13
14
  import { createCrudFormError } from '@open-mercato/ui/backend/utils/serverErrors'
15
+ import { handleSectionMutationError } from './optimisticLock'
14
16
  import { RowActions } from '@open-mercato/ui/backend/RowActions'
15
17
  import { type DictionaryOption } from '@open-mercato/core/modules/dictionaries/components/DictionaryEntrySelect'
16
18
  import {
@@ -31,6 +33,7 @@ type SalesDocumentAdjustmentsSectionProps = {
31
33
  documentId: string
32
34
  kind: 'order' | 'quote'
33
35
  currencyCode: string | null | undefined
36
+ documentUpdatedAt?: string | null
34
37
  organizationId?: string | null
35
38
  tenantId?: string | null
36
39
  onActionChange?: (action: SectionAction | null) => void
@@ -64,6 +67,7 @@ export function SalesDocumentAdjustmentsSection({
64
67
  documentId,
65
68
  kind,
66
69
  currencyCode,
70
+ documentUpdatedAt,
67
71
  organizationId: orgFromProps,
68
72
  tenantId: tenantFromProps,
69
73
  onActionChange,
@@ -317,27 +321,43 @@ export function SalesDocumentAdjustmentsSection({
317
321
  }
318
322
 
319
323
  const action = values.id ? updateCrud : createCrud
320
- const result = await action(
321
- crudResourcePath,
322
- values.id ? { id: values.id, ...payload } : payload,
323
- {
324
- successMessage: values.id
325
- ? t('sales.documents.adjustments.updated', 'Adjustment updated.')
326
- : t('sales.documents.adjustments.created', 'Adjustment added.'),
327
- errorMessage: t('sales.documents.adjustments.errorSave', 'Failed to save adjustment.'),
324
+ try {
325
+ const result = await withScopedApiRequestHeaders(
326
+ buildOptimisticLockHeader(documentUpdatedAt),
327
+ () =>
328
+ action(
329
+ crudResourcePath,
330
+ values.id ? { id: values.id, ...payload } : payload,
331
+ {
332
+ successMessage: values.id
333
+ ? t('sales.documents.adjustments.updated', 'Adjustment updated.')
334
+ : t('sales.documents.adjustments.created', 'Adjustment added.'),
335
+ errorMessage: t('sales.documents.adjustments.errorSave', 'Failed to save adjustment.'),
336
+ }
337
+ )
338
+ )
339
+ if (result.ok) {
340
+ await loadAdjustments()
341
+ emitSalesDocumentTotalsRefresh({ documentId, kind })
342
+ setDialogOpen(false)
343
+ setActiveAdjustment(null)
328
344
  }
329
- )
330
- if (result.ok) {
331
- await loadAdjustments()
332
- emitSalesDocumentTotalsRefresh({ documentId, kind })
333
- setDialogOpen(false)
334
- setActiveAdjustment(null)
345
+ } catch (err) {
346
+ if (
347
+ handleSectionMutationError(err, t, () => void loadAdjustments())
348
+ ) {
349
+ setDialogOpen(false)
350
+ setActiveAdjustment(null)
351
+ return
352
+ }
353
+ throw err
335
354
  }
336
355
  },
337
356
  [
338
357
  currencyCode,
339
358
  documentId,
340
359
  documentKey,
360
+ documentUpdatedAt,
341
361
  kind,
342
362
  loadAdjustments,
343
363
  crudResourcePath,
@@ -350,25 +370,30 @@ export function SalesDocumentAdjustmentsSection({
350
370
  const handleDelete = React.useCallback(
351
371
  async (row: AdjustmentRow) => {
352
372
  try {
353
- const result = await deleteCrud(crudResourcePath, {
354
- body: {
355
- id: row.id,
356
- [documentKey]: documentId,
357
- organizationId: resolvedOrganizationId ?? undefined,
358
- tenantId: resolvedTenantId ?? undefined,
359
- },
360
- errorMessage: t('sales.documents.adjustments.errorDelete', 'Failed to delete adjustment.'),
361
- })
373
+ const result = await withScopedApiRequestHeaders(
374
+ buildOptimisticLockHeader(documentUpdatedAt),
375
+ () =>
376
+ deleteCrud(crudResourcePath, {
377
+ body: {
378
+ id: row.id,
379
+ [documentKey]: documentId,
380
+ organizationId: resolvedOrganizationId ?? undefined,
381
+ tenantId: resolvedTenantId ?? undefined,
382
+ },
383
+ errorMessage: t('sales.documents.adjustments.errorDelete', 'Failed to delete adjustment.'),
384
+ })
385
+ )
362
386
  if (result.ok) {
363
387
  await loadAdjustments()
364
388
  emitSalesDocumentTotalsRefresh({ documentId, kind })
365
389
  }
366
390
  } catch (err) {
391
+ if (handleSectionMutationError(err, t, () => void loadAdjustments())) return
367
392
  console.error('sales.document.adjustments.delete', err)
368
393
  flash(t('sales.documents.adjustments.errorDelete', 'Failed to delete adjustment.'), 'error')
369
394
  }
370
395
  },
371
- [crudResourcePath, documentId, documentKey, kind, loadAdjustments, resolvedOrganizationId, resolvedTenantId, t]
396
+ [crudResourcePath, documentId, documentKey, documentUpdatedAt, kind, loadAdjustments, resolvedOrganizationId, resolvedTenantId, t]
372
397
  )
373
398
 
374
399
  const columns = React.useMemo<ColumnDef<AdjustmentRow>[]>(
@@ -1,7 +1,8 @@
1
1
  "use client";
2
2
 
3
3
  import * as React from "react";
4
- import { apiCall } from "@open-mercato/ui/backend/utils/apiCall";
4
+ import { apiCall, withScopedApiRequestHeaders } from "@open-mercato/ui/backend/utils/apiCall";
5
+ import { buildOptimisticLockHeader } from "@open-mercato/ui/backend/utils/optimisticLock";
5
6
  import { deleteCrud } from "@open-mercato/ui/backend/utils/crud";
6
7
  import { normalizeCrudServerError } from "@open-mercato/ui/backend/utils/serverErrors";
7
8
  import { LoadingMessage, TabEmptyState } from "@open-mercato/ui/backend/detail";
@@ -19,6 +20,7 @@ import { useOrganizationScopeDetail } from "@open-mercato/shared/lib/frontend/us
19
20
  import { useConfirmDialog } from "@open-mercato/ui/backend/confirm-dialog";
20
21
  import { emitSalesDocumentTotalsRefresh } from "@open-mercato/core/modules/sales/lib/frontend/documentTotalsEvents";
21
22
  import { LineItemDialog } from "./LineItemDialog";
23
+ import { handleSectionMutationError } from "./optimisticLock";
22
24
  import type { SalesLineRecord } from "./lineItemTypes";
23
25
  import { formatMoney, normalizeNumber } from "./lineItemUtils";
24
26
  import type { SectionAction } from "@open-mercato/ui/backend/detail";
@@ -109,6 +111,7 @@ type SalesDocumentItemsSectionProps = {
109
111
  documentId: string;
110
112
  kind: "order" | "quote";
111
113
  currencyCode: string | null | undefined;
114
+ documentUpdatedAt?: string | null;
112
115
  organizationId?: string | null;
113
116
  tenantId?: string | null;
114
117
  onActionChange?: (action: SectionAction | null) => void;
@@ -119,6 +122,7 @@ export function SalesDocumentItemsSection({
119
122
  documentId,
120
123
  kind,
121
124
  currencyCode,
125
+ documentUpdatedAt,
122
126
  organizationId: orgFromProps,
123
127
  tenantId: tenantFromProps,
124
128
  onActionChange,
@@ -449,24 +453,29 @@ export function SalesDocumentItemsSection({
449
453
  });
450
454
  if (!confirmed) return;
451
455
  try {
452
- const result = await deleteCrud(resourcePath, {
453
- body: {
454
- id: line.id,
455
- [documentKey]: documentId,
456
- organizationId: resolvedOrganizationId ?? undefined,
457
- tenantId: resolvedTenantId ?? undefined,
458
- },
459
- errorMessage: t(
460
- "sales.documents.items.errorDelete",
461
- "Failed to delete line.",
462
- ),
463
- });
456
+ const result = await withScopedApiRequestHeaders(
457
+ buildOptimisticLockHeader(documentUpdatedAt),
458
+ () =>
459
+ deleteCrud(resourcePath, {
460
+ body: {
461
+ id: line.id,
462
+ [documentKey]: documentId,
463
+ organizationId: resolvedOrganizationId ?? undefined,
464
+ tenantId: resolvedTenantId ?? undefined,
465
+ },
466
+ errorMessage: t(
467
+ "sales.documents.items.errorDelete",
468
+ "Failed to delete line.",
469
+ ),
470
+ }),
471
+ );
464
472
  if (result.ok) {
465
473
  flash(t("sales.documents.items.deleted", "Line removed."), "success");
466
474
  await loadItems();
467
475
  emitSalesDocumentTotalsRefresh({ documentId, kind });
468
476
  }
469
477
  } catch (err) {
478
+ if (handleSectionMutationError(err, t, () => void loadItems())) return;
470
479
  console.error("sales.document.items.delete", err);
471
480
  const normalized = normalizeCrudServerError(err);
472
481
  const fallback = t(
@@ -480,6 +489,7 @@ export function SalesDocumentItemsSection({
480
489
  confirm,
481
490
  documentId,
482
491
  documentKey,
492
+ documentUpdatedAt,
483
493
  kind,
484
494
  loadItems,
485
495
  resolvedOrganizationId,
@@ -800,6 +810,7 @@ export function SalesDocumentItemsSection({
800
810
  kind={kind}
801
811
  documentId={documentId}
802
812
  currencyCode={currencyCode}
813
+ documentUpdatedAt={documentUpdatedAt}
803
814
  organizationId={resolvedOrganizationId}
804
815
  tenantId={resolvedTenantId}
805
816
  initialLine={lineForEdit}
@@ -12,9 +12,11 @@ import {
12
12
  type CrudCustomFieldRenderProps,
13
13
  } from "@open-mercato/ui/backend/CrudForm";
14
14
  import { collectCustomFieldValues } from "@open-mercato/ui/backend/utils/customFieldValues";
15
- import { apiCall } from "@open-mercato/ui/backend/utils/apiCall";
15
+ import { apiCall, withScopedApiRequestHeaders } from "@open-mercato/ui/backend/utils/apiCall";
16
+ import { buildOptimisticLockHeader } from "@open-mercato/ui/backend/utils/optimisticLock";
16
17
  import { createCrud, updateCrud } from "@open-mercato/ui/backend/utils/crud";
17
18
  import { createCrudFormError } from "@open-mercato/ui/backend/utils/serverErrors";
19
+ import { handleSectionMutationError } from "./optimisticLock";
18
20
  import {
19
21
  Dialog,
20
22
  DialogContent,
@@ -233,6 +235,7 @@ type SalesLineDialogProps = {
233
235
  kind: "order" | "quote";
234
236
  documentId: string;
235
237
  currencyCode: string | null | undefined;
238
+ documentUpdatedAt?: string | null;
236
239
  organizationId: string | null;
237
240
  tenantId: string | null;
238
241
  initialLine?: SalesLineRecord | null;
@@ -426,6 +429,7 @@ export function LineItemDialog({
426
429
  kind,
427
430
  documentId,
428
431
  currencyCode,
432
+ documentUpdatedAt,
429
433
  organizationId,
430
434
  tenantId,
431
435
  initialLine,
@@ -1445,21 +1449,33 @@ export function LineItemDialog({
1445
1449
 
1446
1450
  try {
1447
1451
  const action = editingId ? updateCrud : createCrud;
1448
- const result = await action(
1449
- resourcePath,
1450
- editingId ? { id: editingId, ...payload } : payload,
1451
- {
1452
- errorMessage: t(
1453
- "sales.documents.items.errorSave",
1454
- "Failed to save line.",
1452
+ const result = await withScopedApiRequestHeaders(
1453
+ buildOptimisticLockHeader(documentUpdatedAt),
1454
+ () =>
1455
+ action(
1456
+ resourcePath,
1457
+ editingId ? { id: editingId, ...payload } : payload,
1458
+ {
1459
+ errorMessage: t(
1460
+ "sales.documents.items.errorSave",
1461
+ "Failed to save line.",
1462
+ ),
1463
+ },
1455
1464
  ),
1456
- },
1457
1465
  );
1458
1466
  if (result.ok) {
1459
1467
  if (onSaved) await onSaved();
1460
1468
  closeDialog();
1461
1469
  }
1462
1470
  } catch (err) {
1471
+ if (
1472
+ handleSectionMutationError(err, t, () => {
1473
+ if (onSaved) void onSaved();
1474
+ })
1475
+ ) {
1476
+ closeDialog();
1477
+ return;
1478
+ }
1463
1479
  throw err;
1464
1480
  }
1465
1481
  },
@@ -1467,6 +1483,7 @@ export function LineItemDialog({
1467
1483
  currencyCode,
1468
1484
  documentId,
1469
1485
  documentKey,
1486
+ documentUpdatedAt,
1470
1487
  editingId,
1471
1488
  priceOptions,
1472
1489
  productOption,
@@ -4,10 +4,12 @@ import * as React from 'react'
4
4
  import { CreditCard } from 'lucide-react'
5
5
  import { CrudForm, type CrudField, type CrudFormGroup } from '@open-mercato/ui/backend/CrudForm'
6
6
  import { LookupSelect, type LookupSelectItem } from '@open-mercato/ui/backend/inputs'
7
- import { apiCall } from '@open-mercato/ui/backend/utils/apiCall'
7
+ import { apiCall, withScopedApiRequestHeaders } from '@open-mercato/ui/backend/utils/apiCall'
8
+ import { buildOptimisticLockHeader } from '@open-mercato/ui/backend/utils/optimisticLock'
8
9
  import { collectCustomFieldValues } from '@open-mercato/ui/backend/utils/customFieldValues'
9
10
  import { createCrud, updateCrud } from '@open-mercato/ui/backend/utils/crud'
10
11
  import { createCrudFormError } from '@open-mercato/ui/backend/utils/serverErrors'
12
+ import { handleSectionMutationError, rowOptimisticVersion } from './optimisticLock'
11
13
  import { Dialog, DialogContent, DialogHeader, DialogTitle } from '@open-mercato/ui/primitives/dialog'
12
14
  import { useDialogKeyHandler } from '@open-mercato/ui/hooks/useDialogKeyHandler'
13
15
  import { Input } from '@open-mercato/ui/primitives/input'
@@ -24,6 +26,7 @@ export type PaymentTotals = {
24
26
 
25
27
  export type PaymentFormData = {
26
28
  id?: string | null
29
+ updatedAt?: string | null
27
30
  amount?: number | string | null
28
31
  paymentMethodId?: string | null
29
32
  paymentReference?: string | null
@@ -534,23 +537,39 @@ export function PaymentDialog({
534
537
  if (Object.keys(customFields).length) payload.customFields = customFields
535
538
 
536
539
  const action = payment?.id ? updateCrud : createCrud
537
- const result = await action(
538
- 'sales/payments',
539
- payment?.id ? { id: payment.id, ...payload } : payload,
540
- {
541
- errorMessage: t('sales.documents.payments.errorSave', 'Failed to save payment.'),
540
+ try {
541
+ const result = await withScopedApiRequestHeaders(
542
+ buildOptimisticLockHeader(payment?.id ? rowOptimisticVersion(payment) : undefined),
543
+ () =>
544
+ action(
545
+ 'sales/payments',
546
+ payment?.id ? { id: payment.id, ...payload } : payload,
547
+ {
548
+ errorMessage: t('sales.documents.payments.errorSave', 'Failed to save payment.'),
549
+ }
550
+ )
551
+ )
552
+ if (result.ok) {
553
+ const totals = (result.result as any)?.orderTotals as PaymentTotals | undefined
554
+ if (onSaved) {
555
+ await onSaved(totals ?? null)
556
+ }
557
+ setFormResetKey((prev) => prev + 1)
558
+ onOpenChange(false)
542
559
  }
543
- )
544
- if (result.ok) {
545
- const totals = (result.result as any)?.orderTotals as PaymentTotals | undefined
546
- if (onSaved) {
547
- await onSaved(totals ?? null)
560
+ } catch (err) {
561
+ if (
562
+ handleSectionMutationError(err, t, () => {
563
+ if (onSaved) void onSaved()
564
+ })
565
+ ) {
566
+ onOpenChange(false)
567
+ return
548
568
  }
549
- setFormResetKey((prev) => prev + 1)
550
- onOpenChange(false)
569
+ throw err
551
570
  }
552
571
  },
553
- [currencyCode, mode, onOpenChange, onSaved, orderId, organizationId, payment?.id, t, tenantId]
572
+ [currencyCode, mode, onOpenChange, onSaved, orderId, organizationId, payment?.id, payment?.updatedAt, t, tenantId]
554
573
  )
555
574
 
556
575
  const handleSubmitForm = React.useCallback(
@@ -4,8 +4,10 @@ import * as React from 'react'
4
4
  import type { ColumnDef } from '@tanstack/react-table'
5
5
  import { DataTable } from '@open-mercato/ui/backend/DataTable'
6
6
  import { LoadingMessage, ErrorMessage, TabEmptyState } from '@open-mercato/ui/backend/detail'
7
- import { apiCall } from '@open-mercato/ui/backend/utils/apiCall'
7
+ import { apiCall, withScopedApiRequestHeaders } from '@open-mercato/ui/backend/utils/apiCall'
8
+ import { buildOptimisticLockHeader } from '@open-mercato/ui/backend/utils/optimisticLock'
8
9
  import { deleteCrud } from '@open-mercato/ui/backend/utils/crud'
10
+ import { handleSectionMutationError, readRowUpdatedAt, rowOptimisticVersion } from './optimisticLock'
9
11
  import type { SectionAction } from '@open-mercato/ui/backend/detail'
10
12
  import { RowActions } from '@open-mercato/ui/backend/RowActions'
11
13
  import { Button } from '@open-mercato/ui/primitives/button'
@@ -19,6 +21,7 @@ import { Plus } from 'lucide-react'
19
21
 
20
22
  type PaymentRow = {
21
23
  id: string
24
+ updatedAt: string | null
22
25
  paymentReference: string | null
23
26
  paymentMethodId: string | null
24
27
  paymentMethodName: string | null
@@ -108,6 +111,7 @@ export function SalesDocumentPaymentsSection({
108
111
  : {}
109
112
  const record: PaymentRow = {
110
113
  id: item.id,
114
+ updatedAt: readRowUpdatedAt(item),
111
115
  paymentReference: typeof item.payment_reference === 'string' ? item.payment_reference : null,
112
116
  paymentMethodId: typeof item.payment_method_id === 'string' ? item.payment_method_id : null,
113
117
  paymentMethodName:
@@ -183,6 +187,7 @@ export function SalesDocumentPaymentsSection({
183
187
  (record: PaymentRow) => {
184
188
  setEditingPayment({
185
189
  id: record.id,
190
+ updatedAt: record.updatedAt ?? null,
186
191
  amount: record.amount ?? '',
187
192
  paymentMethodId: record.paymentMethodId ?? '',
188
193
  paymentReference: record.paymentReference ?? '',
@@ -210,15 +215,19 @@ export function SalesDocumentPaymentsSection({
210
215
  const handleDelete = React.useCallback(
211
216
  async (row: PaymentRow) => {
212
217
  try {
213
- const result = await deleteCrud<{ orderTotals?: PaymentTotals | null }>('sales/payments', {
214
- body: {
215
- id: row.id,
216
- orderId,
217
- organizationId: resolvedOrganizationId ?? undefined,
218
- tenantId: resolvedTenantId ?? undefined,
219
- },
220
- errorMessage: t('sales.documents.payments.errorDelete', 'Failed to delete payment.'),
221
- })
218
+ const result = await withScopedApiRequestHeaders(
219
+ buildOptimisticLockHeader(rowOptimisticVersion(row)),
220
+ () =>
221
+ deleteCrud<{ orderTotals?: PaymentTotals | null }>('sales/payments', {
222
+ body: {
223
+ id: row.id,
224
+ orderId,
225
+ organizationId: resolvedOrganizationId ?? undefined,
226
+ tenantId: resolvedTenantId ?? undefined,
227
+ },
228
+ errorMessage: t('sales.documents.payments.errorDelete', 'Failed to delete payment.'),
229
+ })
230
+ )
222
231
  if (result.ok) {
223
232
  onTotalsChange?.()
224
233
  flash(t('sales.documents.payments.deleted', 'Payment deleted.'), 'success')
@@ -226,6 +235,9 @@ export function SalesDocumentPaymentsSection({
226
235
  emitSalesDocumentTotalsRefresh({ documentId: orderId, kind: 'order' })
227
236
  }
228
237
  } catch (err) {
238
+ if (handleSectionMutationError(err, t, () => void loadPayments())) {
239
+ return
240
+ }
229
241
  console.error('sales.payments.delete', err)
230
242
  flash(t('sales.documents.payments.errorDelete', 'Failed to delete payment.'), 'error')
231
243
  }
@@ -8,10 +8,12 @@ import { Textarea } from '@open-mercato/ui/primitives/textarea'
8
8
  import { Label } from '@open-mercato/ui/primitives/label'
9
9
  import { Button } from '@open-mercato/ui/primitives/button'
10
10
  import { useT } from '@open-mercato/shared/lib/i18n/context'
11
- import { apiCallOrThrow } from '@open-mercato/ui/backend/utils/apiCall'
11
+ import { apiCallOrThrow, withScopedApiRequestHeaders } from '@open-mercato/ui/backend/utils/apiCall'
12
+ import { buildOptimisticLockHeader } from '@open-mercato/ui/backend/utils/optimisticLock'
12
13
  import { flash } from '@open-mercato/ui/backend/FlashMessages'
13
14
  import { useGuardedMutation } from '@open-mercato/ui/backend/injection/useGuardedMutation'
14
15
  import { computeAvailableReturnQuantity } from '@open-mercato/core/modules/sales/lib/returnQuantity'
16
+ import { handleSectionMutationError } from './optimisticLock'
15
17
 
16
18
  export type ReturnOrderLine = {
17
19
  id: string
@@ -26,6 +28,7 @@ type ReturnDialogProps = {
26
28
  open: boolean
27
29
  orderId: string
28
30
  lines: ReturnOrderLine[]
31
+ documentUpdatedAt?: string | null
29
32
  onClose: () => void
30
33
  onSaved: () => Promise<void>
31
34
  }
@@ -39,7 +42,7 @@ const normalizeNumber = (value: unknown): number => {
39
42
  return 0
40
43
  }
41
44
 
42
- export function ReturnDialog({ open, orderId, lines, onClose, onSaved }: ReturnDialogProps) {
45
+ export function ReturnDialog({ open, orderId, lines, documentUpdatedAt, onClose, onSaved }: ReturnDialogProps) {
43
46
  const t = useT()
44
47
  const { runMutation } = useGuardedMutation({ contextId: `sales-returns-${orderId}` })
45
48
  const [reason, setReason] = React.useState('')
@@ -104,19 +107,23 @@ export function ReturnDialog({ open, orderId, lines, onClose, onSaved }: ReturnD
104
107
  context: { kind: 'order', record: { id: orderId } },
105
108
  mutationPayload: { orderId, lines: linesForRequest, reason, notes },
106
109
  operation: async () => {
107
- const response = await apiCallOrThrow<{ id: string | null }>(
108
- '/api/sales/returns',
109
- {
110
- method: 'POST',
111
- headers: { 'content-type': 'application/json' },
112
- body: JSON.stringify({
113
- orderId,
114
- lines: linesForRequest,
115
- ...(reason.trim().length ? { reason: reason.trim() } : {}),
116
- ...(notes.trim().length ? { notes: notes.trim() } : {}),
117
- }),
118
- },
119
- { errorMessage: t('sales.returns.errors.create', 'Failed to create return.') },
110
+ const response = await withScopedApiRequestHeaders(
111
+ buildOptimisticLockHeader(documentUpdatedAt),
112
+ () =>
113
+ apiCallOrThrow<{ id: string | null }>(
114
+ '/api/sales/returns',
115
+ {
116
+ method: 'POST',
117
+ headers: { 'content-type': 'application/json' },
118
+ body: JSON.stringify({
119
+ orderId,
120
+ lines: linesForRequest,
121
+ ...(reason.trim().length ? { reason: reason.trim() } : {}),
122
+ ...(notes.trim().length ? { notes: notes.trim() } : {}),
123
+ }),
124
+ },
125
+ { errorMessage: t('sales.returns.errors.create', 'Failed to create return.') },
126
+ ),
120
127
  )
121
128
  return response.result?.id ?? null
122
129
  },
@@ -124,12 +131,16 @@ export function ReturnDialog({ open, orderId, lines, onClose, onSaved }: ReturnD
124
131
  flash(t('sales.returns.created', 'Return created.'), 'success')
125
132
  onClose()
126
133
  await onSaved()
127
- } catch {
134
+ } catch (err) {
135
+ if (handleSectionMutationError(err, t, () => void onSaved())) {
136
+ onClose()
137
+ return
138
+ }
128
139
  flash(t('sales.returns.errors.create', 'Failed to create return.'), 'error')
129
140
  } finally {
130
141
  setSaving(false)
131
142
  }
132
- }, [availableLines, notes, onClose, onSaved, orderId, quantities, reason, runMutation, saving, t])
143
+ }, [availableLines, documentUpdatedAt, notes, onClose, onSaved, orderId, quantities, reason, runMutation, saving, t])
133
144
 
134
145
  const onKeyDown = React.useCallback(
135
146
  (e: React.KeyboardEvent) => {