@open-mercato/core 0.6.4-develop.4210.1.d412061cfe → 0.6.4-develop.4236.1.9fa6806b34

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 (370) hide show
  1. package/.turbo/turbo-build.log +2 -2
  2. package/dist/generated/entities/staff_time_entry/index.js +37 -0
  3. package/dist/generated/entities/staff_time_entry/index.js.map +7 -0
  4. package/dist/generated/entities/staff_time_entry_segment/index.js +23 -0
  5. package/dist/generated/entities/staff_time_entry_segment/index.js.map +7 -0
  6. package/dist/generated/entities/staff_time_project/index.js +35 -0
  7. package/dist/generated/entities/staff_time_project/index.js.map +7 -0
  8. package/dist/generated/entities/staff_time_project_member/index.js +29 -0
  9. package/dist/generated/entities/staff_time_project_member/index.js.map +7 -0
  10. package/dist/generated/entities.ids.generated.js +5 -1
  11. package/dist/generated/entities.ids.generated.js.map +2 -2
  12. package/dist/generated/entity-fields-registry.js +64 -0
  13. package/dist/generated/entity-fields-registry.js.map +2 -2
  14. package/dist/helpers/integration/timesheetFixtures.js +50 -0
  15. package/dist/helpers/integration/timesheetFixtures.js.map +7 -0
  16. package/dist/modules/attachments/api/library/[id]/route.js +20 -16
  17. package/dist/modules/attachments/api/library/[id]/route.js.map +2 -2
  18. package/dist/modules/attachments/api/route.js +18 -14
  19. package/dist/modules/attachments/api/route.js.map +2 -2
  20. package/dist/modules/auth/api/roles/acl/route.js +10 -4
  21. package/dist/modules/auth/api/roles/acl/route.js.map +2 -2
  22. package/dist/modules/auth/api/sidebar/preferences/route.js +27 -20
  23. package/dist/modules/auth/api/sidebar/preferences/route.js.map +2 -2
  24. package/dist/modules/auth/api/users/acl/route.js +16 -11
  25. package/dist/modules/auth/api/users/acl/route.js.map +2 -2
  26. package/dist/modules/auth/commands/users.js +87 -71
  27. package/dist/modules/auth/commands/users.js.map +2 -2
  28. package/dist/modules/auth/services/sidebarPreferencesService.js +39 -30
  29. package/dist/modules/auth/services/sidebarPreferencesService.js.map +2 -2
  30. package/dist/modules/catalog/commands/categories.js +61 -12
  31. package/dist/modules/catalog/commands/categories.js.map +2 -2
  32. package/dist/modules/catalog/commands/products.js +79 -54
  33. package/dist/modules/catalog/commands/products.js.map +2 -2
  34. package/dist/modules/catalog/commands/variants.js +29 -16
  35. package/dist/modules/catalog/commands/variants.js.map +2 -2
  36. package/dist/modules/currencies/commands/currencies.js +15 -8
  37. package/dist/modules/currencies/commands/currencies.js.map +2 -2
  38. package/dist/modules/customer_accounts/api/admin/users.js +27 -26
  39. package/dist/modules/customer_accounts/api/admin/users.js.map +2 -2
  40. package/dist/modules/customer_accounts/api/password/reset-confirm.js +5 -5
  41. package/dist/modules/customer_accounts/api/password/reset-confirm.js.map +2 -2
  42. package/dist/modules/customer_accounts/api/portal/users/[id]/roles.js +11 -10
  43. package/dist/modules/customer_accounts/api/portal/users/[id]/roles.js.map +2 -2
  44. package/dist/modules/customers/commands/addresses.js +35 -21
  45. package/dist/modules/customers/commands/addresses.js.map +2 -2
  46. package/dist/modules/customers/commands/companies.js +163 -162
  47. package/dist/modules/customers/commands/companies.js.map +2 -2
  48. package/dist/modules/customers/commands/deals.js +3 -4
  49. package/dist/modules/customers/commands/deals.js.map +2 -2
  50. package/dist/modules/customers/commands/interactions.js +19 -22
  51. package/dist/modules/customers/commands/interactions.js.map +2 -2
  52. package/dist/modules/customers/commands/people.js +18 -15
  53. package/dist/modules/customers/commands/people.js.map +2 -2
  54. package/dist/modules/customers/commands/personCompanyLinks.js +105 -94
  55. package/dist/modules/customers/commands/personCompanyLinks.js.map +2 -2
  56. package/dist/modules/customers/commands/pipeline-stages.js +30 -23
  57. package/dist/modules/customers/commands/pipeline-stages.js.map +2 -2
  58. package/dist/modules/customers/commands/pipelines.js +27 -20
  59. package/dist/modules/customers/commands/pipelines.js.map +2 -2
  60. package/dist/modules/customers/commands/tags.js +13 -5
  61. package/dist/modules/customers/commands/tags.js.map +2 -2
  62. package/dist/modules/dashboards/api/users/widgets/route.js +0 -1
  63. package/dist/modules/dashboards/api/users/widgets/route.js.map +2 -2
  64. package/dist/modules/dashboards/api/widgets/data/route.js +29 -1
  65. package/dist/modules/dashboards/api/widgets/data/route.js.map +2 -2
  66. package/dist/modules/data_sync/lib/sync-engine.js +4 -4
  67. package/dist/modules/data_sync/lib/sync-engine.js.map +2 -2
  68. package/dist/modules/data_sync/lib/sync-run-service.js +51 -27
  69. package/dist/modules/data_sync/lib/sync-run-service.js.map +2 -2
  70. package/dist/modules/directory/commands/organizations.js +192 -158
  71. package/dist/modules/directory/commands/organizations.js.map +3 -3
  72. package/dist/modules/inbox_ops/api/emails/[id]/reprocess/route.js +22 -16
  73. package/dist/modules/inbox_ops/api/emails/[id]/reprocess/route.js.map +2 -2
  74. package/dist/modules/messages/commands/messages.js +77 -75
  75. package/dist/modules/messages/commands/messages.js.map +2 -2
  76. package/dist/modules/messages/commands/shared.js +132 -132
  77. package/dist/modules/messages/commands/shared.js.map +2 -2
  78. package/dist/modules/perspectives/api/[tableId]/route.js +37 -26
  79. package/dist/modules/perspectives/api/[tableId]/route.js.map +2 -2
  80. package/dist/modules/resources/commands/resources.js +125 -117
  81. package/dist/modules/resources/commands/resources.js.map +2 -2
  82. package/dist/modules/resources/commands/tags.js +7 -3
  83. package/dist/modules/resources/commands/tags.js.map +2 -2
  84. package/dist/modules/sales/api/quotes/send/route.js +12 -11
  85. package/dist/modules/sales/api/quotes/send/route.js.map +2 -2
  86. package/dist/modules/sales/commands/documents.js +629 -478
  87. package/dist/modules/sales/commands/documents.js.map +2 -2
  88. package/dist/modules/sales/commands/payments.js +146 -146
  89. package/dist/modules/sales/commands/payments.js.map +2 -2
  90. package/dist/modules/sales/commands/returns.js +68 -60
  91. package/dist/modules/sales/commands/returns.js.map +2 -2
  92. package/dist/modules/staff/acl.js +10 -1
  93. package/dist/modules/staff/acl.js.map +2 -2
  94. package/dist/modules/staff/analytics.js +33 -0
  95. package/dist/modules/staff/analytics.js.map +7 -0
  96. package/dist/modules/staff/api/guards.js +31 -0
  97. package/dist/modules/staff/api/guards.js.map +7 -0
  98. package/dist/modules/staff/api/interceptors.js +96 -0
  99. package/dist/modules/staff/api/interceptors.js.map +7 -0
  100. package/dist/modules/staff/api/timesheets/my-projects/[projectId]/route.js +170 -0
  101. package/dist/modules/staff/api/timesheets/my-projects/[projectId]/route.js.map +7 -0
  102. package/dist/modules/staff/api/timesheets/my-projects/route.js +103 -0
  103. package/dist/modules/staff/api/timesheets/my-projects/route.js.map +7 -0
  104. package/dist/modules/staff/api/timesheets/projects/kpis/route.js +147 -0
  105. package/dist/modules/staff/api/timesheets/projects/kpis/route.js.map +7 -0
  106. package/dist/modules/staff/api/timesheets/time-entries/[id]/segments/[segmentId]/route.js +171 -0
  107. package/dist/modules/staff/api/timesheets/time-entries/[id]/segments/[segmentId]/route.js.map +7 -0
  108. package/dist/modules/staff/api/timesheets/time-entries/[id]/segments/route.js +180 -0
  109. package/dist/modules/staff/api/timesheets/time-entries/[id]/segments/route.js.map +7 -0
  110. package/dist/modules/staff/api/timesheets/time-entries/[id]/timer-start/route.js +155 -0
  111. package/dist/modules/staff/api/timesheets/time-entries/[id]/timer-start/route.js.map +7 -0
  112. package/dist/modules/staff/api/timesheets/time-entries/[id]/timer-stop/route.js +173 -0
  113. package/dist/modules/staff/api/timesheets/time-entries/[id]/timer-stop/route.js.map +7 -0
  114. package/dist/modules/staff/api/timesheets/time-entries/bulk/route.js +260 -0
  115. package/dist/modules/staff/api/timesheets/time-entries/bulk/route.js.map +7 -0
  116. package/dist/modules/staff/api/timesheets/time-entries/route.js +188 -0
  117. package/dist/modules/staff/api/timesheets/time-entries/route.js.map +7 -0
  118. package/dist/modules/staff/api/timesheets/time-projects/[id]/employees/route.js +159 -0
  119. package/dist/modules/staff/api/timesheets/time-projects/[id]/employees/route.js.map +7 -0
  120. package/dist/modules/staff/api/timesheets/time-projects/route.js +230 -0
  121. package/dist/modules/staff/api/timesheets/time-projects/route.js.map +7 -0
  122. package/dist/modules/staff/backend/staff/timesheets/page.js +710 -0
  123. package/dist/modules/staff/backend/staff/timesheets/page.js.map +7 -0
  124. package/dist/modules/staff/backend/staff/timesheets/page.meta.js +22 -0
  125. package/dist/modules/staff/backend/staff/timesheets/page.meta.js.map +7 -0
  126. package/dist/modules/staff/backend/staff/timesheets/projects/[id]/edit/page.js +125 -0
  127. package/dist/modules/staff/backend/staff/timesheets/projects/[id]/edit/page.js.map +7 -0
  128. package/dist/modules/staff/backend/staff/timesheets/projects/[id]/edit/page.meta.js +16 -0
  129. package/dist/modules/staff/backend/staff/timesheets/projects/[id]/edit/page.meta.js.map +7 -0
  130. package/dist/modules/staff/backend/staff/timesheets/projects/[id]/page.js +418 -0
  131. package/dist/modules/staff/backend/staff/timesheets/projects/[id]/page.js.map +7 -0
  132. package/dist/modules/staff/backend/staff/timesheets/projects/[id]/page.meta.js +16 -0
  133. package/dist/modules/staff/backend/staff/timesheets/projects/[id]/page.meta.js.map +7 -0
  134. package/dist/modules/staff/backend/staff/timesheets/projects/create/page.js +79 -0
  135. package/dist/modules/staff/backend/staff/timesheets/projects/create/page.js.map +7 -0
  136. package/dist/modules/staff/backend/staff/timesheets/projects/create/page.meta.js +16 -0
  137. package/dist/modules/staff/backend/staff/timesheets/projects/create/page.meta.js.map +7 -0
  138. package/dist/modules/staff/backend/staff/timesheets/projects/page.js +602 -0
  139. package/dist/modules/staff/backend/staff/timesheets/projects/page.js.map +7 -0
  140. package/dist/modules/staff/backend/staff/timesheets/projects/page.meta.js +25 -0
  141. package/dist/modules/staff/backend/staff/timesheets/projects/page.meta.js.map +7 -0
  142. package/dist/modules/staff/backend/staff/timesheets/projects/projectFormConfig.js +123 -0
  143. package/dist/modules/staff/backend/staff/timesheets/projects/projectFormConfig.js.map +7 -0
  144. package/dist/modules/staff/cli.js +38 -1
  145. package/dist/modules/staff/cli.js.map +2 -2
  146. package/dist/modules/staff/commands/index.js +2 -0
  147. package/dist/modules/staff/commands/index.js.map +2 -2
  148. package/dist/modules/staff/commands/leave-requests.js +30 -28
  149. package/dist/modules/staff/commands/leave-requests.js.map +3 -3
  150. package/dist/modules/staff/commands/team-members.js +21 -20
  151. package/dist/modules/staff/commands/team-members.js.map +2 -2
  152. package/dist/modules/staff/commands/timesheets-entries.js +409 -0
  153. package/dist/modules/staff/commands/timesheets-entries.js.map +7 -0
  154. package/dist/modules/staff/commands/timesheets-projects.js +618 -0
  155. package/dist/modules/staff/commands/timesheets-projects.js.map +7 -0
  156. package/dist/modules/staff/data/enrichers.js +104 -0
  157. package/dist/modules/staff/data/enrichers.js.map +7 -0
  158. package/dist/modules/staff/data/entities.js +226 -1
  159. package/dist/modules/staff/data/entities.js.map +2 -2
  160. package/dist/modules/staff/data/validators.js +113 -1
  161. package/dist/modules/staff/data/validators.js.map +2 -2
  162. package/dist/modules/staff/events.js +13 -1
  163. package/dist/modules/staff/events.js.map +2 -2
  164. package/dist/modules/staff/lib/crud.js +7 -1
  165. package/dist/modules/staff/lib/crud.js.map +2 -2
  166. package/dist/modules/staff/lib/staffMemberResolver.js +15 -0
  167. package/dist/modules/staff/lib/staffMemberResolver.js.map +7 -0
  168. package/dist/modules/staff/lib/timesheets-projects/computeProjectHoursTrend.js +60 -0
  169. package/dist/modules/staff/lib/timesheets-projects/computeProjectHoursTrend.js.map +7 -0
  170. package/dist/modules/staff/lib/timesheets-projects/computeProjectsKpis.js +260 -0
  171. package/dist/modules/staff/lib/timesheets-projects/computeProjectsKpis.js.map +7 -0
  172. package/dist/modules/staff/lib/timesheets-projects/dateBuckets.js +41 -0
  173. package/dist/modules/staff/lib/timesheets-projects/dateBuckets.js.map +7 -0
  174. package/dist/modules/staff/lib/timesheets-projects/initials.js +10 -0
  175. package/dist/modules/staff/lib/timesheets-projects/initials.js.map +7 -0
  176. package/dist/modules/staff/lib/timesheets-projects/kpiMath.js +12 -0
  177. package/dist/modules/staff/lib/timesheets-projects/kpiMath.js.map +7 -0
  178. package/dist/modules/staff/lib/timesheets-projects/listProjectMembersPreview.js +55 -0
  179. package/dist/modules/staff/lib/timesheets-projects/listProjectMembersPreview.js.map +7 -0
  180. package/dist/modules/staff/lib/timesheets-projects-ui/HoursSparkline.js +66 -0
  181. package/dist/modules/staff/lib/timesheets-projects-ui/HoursSparkline.js.map +7 -0
  182. package/dist/modules/staff/lib/timesheets-projects-ui/ProjectCard.js +81 -0
  183. package/dist/modules/staff/lib/timesheets-projects-ui/ProjectCard.js.map +7 -0
  184. package/dist/modules/staff/lib/timesheets-projects-ui/ProjectMembersAvatarStack.js +58 -0
  185. package/dist/modules/staff/lib/timesheets-projects-ui/ProjectMembersAvatarStack.js.map +7 -0
  186. package/dist/modules/staff/lib/timesheets-projects-ui/ProjectsKpiStrip.js +152 -0
  187. package/dist/modules/staff/lib/timesheets-projects-ui/ProjectsKpiStrip.js.map +7 -0
  188. package/dist/modules/staff/lib/timesheets-projects-ui/SavedViewTabs.js +37 -0
  189. package/dist/modules/staff/lib/timesheets-projects-ui/SavedViewTabs.js.map +7 -0
  190. package/dist/modules/staff/lib/timesheets-projects-ui/ViewModeToggle.js +57 -0
  191. package/dist/modules/staff/lib/timesheets-projects-ui/ViewModeToggle.js.map +7 -0
  192. package/dist/modules/staff/lib/timesheets-projects-ui/useProjectsViewMode.js +50 -0
  193. package/dist/modules/staff/lib/timesheets-projects-ui/useProjectsViewMode.js.map +7 -0
  194. package/dist/modules/staff/lib/timesheets-ui/AddRowDropdown.js +163 -0
  195. package/dist/modules/staff/lib/timesheets-ui/AddRowDropdown.js.map +7 -0
  196. package/dist/modules/staff/lib/timesheets-ui/CalendarPicker.js +209 -0
  197. package/dist/modules/staff/lib/timesheets-ui/CalendarPicker.js.map +7 -0
  198. package/dist/modules/staff/lib/timesheets-ui/ColorPicker.js +52 -0
  199. package/dist/modules/staff/lib/timesheets-ui/ColorPicker.js.map +7 -0
  200. package/dist/modules/staff/lib/timesheets-ui/CreateProjectDialog.js +77 -0
  201. package/dist/modules/staff/lib/timesheets-ui/CreateProjectDialog.js.map +7 -0
  202. package/dist/modules/staff/lib/timesheets-ui/ListView.js +173 -0
  203. package/dist/modules/staff/lib/timesheets-ui/ListView.js.map +7 -0
  204. package/dist/modules/staff/lib/timesheets-ui/ProjectColorDot.js +32 -0
  205. package/dist/modules/staff/lib/timesheets-ui/ProjectColorDot.js.map +7 -0
  206. package/dist/modules/staff/lib/timesheets-ui/TimerBar.js +270 -0
  207. package/dist/modules/staff/lib/timesheets-ui/TimerBar.js.map +7 -0
  208. package/dist/modules/staff/lib/timesheets-ui/ViewSwitcher.js +57 -0
  209. package/dist/modules/staff/lib/timesheets-ui/ViewSwitcher.js.map +7 -0
  210. package/dist/modules/staff/lib/timesheets-ui/colors.js +43 -0
  211. package/dist/modules/staff/lib/timesheets-ui/colors.js.map +7 -0
  212. package/dist/modules/staff/migrations/Migration20260326135612.js +24 -0
  213. package/dist/modules/staff/migrations/Migration20260326135612.js.map +7 -0
  214. package/dist/modules/staff/migrations/Migration20260413102715.js +23 -0
  215. package/dist/modules/staff/migrations/Migration20260413102715.js.map +7 -0
  216. package/dist/modules/staff/migrations/Migration20260413111602.js +13 -0
  217. package/dist/modules/staff/migrations/Migration20260413111602.js.map +7 -0
  218. package/dist/modules/staff/migrations/Migration20260511112759.js +19 -0
  219. package/dist/modules/staff/migrations/Migration20260511112759.js.map +7 -0
  220. package/dist/modules/staff/search.js +35 -0
  221. package/dist/modules/staff/search.js.map +2 -2
  222. package/dist/modules/staff/setup.js +15 -1
  223. package/dist/modules/staff/setup.js.map +2 -2
  224. package/dist/modules/staff/widgets/dashboard/timesheets-hours-by-project/config.js +16 -0
  225. package/dist/modules/staff/widgets/dashboard/timesheets-hours-by-project/config.js.map +7 -0
  226. package/dist/modules/staff/widgets/dashboard/timesheets-hours-by-project/widget.client.js +126 -0
  227. package/dist/modules/staff/widgets/dashboard/timesheets-hours-by-project/widget.client.js.map +7 -0
  228. package/dist/modules/staff/widgets/dashboard/timesheets-hours-by-project/widget.js +26 -0
  229. package/dist/modules/staff/widgets/dashboard/timesheets-hours-by-project/widget.js.map +7 -0
  230. package/dist/modules/staff/widgets/dashboard/timesheets-time-reporting/config.js +15 -0
  231. package/dist/modules/staff/widgets/dashboard/timesheets-time-reporting/config.js.map +7 -0
  232. package/dist/modules/staff/widgets/dashboard/timesheets-time-reporting/widget.client.js +238 -0
  233. package/dist/modules/staff/widgets/dashboard/timesheets-time-reporting/widget.client.js.map +7 -0
  234. package/dist/modules/staff/widgets/dashboard/timesheets-time-reporting/widget.js +26 -0
  235. package/dist/modules/staff/widgets/dashboard/timesheets-time-reporting/widget.js.map +7 -0
  236. package/dist/modules/staff/widgets/injection/timer-sidebar-indicator/widget.js +145 -0
  237. package/dist/modules/staff/widgets/injection/timer-sidebar-indicator/widget.js.map +7 -0
  238. package/dist/modules/staff/widgets/injection-table.js +12 -0
  239. package/dist/modules/staff/widgets/injection-table.js.map +7 -0
  240. package/dist/modules/sync_excel/api/import/route.js +19 -17
  241. package/dist/modules/sync_excel/api/import/route.js.map +2 -2
  242. package/dist/modules/translations/commands/translations.js +22 -19
  243. package/dist/modules/translations/commands/translations.js.map +2 -2
  244. package/generated/entities/staff_time_entry/index.ts +17 -0
  245. package/generated/entities/staff_time_entry_segment/index.ts +10 -0
  246. package/generated/entities/staff_time_project/index.ts +16 -0
  247. package/generated/entities/staff_time_project_member/index.ts +13 -0
  248. package/generated/entities.ids.generated.ts +5 -1
  249. package/generated/entity-fields-registry.ts +64 -0
  250. package/package.json +7 -7
  251. package/src/helpers/integration/timesheetFixtures.ts +61 -0
  252. package/src/modules/attachments/api/library/[id]/route.ts +24 -17
  253. package/src/modules/attachments/api/route.ts +20 -14
  254. package/src/modules/auth/api/roles/acl/route.ts +11 -5
  255. package/src/modules/auth/api/sidebar/preferences/route.ts +33 -24
  256. package/src/modules/auth/api/users/acl/route.ts +17 -12
  257. package/src/modules/auth/commands/users.ts +96 -80
  258. package/src/modules/auth/services/sidebarPreferencesService.ts +40 -32
  259. package/src/modules/catalog/commands/categories.ts +61 -12
  260. package/src/modules/catalog/commands/products.ts +93 -60
  261. package/src/modules/catalog/commands/variants.ts +29 -16
  262. package/src/modules/currencies/commands/currencies.ts +27 -14
  263. package/src/modules/customer_accounts/api/admin/users.ts +31 -26
  264. package/src/modules/customer_accounts/api/password/reset-confirm.ts +5 -6
  265. package/src/modules/customer_accounts/api/portal/users/[id]/roles.ts +14 -13
  266. package/src/modules/customers/commands/addresses.ts +35 -23
  267. package/src/modules/customers/commands/companies.ts +166 -165
  268. package/src/modules/customers/commands/deals.ts +2 -4
  269. package/src/modules/customers/commands/interactions.ts +20 -26
  270. package/src/modules/customers/commands/people.ts +18 -15
  271. package/src/modules/customers/commands/personCompanyLinks.ts +109 -100
  272. package/src/modules/customers/commands/pipeline-stages.ts +31 -27
  273. package/src/modules/customers/commands/pipelines.ts +29 -23
  274. package/src/modules/customers/commands/tags.ts +13 -5
  275. package/src/modules/dashboards/api/users/widgets/route.ts +0 -1
  276. package/src/modules/dashboards/api/widgets/data/route.ts +36 -1
  277. package/src/modules/data_sync/lib/sync-engine.ts +4 -5
  278. package/src/modules/data_sync/lib/sync-run-service.ts +57 -28
  279. package/src/modules/directory/commands/organizations.ts +203 -166
  280. package/src/modules/inbox_ops/api/emails/[id]/reprocess/route.ts +26 -18
  281. package/src/modules/messages/commands/messages.ts +82 -80
  282. package/src/modules/messages/commands/shared.ts +138 -133
  283. package/src/modules/perspectives/api/[tableId]/route.ts +38 -27
  284. package/src/modules/resources/commands/resources.ts +127 -117
  285. package/src/modules/resources/commands/tags.ts +7 -3
  286. package/src/modules/sales/api/quotes/send/route.ts +17 -12
  287. package/src/modules/sales/commands/documents.ts +673 -481
  288. package/src/modules/sales/commands/payments.ts +158 -152
  289. package/src/modules/sales/commands/returns.ts +74 -63
  290. package/src/modules/staff/acl.ts +11 -0
  291. package/src/modules/staff/analytics.ts +30 -0
  292. package/src/modules/staff/api/guards.ts +59 -0
  293. package/src/modules/staff/api/interceptors.ts +122 -0
  294. package/src/modules/staff/api/timesheets/my-projects/[projectId]/route.ts +191 -0
  295. package/src/modules/staff/api/timesheets/my-projects/route.ts +115 -0
  296. package/src/modules/staff/api/timesheets/projects/kpis/route.ts +159 -0
  297. package/src/modules/staff/api/timesheets/time-entries/[id]/segments/[segmentId]/route.ts +187 -0
  298. package/src/modules/staff/api/timesheets/time-entries/[id]/segments/route.ts +191 -0
  299. package/src/modules/staff/api/timesheets/time-entries/[id]/timer-start/route.ts +168 -0
  300. package/src/modules/staff/api/timesheets/time-entries/[id]/timer-stop/route.ts +191 -0
  301. package/src/modules/staff/api/timesheets/time-entries/bulk/route.ts +292 -0
  302. package/src/modules/staff/api/timesheets/time-entries/route.ts +193 -0
  303. package/src/modules/staff/api/timesheets/time-projects/[id]/employees/route.ts +167 -0
  304. package/src/modules/staff/api/timesheets/time-projects/route.ts +244 -0
  305. package/src/modules/staff/backend/staff/timesheets/page.meta.ts +20 -0
  306. package/src/modules/staff/backend/staff/timesheets/page.tsx +899 -0
  307. package/src/modules/staff/backend/staff/timesheets/projects/[id]/edit/page.meta.ts +12 -0
  308. package/src/modules/staff/backend/staff/timesheets/projects/[id]/edit/page.tsx +141 -0
  309. package/src/modules/staff/backend/staff/timesheets/projects/[id]/page.meta.ts +12 -0
  310. package/src/modules/staff/backend/staff/timesheets/projects/[id]/page.tsx +579 -0
  311. package/src/modules/staff/backend/staff/timesheets/projects/create/page.meta.ts +12 -0
  312. package/src/modules/staff/backend/staff/timesheets/projects/create/page.tsx +90 -0
  313. package/src/modules/staff/backend/staff/timesheets/projects/page.meta.ts +23 -0
  314. package/src/modules/staff/backend/staff/timesheets/projects/page.tsx +765 -0
  315. package/src/modules/staff/backend/staff/timesheets/projects/projectFormConfig.ts +138 -0
  316. package/src/modules/staff/cli.ts +40 -1
  317. package/src/modules/staff/commands/index.ts +2 -0
  318. package/src/modules/staff/commands/leave-requests.ts +37 -29
  319. package/src/modules/staff/commands/team-members.ts +25 -20
  320. package/src/modules/staff/commands/timesheets-entries.ts +504 -0
  321. package/src/modules/staff/commands/timesheets-projects.ts +699 -0
  322. package/src/modules/staff/data/enrichers.ts +134 -0
  323. package/src/modules/staff/data/entities.ts +198 -0
  324. package/src/modules/staff/data/validators.ts +129 -0
  325. package/src/modules/staff/events.ts +13 -0
  326. package/src/modules/staff/i18n/de.json +209 -1
  327. package/src/modules/staff/i18n/en.json +209 -1
  328. package/src/modules/staff/i18n/es.json +209 -1
  329. package/src/modules/staff/i18n/pl.json +209 -1
  330. package/src/modules/staff/lib/crud.ts +8 -0
  331. package/src/modules/staff/lib/staffMemberResolver.ts +22 -0
  332. package/src/modules/staff/lib/timesheets-projects/computeProjectHoursTrend.ts +89 -0
  333. package/src/modules/staff/lib/timesheets-projects/computeProjectsKpis.ts +311 -0
  334. package/src/modules/staff/lib/timesheets-projects/dateBuckets.ts +37 -0
  335. package/src/modules/staff/lib/timesheets-projects/initials.ts +6 -0
  336. package/src/modules/staff/lib/timesheets-projects/kpiMath.ts +8 -0
  337. package/src/modules/staff/lib/timesheets-projects/listProjectMembersPreview.ts +83 -0
  338. package/src/modules/staff/lib/timesheets-projects-ui/HoursSparkline.tsx +75 -0
  339. package/src/modules/staff/lib/timesheets-projects-ui/ProjectCard.tsx +110 -0
  340. package/src/modules/staff/lib/timesheets-projects-ui/ProjectMembersAvatarStack.tsx +73 -0
  341. package/src/modules/staff/lib/timesheets-projects-ui/ProjectsKpiStrip.tsx +185 -0
  342. package/src/modules/staff/lib/timesheets-projects-ui/SavedViewTabs.tsx +53 -0
  343. package/src/modules/staff/lib/timesheets-projects-ui/ViewModeToggle.tsx +63 -0
  344. package/src/modules/staff/lib/timesheets-projects-ui/useProjectsViewMode.ts +63 -0
  345. package/src/modules/staff/lib/timesheets-ui/AddRowDropdown.tsx +188 -0
  346. package/src/modules/staff/lib/timesheets-ui/CalendarPicker.tsx +229 -0
  347. package/src/modules/staff/lib/timesheets-ui/ColorPicker.tsx +65 -0
  348. package/src/modules/staff/lib/timesheets-ui/CreateProjectDialog.tsx +99 -0
  349. package/src/modules/staff/lib/timesheets-ui/ListView.tsx +230 -0
  350. package/src/modules/staff/lib/timesheets-ui/ProjectColorDot.tsx +40 -0
  351. package/src/modules/staff/lib/timesheets-ui/TimerBar.tsx +327 -0
  352. package/src/modules/staff/lib/timesheets-ui/ViewSwitcher.tsx +60 -0
  353. package/src/modules/staff/lib/timesheets-ui/colors.ts +58 -0
  354. package/src/modules/staff/migrations/.snapshot-open-mercato.json +1148 -0
  355. package/src/modules/staff/migrations/Migration20260326135612.ts +26 -0
  356. package/src/modules/staff/migrations/Migration20260413102715.ts +25 -0
  357. package/src/modules/staff/migrations/Migration20260413111602.ts +13 -0
  358. package/src/modules/staff/migrations/Migration20260511112759.ts +21 -0
  359. package/src/modules/staff/search.ts +35 -0
  360. package/src/modules/staff/setup.ts +15 -0
  361. package/src/modules/staff/widgets/dashboard/timesheets-hours-by-project/config.ts +17 -0
  362. package/src/modules/staff/widgets/dashboard/timesheets-hours-by-project/widget.client.tsx +158 -0
  363. package/src/modules/staff/widgets/dashboard/timesheets-hours-by-project/widget.ts +25 -0
  364. package/src/modules/staff/widgets/dashboard/timesheets-time-reporting/config.ts +15 -0
  365. package/src/modules/staff/widgets/dashboard/timesheets-time-reporting/widget.client.tsx +297 -0
  366. package/src/modules/staff/widgets/dashboard/timesheets-time-reporting/widget.ts +25 -0
  367. package/src/modules/staff/widgets/injection/timer-sidebar-indicator/widget.tsx +161 -0
  368. package/src/modules/staff/widgets/injection-table.ts +10 -0
  369. package/src/modules/sync_excel/api/import/route.ts +23 -18
  370. package/src/modules/translations/commands/translations.ts +49 -41
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/modules/staff/commands/timesheets-projects.ts"],
4
+ "sourcesContent": ["import type { CommandHandler } from '@open-mercato/shared/lib/commands'\nimport { registerCommand } from '@open-mercato/shared/lib/commands'\nimport type { EntityManager } from '@mikro-orm/postgresql'\nimport { UniqueConstraintViolationException } from '@mikro-orm/core'\nimport { CrudHttpError } from '@open-mercato/shared/lib/crud/errors'\nimport { resolveTranslations } from '@open-mercato/shared/lib/i18n/server'\nimport { findOneWithDecryption } from '@open-mercato/shared/lib/encryption/find'\nimport { buildChanges, emitCrudSideEffects, emitCrudUndoSideEffects } from '@open-mercato/shared/lib/commands/helpers'\nimport type { CrudIndexerConfig } from '@open-mercato/shared/lib/crud/types'\nimport { StaffTeamMember, StaffTimeProject, StaffTimeProjectMember, type StaffTimeProjectStatus, type StaffTimeProjectMemberStatus } from '../data/entities'\n\nconst timeProjectCrudIndexer: CrudIndexerConfig<StaffTimeProject> = {\n entityType: 'staff:staff_time_project',\n}\nconst timeProjectMemberCrudIndexer: CrudIndexerConfig<StaffTimeProjectMember> = {\n entityType: 'staff:staff_time_project_member',\n}\nimport {\n staffTimeProjectCreateSchema,\n staffTimeProjectUpdateSchema,\n staffTimeProjectMemberAssignSchema,\n staffTimeProjectMemberUpdateSchema,\n type StaffTimeProjectCreateInput,\n type StaffTimeProjectUpdateInput,\n type StaffTimeProjectMemberAssignInput,\n type StaffTimeProjectMemberUpdateInput,\n} from '../data/validators'\nimport { staffTimeProjectCrudEvents, staffTimeProjectMemberCrudEvents } from '../lib/crud'\nimport { ensureOrganizationScope, ensureTenantScope, extractUndoPayload } from './shared'\n\nfunction isUniqueViolation(error: unknown): boolean {\n if (error instanceof UniqueConstraintViolationException) return true\n if (!error || typeof error !== 'object') return false\n const code = (error as { code?: string }).code\n if (code === '23505') return true\n const message = (error as { message?: string }).message\n return typeof message === 'string' && message.toLowerCase().includes('duplicate key')\n}\n\ntype TimeProjectSnapshot = {\n id: string\n tenantId: string\n organizationId: string\n name: string\n customerId: string | null\n code: string\n description: string | null\n projectType: string | null\n color: string | null\n status: string\n ownerUserId: string | null\n costCenter: string | null\n startDate: string | null\n deletedAt: string | null\n}\n\ntype TimeProjectUndoPayload = {\n before?: TimeProjectSnapshot | null\n after?: TimeProjectSnapshot | null\n}\n\ntype TimeProjectMemberSnapshot = {\n id: string\n tenantId: string\n organizationId: string\n timeProjectId: string\n staffMemberId: string\n role: string | null\n status: string\n showInGrid: boolean\n assignedStartDate: string\n assignedEndDate: string | null\n deletedAt: string | null\n}\n\ntype TimeProjectMemberUndoPayload = {\n before?: TimeProjectMemberSnapshot | null\n after?: TimeProjectMemberSnapshot | null\n}\n\nasync function loadTimeProjectSnapshot(em: EntityManager, id: string): Promise<TimeProjectSnapshot | null> {\n const project = await findOneWithDecryption(em, StaffTimeProject, { id }, undefined, { tenantId: null, organizationId: null })\n if (!project) return null\n return {\n id: project.id,\n tenantId: project.tenantId,\n organizationId: project.organizationId,\n name: project.name,\n customerId: project.customerId ?? null,\n code: project.code,\n description: project.description ?? null,\n projectType: project.projectType ?? null,\n color: project.color ?? null,\n status: project.status,\n ownerUserId: project.ownerUserId ?? null,\n costCenter: project.costCenter ?? null,\n startDate: project.startDate instanceof Date ? project.startDate.toISOString().split('T')[0] : (project.startDate ?? null),\n deletedAt: project.deletedAt ? project.deletedAt.toISOString() : null,\n }\n}\n\nasync function loadTimeProjectMemberSnapshot(em: EntityManager, id: string): Promise<TimeProjectMemberSnapshot | null> {\n const member = await findOneWithDecryption(em, StaffTimeProjectMember, { id }, undefined, { tenantId: null, organizationId: null })\n if (!member) return null\n return {\n id: member.id,\n tenantId: member.tenantId,\n organizationId: member.organizationId,\n timeProjectId: member.timeProjectId,\n staffMemberId: member.staffMemberId,\n role: member.role ?? null,\n status: member.status,\n showInGrid: member.showInGrid ?? false,\n assignedStartDate: member.assignedStartDate instanceof Date ? member.assignedStartDate.toISOString().split('T')[0] : String(member.assignedStartDate),\n assignedEndDate: member.assignedEndDate instanceof Date ? member.assignedEndDate.toISOString().split('T')[0] : (member.assignedEndDate ?? null),\n deletedAt: member.deletedAt ? member.deletedAt.toISOString() : null,\n }\n}\n\nconst createTimeProjectCommand: CommandHandler<StaffTimeProjectCreateInput, { timeProjectId: string }> = {\n id: 'staff.timesheets.time_projects.create',\n async execute(rawInput, ctx) {\n const parsed = staffTimeProjectCreateSchema.parse(rawInput)\n ensureTenantScope(ctx, parsed.tenantId)\n ensureOrganizationScope(ctx, parsed.organizationId)\n\n const em = (ctx.container.resolve('em') as EntityManager).fork()\n const now = new Date()\n const project = em.create(StaffTimeProject, {\n tenantId: parsed.tenantId,\n organizationId: parsed.organizationId,\n name: parsed.name,\n customerId: parsed.customerId ?? null,\n code: parsed.code,\n description: parsed.description ?? null,\n projectType: parsed.projectType ?? null,\n color: parsed.color ?? null,\n status: parsed.status ?? 'active',\n ownerUserId: parsed.ownerUserId ?? null,\n costCenter: parsed.costCenter ?? null,\n startDate: parsed.startDate ?? null,\n createdAt: now,\n updatedAt: now,\n deletedAt: null,\n })\n em.persist(project)\n try {\n await em.flush()\n } catch (err) {\n if (isUniqueViolation(err)) {\n const { translate } = await resolveTranslations()\n throw new CrudHttpError(409, {\n error: translate('staff.timesheets.errors.projectCodeDuplicate', 'A project with this code already exists.'),\n fieldErrors: { code: translate('staff.timesheets.errors.projectCodeDuplicate', 'A project with this code already exists.') },\n })\n }\n throw err\n }\n\n await emitCrudSideEffects({\n dataEngine: ctx.container.resolve('dataEngine'),\n action: 'created',\n entity: project,\n identifiers: {\n id: project.id,\n organizationId: project.organizationId,\n tenantId: project.tenantId,\n },\n events: staffTimeProjectCrudEvents,\n indexer: timeProjectCrudIndexer,\n })\n\n return { timeProjectId: project.id }\n },\n captureAfter: async (_input, result, ctx) => {\n const em = (ctx.container.resolve('em') as EntityManager).fork()\n const snapshot = await loadTimeProjectSnapshot(em, result.timeProjectId)\n if (!snapshot) return null\n return { snapshot }\n },\n buildLog: async ({ result, ctx }) => {\n const em = (ctx.container.resolve('em') as EntityManager).fork()\n const snapshot = await loadTimeProjectSnapshot(em, result.timeProjectId)\n if (!snapshot) return null\n const { translate } = await resolveTranslations()\n return {\n actionLabel: translate('staff.audit.timesheets.time_projects.create', 'Create time project'),\n resourceKind: 'staff.timesheets.time_project',\n resourceId: snapshot.id,\n tenantId: snapshot.tenantId,\n organizationId: snapshot.organizationId,\n snapshotAfter: snapshot,\n payload: {\n undo: {\n after: snapshot,\n } satisfies TimeProjectUndoPayload,\n },\n }\n },\n undo: async ({ logEntry, ctx }) => {\n const payload = extractUndoPayload<TimeProjectUndoPayload>(logEntry)\n const after = payload?.after\n if (!after) return\n const em = (ctx.container.resolve('em') as EntityManager).fork()\n const project = await em.findOne(StaffTimeProject, { id: after.id })\n if (project) {\n project.deletedAt = new Date()\n await em.flush()\n\n await emitCrudUndoSideEffects({\n dataEngine: ctx.container.resolve('dataEngine'),\n action: 'deleted',\n entity: project,\n identifiers: {\n id: project.id,\n organizationId: project.organizationId,\n tenantId: project.tenantId,\n },\n events: staffTimeProjectCrudEvents,\n })\n }\n },\n}\n\nconst updateTimeProjectCommand: CommandHandler<StaffTimeProjectUpdateInput, { timeProjectId: string }> = {\n id: 'staff.timesheets.time_projects.update',\n async prepare(rawInput, ctx) {\n const parsed = staffTimeProjectUpdateSchema.parse(rawInput)\n const em = (ctx.container.resolve('em') as EntityManager)\n const snapshot = await loadTimeProjectSnapshot(em, parsed.id)\n if (!snapshot) return {}\n return { before: snapshot }\n },\n async execute(rawInput, ctx) {\n const parsed = staffTimeProjectUpdateSchema.parse(rawInput)\n const em = (ctx.container.resolve('em') as EntityManager).fork()\n const project = await findOneWithDecryption(\n em,\n StaffTimeProject,\n { id: parsed.id, deletedAt: null },\n undefined,\n { tenantId: ctx.auth?.tenantId ?? null, organizationId: ctx.auth?.orgId ?? null },\n )\n if (!project) throw new CrudHttpError(404, { error: 'Time project not found.' })\n ensureTenantScope(ctx, project.tenantId)\n ensureOrganizationScope(ctx, project.organizationId)\n\n if (parsed.name !== undefined) project.name = parsed.name\n if (parsed.customerId !== undefined) project.customerId = parsed.customerId ?? null\n if (parsed.code !== undefined) project.code = parsed.code\n if (parsed.description !== undefined) project.description = parsed.description ?? null\n if (parsed.projectType !== undefined) project.projectType = parsed.projectType ?? null\n if (parsed.color !== undefined) project.color = parsed.color ?? null\n if (parsed.status !== undefined) project.status = parsed.status\n if (parsed.ownerUserId !== undefined) project.ownerUserId = parsed.ownerUserId ?? null\n if (parsed.costCenter !== undefined) project.costCenter = parsed.costCenter ?? null\n if (parsed.startDate !== undefined) project.startDate = parsed.startDate ?? null\n project.updatedAt = new Date()\n try {\n await em.flush()\n } catch (err) {\n if (isUniqueViolation(err)) {\n const { translate } = await resolveTranslations()\n throw new CrudHttpError(409, {\n error: translate('staff.timesheets.errors.projectCodeDuplicate', 'A project with this code already exists.'),\n fieldErrors: { code: translate('staff.timesheets.errors.projectCodeDuplicate', 'A project with this code already exists.') },\n })\n }\n throw err\n }\n\n await emitCrudSideEffects({\n dataEngine: ctx.container.resolve('dataEngine'),\n action: 'updated',\n entity: project,\n identifiers: {\n id: project.id,\n organizationId: project.organizationId,\n tenantId: project.tenantId,\n },\n events: staffTimeProjectCrudEvents,\n indexer: timeProjectCrudIndexer,\n })\n\n return { timeProjectId: project.id }\n },\n buildLog: async ({ snapshots, ctx }) => {\n const before = snapshots.before as TimeProjectSnapshot | undefined\n if (!before) return null\n const em = (ctx.container.resolve('em') as EntityManager).fork()\n const after = await loadTimeProjectSnapshot(em, before.id)\n if (!after) return null\n const changes = buildChanges(before as unknown as Record<string, unknown>, after as unknown as Record<string, unknown>, [\n 'name',\n 'customerId',\n 'code',\n 'description',\n 'projectType',\n 'color',\n 'status',\n 'ownerUserId',\n 'costCenter',\n 'startDate',\n 'deletedAt',\n ])\n const { translate } = await resolveTranslations()\n return {\n actionLabel: translate('staff.audit.timesheets.time_projects.update', 'Update time project'),\n resourceKind: 'staff.timesheets.time_project',\n resourceId: before.id,\n tenantId: before.tenantId,\n organizationId: before.organizationId,\n snapshotBefore: before,\n snapshotAfter: after,\n changes,\n payload: {\n undo: {\n before,\n after,\n } satisfies TimeProjectUndoPayload,\n },\n }\n },\n undo: async ({ logEntry, ctx }) => {\n const payload = extractUndoPayload<TimeProjectUndoPayload>(logEntry)\n const before = payload?.before\n if (!before) return\n const em = (ctx.container.resolve('em') as EntityManager).fork()\n const project = await em.findOne(StaffTimeProject, { id: before.id })\n if (!project) return\n project.name = before.name\n project.customerId = before.customerId ?? null\n project.code = before.code\n project.description = before.description ?? null\n project.projectType = before.projectType ?? null\n project.color = before.color ?? null\n project.status = (before.status ?? 'active') as StaffTimeProjectStatus\n project.ownerUserId = before.ownerUserId ?? null\n project.costCenter = before.costCenter ?? null\n project.startDate = before.startDate ? new Date(before.startDate) : null\n project.deletedAt = before.deletedAt ? new Date(before.deletedAt) : null\n project.updatedAt = new Date()\n await em.flush()\n\n await emitCrudUndoSideEffects({\n dataEngine: ctx.container.resolve('dataEngine'),\n action: 'updated',\n entity: project,\n identifiers: {\n id: project.id,\n organizationId: project.organizationId,\n tenantId: project.tenantId,\n },\n events: staffTimeProjectCrudEvents,\n indexer: timeProjectCrudIndexer,\n })\n },\n}\n\nconst deleteTimeProjectCommand: CommandHandler<{ id?: string }, { timeProjectId: string }> = {\n id: 'staff.timesheets.time_projects.delete',\n async prepare(input, ctx) {\n const id = input?.id\n if (!id) throw new CrudHttpError(400, { error: 'Time project id is required.' })\n const em = (ctx.container.resolve('em') as EntityManager)\n const snapshot = await loadTimeProjectSnapshot(em, id)\n if (!snapshot) return {}\n return { before: snapshot }\n },\n async execute(input, ctx) {\n const id = input?.id\n if (!id) throw new CrudHttpError(400, { error: 'Time project id is required.' })\n const em = (ctx.container.resolve('em') as EntityManager).fork()\n const project = await findOneWithDecryption(\n em,\n StaffTimeProject,\n { id, deletedAt: null },\n undefined,\n { tenantId: ctx.auth?.tenantId ?? null, organizationId: ctx.auth?.orgId ?? null },\n )\n if (!project) throw new CrudHttpError(404, { error: 'Time project not found.' })\n ensureTenantScope(ctx, project.tenantId)\n ensureOrganizationScope(ctx, project.organizationId)\n\n project.deletedAt = new Date()\n project.updatedAt = new Date()\n await em.flush()\n\n await emitCrudSideEffects({\n dataEngine: ctx.container.resolve('dataEngine'),\n action: 'deleted',\n entity: project,\n identifiers: {\n id: project.id,\n organizationId: project.organizationId,\n tenantId: project.tenantId,\n },\n events: staffTimeProjectCrudEvents,\n indexer: timeProjectCrudIndexer,\n })\n return { timeProjectId: project.id }\n },\n buildLog: async ({ snapshots }) => {\n const before = snapshots.before as TimeProjectSnapshot | undefined\n if (!before) return null\n const { translate } = await resolveTranslations()\n return {\n actionLabel: translate('staff.audit.timesheets.time_projects.delete', 'Delete time project'),\n resourceKind: 'staff.timesheets.time_project',\n resourceId: before.id,\n tenantId: before.tenantId,\n organizationId: before.organizationId,\n snapshotBefore: before,\n payload: {\n undo: {\n before,\n } satisfies TimeProjectUndoPayload,\n },\n }\n },\n undo: async ({ logEntry, ctx }) => {\n const payload = extractUndoPayload<TimeProjectUndoPayload>(logEntry)\n const before = payload?.before\n if (!before) return\n const em = (ctx.container.resolve('em') as EntityManager).fork()\n let project = await em.findOne(StaffTimeProject, { id: before.id })\n if (!project) {\n project = em.create(StaffTimeProject, {\n id: before.id,\n tenantId: before.tenantId,\n organizationId: before.organizationId,\n name: before.name,\n customerId: before.customerId ?? null,\n code: before.code,\n description: before.description ?? null,\n projectType: before.projectType ?? null,\n status: (before.status ?? 'active') as StaffTimeProjectStatus,\n ownerUserId: before.ownerUserId ?? null,\n costCenter: before.costCenter ?? null,\n startDate: before.startDate ? new Date(before.startDate) : null,\n deletedAt: null,\n createdAt: new Date(),\n updatedAt: new Date(),\n })\n em.persist(project)\n } else {\n project.name = before.name\n project.customerId = before.customerId ?? null\n project.code = before.code\n project.description = before.description ?? null\n project.projectType = before.projectType ?? null\n project.status = (before.status ?? 'active') as StaffTimeProjectStatus\n project.ownerUserId = before.ownerUserId ?? null\n project.costCenter = before.costCenter ?? null\n project.startDate = before.startDate ? new Date(before.startDate) : null\n project.deletedAt = null\n project.updatedAt = new Date()\n }\n await em.flush()\n\n await emitCrudUndoSideEffects({\n dataEngine: ctx.container.resolve('dataEngine'),\n action: 'created',\n entity: project,\n identifiers: {\n id: project.id,\n organizationId: project.organizationId,\n tenantId: project.tenantId,\n },\n events: staffTimeProjectCrudEvents,\n indexer: timeProjectCrudIndexer,\n })\n },\n}\n\nconst assignTimeProjectMemberCommand: CommandHandler<StaffTimeProjectMemberAssignInput, { timeProjectMemberId: string }> = {\n id: 'staff.timesheets.time_project_members.assign',\n async execute(rawInput, ctx) {\n const parsed = staffTimeProjectMemberAssignSchema.parse(rawInput)\n ensureTenantScope(ctx, parsed.tenantId)\n ensureOrganizationScope(ctx, parsed.organizationId)\n\n const em = (ctx.container.resolve('em') as EntityManager).fork()\n\n // Validate referenced project and staff member are in-scope before persisting.\n // Without this check a foreign or stale UUID would produce a dangling reference.\n const projectExists = await em.findOne(\n StaffTimeProject,\n { id: parsed.timeProjectId, tenantId: parsed.tenantId, organizationId: parsed.organizationId, deletedAt: null },\n { fields: ['id'] },\n )\n if (!projectExists) {\n const { translate } = await resolveTranslations()\n throw new CrudHttpError(422, {\n error: translate('staff.timesheets.errors.projectNotFound', 'Time project not found or not accessible.'),\n fieldErrors: {\n timeProjectId: translate('staff.timesheets.errors.projectNotFound', 'Time project not found or not accessible.'),\n },\n })\n }\n const memberExists = await em.findOne(\n StaffTeamMember,\n { id: parsed.staffMemberId, tenantId: parsed.tenantId, organizationId: parsed.organizationId, deletedAt: null },\n { fields: ['id'] },\n )\n if (!memberExists) {\n const { translate } = await resolveTranslations()\n throw new CrudHttpError(422, {\n error: translate('staff.timesheets.errors.staffMemberNotFound', 'Staff member not found or not accessible.'),\n fieldErrors: {\n staffMemberId: translate('staff.timesheets.errors.staffMemberNotFound', 'Staff member not found or not accessible.'),\n },\n })\n }\n\n const now = new Date()\n const member = em.create(StaffTimeProjectMember, {\n tenantId: parsed.tenantId,\n organizationId: parsed.organizationId,\n timeProjectId: parsed.timeProjectId,\n staffMemberId: parsed.staffMemberId,\n role: parsed.role ?? null,\n status: parsed.status ?? 'active',\n showInGrid: false,\n assignedStartDate: parsed.assignedStartDate,\n assignedEndDate: parsed.assignedEndDate ?? null,\n createdAt: now,\n updatedAt: now,\n deletedAt: null,\n })\n em.persist(member)\n await em.flush()\n\n await emitCrudSideEffects({\n dataEngine: ctx.container.resolve('dataEngine'),\n action: 'created',\n entity: member,\n identifiers: { id: member.id, organizationId: member.organizationId, tenantId: member.tenantId },\n events: staffTimeProjectMemberCrudEvents,\n indexer: timeProjectMemberCrudIndexer,\n })\n\n return { timeProjectMemberId: member.id }\n },\n captureAfter: async (_input, result, ctx) => {\n const em = (ctx.container.resolve('em') as EntityManager).fork()\n const snapshot = await loadTimeProjectMemberSnapshot(em, result.timeProjectMemberId)\n if (!snapshot) return null\n return { snapshot }\n },\n buildLog: async ({ result, ctx }) => {\n const em = (ctx.container.resolve('em') as EntityManager).fork()\n const snapshot = await loadTimeProjectMemberSnapshot(em, result.timeProjectMemberId)\n if (!snapshot) return null\n const { translate } = await resolveTranslations()\n return {\n actionLabel: translate('staff.audit.timesheets.time_project_members.assign', 'Assign time project member'),\n resourceKind: 'staff.timesheets.time_project_member',\n resourceId: snapshot.id,\n tenantId: snapshot.tenantId,\n organizationId: snapshot.organizationId,\n snapshotAfter: snapshot,\n payload: {\n undo: {\n after: snapshot,\n } satisfies TimeProjectMemberUndoPayload,\n },\n }\n },\n undo: async ({ logEntry, ctx }) => {\n const payload = extractUndoPayload<TimeProjectMemberUndoPayload>(logEntry)\n const after = payload?.after\n if (!after) return\n const em = (ctx.container.resolve('em') as EntityManager).fork()\n const member = await em.findOne(StaffTimeProjectMember, { id: after.id })\n if (member) {\n member.deletedAt = new Date()\n await em.flush()\n\n await emitCrudUndoSideEffects({\n dataEngine: ctx.container.resolve('dataEngine'),\n action: 'deleted',\n entity: member,\n identifiers: { id: member.id, organizationId: member.organizationId, tenantId: member.tenantId },\n events: staffTimeProjectMemberCrudEvents,\n })\n }\n },\n}\n\nconst unassignTimeProjectMemberCommand: CommandHandler<{ id?: string }, { timeProjectMemberId: string }> = {\n id: 'staff.timesheets.time_project_members.unassign',\n async prepare(input, ctx) {\n const id = input?.id\n if (!id) throw new CrudHttpError(400, { error: 'Time project member id is required.' })\n const em = (ctx.container.resolve('em') as EntityManager)\n const snapshot = await loadTimeProjectMemberSnapshot(em, id)\n if (!snapshot) return {}\n return { before: snapshot }\n },\n async execute(input, ctx) {\n const id = input?.id\n if (!id) throw new CrudHttpError(400, { error: 'Time project member id is required.' })\n const em = (ctx.container.resolve('em') as EntityManager).fork()\n const member = await findOneWithDecryption(\n em,\n StaffTimeProjectMember,\n { id, deletedAt: null },\n undefined,\n { tenantId: ctx.auth?.tenantId ?? null, organizationId: ctx.auth?.orgId ?? null },\n )\n if (!member) throw new CrudHttpError(404, { error: 'Time project member not found.' })\n ensureTenantScope(ctx, member.tenantId)\n ensureOrganizationScope(ctx, member.organizationId)\n\n member.deletedAt = new Date()\n member.updatedAt = new Date()\n await em.flush()\n\n await emitCrudSideEffects({\n dataEngine: ctx.container.resolve('dataEngine'),\n action: 'deleted',\n entity: member,\n identifiers: { id: member.id, organizationId: member.organizationId, tenantId: member.tenantId },\n events: staffTimeProjectMemberCrudEvents,\n indexer: timeProjectMemberCrudIndexer,\n })\n\n return { timeProjectMemberId: member.id }\n },\n buildLog: async ({ snapshots }) => {\n const before = snapshots.before as TimeProjectMemberSnapshot | undefined\n if (!before) return null\n const { translate } = await resolveTranslations()\n return {\n actionLabel: translate('staff.audit.timesheets.time_project_members.unassign', 'Unassign time project member'),\n resourceKind: 'staff.timesheets.time_project_member',\n resourceId: before.id,\n tenantId: before.tenantId,\n organizationId: before.organizationId,\n snapshotBefore: before,\n payload: {\n undo: {\n before,\n } satisfies TimeProjectMemberUndoPayload,\n },\n }\n },\n undo: async ({ logEntry, ctx }) => {\n const payload = extractUndoPayload<TimeProjectMemberUndoPayload>(logEntry)\n const before = payload?.before\n if (!before) return\n const em = (ctx.container.resolve('em') as EntityManager).fork()\n let member = await em.findOne(StaffTimeProjectMember, { id: before.id })\n if (!member) {\n member = em.create(StaffTimeProjectMember, {\n id: before.id,\n tenantId: before.tenantId,\n organizationId: before.organizationId,\n timeProjectId: before.timeProjectId,\n staffMemberId: before.staffMemberId,\n role: before.role ?? null,\n status: (before.status ?? 'active') as StaffTimeProjectMemberStatus,\n showInGrid: before.showInGrid ?? false,\n assignedStartDate: new Date(before.assignedStartDate),\n assignedEndDate: before.assignedEndDate ? new Date(before.assignedEndDate) : null,\n deletedAt: null,\n createdAt: new Date(),\n updatedAt: new Date(),\n })\n em.persist(member)\n } else {\n member.timeProjectId = before.timeProjectId\n member.staffMemberId = before.staffMemberId\n member.role = before.role ?? null\n member.status = (before.status ?? 'active') as StaffTimeProjectMemberStatus\n member.assignedStartDate = new Date(before.assignedStartDate)\n member.assignedEndDate = before.assignedEndDate ? new Date(before.assignedEndDate) : null\n member.deletedAt = null\n member.updatedAt = new Date()\n }\n await em.flush()\n\n await emitCrudUndoSideEffects({\n dataEngine: ctx.container.resolve('dataEngine'),\n action: 'created',\n entity: member,\n identifiers: { id: member.id, organizationId: member.organizationId, tenantId: member.tenantId },\n events: staffTimeProjectMemberCrudEvents,\n indexer: timeProjectMemberCrudIndexer,\n })\n },\n}\n\nregisterCommand(createTimeProjectCommand)\nregisterCommand(updateTimeProjectCommand)\nregisterCommand(deleteTimeProjectCommand)\nregisterCommand(assignTimeProjectMemberCommand)\nregisterCommand(unassignTimeProjectMemberCommand)\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,104 @@
1
+ import { findOneWithDecryption } from "@open-mercato/shared/lib/encryption/find";
2
+ import { StaffTeamMember } from "./entities.js";
3
+ import { computeProjectHoursTrend } from "../lib/timesheets-projects/computeProjectHoursTrend.js";
4
+ import {
5
+ listProjectMembersPreview
6
+ } from "../lib/timesheets-projects/listProjectMembersPreview.js";
7
+ const MANAGE_FEATURE = "staff.timesheets.projects.manage";
8
+ const FALLBACK = {
9
+ _staff: {
10
+ hoursWeek: 0,
11
+ hoursTrend: [0, 0, 0, 0, 0, 0, 0],
12
+ myRole: null
13
+ }
14
+ };
15
+ async function callerHasManage(ctx) {
16
+ if (ctx.userFeatures?.includes(MANAGE_FEATURE)) return true;
17
+ try {
18
+ const rbac = ctx.container.resolve("rbacService");
19
+ return await rbac.userHasAllFeatures(ctx.userId, [MANAGE_FEATURE], {
20
+ tenantId: ctx.tenantId,
21
+ organizationId: ctx.organizationId
22
+ });
23
+ } catch {
24
+ return false;
25
+ }
26
+ }
27
+ async function resolveCallerStaffMemberId(ctx) {
28
+ const member = await findOneWithDecryption(
29
+ ctx.em.fork(),
30
+ StaffTeamMember,
31
+ {
32
+ userId: ctx.userId,
33
+ tenantId: ctx.tenantId,
34
+ organizationId: ctx.organizationId,
35
+ deletedAt: null
36
+ },
37
+ {},
38
+ { tenantId: ctx.tenantId, organizationId: ctx.organizationId }
39
+ );
40
+ return member?.id ?? null;
41
+ }
42
+ const portfolioEnricher = {
43
+ id: "staff.timesheets-projects-portfolio",
44
+ targetEntity: "staff:staff_time_project",
45
+ // ACL is enforced by the route (`requireFeatures: ['staff.timesheets.projects.view']`).
46
+ // Per-field gating (e.g. `members` for manage-only) happens inline below via rbacService.
47
+ priority: 10,
48
+ timeout: 3e3,
49
+ critical: false,
50
+ fallback: FALLBACK,
51
+ async enrichOne(record, context) {
52
+ const enriched = await this.enrichMany([record], context);
53
+ return enriched[0];
54
+ },
55
+ async enrichMany(records, context) {
56
+ if (records.length === 0) return records;
57
+ const ctx = context;
58
+ const projectIds = records.map((r) => r.id);
59
+ const [callerStaffMemberId, hasManage] = await Promise.all([
60
+ resolveCallerStaffMemberId(ctx),
61
+ callerHasManage(ctx)
62
+ ]);
63
+ const [trendMap, membersMap] = await Promise.all([
64
+ computeProjectHoursTrend({
65
+ em: ctx.em,
66
+ tenantId: ctx.tenantId,
67
+ organizationId: ctx.organizationId,
68
+ projectIds,
69
+ staffMemberId: hasManage ? null : callerStaffMemberId
70
+ }),
71
+ listProjectMembersPreview({
72
+ em: ctx.em,
73
+ tenantId: ctx.tenantId,
74
+ organizationId: ctx.organizationId,
75
+ projectIds,
76
+ callerStaffMemberId
77
+ })
78
+ ]);
79
+ return records.map((record) => {
80
+ const trend = trendMap.get(record.id) ?? {
81
+ hoursWeek: 0,
82
+ hoursTrend: [0, 0, 0, 0, 0, 0, 0]
83
+ };
84
+ const members = membersMap.get(record.id);
85
+ const enrichment = {
86
+ hoursWeek: trend.hoursWeek,
87
+ hoursTrend: trend.hoursTrend,
88
+ myRole: members?.myRole ?? null
89
+ };
90
+ if (hasManage && members) {
91
+ enrichment.members = members.preview;
92
+ enrichment.memberCount = members.total;
93
+ }
94
+ return { ...record, _staff: enrichment };
95
+ });
96
+ }
97
+ };
98
+ const enrichers = [portfolioEnricher];
99
+ var enrichers_default = enrichers;
100
+ export {
101
+ enrichers_default as default,
102
+ enrichers
103
+ };
104
+ //# sourceMappingURL=enrichers.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/modules/staff/data/enrichers.ts"],
4
+ "sourcesContent": ["import type { EntityManager } from '@mikro-orm/postgresql'\nimport type { AwilixContainer } from 'awilix'\nimport type { ResponseEnricher, EnricherContext } from '@open-mercato/shared/lib/crud/response-enricher'\nimport type { RbacService } from '@open-mercato/core/modules/auth/services/rbacService'\nimport { findOneWithDecryption } from '@open-mercato/shared/lib/encryption/find'\nimport { StaffTeamMember } from './entities'\nimport { computeProjectHoursTrend } from '../lib/timesheets-projects/computeProjectHoursTrend'\nimport {\n listProjectMembersPreview,\n type MemberPreview,\n} from '../lib/timesheets-projects/listProjectMembersPreview'\n\nconst MANAGE_FEATURE = 'staff.timesheets.projects.manage'\n\ntype EntityRecord = Record<string, unknown> & { id: string }\n\ntype StaffEnrichment = {\n _staff: {\n hoursWeek: number\n hoursTrend: number[]\n myRole: string | null\n members?: MemberPreview[]\n memberCount?: number\n }\n}\n\nconst FALLBACK: StaffEnrichment = {\n _staff: {\n hoursWeek: 0,\n hoursTrend: [0, 0, 0, 0, 0, 0, 0],\n myRole: null,\n },\n}\n\ntype InternalContext = EnricherContext & {\n em: EntityManager\n container: AwilixContainer\n}\n\nasync function callerHasManage(ctx: InternalContext): Promise<boolean> {\n if (ctx.userFeatures?.includes(MANAGE_FEATURE)) return true\n try {\n const rbac = ctx.container.resolve('rbacService') as RbacService\n return await rbac.userHasAllFeatures(ctx.userId, [MANAGE_FEATURE], {\n tenantId: ctx.tenantId,\n organizationId: ctx.organizationId,\n })\n } catch {\n return false\n }\n}\n\nasync function resolveCallerStaffMemberId(ctx: InternalContext): Promise<string | null> {\n const member = await findOneWithDecryption(\n ctx.em.fork(),\n StaffTeamMember,\n {\n userId: ctx.userId,\n tenantId: ctx.tenantId,\n organizationId: ctx.organizationId,\n deletedAt: null,\n },\n {},\n { tenantId: ctx.tenantId, organizationId: ctx.organizationId },\n )\n return member?.id ?? null\n}\n\nconst portfolioEnricher: ResponseEnricher<EntityRecord, StaffEnrichment> = {\n id: 'staff.timesheets-projects-portfolio',\n targetEntity: 'staff:staff_time_project',\n // ACL is enforced by the route (`requireFeatures: ['staff.timesheets.projects.view']`).\n // Per-field gating (e.g. `members` for manage-only) happens inline below via rbacService.\n priority: 10,\n timeout: 3000,\n critical: false,\n fallback: FALLBACK,\n\n async enrichOne(record, context) {\n const enriched = await this.enrichMany!([record], context)\n return enriched[0]\n },\n\n async enrichMany(records, context) {\n if (records.length === 0) return records as (EntityRecord & StaffEnrichment)[]\n\n const ctx = context as InternalContext\n const projectIds = records.map((r) => r.id)\n\n const [callerStaffMemberId, hasManage] = await Promise.all([\n resolveCallerStaffMemberId(ctx),\n callerHasManage(ctx),\n ])\n\n const [trendMap, membersMap] = await Promise.all([\n computeProjectHoursTrend({\n em: ctx.em,\n tenantId: ctx.tenantId,\n organizationId: ctx.organizationId,\n projectIds,\n staffMemberId: hasManage ? null : callerStaffMemberId,\n }),\n listProjectMembersPreview({\n em: ctx.em,\n tenantId: ctx.tenantId,\n organizationId: ctx.organizationId,\n projectIds,\n callerStaffMemberId,\n }),\n ])\n\n return records.map((record) => {\n const trend = trendMap.get(record.id) ?? {\n hoursWeek: 0,\n hoursTrend: [0, 0, 0, 0, 0, 0, 0],\n }\n const members = membersMap.get(record.id)\n const enrichment: StaffEnrichment['_staff'] = {\n hoursWeek: trend.hoursWeek,\n hoursTrend: trend.hoursTrend,\n myRole: members?.myRole ?? null,\n }\n if (hasManage && members) {\n enrichment.members = members.preview\n enrichment.memberCount = members.total\n }\n return { ...record, _staff: enrichment }\n })\n },\n}\n\nexport const enrichers: ResponseEnricher[] = [portfolioEnricher]\n\nexport default enrichers\n"],
5
+ "mappings": "AAIA,SAAS,6BAA6B;AACtC,SAAS,uBAAuB;AAChC,SAAS,gCAAgC;AACzC;AAAA,EACE;AAAA,OAEK;AAEP,MAAM,iBAAiB;AAcvB,MAAM,WAA4B;AAAA,EAChC,QAAQ;AAAA,IACN,WAAW;AAAA,IACX,YAAY,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAAA,IAChC,QAAQ;AAAA,EACV;AACF;AAOA,eAAe,gBAAgB,KAAwC;AACrE,MAAI,IAAI,cAAc,SAAS,cAAc,EAAG,QAAO;AACvD,MAAI;AACF,UAAM,OAAO,IAAI,UAAU,QAAQ,aAAa;AAChD,WAAO,MAAM,KAAK,mBAAmB,IAAI,QAAQ,CAAC,cAAc,GAAG;AAAA,MACjE,UAAU,IAAI;AAAA,MACd,gBAAgB,IAAI;AAAA,IACtB,CAAC;AAAA,EACH,QAAQ;AACN,WAAO;AAAA,EACT;AACF;AAEA,eAAe,2BAA2B,KAA8C;AACtF,QAAM,SAAS,MAAM;AAAA,IACnB,IAAI,GAAG,KAAK;AAAA,IACZ;AAAA,IACA;AAAA,MACE,QAAQ,IAAI;AAAA,MACZ,UAAU,IAAI;AAAA,MACd,gBAAgB,IAAI;AAAA,MACpB,WAAW;AAAA,IACb;AAAA,IACA,CAAC;AAAA,IACD,EAAE,UAAU,IAAI,UAAU,gBAAgB,IAAI,eAAe;AAAA,EAC/D;AACA,SAAO,QAAQ,MAAM;AACvB;AAEA,MAAM,oBAAqE;AAAA,EACzE,IAAI;AAAA,EACJ,cAAc;AAAA;AAAA;AAAA,EAGd,UAAU;AAAA,EACV,SAAS;AAAA,EACT,UAAU;AAAA,EACV,UAAU;AAAA,EAEV,MAAM,UAAU,QAAQ,SAAS;AAC/B,UAAM,WAAW,MAAM,KAAK,WAAY,CAAC,MAAM,GAAG,OAAO;AACzD,WAAO,SAAS,CAAC;AAAA,EACnB;AAAA,EAEA,MAAM,WAAW,SAAS,SAAS;AACjC,QAAI,QAAQ,WAAW,EAAG,QAAO;AAEjC,UAAM,MAAM;AACZ,UAAM,aAAa,QAAQ,IAAI,CAAC,MAAM,EAAE,EAAE;AAE1C,UAAM,CAAC,qBAAqB,SAAS,IAAI,MAAM,QAAQ,IAAI;AAAA,MACzD,2BAA2B,GAAG;AAAA,MAC9B,gBAAgB,GAAG;AAAA,IACrB,CAAC;AAED,UAAM,CAAC,UAAU,UAAU,IAAI,MAAM,QAAQ,IAAI;AAAA,MAC/C,yBAAyB;AAAA,QACvB,IAAI,IAAI;AAAA,QACR,UAAU,IAAI;AAAA,QACd,gBAAgB,IAAI;AAAA,QACpB;AAAA,QACA,eAAe,YAAY,OAAO;AAAA,MACpC,CAAC;AAAA,MACD,0BAA0B;AAAA,QACxB,IAAI,IAAI;AAAA,QACR,UAAU,IAAI;AAAA,QACd,gBAAgB,IAAI;AAAA,QACpB;AAAA,QACA;AAAA,MACF,CAAC;AAAA,IACH,CAAC;AAED,WAAO,QAAQ,IAAI,CAAC,WAAW;AAC7B,YAAM,QAAQ,SAAS,IAAI,OAAO,EAAE,KAAK;AAAA,QACvC,WAAW;AAAA,QACX,YAAY,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAAA,MAClC;AACA,YAAM,UAAU,WAAW,IAAI,OAAO,EAAE;AACxC,YAAM,aAAwC;AAAA,QAC5C,WAAW,MAAM;AAAA,QACjB,YAAY,MAAM;AAAA,QAClB,QAAQ,SAAS,UAAU;AAAA,MAC7B;AACA,UAAI,aAAa,SAAS;AACxB,mBAAW,UAAU,QAAQ;AAC7B,mBAAW,cAAc,QAAQ;AAAA,MACnC;AACA,aAAO,EAAE,GAAG,QAAQ,QAAQ,WAAW;AAAA,IACzC,CAAC;AAAA,EACH;AACF;AAEO,MAAM,YAAgC,CAAC,iBAAiB;AAE/D,IAAO,oBAAQ;",
6
+ "names": []
7
+ }
@@ -424,6 +424,227 @@ StaffTeamMemberAddress = __decorateClass([
424
424
  Index({ name: "staff_team_member_addresses_member_idx", properties: ["member"] }),
425
425
  Index({ name: "staff_team_member_addresses_tenant_org_idx", properties: ["tenantId", "organizationId"] })
426
426
  ], StaffTeamMemberAddress);
427
+ let StaffTimeEntry = class {
428
+ constructor() {
429
+ this.durationMinutes = 0;
430
+ this.source = "manual";
431
+ this.createdAt = /* @__PURE__ */ new Date();
432
+ this.updatedAt = /* @__PURE__ */ new Date();
433
+ }
434
+ };
435
+ __decorateClass([
436
+ PrimaryKey({ type: "uuid", defaultRaw: "gen_random_uuid()" })
437
+ ], StaffTimeEntry.prototype, "id", 2);
438
+ __decorateClass([
439
+ Property({ name: "tenant_id", type: "uuid" })
440
+ ], StaffTimeEntry.prototype, "tenantId", 2);
441
+ __decorateClass([
442
+ Property({ name: "organization_id", type: "uuid" })
443
+ ], StaffTimeEntry.prototype, "organizationId", 2);
444
+ __decorateClass([
445
+ Property({ name: "staff_member_id", type: "uuid" })
446
+ ], StaffTimeEntry.prototype, "staffMemberId", 2);
447
+ __decorateClass([
448
+ Property({ name: "date", type: "date" })
449
+ ], StaffTimeEntry.prototype, "date", 2);
450
+ __decorateClass([
451
+ Property({ name: "duration_minutes", type: "integer", default: 0 })
452
+ ], StaffTimeEntry.prototype, "durationMinutes", 2);
453
+ __decorateClass([
454
+ Property({ name: "started_at", type: Date, nullable: true })
455
+ ], StaffTimeEntry.prototype, "startedAt", 2);
456
+ __decorateClass([
457
+ Property({ name: "ended_at", type: Date, nullable: true })
458
+ ], StaffTimeEntry.prototype, "endedAt", 2);
459
+ __decorateClass([
460
+ Property({ type: "text", nullable: true })
461
+ ], StaffTimeEntry.prototype, "notes", 2);
462
+ __decorateClass([
463
+ Property({ name: "time_project_id", type: "uuid", nullable: true })
464
+ ], StaffTimeEntry.prototype, "timeProjectId", 2);
465
+ __decorateClass([
466
+ Property({ name: "customer_id", type: "uuid", nullable: true })
467
+ ], StaffTimeEntry.prototype, "customerId", 2);
468
+ __decorateClass([
469
+ Property({ name: "deal_id", type: "uuid", nullable: true })
470
+ ], StaffTimeEntry.prototype, "dealId", 2);
471
+ __decorateClass([
472
+ Property({ name: "order_id", type: "uuid", nullable: true })
473
+ ], StaffTimeEntry.prototype, "orderId", 2);
474
+ __decorateClass([
475
+ Enum({ items: ["manual", "timer", "kiosk", "mobile"], type: "text", name: "source", default: "manual" })
476
+ ], StaffTimeEntry.prototype, "source", 2);
477
+ __decorateClass([
478
+ Property({ name: "created_at", type: Date, onCreate: () => /* @__PURE__ */ new Date() })
479
+ ], StaffTimeEntry.prototype, "createdAt", 2);
480
+ __decorateClass([
481
+ Property({ name: "updated_at", type: Date, onUpdate: () => /* @__PURE__ */ new Date() })
482
+ ], StaffTimeEntry.prototype, "updatedAt", 2);
483
+ __decorateClass([
484
+ Property({ name: "deleted_at", type: Date, nullable: true })
485
+ ], StaffTimeEntry.prototype, "deletedAt", 2);
486
+ StaffTimeEntry = __decorateClass([
487
+ Entity({ tableName: "staff_time_entries" }),
488
+ Index({ name: "staff_time_entries_tenant_org_idx", properties: ["tenantId", "organizationId"] }),
489
+ Index({ name: "staff_time_entries_member_date_idx", properties: ["organizationId", "staffMemberId", "date"] }),
490
+ Index({ name: "staff_time_entries_project_date_idx", properties: ["organizationId", "timeProjectId", "date"] })
491
+ ], StaffTimeEntry);
492
+ let StaffTimeEntrySegment = class {
493
+ constructor() {
494
+ this.segmentType = "work";
495
+ this.createdAt = /* @__PURE__ */ new Date();
496
+ this.updatedAt = /* @__PURE__ */ new Date();
497
+ }
498
+ };
499
+ __decorateClass([
500
+ PrimaryKey({ type: "uuid", defaultRaw: "gen_random_uuid()" })
501
+ ], StaffTimeEntrySegment.prototype, "id", 2);
502
+ __decorateClass([
503
+ Property({ name: "tenant_id", type: "uuid" })
504
+ ], StaffTimeEntrySegment.prototype, "tenantId", 2);
505
+ __decorateClass([
506
+ Property({ name: "organization_id", type: "uuid" })
507
+ ], StaffTimeEntrySegment.prototype, "organizationId", 2);
508
+ __decorateClass([
509
+ Property({ name: "time_entry_id", type: "uuid" })
510
+ ], StaffTimeEntrySegment.prototype, "timeEntryId", 2);
511
+ __decorateClass([
512
+ Property({ name: "started_at", type: Date })
513
+ ], StaffTimeEntrySegment.prototype, "startedAt", 2);
514
+ __decorateClass([
515
+ Property({ name: "ended_at", type: Date, nullable: true })
516
+ ], StaffTimeEntrySegment.prototype, "endedAt", 2);
517
+ __decorateClass([
518
+ Enum({ items: ["work", "break"], type: "text", name: "segment_type", default: "work" })
519
+ ], StaffTimeEntrySegment.prototype, "segmentType", 2);
520
+ __decorateClass([
521
+ Property({ name: "created_at", type: Date, onCreate: () => /* @__PURE__ */ new Date() })
522
+ ], StaffTimeEntrySegment.prototype, "createdAt", 2);
523
+ __decorateClass([
524
+ Property({ name: "updated_at", type: Date, onUpdate: () => /* @__PURE__ */ new Date() })
525
+ ], StaffTimeEntrySegment.prototype, "updatedAt", 2);
526
+ __decorateClass([
527
+ Property({ name: "deleted_at", type: Date, nullable: true })
528
+ ], StaffTimeEntrySegment.prototype, "deletedAt", 2);
529
+ StaffTimeEntrySegment = __decorateClass([
530
+ Entity({ tableName: "staff_time_entry_segments" }),
531
+ Index({ name: "staff_time_entry_segments_tenant_org_idx", properties: ["tenantId", "organizationId"] }),
532
+ Index({ name: "staff_time_entry_segments_entry_idx", properties: ["timeEntryId"] })
533
+ ], StaffTimeEntrySegment);
534
+ let StaffTimeProject = class {
535
+ constructor() {
536
+ this.status = "active";
537
+ this.createdAt = /* @__PURE__ */ new Date();
538
+ this.updatedAt = /* @__PURE__ */ new Date();
539
+ }
540
+ };
541
+ __decorateClass([
542
+ PrimaryKey({ type: "uuid", defaultRaw: "gen_random_uuid()" })
543
+ ], StaffTimeProject.prototype, "id", 2);
544
+ __decorateClass([
545
+ Property({ name: "tenant_id", type: "uuid" })
546
+ ], StaffTimeProject.prototype, "tenantId", 2);
547
+ __decorateClass([
548
+ Property({ name: "organization_id", type: "uuid" })
549
+ ], StaffTimeProject.prototype, "organizationId", 2);
550
+ __decorateClass([
551
+ Property({ type: "text" })
552
+ ], StaffTimeProject.prototype, "name", 2);
553
+ __decorateClass([
554
+ Property({ name: "customer_id", type: "uuid", nullable: true })
555
+ ], StaffTimeProject.prototype, "customerId", 2);
556
+ __decorateClass([
557
+ Property({ type: "text" })
558
+ ], StaffTimeProject.prototype, "code", 2);
559
+ __decorateClass([
560
+ Property({ type: "text", nullable: true })
561
+ ], StaffTimeProject.prototype, "description", 2);
562
+ __decorateClass([
563
+ Property({ name: "project_type", type: "text", nullable: true })
564
+ ], StaffTimeProject.prototype, "projectType", 2);
565
+ __decorateClass([
566
+ Property({ type: "varchar", length: 20, nullable: true })
567
+ ], StaffTimeProject.prototype, "color", 2);
568
+ __decorateClass([
569
+ Enum({ items: ["active", "on_hold", "completed"], type: "text", name: "status", default: "active" })
570
+ ], StaffTimeProject.prototype, "status", 2);
571
+ __decorateClass([
572
+ Property({ name: "owner_user_id", type: "uuid", nullable: true })
573
+ ], StaffTimeProject.prototype, "ownerUserId", 2);
574
+ __decorateClass([
575
+ Property({ name: "cost_center", type: "text", nullable: true })
576
+ ], StaffTimeProject.prototype, "costCenter", 2);
577
+ __decorateClass([
578
+ Property({ name: "start_date", type: "date", nullable: true })
579
+ ], StaffTimeProject.prototype, "startDate", 2);
580
+ __decorateClass([
581
+ Property({ name: "created_at", type: Date, onCreate: () => /* @__PURE__ */ new Date() })
582
+ ], StaffTimeProject.prototype, "createdAt", 2);
583
+ __decorateClass([
584
+ Property({ name: "updated_at", type: Date, onUpdate: () => /* @__PURE__ */ new Date() })
585
+ ], StaffTimeProject.prototype, "updatedAt", 2);
586
+ __decorateClass([
587
+ Property({ name: "deleted_at", type: Date, nullable: true })
588
+ ], StaffTimeProject.prototype, "deletedAt", 2);
589
+ StaffTimeProject = __decorateClass([
590
+ Entity({ tableName: "staff_time_projects" }),
591
+ Index({ name: "staff_time_projects_tenant_org_idx", properties: ["tenantId", "organizationId"] }),
592
+ Index({ name: "staff_time_projects_code_unique_idx", properties: ["organizationId", "tenantId", "code"], options: { unique: true, where: "deleted_at IS NULL" } })
593
+ ], StaffTimeProject);
594
+ let StaffTimeProjectMember = class {
595
+ constructor() {
596
+ this.status = "active";
597
+ this.showInGrid = false;
598
+ this.createdAt = /* @__PURE__ */ new Date();
599
+ this.updatedAt = /* @__PURE__ */ new Date();
600
+ }
601
+ };
602
+ __decorateClass([
603
+ PrimaryKey({ type: "uuid", defaultRaw: "gen_random_uuid()" })
604
+ ], StaffTimeProjectMember.prototype, "id", 2);
605
+ __decorateClass([
606
+ Property({ name: "tenant_id", type: "uuid" })
607
+ ], StaffTimeProjectMember.prototype, "tenantId", 2);
608
+ __decorateClass([
609
+ Property({ name: "organization_id", type: "uuid" })
610
+ ], StaffTimeProjectMember.prototype, "organizationId", 2);
611
+ __decorateClass([
612
+ Property({ name: "time_project_id", type: "uuid" })
613
+ ], StaffTimeProjectMember.prototype, "timeProjectId", 2);
614
+ __decorateClass([
615
+ Property({ name: "staff_member_id", type: "uuid" })
616
+ ], StaffTimeProjectMember.prototype, "staffMemberId", 2);
617
+ __decorateClass([
618
+ Property({ type: "text", nullable: true })
619
+ ], StaffTimeProjectMember.prototype, "role", 2);
620
+ __decorateClass([
621
+ Enum({ items: ["active", "inactive"], type: "text", name: "status", default: "active" })
622
+ ], StaffTimeProjectMember.prototype, "status", 2);
623
+ __decorateClass([
624
+ Property({ name: "show_in_grid", type: "boolean", default: false })
625
+ ], StaffTimeProjectMember.prototype, "showInGrid", 2);
626
+ __decorateClass([
627
+ Property({ name: "assigned_start_date", type: "date" })
628
+ ], StaffTimeProjectMember.prototype, "assignedStartDate", 2);
629
+ __decorateClass([
630
+ Property({ name: "assigned_end_date", type: "date", nullable: true })
631
+ ], StaffTimeProjectMember.prototype, "assignedEndDate", 2);
632
+ __decorateClass([
633
+ Property({ name: "created_at", type: Date, onCreate: () => /* @__PURE__ */ new Date() })
634
+ ], StaffTimeProjectMember.prototype, "createdAt", 2);
635
+ __decorateClass([
636
+ Property({ name: "updated_at", type: Date, onUpdate: () => /* @__PURE__ */ new Date() })
637
+ ], StaffTimeProjectMember.prototype, "updatedAt", 2);
638
+ __decorateClass([
639
+ Property({ name: "deleted_at", type: Date, nullable: true })
640
+ ], StaffTimeProjectMember.prototype, "deletedAt", 2);
641
+ StaffTimeProjectMember = __decorateClass([
642
+ Entity({ tableName: "staff_time_project_members" }),
643
+ Index({ name: "staff_time_project_members_tenant_org_idx", properties: ["tenantId", "organizationId"] }),
644
+ Index({ name: "staff_time_project_members_project_idx", properties: ["organizationId", "timeProjectId"] }),
645
+ Index({ name: "staff_time_project_members_member_idx", properties: ["organizationId", "staffMemberId"] }),
646
+ Index({ name: "staff_time_project_members_unique_idx", properties: ["organizationId", "tenantId", "timeProjectId", "staffMemberId"], options: { unique: true, where: "deleted_at IS NULL" } })
647
+ ], StaffTimeProjectMember);
427
648
  export {
428
649
  StaffLeaveRequest,
429
650
  StaffTeam,
@@ -432,6 +653,10 @@ export {
432
653
  StaffTeamMemberAddress,
433
654
  StaffTeamMemberComment,
434
655
  StaffTeamMemberJobHistory,
435
- StaffTeamRole
656
+ StaffTeamRole,
657
+ StaffTimeEntry,
658
+ StaffTimeEntrySegment,
659
+ StaffTimeProject,
660
+ StaffTimeProjectMember
436
661
  };
437
662
  //# sourceMappingURL=entities.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../src/modules/staff/data/entities.ts"],
4
- "sourcesContent": ["import { Entity, Enum, Index, ManyToOne, PrimaryKey, Property } from '@mikro-orm/decorators/legacy'\n\nexport type StaffLeaveRequestStatus = 'pending' | 'approved' | 'rejected'\n\n@Entity({ tableName: 'staff_teams' })\n@Index({ name: 'staff_teams_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\nexport class StaffTeam {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ type: 'text' })\n name!: string\n\n @Property({ type: 'text', nullable: true })\n description?: string | null\n\n @Property({ name: 'is_active', type: 'boolean', default: true })\n isActive: boolean = true\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n}\n\n@Entity({ tableName: 'staff_team_roles' })\n@Index({ name: 'staff_team_roles_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\nexport class StaffTeamRole {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'team_id', type: 'uuid', nullable: true })\n teamId?: string | null\n\n @Property({ type: 'text' })\n name!: string\n\n @Property({ type: 'text', nullable: true })\n description?: string | null\n\n @Property({ name: 'appearance_icon', type: 'text', nullable: true })\n appearanceIcon?: string | null\n\n @Property({ name: 'appearance_color', type: 'text', nullable: true })\n appearanceColor?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n}\n\n@Entity({ tableName: 'staff_team_members' })\n@Index({ name: 'staff_team_members_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\nexport class StaffTeamMember {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'team_id', type: 'uuid', nullable: true })\n teamId?: string | null\n\n @Property({ name: 'display_name', type: 'text' })\n displayName!: string\n\n @Property({ type: 'text', nullable: true })\n description?: string | null\n\n @Property({ name: 'user_id', type: 'uuid', nullable: true })\n userId?: string | null\n\n @Property({ name: 'role_ids', type: 'jsonb', default: [] })\n roleIds: string[] = []\n\n @Property({ type: 'jsonb', default: [] })\n tags: string[] = []\n\n @Property({ name: 'availability_rule_set_id', type: 'uuid', nullable: true })\n availabilityRuleSetId?: string | null\n\n @Property({ name: 'is_active', type: 'boolean', default: true })\n isActive: boolean = true\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n}\n\n@Entity({ tableName: 'staff_leave_requests' })\n@Index({ name: 'staff_leave_requests_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\n@Index({ name: 'staff_leave_requests_member_idx', properties: ['member'] })\n@Index({ name: 'staff_leave_requests_status_idx', properties: ['status', 'tenantId', 'organizationId'] })\nexport class StaffLeaveRequest {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @ManyToOne(() => StaffTeamMember, { fieldName: 'member_id' })\n member!: StaffTeamMember\n\n @Property({ name: 'start_date', type: Date })\n startDate!: Date\n\n @Property({ name: 'end_date', type: Date })\n endDate!: Date\n\n @Property({ type: 'text' })\n timezone!: string\n\n @Enum({ items: ['pending', 'approved', 'rejected'], type: 'text', name: 'status' })\n status: StaffLeaveRequestStatus = 'pending'\n\n @Property({ name: 'unavailability_reason_entry_id', type: 'uuid', nullable: true })\n unavailabilityReasonEntryId?: string | null\n\n @Property({ name: 'unavailability_reason_value', type: 'text', nullable: true })\n unavailabilityReasonValue?: string | null\n\n @Property({ type: 'text', nullable: true })\n note?: string | null\n\n @Property({ name: 'decision_comment', type: 'text', nullable: true })\n decisionComment?: string | null\n\n @Property({ name: 'submitted_by_user_id', type: 'uuid', nullable: true })\n submittedByUserId?: string | null\n\n @Property({ name: 'decided_by_user_id', type: 'uuid', nullable: true })\n decidedByUserId?: string | null\n\n @Property({ name: 'decided_at', type: Date, nullable: true })\n decidedAt?: Date | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n}\n\n@Entity({ tableName: 'staff_team_member_comments' })\n@Index({ name: 'staff_team_member_comments_member_idx', properties: ['member'] })\n@Index({ name: 'staff_team_member_comments_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\nexport class StaffTeamMemberComment {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'body', type: 'text' })\n body!: string\n\n @Property({ name: 'author_user_id', type: 'uuid', nullable: true })\n authorUserId?: string | null\n\n @Property({ name: 'appearance_icon', type: 'text', nullable: true })\n appearanceIcon?: string | null\n\n @Property({ name: 'appearance_color', type: 'text', nullable: true })\n appearanceColor?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n\n @ManyToOne(() => StaffTeamMember, { fieldName: 'member_id' })\n member!: StaffTeamMember\n}\n\n@Entity({ tableName: 'staff_team_member_activities' })\n@Index({ name: 'staff_team_member_activities_member_idx', properties: ['member'] })\n@Index({ name: 'staff_team_member_activities_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\n@Index({ name: 'staff_team_member_activities_member_occurred_created_idx', properties: ['member', 'occurredAt', 'createdAt'] })\nexport class StaffTeamMemberActivity {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'activity_type', type: 'text' })\n activityType!: string\n\n @Property({ name: 'subject', type: 'text', nullable: true })\n subject?: string | null\n\n @Property({ name: 'body', type: 'text', nullable: true })\n body?: string | null\n\n @Property({ name: 'occurred_at', type: Date, nullable: true })\n occurredAt?: Date | null\n\n @Property({ name: 'author_user_id', type: 'uuid', nullable: true })\n authorUserId?: string | null\n\n @Property({ name: 'appearance_icon', type: 'text', nullable: true })\n appearanceIcon?: string | null\n\n @Property({ name: 'appearance_color', type: 'text', nullable: true })\n appearanceColor?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @ManyToOne(() => StaffTeamMember, { fieldName: 'member_id' })\n member!: StaffTeamMember\n}\n\n@Entity({ tableName: 'staff_team_member_job_histories' })\n@Index({ name: 'staff_team_member_job_histories_member_idx', properties: ['member'] })\n@Index({ name: 'staff_team_member_job_histories_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\n@Index({ name: 'staff_team_member_job_histories_member_start_idx', properties: ['member', 'startDate'] })\nexport class StaffTeamMemberJobHistory {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ type: 'text' })\n name!: string\n\n @Property({ name: 'company_name', type: 'text', nullable: true })\n companyName?: string | null\n\n @Property({ type: 'text', nullable: true })\n description?: string | null\n\n @Property({ name: 'start_date', type: Date })\n startDate!: Date\n\n @Property({ name: 'end_date', type: Date, nullable: true })\n endDate?: Date | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @ManyToOne(() => StaffTeamMember, { fieldName: 'member_id' })\n member!: StaffTeamMember\n}\n\n@Entity({ tableName: 'staff_team_member_addresses' })\n@Index({ name: 'staff_team_member_addresses_member_idx', properties: ['member'] })\n@Index({ name: 'staff_team_member_addresses_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\nexport class StaffTeamMemberAddress {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'name', type: 'text', nullable: true })\n name?: string | null\n\n @Property({ name: 'purpose', type: 'text', nullable: true })\n purpose?: string | null\n\n @Property({ name: 'company_name', type: 'text', nullable: true })\n companyName?: string | null\n\n @Property({ name: 'address_line1', type: 'text' })\n addressLine1!: string\n\n @Property({ name: 'address_line2', type: 'text', nullable: true })\n addressLine2?: string | null\n\n @Property({ name: 'city', type: 'text', nullable: true })\n city?: string | null\n\n @Property({ name: 'region', type: 'text', nullable: true })\n region?: string | null\n\n @Property({ name: 'postal_code', type: 'text', nullable: true })\n postalCode?: string | null\n\n @Property({ name: 'country', type: 'text', nullable: true })\n country?: string | null\n\n @Property({ name: 'building_number', type: 'text', nullable: true })\n buildingNumber?: string | null\n\n @Property({ name: 'flat_number', type: 'text', nullable: true })\n flatNumber?: string | null\n\n @Property({ name: 'latitude', type: 'float', nullable: true })\n latitude?: number | null\n\n @Property({ name: 'longitude', type: 'float', nullable: true })\n longitude?: number | null\n\n @Property({ name: 'is_primary', type: 'boolean', default: false })\n isPrimary: boolean = false\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @ManyToOne(() => StaffTeamMember, { fieldName: 'member_id' })\n member!: StaffTeamMember\n}\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["import { Entity, Enum, Index, ManyToOne, PrimaryKey, Property } from '@mikro-orm/decorators/legacy'\n\nexport type StaffLeaveRequestStatus = 'pending' | 'approved' | 'rejected'\n\n@Entity({ tableName: 'staff_teams' })\n@Index({ name: 'staff_teams_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\nexport class StaffTeam {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ type: 'text' })\n name!: string\n\n @Property({ type: 'text', nullable: true })\n description?: string | null\n\n @Property({ name: 'is_active', type: 'boolean', default: true })\n isActive: boolean = true\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n}\n\n@Entity({ tableName: 'staff_team_roles' })\n@Index({ name: 'staff_team_roles_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\nexport class StaffTeamRole {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'team_id', type: 'uuid', nullable: true })\n teamId?: string | null\n\n @Property({ type: 'text' })\n name!: string\n\n @Property({ type: 'text', nullable: true })\n description?: string | null\n\n @Property({ name: 'appearance_icon', type: 'text', nullable: true })\n appearanceIcon?: string | null\n\n @Property({ name: 'appearance_color', type: 'text', nullable: true })\n appearanceColor?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n}\n\n@Entity({ tableName: 'staff_team_members' })\n@Index({ name: 'staff_team_members_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\nexport class StaffTeamMember {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'team_id', type: 'uuid', nullable: true })\n teamId?: string | null\n\n @Property({ name: 'display_name', type: 'text' })\n displayName!: string\n\n @Property({ type: 'text', nullable: true })\n description?: string | null\n\n @Property({ name: 'user_id', type: 'uuid', nullable: true })\n userId?: string | null\n\n @Property({ name: 'role_ids', type: 'jsonb', default: [] })\n roleIds: string[] = []\n\n @Property({ type: 'jsonb', default: [] })\n tags: string[] = []\n\n @Property({ name: 'availability_rule_set_id', type: 'uuid', nullable: true })\n availabilityRuleSetId?: string | null\n\n @Property({ name: 'is_active', type: 'boolean', default: true })\n isActive: boolean = true\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n}\n\n@Entity({ tableName: 'staff_leave_requests' })\n@Index({ name: 'staff_leave_requests_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\n@Index({ name: 'staff_leave_requests_member_idx', properties: ['member'] })\n@Index({ name: 'staff_leave_requests_status_idx', properties: ['status', 'tenantId', 'organizationId'] })\nexport class StaffLeaveRequest {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @ManyToOne(() => StaffTeamMember, { fieldName: 'member_id' })\n member!: StaffTeamMember\n\n @Property({ name: 'start_date', type: Date })\n startDate!: Date\n\n @Property({ name: 'end_date', type: Date })\n endDate!: Date\n\n @Property({ type: 'text' })\n timezone!: string\n\n @Enum({ items: ['pending', 'approved', 'rejected'], type: 'text', name: 'status' })\n status: StaffLeaveRequestStatus = 'pending'\n\n @Property({ name: 'unavailability_reason_entry_id', type: 'uuid', nullable: true })\n unavailabilityReasonEntryId?: string | null\n\n @Property({ name: 'unavailability_reason_value', type: 'text', nullable: true })\n unavailabilityReasonValue?: string | null\n\n @Property({ type: 'text', nullable: true })\n note?: string | null\n\n @Property({ name: 'decision_comment', type: 'text', nullable: true })\n decisionComment?: string | null\n\n @Property({ name: 'submitted_by_user_id', type: 'uuid', nullable: true })\n submittedByUserId?: string | null\n\n @Property({ name: 'decided_by_user_id', type: 'uuid', nullable: true })\n decidedByUserId?: string | null\n\n @Property({ name: 'decided_at', type: Date, nullable: true })\n decidedAt?: Date | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n}\n\n@Entity({ tableName: 'staff_team_member_comments' })\n@Index({ name: 'staff_team_member_comments_member_idx', properties: ['member'] })\n@Index({ name: 'staff_team_member_comments_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\nexport class StaffTeamMemberComment {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'body', type: 'text' })\n body!: string\n\n @Property({ name: 'author_user_id', type: 'uuid', nullable: true })\n authorUserId?: string | null\n\n @Property({ name: 'appearance_icon', type: 'text', nullable: true })\n appearanceIcon?: string | null\n\n @Property({ name: 'appearance_color', type: 'text', nullable: true })\n appearanceColor?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n\n @ManyToOne(() => StaffTeamMember, { fieldName: 'member_id' })\n member!: StaffTeamMember\n}\n\n@Entity({ tableName: 'staff_team_member_activities' })\n@Index({ name: 'staff_team_member_activities_member_idx', properties: ['member'] })\n@Index({ name: 'staff_team_member_activities_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\n@Index({ name: 'staff_team_member_activities_member_occurred_created_idx', properties: ['member', 'occurredAt', 'createdAt'] })\nexport class StaffTeamMemberActivity {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'activity_type', type: 'text' })\n activityType!: string\n\n @Property({ name: 'subject', type: 'text', nullable: true })\n subject?: string | null\n\n @Property({ name: 'body', type: 'text', nullable: true })\n body?: string | null\n\n @Property({ name: 'occurred_at', type: Date, nullable: true })\n occurredAt?: Date | null\n\n @Property({ name: 'author_user_id', type: 'uuid', nullable: true })\n authorUserId?: string | null\n\n @Property({ name: 'appearance_icon', type: 'text', nullable: true })\n appearanceIcon?: string | null\n\n @Property({ name: 'appearance_color', type: 'text', nullable: true })\n appearanceColor?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @ManyToOne(() => StaffTeamMember, { fieldName: 'member_id' })\n member!: StaffTeamMember\n}\n\n@Entity({ tableName: 'staff_team_member_job_histories' })\n@Index({ name: 'staff_team_member_job_histories_member_idx', properties: ['member'] })\n@Index({ name: 'staff_team_member_job_histories_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\n@Index({ name: 'staff_team_member_job_histories_member_start_idx', properties: ['member', 'startDate'] })\nexport class StaffTeamMemberJobHistory {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ type: 'text' })\n name!: string\n\n @Property({ name: 'company_name', type: 'text', nullable: true })\n companyName?: string | null\n\n @Property({ type: 'text', nullable: true })\n description?: string | null\n\n @Property({ name: 'start_date', type: Date })\n startDate!: Date\n\n @Property({ name: 'end_date', type: Date, nullable: true })\n endDate?: Date | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @ManyToOne(() => StaffTeamMember, { fieldName: 'member_id' })\n member!: StaffTeamMember\n}\n\n@Entity({ tableName: 'staff_team_member_addresses' })\n@Index({ name: 'staff_team_member_addresses_member_idx', properties: ['member'] })\n@Index({ name: 'staff_team_member_addresses_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\nexport class StaffTeamMemberAddress {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'name', type: 'text', nullable: true })\n name?: string | null\n\n @Property({ name: 'purpose', type: 'text', nullable: true })\n purpose?: string | null\n\n @Property({ name: 'company_name', type: 'text', nullable: true })\n companyName?: string | null\n\n @Property({ name: 'address_line1', type: 'text' })\n addressLine1!: string\n\n @Property({ name: 'address_line2', type: 'text', nullable: true })\n addressLine2?: string | null\n\n @Property({ name: 'city', type: 'text', nullable: true })\n city?: string | null\n\n @Property({ name: 'region', type: 'text', nullable: true })\n region?: string | null\n\n @Property({ name: 'postal_code', type: 'text', nullable: true })\n postalCode?: string | null\n\n @Property({ name: 'country', type: 'text', nullable: true })\n country?: string | null\n\n @Property({ name: 'building_number', type: 'text', nullable: true })\n buildingNumber?: string | null\n\n @Property({ name: 'flat_number', type: 'text', nullable: true })\n flatNumber?: string | null\n\n @Property({ name: 'latitude', type: 'float', nullable: true })\n latitude?: number | null\n\n @Property({ name: 'longitude', type: 'float', nullable: true })\n longitude?: number | null\n\n @Property({ name: 'is_primary', type: 'boolean', default: false })\n isPrimary: boolean = false\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @ManyToOne(() => StaffTeamMember, { fieldName: 'member_id' })\n member!: StaffTeamMember\n}\n\n// --- Timesheets entities (Phase 1) ---\n\nexport type StaffTimeEntrySource = 'manual' | 'timer' | 'kiosk' | 'mobile'\nexport type StaffTimeProjectStatus = 'active' | 'on_hold' | 'completed'\nexport type StaffTimeProjectMemberStatus = 'active' | 'inactive'\nexport type StaffTimeEntrySegmentType = 'work' | 'break'\n\n@Entity({ tableName: 'staff_time_entries' })\n@Index({ name: 'staff_time_entries_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\n@Index({ name: 'staff_time_entries_member_date_idx', properties: ['organizationId', 'staffMemberId', 'date'] })\n@Index({ name: 'staff_time_entries_project_date_idx', properties: ['organizationId', 'timeProjectId', 'date'] })\nexport class StaffTimeEntry {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'staff_member_id', type: 'uuid' })\n staffMemberId!: string\n\n @Property({ name: 'date', type: 'date' })\n date!: Date\n\n @Property({ name: 'duration_minutes', type: 'integer', default: 0 })\n durationMinutes: number = 0\n\n @Property({ name: 'started_at', type: Date, nullable: true })\n startedAt?: Date | null\n\n @Property({ name: 'ended_at', type: Date, nullable: true })\n endedAt?: Date | null\n\n @Property({ type: 'text', nullable: true })\n notes?: string | null\n\n @Property({ name: 'time_project_id', type: 'uuid', nullable: true })\n timeProjectId?: string | null\n\n @Property({ name: 'customer_id', type: 'uuid', nullable: true })\n customerId?: string | null\n\n @Property({ name: 'deal_id', type: 'uuid', nullable: true })\n dealId?: string | null\n\n @Property({ name: 'order_id', type: 'uuid', nullable: true })\n orderId?: string | null\n\n @Enum({ items: ['manual', 'timer', 'kiosk', 'mobile'], type: 'text', name: 'source', default: 'manual' })\n source: StaffTimeEntrySource = 'manual'\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n}\n\n@Entity({ tableName: 'staff_time_entry_segments' })\n@Index({ name: 'staff_time_entry_segments_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\n@Index({ name: 'staff_time_entry_segments_entry_idx', properties: ['timeEntryId'] })\nexport class StaffTimeEntrySegment {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'time_entry_id', type: 'uuid' })\n timeEntryId!: string\n\n @Property({ name: 'started_at', type: Date })\n startedAt!: Date\n\n @Property({ name: 'ended_at', type: Date, nullable: true })\n endedAt?: Date | null\n\n @Enum({ items: ['work', 'break'], type: 'text', name: 'segment_type', default: 'work' })\n segmentType: StaffTimeEntrySegmentType = 'work'\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n}\n\n@Entity({ tableName: 'staff_time_projects' })\n@Index({ name: 'staff_time_projects_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\n@Index({ name: 'staff_time_projects_code_unique_idx', properties: ['organizationId', 'tenantId', 'code'], options: { unique: true, where: 'deleted_at IS NULL' } })\nexport class StaffTimeProject {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ type: 'text' })\n name!: string\n\n @Property({ name: 'customer_id', type: 'uuid', nullable: true })\n customerId?: string | null\n\n @Property({ type: 'text' })\n code!: string\n\n @Property({ type: 'text', nullable: true })\n description?: string | null\n\n @Property({ name: 'project_type', type: 'text', nullable: true })\n projectType?: string | null\n\n @Property({ type: 'varchar', length: 20, nullable: true })\n color?: string | null\n\n @Enum({ items: ['active', 'on_hold', 'completed'], type: 'text', name: 'status', default: 'active' })\n status: StaffTimeProjectStatus = 'active'\n\n @Property({ name: 'owner_user_id', type: 'uuid', nullable: true })\n ownerUserId?: string | null\n\n @Property({ name: 'cost_center', type: 'text', nullable: true })\n costCenter?: string | null\n\n @Property({ name: 'start_date', type: 'date', nullable: true })\n startDate?: Date | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n}\n\n@Entity({ tableName: 'staff_time_project_members' })\n@Index({ name: 'staff_time_project_members_tenant_org_idx', properties: ['tenantId', 'organizationId'] })\n@Index({ name: 'staff_time_project_members_project_idx', properties: ['organizationId', 'timeProjectId'] })\n@Index({ name: 'staff_time_project_members_member_idx', properties: ['organizationId', 'staffMemberId'] })\n@Index({ name: 'staff_time_project_members_unique_idx', properties: ['organizationId', 'tenantId', 'timeProjectId', 'staffMemberId'], options: { unique: true, where: 'deleted_at IS NULL' } })\nexport class StaffTimeProjectMember {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'time_project_id', type: 'uuid' })\n timeProjectId!: string\n\n @Property({ name: 'staff_member_id', type: 'uuid' })\n staffMemberId!: string\n\n @Property({ type: 'text', nullable: true })\n role?: string | null\n\n @Enum({ items: ['active', 'inactive'], type: 'text', name: 'status', default: 'active' })\n status: StaffTimeProjectMemberStatus = 'active'\n\n @Property({ name: 'show_in_grid', type: 'boolean', default: false })\n showInGrid: boolean = false\n\n @Property({ name: 'assigned_start_date', type: 'date' })\n assignedStartDate!: Date\n\n @Property({ name: 'assigned_end_date', type: 'date', nullable: true })\n assignedEndDate?: Date | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n}\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }