@open-mercato/core 0.4.2-canary-15c0b23a3a → 0.4.2-canary-da2b080494

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 (433) hide show
  1. package/dist/generated/entities.ids.generated.js +1 -5
  2. package/dist/generated/entities.ids.generated.js.map +2 -2
  3. package/dist/generated/entity-fields-registry.js +0 -2
  4. package/dist/generated/entity-fields-registry.js.map +2 -2
  5. package/dist/modules/api_docs/frontend/docs/api/page.js +2 -3
  6. package/dist/modules/api_docs/frontend/docs/api/page.js.map +2 -2
  7. package/dist/modules/api_keys/backend/api-keys/page.js +1 -1
  8. package/dist/modules/api_keys/backend/api-keys/page.js.map +2 -2
  9. package/dist/modules/attachments/components/AttachmentLibrary.js +0 -4
  10. package/dist/modules/attachments/components/AttachmentLibrary.js.map +2 -2
  11. package/dist/modules/attachments/components/AttachmentPartitionSettings.js +0 -2
  12. package/dist/modules/attachments/components/AttachmentPartitionSettings.js.map +2 -2
  13. package/dist/modules/auth/api/admin/nav.js +3 -4
  14. package/dist/modules/auth/api/admin/nav.js.map +2 -2
  15. package/dist/modules/auth/api/reset/confirm.js +2 -25
  16. package/dist/modules/auth/api/reset/confirm.js.map +2 -2
  17. package/dist/modules/auth/api/reset.js +0 -23
  18. package/dist/modules/auth/api/reset.js.map +2 -2
  19. package/dist/modules/auth/api/sidebar/preferences/route.js +9 -14
  20. package/dist/modules/auth/api/sidebar/preferences/route.js.map +2 -2
  21. package/dist/modules/auth/api/users/route.js +2 -4
  22. package/dist/modules/auth/api/users/route.js.map +2 -2
  23. package/dist/modules/auth/backend/roles/[id]/edit/page.js +1 -4
  24. package/dist/modules/auth/backend/roles/[id]/edit/page.js.map +2 -2
  25. package/dist/modules/auth/backend/roles/page.js +3 -3
  26. package/dist/modules/auth/backend/roles/page.js.map +2 -2
  27. package/dist/modules/auth/backend/users/[id]/edit/page.js +3 -18
  28. package/dist/modules/auth/backend/users/[id]/edit/page.js.map +2 -2
  29. package/dist/modules/auth/backend/users/create/page.js +2 -15
  30. package/dist/modules/auth/backend/users/create/page.js.map +2 -2
  31. package/dist/modules/auth/backend/users/page.js +3 -3
  32. package/dist/modules/auth/backend/users/page.js.map +2 -2
  33. package/dist/modules/auth/cli.js +11 -25
  34. package/dist/modules/auth/cli.js.map +2 -2
  35. package/dist/modules/auth/commands/users.js +2 -59
  36. package/dist/modules/auth/commands/users.js.map +2 -2
  37. package/dist/modules/auth/data/validators.js +2 -4
  38. package/dist/modules/auth/data/validators.js.map +2 -2
  39. package/dist/modules/auth/frontend/reset/[token]/page.js +10 -20
  40. package/dist/modules/auth/frontend/reset/[token]/page.js.map +2 -2
  41. package/dist/modules/auth/lib/setup-app.js +0 -1
  42. package/dist/modules/auth/lib/setup-app.js.map +2 -2
  43. package/dist/modules/auth/services/authService.js +3 -3
  44. package/dist/modules/auth/services/authService.js.map +2 -2
  45. package/dist/modules/business_rules/api/execute/route.js +1 -7
  46. package/dist/modules/business_rules/api/execute/route.js.map +2 -2
  47. package/dist/modules/business_rules/backend/rules/page.js +0 -4
  48. package/dist/modules/business_rules/backend/rules/page.js.map +2 -2
  49. package/dist/modules/business_rules/backend/sets/page.js +0 -3
  50. package/dist/modules/business_rules/backend/sets/page.js.map +2 -2
  51. package/dist/modules/business_rules/lib/rule-engine.js +3 -33
  52. package/dist/modules/business_rules/lib/rule-engine.js.map +2 -2
  53. package/dist/modules/catalog/components/PriceKindSettings.js +0 -2
  54. package/dist/modules/catalog/components/PriceKindSettings.js.map +2 -2
  55. package/dist/modules/catalog/components/categories/CategoriesDataTable.js +2 -2
  56. package/dist/modules/catalog/components/categories/CategoriesDataTable.js.map +2 -2
  57. package/dist/modules/catalog/components/products/ProductsDataTable.js +0 -2
  58. package/dist/modules/catalog/components/products/ProductsDataTable.js.map +2 -2
  59. package/dist/modules/configs/cli.js +0 -6
  60. package/dist/modules/configs/cli.js.map +2 -2
  61. package/dist/modules/configs/components/CachePanel.js +4 -4
  62. package/dist/modules/configs/components/CachePanel.js.map +2 -2
  63. package/dist/modules/configs/lib/system-status.js +1 -48
  64. package/dist/modules/configs/lib/system-status.js.map +2 -2
  65. package/dist/modules/configs/lib/upgrade-actions.js +0 -18
  66. package/dist/modules/configs/lib/upgrade-actions.js.map +2 -2
  67. package/dist/modules/currencies/backend/currencies/page.js +0 -3
  68. package/dist/modules/currencies/backend/currencies/page.js.map +2 -2
  69. package/dist/modules/currencies/backend/exchange-rates/page.js +0 -2
  70. package/dist/modules/currencies/backend/exchange-rates/page.js.map +2 -2
  71. package/dist/modules/customers/backend/customers/companies/page.js +0 -3
  72. package/dist/modules/customers/backend/customers/companies/page.js.map +2 -2
  73. package/dist/modules/customers/backend/customers/deals/page.js +0 -3
  74. package/dist/modules/customers/backend/customers/deals/page.js.map +2 -2
  75. package/dist/modules/customers/backend/customers/people/page.js +0 -3
  76. package/dist/modules/customers/backend/customers/people/page.js.map +2 -2
  77. package/dist/modules/customers/commands/deals.js +0 -31
  78. package/dist/modules/customers/commands/deals.js.map +2 -2
  79. package/dist/modules/customers/components/CustomerTodosTable.js +0 -1
  80. package/dist/modules/customers/components/CustomerTodosTable.js.map +2 -2
  81. package/dist/modules/dashboards/cli.js +5 -44
  82. package/dist/modules/dashboards/cli.js.map +2 -2
  83. package/dist/modules/dashboards/components/WidgetVisibilityEditor.js +11 -16
  84. package/dist/modules/dashboards/components/WidgetVisibilityEditor.js.map +3 -3
  85. package/dist/modules/dashboards/services/widgetDataService.js +3 -132
  86. package/dist/modules/dashboards/services/widgetDataService.js.map +2 -2
  87. package/dist/modules/dictionaries/components/DictionaryTable.js +0 -2
  88. package/dist/modules/dictionaries/components/DictionaryTable.js.map +2 -2
  89. package/dist/modules/directory/backend/directory/organizations/page.js +2 -2
  90. package/dist/modules/directory/backend/directory/organizations/page.js.map +2 -2
  91. package/dist/modules/directory/backend/directory/tenants/page.js +2 -2
  92. package/dist/modules/directory/backend/directory/tenants/page.js.map +2 -2
  93. package/dist/modules/entities/backend/entities/user/[entityId]/records/page.js +2 -2
  94. package/dist/modules/entities/backend/entities/user/[entityId]/records/page.js.map +2 -2
  95. package/dist/modules/entities/components/SystemEntitiesTable.js +1 -1
  96. package/dist/modules/entities/components/SystemEntitiesTable.js.map +2 -2
  97. package/dist/modules/entities/components/UserEntitiesTable.js +2 -2
  98. package/dist/modules/entities/components/UserEntitiesTable.js.map +2 -2
  99. package/dist/modules/feature_toggles/components/FeatureTogglesTable.js +3 -3
  100. package/dist/modules/feature_toggles/components/FeatureTogglesTable.js.map +2 -2
  101. package/dist/modules/feature_toggles/components/OverridesTable.js +1 -1
  102. package/dist/modules/feature_toggles/components/OverridesTable.js.map +2 -2
  103. package/dist/modules/planner/backend/planner/availability-rulesets/page.js +2 -2
  104. package/dist/modules/planner/backend/planner/availability-rulesets/page.js.map +2 -2
  105. package/dist/modules/query_index/components/QueryIndexesTable.js +1 -7
  106. package/dist/modules/query_index/components/QueryIndexesTable.js.map +2 -2
  107. package/dist/modules/resources/backend/resources/resource-types/page.js +2 -2
  108. package/dist/modules/resources/backend/resources/resource-types/page.js.map +2 -2
  109. package/dist/modules/resources/backend/resources/resources/page.js +2 -2
  110. package/dist/modules/resources/backend/resources/resources/page.js.map +2 -2
  111. package/dist/modules/sales/backend/sales/channels/offers/page.js +0 -2
  112. package/dist/modules/sales/backend/sales/channels/offers/page.js.map +2 -2
  113. package/dist/modules/sales/backend/sales/channels/page.js +0 -2
  114. package/dist/modules/sales/backend/sales/channels/page.js.map +2 -2
  115. package/dist/modules/sales/commands/documents.js +0 -53
  116. package/dist/modules/sales/commands/documents.js.map +2 -2
  117. package/dist/modules/sales/commands/payments.js +0 -26
  118. package/dist/modules/sales/commands/payments.js.map +2 -2
  119. package/dist/modules/sales/components/AdjustmentKindSettings.js +2 -2
  120. package/dist/modules/sales/components/AdjustmentKindSettings.js.map +2 -2
  121. package/dist/modules/sales/components/PaymentMethodsSettings.js +2 -2
  122. package/dist/modules/sales/components/PaymentMethodsSettings.js.map +2 -2
  123. package/dist/modules/sales/components/ShippingMethodsSettings.js +2 -2
  124. package/dist/modules/sales/components/ShippingMethodsSettings.js.map +2 -2
  125. package/dist/modules/sales/components/TaxRatesSettings.js +2 -2
  126. package/dist/modules/sales/components/TaxRatesSettings.js.map +2 -2
  127. package/dist/modules/sales/components/channels/SalesChannelOffersPanel.js +0 -2
  128. package/dist/modules/sales/components/channels/SalesChannelOffersPanel.js.map +2 -2
  129. package/dist/modules/sales/components/documents/AdjustmentsSection.js +0 -2
  130. package/dist/modules/sales/components/documents/AdjustmentsSection.js.map +2 -2
  131. package/dist/modules/sales/components/documents/PaymentsSection.js +1 -2
  132. package/dist/modules/sales/components/documents/PaymentsSection.js.map +2 -2
  133. package/dist/modules/sales/components/documents/SalesDocumentsTable.js +0 -2
  134. package/dist/modules/sales/components/documents/SalesDocumentsTable.js.map +2 -2
  135. package/dist/modules/staff/backend/staff/team-members/page.js +1 -1
  136. package/dist/modules/staff/backend/staff/team-members/page.js.map +2 -2
  137. package/dist/modules/staff/backend/staff/team-roles/page.js +2 -2
  138. package/dist/modules/staff/backend/staff/team-roles/page.js.map +2 -2
  139. package/dist/modules/staff/backend/staff/teams/[id]/edit/page.js +2 -2
  140. package/dist/modules/staff/backend/staff/teams/[id]/edit/page.js.map +2 -2
  141. package/dist/modules/staff/backend/staff/teams/page.js +2 -2
  142. package/dist/modules/staff/backend/staff/teams/page.js.map +2 -2
  143. package/dist/modules/staff/commands/leave-requests.js +0 -79
  144. package/dist/modules/staff/commands/leave-requests.js.map +2 -2
  145. package/dist/modules/workflows/backend/definitions/page.js +0 -5
  146. package/dist/modules/workflows/backend/definitions/page.js.map +2 -2
  147. package/dist/modules/workflows/backend/instances/page.js +0 -3
  148. package/dist/modules/workflows/backend/instances/page.js.map +2 -2
  149. package/dist/modules/workflows/backend/tasks/page.js +0 -3
  150. package/dist/modules/workflows/backend/tasks/page.js.map +2 -2
  151. package/dist/modules/workflows/lib/transition-handler.js +6 -14
  152. package/dist/modules/workflows/lib/transition-handler.js.map +2 -2
  153. package/generated/entities.ids.generated.ts +1 -5
  154. package/generated/entity-fields-registry.ts +0 -2
  155. package/package.json +2 -2
  156. package/src/modules/api_docs/frontend/docs/api/page.tsx +2 -3
  157. package/src/modules/api_keys/backend/api-keys/page.tsx +1 -1
  158. package/src/modules/attachments/components/AttachmentLibrary.tsx +0 -4
  159. package/src/modules/attachments/components/AttachmentPartitionSettings.tsx +0 -2
  160. package/src/modules/auth/README.md +1 -1
  161. package/src/modules/auth/__tests__/cli-setup-acl.test.ts +1 -1
  162. package/src/modules/auth/api/admin/nav.ts +6 -10
  163. package/src/modules/auth/api/reset/confirm.ts +2 -25
  164. package/src/modules/auth/api/reset.ts +0 -23
  165. package/src/modules/auth/api/sidebar/preferences/route.ts +12 -21
  166. package/src/modules/auth/api/users/route.ts +2 -5
  167. package/src/modules/auth/backend/roles/[id]/edit/page.tsx +1 -4
  168. package/src/modules/auth/backend/roles/page.tsx +3 -3
  169. package/src/modules/auth/backend/users/[id]/edit/page.tsx +3 -22
  170. package/src/modules/auth/backend/users/create/page.tsx +2 -19
  171. package/src/modules/auth/backend/users/page.tsx +3 -3
  172. package/src/modules/auth/cli.ts +11 -38
  173. package/src/modules/auth/commands/users.ts +2 -73
  174. package/src/modules/auth/data/validators.ts +2 -5
  175. package/src/modules/auth/frontend/reset/[token]/page.tsx +11 -24
  176. package/src/modules/auth/i18n/de.json +1 -43
  177. package/src/modules/auth/i18n/en.json +1 -43
  178. package/src/modules/auth/i18n/es.json +1 -43
  179. package/src/modules/auth/i18n/pl.json +1 -43
  180. package/src/modules/auth/lib/setup-app.ts +0 -1
  181. package/src/modules/auth/services/authService.ts +4 -4
  182. package/src/modules/business_rules/api/execute/route.ts +1 -8
  183. package/src/modules/business_rules/backend/rules/page.tsx +0 -4
  184. package/src/modules/business_rules/backend/sets/page.tsx +0 -3
  185. package/src/modules/business_rules/i18n/en.json +1 -3
  186. package/src/modules/business_rules/lib/__tests__/rule-engine.test.ts +0 -51
  187. package/src/modules/business_rules/lib/rule-engine.ts +3 -57
  188. package/src/modules/catalog/components/PriceKindSettings.tsx +0 -2
  189. package/src/modules/catalog/components/categories/CategoriesDataTable.tsx +2 -2
  190. package/src/modules/catalog/components/products/ProductsDataTable.tsx +0 -2
  191. package/src/modules/catalog/i18n/en.json +1 -3
  192. package/src/modules/configs/cli.ts +0 -6
  193. package/src/modules/configs/components/CachePanel.tsx +4 -4
  194. package/src/modules/configs/i18n/en.json +2 -12
  195. package/src/modules/configs/i18n/pl.json +2 -12
  196. package/src/modules/configs/lib/system-status.ts +1 -48
  197. package/src/modules/configs/lib/system-status.types.ts +0 -1
  198. package/src/modules/configs/lib/upgrade-actions.ts +0 -18
  199. package/src/modules/currencies/backend/currencies/page.tsx +0 -3
  200. package/src/modules/currencies/backend/exchange-rates/page.tsx +0 -2
  201. package/src/modules/customers/backend/customers/companies/page.tsx +0 -3
  202. package/src/modules/customers/backend/customers/deals/page.tsx +0 -3
  203. package/src/modules/customers/backend/customers/people/page.tsx +0 -3
  204. package/src/modules/customers/commands/deals.ts +0 -39
  205. package/src/modules/customers/components/CustomerTodosTable.tsx +0 -1
  206. package/src/modules/customers/i18n/en.json +1 -5
  207. package/src/modules/dashboards/cli.ts +5 -55
  208. package/src/modules/dashboards/components/WidgetVisibilityEditor.tsx +11 -22
  209. package/src/modules/dashboards/services/widgetDataService.ts +4 -157
  210. package/src/modules/dictionaries/components/DictionaryTable.tsx +0 -2
  211. package/src/modules/directory/backend/directory/organizations/page.tsx +2 -2
  212. package/src/modules/directory/backend/directory/tenants/page.tsx +2 -2
  213. package/src/modules/entities/backend/entities/user/[entityId]/records/page.tsx +2 -2
  214. package/src/modules/entities/components/SystemEntitiesTable.tsx +1 -1
  215. package/src/modules/entities/components/UserEntitiesTable.tsx +2 -2
  216. package/src/modules/feature_toggles/components/FeatureTogglesTable.tsx +4 -3
  217. package/src/modules/feature_toggles/components/OverridesTable.tsx +1 -1
  218. package/src/modules/planner/backend/planner/availability-rulesets/page.tsx +2 -2
  219. package/src/modules/query_index/components/QueryIndexesTable.tsx +2 -8
  220. package/src/modules/resources/backend/resources/resource-types/page.tsx +2 -2
  221. package/src/modules/resources/backend/resources/resources/page.tsx +2 -2
  222. package/src/modules/sales/backend/sales/channels/offers/page.tsx +0 -2
  223. package/src/modules/sales/backend/sales/channels/page.tsx +0 -2
  224. package/src/modules/sales/commands/documents.ts +0 -65
  225. package/src/modules/sales/commands/payments.ts +0 -33
  226. package/src/modules/sales/components/AdjustmentKindSettings.tsx +2 -2
  227. package/src/modules/sales/components/PaymentMethodsSettings.tsx +2 -2
  228. package/src/modules/sales/components/ShippingMethodsSettings.tsx +2 -2
  229. package/src/modules/sales/components/TaxRatesSettings.tsx +2 -2
  230. package/src/modules/sales/components/channels/SalesChannelOffersPanel.tsx +0 -2
  231. package/src/modules/sales/components/documents/AdjustmentsSection.tsx +0 -2
  232. package/src/modules/sales/components/documents/PaymentsSection.tsx +1 -2
  233. package/src/modules/sales/components/documents/SalesDocumentsTable.tsx +0 -2
  234. package/src/modules/sales/i18n/de.json +0 -20
  235. package/src/modules/sales/i18n/en.json +1 -25
  236. package/src/modules/sales/i18n/es.json +0 -20
  237. package/src/modules/sales/i18n/pl.json +0 -20
  238. package/src/modules/staff/backend/staff/team-members/page.tsx +1 -1
  239. package/src/modules/staff/backend/staff/team-roles/page.tsx +2 -2
  240. package/src/modules/staff/backend/staff/teams/[id]/edit/page.tsx +2 -2
  241. package/src/modules/staff/backend/staff/teams/page.tsx +2 -2
  242. package/src/modules/staff/commands/leave-requests.ts +0 -94
  243. package/src/modules/staff/i18n/de.json +0 -4
  244. package/src/modules/staff/i18n/en.json +1 -9
  245. package/src/modules/staff/i18n/es.json +0 -4
  246. package/src/modules/staff/i18n/pl.json +0 -4
  247. package/src/modules/workflows/backend/definitions/page.tsx +0 -5
  248. package/src/modules/workflows/backend/instances/page.tsx +1 -4
  249. package/src/modules/workflows/backend/tasks/page.tsx +1 -4
  250. package/src/modules/workflows/i18n/en.json +1 -3
  251. package/src/modules/workflows/lib/transition-handler.ts +6 -18
  252. package/dist/generated/entities/notification/index.js +0 -57
  253. package/dist/generated/entities/notification/index.js.map +0 -7
  254. package/dist/modules/auth/api/profile/route.js +0 -157
  255. package/dist/modules/auth/api/profile/route.js.map +0 -7
  256. package/dist/modules/auth/backend/auth/profile/page.js +0 -141
  257. package/dist/modules/auth/backend/auth/profile/page.js.map +0 -7
  258. package/dist/modules/auth/backend/auth/profile/page.meta.js +0 -13
  259. package/dist/modules/auth/backend/auth/profile/page.meta.js.map +0 -7
  260. package/dist/modules/auth/notifications.js +0 -112
  261. package/dist/modules/auth/notifications.js.map +0 -7
  262. package/dist/modules/business_rules/notifications.js +0 -28
  263. package/dist/modules/business_rules/notifications.js.map +0 -7
  264. package/dist/modules/business_rules/subscribers/rule-execution-failed-notification.js +0 -37
  265. package/dist/modules/business_rules/subscribers/rule-execution-failed-notification.js.map +0 -7
  266. package/dist/modules/catalog/notifications.js +0 -28
  267. package/dist/modules/catalog/notifications.js.map +0 -7
  268. package/dist/modules/catalog/subscribers/low-stock-notification.js +0 -38
  269. package/dist/modules/catalog/subscribers/low-stock-notification.js.map +0 -7
  270. package/dist/modules/customers/notifications.js +0 -48
  271. package/dist/modules/customers/notifications.js.map +0 -7
  272. package/dist/modules/dashboards/lib/role-widgets.js +0 -58
  273. package/dist/modules/dashboards/lib/role-widgets.js.map +0 -7
  274. package/dist/modules/notifications/acl.js +0 -11
  275. package/dist/modules/notifications/acl.js.map +0 -7
  276. package/dist/modules/notifications/api/[id]/action/route.js +0 -74
  277. package/dist/modules/notifications/api/[id]/action/route.js.map +0 -7
  278. package/dist/modules/notifications/api/[id]/dismiss/route.js +0 -15
  279. package/dist/modules/notifications/api/[id]/dismiss/route.js.map +0 -7
  280. package/dist/modules/notifications/api/[id]/read/route.js +0 -15
  281. package/dist/modules/notifications/api/[id]/read/route.js.map +0 -7
  282. package/dist/modules/notifications/api/[id]/restore/route.js +0 -53
  283. package/dist/modules/notifications/api/[id]/restore/route.js.map +0 -7
  284. package/dist/modules/notifications/api/batch/route.js +0 -17
  285. package/dist/modules/notifications/api/batch/route.js.map +0 -7
  286. package/dist/modules/notifications/api/feature/route.js +0 -17
  287. package/dist/modules/notifications/api/feature/route.js.map +0 -7
  288. package/dist/modules/notifications/api/mark-all-read/route.js +0 -35
  289. package/dist/modules/notifications/api/mark-all-read/route.js.map +0 -7
  290. package/dist/modules/notifications/api/openapi.js +0 -76
  291. package/dist/modules/notifications/api/openapi.js.map +0 -7
  292. package/dist/modules/notifications/api/role/route.js +0 -17
  293. package/dist/modules/notifications/api/role/route.js.map +0 -7
  294. package/dist/modules/notifications/api/route.js +0 -85
  295. package/dist/modules/notifications/api/route.js.map +0 -7
  296. package/dist/modules/notifications/api/settings/route.js +0 -155
  297. package/dist/modules/notifications/api/settings/route.js.map +0 -7
  298. package/dist/modules/notifications/api/unread-count/route.js +0 -38
  299. package/dist/modules/notifications/api/unread-count/route.js.map +0 -7
  300. package/dist/modules/notifications/backend/config/notifications/page.js +0 -10
  301. package/dist/modules/notifications/backend/config/notifications/page.js.map +0 -7
  302. package/dist/modules/notifications/backend/config/notifications/page.meta.js +0 -24
  303. package/dist/modules/notifications/backend/config/notifications/page.meta.js.map +0 -7
  304. package/dist/modules/notifications/cli.js +0 -16
  305. package/dist/modules/notifications/cli.js.map +0 -7
  306. package/dist/modules/notifications/data/entities.js +0 -112
  307. package/dist/modules/notifications/data/entities.js.map +0 -7
  308. package/dist/modules/notifications/data/validators.js +0 -98
  309. package/dist/modules/notifications/data/validators.js.map +0 -7
  310. package/dist/modules/notifications/di.js +0 -13
  311. package/dist/modules/notifications/di.js.map +0 -7
  312. package/dist/modules/notifications/emails/NotificationEmail.js +0 -58
  313. package/dist/modules/notifications/emails/NotificationEmail.js.map +0 -7
  314. package/dist/modules/notifications/frontend/NotificationInboxPageClient.js +0 -44
  315. package/dist/modules/notifications/frontend/NotificationInboxPageClient.js.map +0 -7
  316. package/dist/modules/notifications/frontend/NotificationSettingsPageClient.js +0 -220
  317. package/dist/modules/notifications/frontend/NotificationSettingsPageClient.js.map +0 -7
  318. package/dist/modules/notifications/index.js +0 -14
  319. package/dist/modules/notifications/index.js.map +0 -7
  320. package/dist/modules/notifications/lib/deliveryConfig.js +0 -107
  321. package/dist/modules/notifications/lib/deliveryConfig.js.map +0 -7
  322. package/dist/modules/notifications/lib/deliveryStrategies.js +0 -14
  323. package/dist/modules/notifications/lib/deliveryStrategies.js.map +0 -7
  324. package/dist/modules/notifications/lib/events.js +0 -12
  325. package/dist/modules/notifications/lib/events.js.map +0 -7
  326. package/dist/modules/notifications/lib/notificationBuilder.js +0 -66
  327. package/dist/modules/notifications/lib/notificationBuilder.js.map +0 -7
  328. package/dist/modules/notifications/lib/notificationFactory.js +0 -54
  329. package/dist/modules/notifications/lib/notificationFactory.js.map +0 -7
  330. package/dist/modules/notifications/lib/notificationMapper.js +0 -34
  331. package/dist/modules/notifications/lib/notificationMapper.js.map +0 -7
  332. package/dist/modules/notifications/lib/notificationRecipients.js +0 -35
  333. package/dist/modules/notifications/lib/notificationRecipients.js.map +0 -7
  334. package/dist/modules/notifications/lib/notificationService.js +0 -279
  335. package/dist/modules/notifications/lib/notificationService.js.map +0 -7
  336. package/dist/modules/notifications/lib/routeHelpers.js +0 -101
  337. package/dist/modules/notifications/lib/routeHelpers.js.map +0 -7
  338. package/dist/modules/notifications/lib/safeHref.js +0 -24
  339. package/dist/modules/notifications/lib/safeHref.js.map +0 -7
  340. package/dist/modules/notifications/migrations/Migration20260123000001.js +0 -70
  341. package/dist/modules/notifications/migrations/Migration20260123000001.js.map +0 -7
  342. package/dist/modules/notifications/migrations/Migration20260126150000.js +0 -37
  343. package/dist/modules/notifications/migrations/Migration20260126150000.js.map +0 -7
  344. package/dist/modules/notifications/subscribers/deliver-notification.js +0 -165
  345. package/dist/modules/notifications/subscribers/deliver-notification.js.map +0 -7
  346. package/dist/modules/notifications/workers/create-notification.worker.js +0 -70
  347. package/dist/modules/notifications/workers/create-notification.worker.js.map +0 -7
  348. package/dist/modules/sales/notifications.client.js +0 -51
  349. package/dist/modules/sales/notifications.client.js.map +0 -7
  350. package/dist/modules/sales/notifications.js +0 -88
  351. package/dist/modules/sales/notifications.js.map +0 -7
  352. package/dist/modules/sales/subscribers/quote-expiring-notification.js +0 -38
  353. package/dist/modules/sales/subscribers/quote-expiring-notification.js.map +0 -7
  354. package/dist/modules/sales/widgets/notifications/SalesOrderCreatedRenderer.js +0 -137
  355. package/dist/modules/sales/widgets/notifications/SalesOrderCreatedRenderer.js.map +0 -7
  356. package/dist/modules/sales/widgets/notifications/SalesQuoteCreatedRenderer.js +0 -137
  357. package/dist/modules/sales/widgets/notifications/SalesQuoteCreatedRenderer.js.map +0 -7
  358. package/dist/modules/sales/widgets/notifications/index.js +0 -7
  359. package/dist/modules/sales/widgets/notifications/index.js.map +0 -7
  360. package/dist/modules/sales/widgets/notifications/useSalesDocumentTotals.js +0 -60
  361. package/dist/modules/sales/widgets/notifications/useSalesDocumentTotals.js.map +0 -7
  362. package/dist/modules/staff/notifications.js +0 -75
  363. package/dist/modules/staff/notifications.js.map +0 -7
  364. package/dist/modules/workflows/notifications.js +0 -28
  365. package/dist/modules/workflows/notifications.js.map +0 -7
  366. package/dist/modules/workflows/subscribers/task-assigned-notification.js +0 -38
  367. package/dist/modules/workflows/subscribers/task-assigned-notification.js.map +0 -7
  368. package/generated/entities/notification/index.ts +0 -27
  369. package/src/modules/auth/api/profile/route.ts +0 -163
  370. package/src/modules/auth/backend/auth/profile/page.meta.ts +0 -9
  371. package/src/modules/auth/backend/auth/profile/page.tsx +0 -174
  372. package/src/modules/auth/notifications.ts +0 -109
  373. package/src/modules/business_rules/notifications.ts +0 -25
  374. package/src/modules/business_rules/subscribers/rule-execution-failed-notification.ts +0 -50
  375. package/src/modules/catalog/notifications.ts +0 -25
  376. package/src/modules/catalog/subscribers/low-stock-notification.ts +0 -52
  377. package/src/modules/customers/notifications.ts +0 -44
  378. package/src/modules/dashboards/lib/role-widgets.ts +0 -80
  379. package/src/modules/notifications/__tests__/deliver-notification.test.ts +0 -195
  380. package/src/modules/notifications/__tests__/deliveryStrategies.test.ts +0 -19
  381. package/src/modules/notifications/__tests__/notificationService.test.ts +0 -208
  382. package/src/modules/notifications/acl.ts +0 -7
  383. package/src/modules/notifications/api/[id]/action/route.ts +0 -75
  384. package/src/modules/notifications/api/[id]/dismiss/route.ts +0 -12
  385. package/src/modules/notifications/api/[id]/read/route.ts +0 -12
  386. package/src/modules/notifications/api/[id]/restore/route.ts +0 -53
  387. package/src/modules/notifications/api/batch/route.ts +0 -14
  388. package/src/modules/notifications/api/feature/route.ts +0 -14
  389. package/src/modules/notifications/api/mark-all-read/route.ts +0 -34
  390. package/src/modules/notifications/api/openapi.ts +0 -76
  391. package/src/modules/notifications/api/role/route.ts +0 -14
  392. package/src/modules/notifications/api/route.ts +0 -92
  393. package/src/modules/notifications/api/settings/route.ts +0 -157
  394. package/src/modules/notifications/api/unread-count/route.ts +0 -38
  395. package/src/modules/notifications/backend/config/notifications/page.meta.ts +0 -22
  396. package/src/modules/notifications/backend/config/notifications/page.tsx +0 -12
  397. package/src/modules/notifications/cli.ts +0 -18
  398. package/src/modules/notifications/data/entities.ts +0 -99
  399. package/src/modules/notifications/data/validators.ts +0 -115
  400. package/src/modules/notifications/di.ts +0 -11
  401. package/src/modules/notifications/emails/NotificationEmail.tsx +0 -98
  402. package/src/modules/notifications/frontend/NotificationInboxPageClient.tsx +0 -42
  403. package/src/modules/notifications/frontend/NotificationSettingsPageClient.tsx +0 -233
  404. package/src/modules/notifications/i18n/de.json +0 -50
  405. package/src/modules/notifications/i18n/en.json +0 -50
  406. package/src/modules/notifications/i18n/es.json +0 -50
  407. package/src/modules/notifications/i18n/pl.json +0 -50
  408. package/src/modules/notifications/index.ts +0 -12
  409. package/src/modules/notifications/lib/deliveryConfig.ts +0 -153
  410. package/src/modules/notifications/lib/deliveryStrategies.ts +0 -50
  411. package/src/modules/notifications/lib/events.ts +0 -48
  412. package/src/modules/notifications/lib/notificationBuilder.ts +0 -121
  413. package/src/modules/notifications/lib/notificationFactory.ts +0 -76
  414. package/src/modules/notifications/lib/notificationMapper.ts +0 -33
  415. package/src/modules/notifications/lib/notificationRecipients.ts +0 -83
  416. package/src/modules/notifications/lib/notificationService.ts +0 -414
  417. package/src/modules/notifications/lib/routeHelpers.ts +0 -151
  418. package/src/modules/notifications/lib/safeHref.ts +0 -29
  419. package/src/modules/notifications/migrations/.snapshot-open-mercato.json +0 -300
  420. package/src/modules/notifications/migrations/Migration20260123000001.ts +0 -73
  421. package/src/modules/notifications/migrations/Migration20260126150000.ts +0 -39
  422. package/src/modules/notifications/subscribers/deliver-notification.ts +0 -204
  423. package/src/modules/notifications/workers/create-notification.worker.ts +0 -122
  424. package/src/modules/sales/notifications.client.ts +0 -65
  425. package/src/modules/sales/notifications.ts +0 -82
  426. package/src/modules/sales/subscribers/quote-expiring-notification.ts +0 -53
  427. package/src/modules/sales/widgets/notifications/SalesOrderCreatedRenderer.tsx +0 -156
  428. package/src/modules/sales/widgets/notifications/SalesQuoteCreatedRenderer.tsx +0 -156
  429. package/src/modules/sales/widgets/notifications/index.ts +0 -2
  430. package/src/modules/sales/widgets/notifications/useSalesDocumentTotals.ts +0 -81
  431. package/src/modules/staff/notifications.ts +0 -71
  432. package/src/modules/workflows/notifications.ts +0 -25
  433. package/src/modules/workflows/subscribers/task-assigned-notification.ts +0 -53
@@ -1,75 +0,0 @@
1
- const notificationTypes = [
2
- {
3
- type: "staff.leave_request.pending",
4
- module: "staff",
5
- titleKey: "staff.notifications.leaveRequest.pending.title",
6
- bodyKey: "staff.notifications.leaveRequest.pending.body",
7
- icon: "calendar-off",
8
- severity: "warning",
9
- actions: [
10
- {
11
- id: "approve",
12
- labelKey: "staff.notifications.leaveRequest.actions.approve",
13
- variant: "default",
14
- icon: "check",
15
- commandId: "staff.leave-requests.accept"
16
- },
17
- {
18
- id: "reject",
19
- labelKey: "staff.notifications.leaveRequest.actions.reject",
20
- variant: "destructive",
21
- icon: "x",
22
- commandId: "staff.leave-requests.reject"
23
- }
24
- ],
25
- primaryActionId: "approve",
26
- linkHref: "/backend/staff/leave-requests/{sourceEntityId}",
27
- expiresAfterHours: 168
28
- },
29
- {
30
- type: "staff.leave_request.approved",
31
- module: "staff",
32
- titleKey: "staff.notifications.leaveRequest.approved.title",
33
- bodyKey: "staff.notifications.leaveRequest.approved.body",
34
- icon: "calendar-check",
35
- severity: "success",
36
- actions: [
37
- {
38
- id: "view",
39
- labelKey: "common.view",
40
- variant: "outline",
41
- href: "/backend/staff/leave-requests/{sourceEntityId}",
42
- icon: "external-link"
43
- }
44
- ],
45
- linkHref: "/backend/staff/leave-requests/{sourceEntityId}",
46
- expiresAfterHours: 168
47
- // 7 days
48
- },
49
- {
50
- type: "staff.leave_request.rejected",
51
- module: "staff",
52
- titleKey: "staff.notifications.leaveRequest.rejected.title",
53
- bodyKey: "staff.notifications.leaveRequest.rejected.body",
54
- icon: "calendar-x",
55
- severity: "warning",
56
- actions: [
57
- {
58
- id: "view",
59
- labelKey: "common.view",
60
- variant: "outline",
61
- href: "/backend/staff/leave-requests/{sourceEntityId}",
62
- icon: "external-link"
63
- }
64
- ],
65
- linkHref: "/backend/staff/leave-requests/{sourceEntityId}",
66
- expiresAfterHours: 168
67
- // 7 days
68
- }
69
- ];
70
- var notifications_default = notificationTypes;
71
- export {
72
- notifications_default as default,
73
- notificationTypes
74
- };
75
- //# sourceMappingURL=notifications.js.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/modules/staff/notifications.ts"],
4
- "sourcesContent": ["import type { NotificationTypeDefinition } from '@open-mercato/shared/modules/notifications/types'\n\nexport const notificationTypes: NotificationTypeDefinition[] = [\n {\n type: 'staff.leave_request.pending',\n module: 'staff',\n titleKey: 'staff.notifications.leaveRequest.pending.title',\n bodyKey: 'staff.notifications.leaveRequest.pending.body',\n icon: 'calendar-off',\n severity: 'warning',\n actions: [\n {\n id: 'approve',\n labelKey: 'staff.notifications.leaveRequest.actions.approve',\n variant: 'default',\n icon: 'check',\n commandId: 'staff.leave-requests.accept',\n },\n {\n id: 'reject',\n labelKey: 'staff.notifications.leaveRequest.actions.reject',\n variant: 'destructive',\n icon: 'x',\n commandId: 'staff.leave-requests.reject',\n },\n ],\n primaryActionId: 'approve',\n linkHref: '/backend/staff/leave-requests/{sourceEntityId}',\n expiresAfterHours: 168,\n },\n {\n type: 'staff.leave_request.approved',\n module: 'staff',\n titleKey: 'staff.notifications.leaveRequest.approved.title',\n bodyKey: 'staff.notifications.leaveRequest.approved.body',\n icon: 'calendar-check',\n severity: 'success',\n actions: [\n {\n id: 'view',\n labelKey: 'common.view',\n variant: 'outline',\n href: '/backend/staff/leave-requests/{sourceEntityId}',\n icon: 'external-link',\n },\n ],\n linkHref: '/backend/staff/leave-requests/{sourceEntityId}',\n expiresAfterHours: 168, // 7 days\n },\n {\n type: 'staff.leave_request.rejected',\n module: 'staff',\n titleKey: 'staff.notifications.leaveRequest.rejected.title',\n bodyKey: 'staff.notifications.leaveRequest.rejected.body',\n icon: 'calendar-x',\n severity: 'warning',\n actions: [\n {\n id: 'view',\n labelKey: 'common.view',\n variant: 'outline',\n href: '/backend/staff/leave-requests/{sourceEntityId}',\n icon: 'external-link',\n },\n ],\n linkHref: '/backend/staff/leave-requests/{sourceEntityId}',\n expiresAfterHours: 168, // 7 days\n },\n]\n\nexport default notificationTypes\n"],
5
- "mappings": "AAEO,MAAM,oBAAkD;AAAA,EAC7D;AAAA,IACE,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,SAAS;AAAA,IACT,MAAM;AAAA,IACN,UAAU;AAAA,IACV,SAAS;AAAA,MACP;AAAA,QACE,IAAI;AAAA,QACJ,UAAU;AAAA,QACV,SAAS;AAAA,QACT,MAAM;AAAA,QACN,WAAW;AAAA,MACb;AAAA,MACA;AAAA,QACE,IAAI;AAAA,QACJ,UAAU;AAAA,QACV,SAAS;AAAA,QACT,MAAM;AAAA,QACN,WAAW;AAAA,MACb;AAAA,IACF;AAAA,IACA,iBAAiB;AAAA,IACjB,UAAU;AAAA,IACV,mBAAmB;AAAA,EACrB;AAAA,EACA;AAAA,IACE,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,SAAS;AAAA,IACT,MAAM;AAAA,IACN,UAAU;AAAA,IACV,SAAS;AAAA,MACP;AAAA,QACE,IAAI;AAAA,QACJ,UAAU;AAAA,QACV,SAAS;AAAA,QACT,MAAM;AAAA,QACN,MAAM;AAAA,MACR;AAAA,IACF;AAAA,IACA,UAAU;AAAA,IACV,mBAAmB;AAAA;AAAA,EACrB;AAAA,EACA;AAAA,IACE,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,SAAS;AAAA,IACT,MAAM;AAAA,IACN,UAAU;AAAA,IACV,SAAS;AAAA,MACP;AAAA,QACE,IAAI;AAAA,QACJ,UAAU;AAAA,QACV,SAAS;AAAA,QACT,MAAM;AAAA,QACN,MAAM;AAAA,MACR;AAAA,IACF;AAAA,IACA,UAAU;AAAA,IACV,mBAAmB;AAAA;AAAA,EACrB;AACF;AAEA,IAAO,wBAAQ;",
6
- "names": []
7
- }
@@ -1,28 +0,0 @@
1
- const notificationTypes = [
2
- {
3
- type: "workflows.task.assigned",
4
- module: "workflows",
5
- titleKey: "workflows.notifications.task.assigned.title",
6
- bodyKey: "workflows.notifications.task.assigned.body",
7
- icon: "clipboard-list",
8
- severity: "info",
9
- actions: [
10
- {
11
- id: "view",
12
- labelKey: "common.view",
13
- variant: "outline",
14
- href: "/backend/workflows/tasks/{sourceEntityId}",
15
- icon: "external-link"
16
- }
17
- ],
18
- linkHref: "/backend/workflows/tasks/{sourceEntityId}",
19
- expiresAfterHours: 168
20
- // 7 days
21
- }
22
- ];
23
- var notifications_default = notificationTypes;
24
- export {
25
- notifications_default as default,
26
- notificationTypes
27
- };
28
- //# sourceMappingURL=notifications.js.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/modules/workflows/notifications.ts"],
4
- "sourcesContent": ["import type { NotificationTypeDefinition } from '@open-mercato/shared/modules/notifications/types'\n\nexport const notificationTypes: NotificationTypeDefinition[] = [\n {\n type: 'workflows.task.assigned',\n module: 'workflows',\n titleKey: 'workflows.notifications.task.assigned.title',\n bodyKey: 'workflows.notifications.task.assigned.body',\n icon: 'clipboard-list',\n severity: 'info',\n actions: [\n {\n id: 'view',\n labelKey: 'common.view',\n variant: 'outline',\n href: '/backend/workflows/tasks/{sourceEntityId}',\n icon: 'external-link',\n },\n ],\n linkHref: '/backend/workflows/tasks/{sourceEntityId}',\n expiresAfterHours: 168, // 7 days\n },\n]\n\nexport default notificationTypes\n"],
5
- "mappings": "AAEO,MAAM,oBAAkD;AAAA,EAC7D;AAAA,IACE,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,SAAS;AAAA,IACT,MAAM;AAAA,IACN,UAAU;AAAA,IACV,SAAS;AAAA,MACP;AAAA,QACE,IAAI;AAAA,QACJ,UAAU;AAAA,QACV,SAAS;AAAA,QACT,MAAM;AAAA,QACN,MAAM;AAAA,MACR;AAAA,IACF;AAAA,IACA,UAAU;AAAA,IACV,mBAAmB;AAAA;AAAA,EACrB;AACF;AAEA,IAAO,wBAAQ;",
6
- "names": []
7
- }
@@ -1,38 +0,0 @@
1
- import { resolveNotificationService } from "../../notifications/lib/notificationService.js";
2
- import { buildNotificationFromType } from "../../notifications/lib/notificationBuilder.js";
3
- import { notificationTypes } from "../notifications.js";
4
- const metadata = {
5
- event: "workflows.task.assigned",
6
- persistent: true,
7
- id: "workflows:task-assigned-notification"
8
- };
9
- async function handle(payload, ctx) {
10
- if (!payload.assignedUserId) return;
11
- try {
12
- const notificationService = resolveNotificationService(ctx);
13
- const typeDef = notificationTypes.find((type) => type.type === "workflows.task.assigned");
14
- if (!typeDef) return;
15
- const notificationInput = buildNotificationFromType(typeDef, {
16
- recipientUserId: payload.assignedUserId,
17
- bodyVariables: {
18
- taskName: payload.taskName,
19
- workflowName: payload.workflowName,
20
- dueDate: payload.dueDate ?? ""
21
- },
22
- sourceEntityType: "workflows:user_task",
23
- sourceEntityId: payload.taskId,
24
- linkHref: `/backend/workflows/tasks/${payload.taskId}`
25
- });
26
- await notificationService.create(notificationInput, {
27
- tenantId: payload.tenantId,
28
- organizationId: payload.organizationId ?? null
29
- });
30
- } catch (err) {
31
- console.error("[workflows:task-assigned-notification] Failed to create notification:", err);
32
- }
33
- }
34
- export {
35
- handle as default,
36
- metadata
37
- };
38
- //# sourceMappingURL=task-assigned-notification.js.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../../src/modules/workflows/subscribers/task-assigned-notification.ts"],
4
- "sourcesContent": ["import type { EntityManager } from '@mikro-orm/postgresql'\nimport { resolveNotificationService } from '../../notifications/lib/notificationService'\nimport { buildNotificationFromType } from '../../notifications/lib/notificationBuilder'\nimport { notificationTypes } from '../notifications'\n\nexport const metadata = {\n event: 'workflows.task.assigned',\n persistent: true,\n id: 'workflows:task-assigned-notification',\n}\n\ntype TaskAssignedPayload = {\n taskId: string\n taskName: string\n workflowName: string\n assignedUserId: string\n dueDate?: string | null\n tenantId: string\n organizationId?: string | null\n}\n\ntype ResolverContext = {\n resolve: <T = unknown>(name: string) => T\n}\n\nexport default async function handle(payload: TaskAssignedPayload, ctx: ResolverContext) {\n if (!payload.assignedUserId) return\n\n try {\n const notificationService = resolveNotificationService(ctx)\n const typeDef = notificationTypes.find((type) => type.type === 'workflows.task.assigned')\n if (!typeDef) return\n\n const notificationInput = buildNotificationFromType(typeDef, {\n recipientUserId: payload.assignedUserId,\n bodyVariables: {\n taskName: payload.taskName,\n workflowName: payload.workflowName,\n dueDate: payload.dueDate ?? '',\n },\n sourceEntityType: 'workflows:user_task',\n sourceEntityId: payload.taskId,\n linkHref: `/backend/workflows/tasks/${payload.taskId}`,\n })\n\n await notificationService.create(notificationInput, {\n tenantId: payload.tenantId,\n organizationId: payload.organizationId ?? null,\n })\n } catch (err) {\n console.error('[workflows:task-assigned-notification] Failed to create notification:', err)\n }\n}\n"],
5
- "mappings": "AACA,SAAS,kCAAkC;AAC3C,SAAS,iCAAiC;AAC1C,SAAS,yBAAyB;AAE3B,MAAM,WAAW;AAAA,EACtB,OAAO;AAAA,EACP,YAAY;AAAA,EACZ,IAAI;AACN;AAgBA,eAAO,OAA8B,SAA8B,KAAsB;AACvF,MAAI,CAAC,QAAQ,eAAgB;AAE7B,MAAI;AACF,UAAM,sBAAsB,2BAA2B,GAAG;AAC1D,UAAM,UAAU,kBAAkB,KAAK,CAAC,SAAS,KAAK,SAAS,yBAAyB;AACxF,QAAI,CAAC,QAAS;AAEd,UAAM,oBAAoB,0BAA0B,SAAS;AAAA,MAC3D,iBAAiB,QAAQ;AAAA,MACzB,eAAe;AAAA,QACb,UAAU,QAAQ;AAAA,QAClB,cAAc,QAAQ;AAAA,QACtB,SAAS,QAAQ,WAAW;AAAA,MAC9B;AAAA,MACA,kBAAkB;AAAA,MAClB,gBAAgB,QAAQ;AAAA,MACxB,UAAU,4BAA4B,QAAQ,MAAM;AAAA,IACtD,CAAC;AAED,UAAM,oBAAoB,OAAO,mBAAmB;AAAA,MAClD,UAAU,QAAQ;AAAA,MAClB,gBAAgB,QAAQ,kBAAkB;AAAA,IAC5C,CAAC;AAAA,EACH,SAAS,KAAK;AACZ,YAAQ,MAAM,yEAAyE,GAAG;AAAA,EAC5F;AACF;",
6
- "names": []
7
- }
@@ -1,27 +0,0 @@
1
- export const id = 'id'
2
- export const recipient_user_id = 'recipient_user_id'
3
- export const type = 'type'
4
- export const title_key = 'title_key'
5
- export const body_key = 'body_key'
6
- export const title_variables = 'title_variables'
7
- export const body_variables = 'body_variables'
8
- export const title = 'title'
9
- export const body = 'body'
10
- export const icon = 'icon'
11
- export const severity = 'severity'
12
- export const status = 'status'
13
- export const action_data = 'action_data'
14
- export const action_result = 'action_result'
15
- export const action_taken = 'action_taken'
16
- export const source_module = 'source_module'
17
- export const source_entity_type = 'source_entity_type'
18
- export const source_entity_id = 'source_entity_id'
19
- export const link_href = 'link_href'
20
- export const group_key = 'group_key'
21
- export const created_at = 'created_at'
22
- export const read_at = 'read_at'
23
- export const actioned_at = 'actioned_at'
24
- export const dismissed_at = 'dismissed_at'
25
- export const expires_at = 'expires_at'
26
- export const tenant_id = 'tenant_id'
27
- export const organization_id = 'organization_id'
@@ -1,163 +0,0 @@
1
- import { NextResponse } from 'next/server'
2
- import { z } from 'zod'
3
- import type { OpenApiRouteDoc } from '@open-mercato/shared/lib/openapi'
4
- import type { CommandBus, CommandRuntimeContext } from '@open-mercato/shared/lib/commands'
5
- import { createRequestContainer } from '@open-mercato/shared/lib/di/container'
6
- import { getAuthFromRequest } from '@open-mercato/shared/lib/auth/server'
7
- import { signJwt } from '@open-mercato/shared/lib/auth/jwt'
8
- import { resolveTranslations } from '@open-mercato/shared/lib/i18n/server'
9
- import { CrudHttpError } from '@open-mercato/shared/lib/crud/errors'
10
- import { AuthService } from '@open-mercato/core/modules/auth/services/authService'
11
- import { User } from '@open-mercato/core/modules/auth/data/entities'
12
- import type { EntityManager } from '@mikro-orm/postgresql'
13
- import { findOneWithDecryption } from '@open-mercato/shared/lib/encryption/find'
14
- import { buildPasswordSchema } from '@open-mercato/shared/lib/auth/passwordPolicy'
15
-
16
- const profileResponseSchema = z.object({
17
- email: z.string().email(),
18
- })
19
-
20
- const passwordSchema = buildPasswordSchema()
21
-
22
- const updateSchema = z.object({
23
- email: z.string().email().optional(),
24
- password: passwordSchema.optional(),
25
- }).refine((data) => Boolean(data.email || data.password), {
26
- message: 'Provide an email or password.',
27
- path: ['email'],
28
- })
29
-
30
- const profileUpdateResponseSchema = z.object({
31
- ok: z.literal(true),
32
- email: z.string().email(),
33
- })
34
-
35
- export const metadata = {
36
- GET: { requireAuth: true },
37
- PUT: { requireAuth: true },
38
- }
39
-
40
- function buildCommandContext(container: Awaited<ReturnType<typeof createRequestContainer>>, auth: NonNullable<Awaited<ReturnType<typeof getAuthFromRequest>>>, req: Request): CommandRuntimeContext {
41
- return {
42
- container,
43
- auth,
44
- organizationScope: null,
45
- selectedOrganizationId: auth.orgId ?? null,
46
- organizationIds: auth.orgId ? [auth.orgId] : null,
47
- request: req,
48
- }
49
- }
50
-
51
- export async function GET(req: Request) {
52
- const { translate } = await resolveTranslations()
53
- const auth = await getAuthFromRequest(req)
54
- if (!auth?.sub) {
55
- return NextResponse.json({ error: translate('api.errors.unauthorized', 'Unauthorized') }, { status: 401 })
56
- }
57
- try {
58
- const container = await createRequestContainer()
59
- const em = (container.resolve('em') as EntityManager)
60
- const user = await findOneWithDecryption(
61
- em,
62
- User,
63
- { id: auth.sub, deletedAt: null },
64
- undefined,
65
- { tenantId: auth.tenantId ?? null, organizationId: auth.orgId ?? null },
66
- )
67
- if (!user) {
68
- return NextResponse.json({ error: translate('auth.users.form.errors.notFound', 'User not found') }, { status: 404 })
69
- }
70
- return NextResponse.json({ email: String(user.email) })
71
- } catch (err) {
72
- console.error('auth.profile.load failed', err)
73
- return NextResponse.json({ error: translate('auth.profile.form.errors.load', 'Failed to load profile.') }, { status: 400 })
74
- }
75
- }
76
-
77
- export async function PUT(req: Request) {
78
- const { translate } = await resolveTranslations()
79
- const auth = await getAuthFromRequest(req)
80
- if (!auth?.sub) {
81
- return NextResponse.json({ error: translate('api.errors.unauthorized', 'Unauthorized') }, { status: 401 })
82
- }
83
- try {
84
- const body = await req.json().catch(() => ({}))
85
- const parsed = updateSchema.safeParse(body)
86
- if (!parsed.success) {
87
- return NextResponse.json(
88
- {
89
- error: translate('auth.profile.form.errors.invalid', 'Invalid profile update.'),
90
- issues: parsed.error.issues,
91
- },
92
- { status: 400 },
93
- )
94
- }
95
- const container = await createRequestContainer()
96
- const commandBus = (container.resolve('commandBus') as CommandBus)
97
- const ctx = buildCommandContext(container, auth, req)
98
- const { result } = await commandBus.execute<{ id: string; email?: string; password?: string }, User>(
99
- 'auth.users.update',
100
- {
101
- input: {
102
- id: auth.sub,
103
- email: parsed.data.email,
104
- password: parsed.data.password,
105
- },
106
- ctx,
107
- },
108
- )
109
- const authService = container.resolve('authService') as AuthService
110
- const roles = await authService.getUserRoles(result, result.tenantId ? String(result.tenantId) : null)
111
- const jwt = signJwt({
112
- sub: String(result.id),
113
- tenantId: result.tenantId ? String(result.tenantId) : null,
114
- orgId: result.organizationId ? String(result.organizationId) : null,
115
- email: result.email,
116
- roles,
117
- })
118
- const res = NextResponse.json({ ok: true, email: String(result.email) })
119
- res.cookies.set('auth_token', jwt, {
120
- httpOnly: true,
121
- path: '/',
122
- sameSite: 'lax',
123
- secure: process.env.NODE_ENV === 'production',
124
- maxAge: 60 * 60 * 8,
125
- })
126
- return res
127
- } catch (err) {
128
- if (err instanceof CrudHttpError) {
129
- return NextResponse.json(err.body, { status: err.status })
130
- }
131
- console.error('auth.profile.update failed', err)
132
- return NextResponse.json({ error: translate('auth.profile.form.errors.save', 'Failed to update profile.') }, { status: 400 })
133
- }
134
- }
135
-
136
- export const openApi: OpenApiRouteDoc = {
137
- tag: 'Authentication & Accounts',
138
- summary: 'Profile settings',
139
- methods: {
140
- GET: {
141
- summary: 'Get current profile',
142
- description: 'Returns the email address for the signed-in user.',
143
- responses: [
144
- { status: 200, description: 'Profile payload', schema: profileResponseSchema },
145
- { status: 401, description: 'Unauthorized', schema: z.object({ error: z.string() }) },
146
- { status: 404, description: 'User not found', schema: z.object({ error: z.string() }) },
147
- ],
148
- },
149
- PUT: {
150
- summary: 'Update current profile',
151
- description: 'Updates the email address or password for the signed-in user.',
152
- requestBody: {
153
- contentType: 'application/json',
154
- schema: updateSchema,
155
- },
156
- responses: [
157
- { status: 200, description: 'Profile updated', schema: profileUpdateResponseSchema },
158
- { status: 400, description: 'Invalid payload', schema: z.object({ error: z.string() }) },
159
- { status: 401, description: 'Unauthorized', schema: z.object({ error: z.string() }) },
160
- ],
161
- },
162
- },
163
- }
@@ -1,9 +0,0 @@
1
- export const metadata = {
2
- requireAuth: true,
3
- navHidden: true,
4
- pageTitle: 'Profile',
5
- pageTitleKey: 'auth.profile.title',
6
- breadcrumb: [
7
- { label: 'Profile', labelKey: 'auth.profile.title' },
8
- ],
9
- }
@@ -1,174 +0,0 @@
1
- "use client"
2
- import * as React from 'react'
3
- import { useRouter } from 'next/navigation'
4
- import { z } from 'zod'
5
- import { Save } from 'lucide-react'
6
- import { Page, PageBody } from '@open-mercato/ui/backend/Page'
7
- import { CrudForm, type CrudField } from '@open-mercato/ui/backend/CrudForm'
8
- import { apiCall, readApiResultOrThrow } from '@open-mercato/ui/backend/utils/apiCall'
9
- import { createCrudFormError } from '@open-mercato/ui/backend/utils/serverErrors'
10
- import { flash } from '@open-mercato/ui/backend/FlashMessages'
11
- import { LoadingMessage, ErrorMessage } from '@open-mercato/ui/backend/detail'
12
- import { Button } from '@open-mercato/ui/primitives/button'
13
- import { useT } from '@open-mercato/shared/lib/i18n/context'
14
- import { buildPasswordSchema, formatPasswordRequirements, getPasswordPolicy } from '@open-mercato/shared/lib/auth/passwordPolicy'
15
-
16
- type ProfileResponse = {
17
- email?: string | null
18
- }
19
-
20
- type ProfileUpdateResponse = {
21
- ok?: boolean
22
- email?: string | null
23
- }
24
-
25
- type ProfileFormValues = {
26
- email: string
27
- password?: string
28
- confirmPassword?: string
29
- }
30
-
31
- export default function AuthProfilePage() {
32
- const t = useT()
33
- const router = useRouter()
34
- const [loading, setLoading] = React.useState(true)
35
- const [error, setError] = React.useState<string | null>(null)
36
- const [email, setEmail] = React.useState('')
37
- const [formKey, setFormKey] = React.useState(0)
38
- const formId = React.useId()
39
- const passwordPolicy = React.useMemo(() => getPasswordPolicy(), [])
40
- const passwordRequirements = React.useMemo(
41
- () => formatPasswordRequirements(passwordPolicy, t),
42
- [passwordPolicy, t],
43
- )
44
- const passwordDescription = React.useMemo(() => (
45
- passwordRequirements
46
- ? t('auth.password.requirements.help', 'Password requirements: {requirements}', { requirements: passwordRequirements })
47
- : undefined
48
- ), [passwordRequirements, t])
49
-
50
- React.useEffect(() => {
51
- let cancelled = false
52
- async function load() {
53
- setLoading(true)
54
- setError(null)
55
- try {
56
- const { ok, result } = await apiCall<ProfileResponse>('/api/auth/profile')
57
- if (!ok) throw new Error('load_failed')
58
- const resolvedEmail = typeof result?.email === 'string' ? result.email : ''
59
- if (!cancelled) setEmail(resolvedEmail)
60
- } catch (err) {
61
- console.error('Failed to load auth profile', err)
62
- if (!cancelled) setError(t('auth.profile.form.errors.load', 'Failed to load profile.'))
63
- } finally {
64
- if (!cancelled) setLoading(false)
65
- }
66
- }
67
- load()
68
- return () => { cancelled = true }
69
- }, [t])
70
-
71
- const fields = React.useMemo<CrudField[]>(() => [
72
- { id: 'email', label: t('auth.profile.form.email', 'Email'), type: 'text', required: true },
73
- {
74
- id: 'password',
75
- label: t('auth.profile.form.password', 'New password'),
76
- type: 'text',
77
- description: passwordDescription,
78
- },
79
- { id: 'confirmPassword', label: t('auth.profile.form.confirmPassword', 'Confirm new password'), type: 'text' },
80
- ], [passwordDescription, t])
81
-
82
- const schema = React.useMemo(() => {
83
- const passwordSchema = buildPasswordSchema({
84
- policy: passwordPolicy,
85
- message: t('auth.profile.form.errors.passwordRequirements', 'Password must meet the requirements.'),
86
- })
87
- const optionalPasswordSchema = z.union([z.literal(''), passwordSchema]).optional()
88
- return z.object({
89
- email: z.string().trim().min(1, t('auth.profile.form.errors.emailRequired', 'Email is required.')),
90
- password: optionalPasswordSchema,
91
- confirmPassword: z.string().optional(),
92
- }).superRefine((values, ctx) => {
93
- const password = values.password?.trim() ?? ''
94
- const confirmPassword = values.confirmPassword?.trim() ?? ''
95
- if ((password || confirmPassword) && password !== confirmPassword) {
96
- ctx.addIssue({
97
- code: z.ZodIssueCode.custom,
98
- message: t('auth.profile.form.errors.passwordMismatch', 'Passwords do not match.'),
99
- path: ['confirmPassword'],
100
- })
101
- }
102
- })
103
- }, [passwordPolicy, t])
104
-
105
- const handleSubmit = React.useCallback(async (values: ProfileFormValues) => {
106
- const nextEmail = values.email?.trim() ?? ''
107
- const password = values.password?.trim() ?? ''
108
-
109
- if (!password && nextEmail === email) {
110
- throw createCrudFormError(t('auth.profile.form.errors.noChanges', 'No changes to save.'))
111
- }
112
-
113
- const payload: { email: string; password?: string } = { email: nextEmail }
114
- if (password) payload.password = password
115
-
116
- const result = await readApiResultOrThrow<ProfileUpdateResponse>(
117
- '/api/auth/profile',
118
- {
119
- method: 'PUT',
120
- headers: { 'content-type': 'application/json' },
121
- body: JSON.stringify(payload),
122
- },
123
- { errorMessage: t('auth.profile.form.errors.save', 'Failed to update profile.') },
124
- )
125
-
126
- const resolvedEmail = typeof result?.email === 'string' ? result.email : nextEmail
127
- setEmail(resolvedEmail)
128
- setFormKey((prev) => prev + 1)
129
- flash(t('auth.profile.form.success', 'Profile updated.'), 'success')
130
- router.refresh()
131
- }, [email, router, t])
132
-
133
- return (
134
- <Page>
135
- <PageBody>
136
- {loading ? (
137
- <LoadingMessage label={t('auth.profile.form.loading', 'Loading profile...')} />
138
- ) : error ? (
139
- <ErrorMessage label={error} />
140
- ) : (
141
- <section className="space-y-6 rounded-lg border bg-background p-6">
142
- <header className="flex flex-col gap-4 sm:flex-row sm:items-start sm:justify-between">
143
- <div className="space-y-1">
144
- <h2 className="text-lg font-semibold">{t('auth.profile.title', 'Profile')}</h2>
145
- <p className="text-sm text-muted-foreground">
146
- {t('auth.profile.subtitle', 'Change password')}
147
- </p>
148
- </div>
149
- <Button type="submit" form={formId}>
150
- <Save className="size-4 mr-2" />
151
- {t('auth.profile.form.save', 'Save changes')}
152
- </Button>
153
- </header>
154
- <CrudForm<ProfileFormValues>
155
- key={formKey}
156
- formId={formId}
157
- schema={schema}
158
- fields={fields}
159
- initialValues={{
160
- email,
161
- password: '',
162
- confirmPassword: '',
163
- }}
164
- submitLabel={t('auth.profile.form.save', 'Save changes')}
165
- onSubmit={handleSubmit}
166
- embedded
167
- hideFooterActions
168
- />
169
- </section>
170
- )}
171
- </PageBody>
172
- </Page>
173
- )
174
- }
@@ -1,109 +0,0 @@
1
- import type { NotificationTypeDefinition } from '@open-mercato/shared/modules/notifications/types'
2
-
3
- export const notificationTypes: NotificationTypeDefinition[] = [
4
- {
5
- type: 'auth.password_reset.requested',
6
- module: 'auth',
7
- titleKey: 'auth.notifications.passwordReset.requested.title',
8
- bodyKey: 'auth.notifications.passwordReset.requested.body',
9
- icon: 'key',
10
- severity: 'info',
11
- actions: [
12
- {
13
- id: 'view',
14
- labelKey: 'common.view',
15
- variant: 'outline',
16
- href: '/backend/auth/profile',
17
- icon: 'external-link',
18
- },
19
- ],
20
- linkHref: '/backend/auth/profile',
21
- expiresAfterHours: 24,
22
- },
23
- {
24
- type: 'auth.password_reset.completed',
25
- module: 'auth',
26
- titleKey: 'auth.notifications.passwordReset.completed.title',
27
- bodyKey: 'auth.notifications.passwordReset.completed.body',
28
- icon: 'check-circle',
29
- severity: 'success',
30
- actions: [],
31
- expiresAfterHours: 72,
32
- },
33
- {
34
- type: 'auth.account.locked',
35
- module: 'auth',
36
- titleKey: 'auth.notifications.account.locked.title',
37
- bodyKey: 'auth.notifications.account.locked.body',
38
- icon: 'lock',
39
- severity: 'warning',
40
- actions: [
41
- {
42
- id: 'contact_support',
43
- labelKey: 'auth.actions.contactSupport',
44
- variant: 'default',
45
- href: '/backend/support',
46
- icon: 'mail',
47
- },
48
- ],
49
- linkHref: '/backend/support',
50
- },
51
- {
52
- type: 'auth.login.new_device',
53
- module: 'auth',
54
- titleKey: 'auth.notifications.login.newDevice.title',
55
- bodyKey: 'auth.notifications.login.newDevice.body',
56
- icon: 'smartphone',
57
- severity: 'info',
58
- actions: [
59
- {
60
- id: 'view_sessions',
61
- labelKey: 'auth.actions.viewSessions',
62
- variant: 'outline',
63
- href: '/backend/auth/sessions',
64
- icon: 'list',
65
- },
66
- ],
67
- linkHref: '/backend/auth/sessions',
68
- expiresAfterHours: 168, // 7 days
69
- },
70
- {
71
- type: 'auth.role.assigned',
72
- module: 'auth',
73
- titleKey: 'auth.notifications.role.assigned.title',
74
- bodyKey: 'auth.notifications.role.assigned.body',
75
- icon: 'user-plus',
76
- severity: 'success',
77
- actions: [
78
- {
79
- id: 'view_permissions',
80
- labelKey: 'auth.actions.viewPermissions',
81
- variant: 'outline',
82
- href: '/backend/auth/profile',
83
- icon: 'shield',
84
- },
85
- ],
86
- linkHref: '/backend/auth/profile',
87
- expiresAfterHours: 168,
88
- },
89
- {
90
- type: 'auth.role.revoked',
91
- module: 'auth',
92
- titleKey: 'auth.notifications.role.revoked.title',
93
- bodyKey: 'auth.notifications.role.revoked.body',
94
- icon: 'user-minus',
95
- severity: 'warning',
96
- actions: [
97
- {
98
- id: 'view_profile',
99
- labelKey: 'common.view',
100
- variant: 'outline',
101
- href: '/backend/auth/profile',
102
- },
103
- ],
104
- linkHref: '/backend/auth/profile',
105
- expiresAfterHours: 168,
106
- },
107
- ]
108
-
109
- export default notificationTypes