rez_core 3.1.178 → 3.1.180

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 (387) hide show
  1. package/.claude/settings.local.json +26 -0
  2. package/.idea/250218_nodejs_core.iml +9 -0
  3. package/.idea/codeStyles/Project.xml +59 -0
  4. package/.idea/codeStyles/codeStyleConfig.xml +5 -0
  5. package/.idea/copilot.data.migration.agent.xml +6 -0
  6. package/.idea/copilot.data.migration.ask.xml +6 -0
  7. package/.idea/copilot.data.migration.ask2agent.xml +6 -0
  8. package/.idea/copilot.data.migration.edit.xml +6 -0
  9. package/.idea/inspectionProfiles/Project_Default.xml +6 -0
  10. package/.idea/misc.xml +6 -0
  11. package/.idea/modules.xml +8 -0
  12. package/.idea/prettier.xml +6 -0
  13. package/.idea/vcs.xml +6 -0
  14. package/.prettierrc +3 -3
  15. package/README.md +99 -99
  16. package/dist/module/auth/guards/role.guard.js +3 -3
  17. package/dist/module/auth/services/auth.service.js +2 -2
  18. package/dist/module/filter/repository/saved-filter.repository.js +4 -4
  19. package/dist/module/filter/service/filter-evaluator.service.js +2 -2
  20. package/dist/module/filter/service/filter.service.js +7 -7
  21. package/dist/module/integration/controller/wrapper.controller.js +0 -2
  22. package/dist/module/integration/controller/wrapper.controller.js.map +1 -1
  23. package/dist/module/integration/examples/usage.example.js +9 -9
  24. package/dist/module/integration/service/integration.service.js +1 -1
  25. package/dist/module/integration/service/wrapper.service.js +27 -27
  26. package/dist/module/integration/service/wrapper.service.js.map +1 -1
  27. package/dist/module/listmaster/service/list-master-item.service.js +2 -2
  28. package/dist/module/listmaster/service/list-master.service.js +2 -2
  29. package/dist/module/mapper/service/field-mapper.service.js +4 -4
  30. package/dist/module/mapper/service/mapper.service.js +2 -2
  31. package/dist/module/meta/service/entity-dynamic.service.js +18 -18
  32. package/dist/module/meta/service/entity-list.service.js +3 -3
  33. package/dist/module/meta/service/entity-master.service.js +3 -3
  34. package/dist/module/meta/service/entity-relation.service.js +11 -11
  35. package/dist/module/meta/service/entity-service-impl.service.js +3 -3
  36. package/dist/module/meta/service/resolver.service.js +3 -3
  37. package/dist/module/module/repository/menu.repository.js +12 -12
  38. package/dist/module/notification/service/notification.service.js +12 -12
  39. package/dist/module/user/controller/login.controller.js +18 -18
  40. package/dist/module/user/service/role.service.js +4 -4
  41. package/dist/module/user/service/user-session.service.js +2 -2
  42. package/dist/module/workflow/repository/action.repository.js +16 -16
  43. package/dist/module/workflow/repository/comm-template.repository.js +6 -6
  44. package/dist/module/workflow/repository/form-master.repository.js +2 -2
  45. package/dist/module/workflow/repository/stage-group.repository.js +23 -23
  46. package/dist/module/workflow/repository/stage-movement.repository.js +11 -11
  47. package/dist/module/workflow/repository/stage.repository.js +8 -8
  48. package/dist/module/workflow/service/action-template-mapping.service.js +10 -10
  49. package/dist/module/workflow/service/action.service.js +7 -7
  50. package/dist/module/workflow/service/entity-modification.service.js +6 -6
  51. package/dist/module/workflow/service/stage-group.service.js +5 -5
  52. package/dist/module/workflow/service/stage.service.js +2 -2
  53. package/dist/module/workflow/service/task.service.js +54 -33
  54. package/dist/module/workflow/service/task.service.js.map +1 -1
  55. package/dist/module/workflow/service/workflow-list-master.service.js +15 -15
  56. package/dist/module/workflow/service/workflow-meta.service.js +50 -50
  57. package/dist/module/workflow/service/workflow.service.js +2 -2
  58. package/dist/tsconfig.build.tsbuildinfo +1 -1
  59. package/dist/utils/service/reflection-helper.service.js +2 -2
  60. package/docs/modules/event-driven-integration-design.md +91 -91
  61. package/docs/modules/integration.md +250 -250
  62. package/eslint.config.mjs +34 -34
  63. package/nest-cli.json +14 -14
  64. package/package.json +118 -118
  65. package/server.log +850 -0
  66. package/src/app.controller.ts +12 -12
  67. package/src/app.module.ts +49 -49
  68. package/src/app.service.ts +8 -8
  69. package/src/config/config.module.ts +18 -18
  70. package/src/config/database.config.ts +23 -23
  71. package/src/constant/global.constant.ts +67 -67
  72. package/src/core.module.ts +81 -81
  73. package/src/decorators/roles.decorator.ts +7 -7
  74. package/src/dtos/response.dto.ts +6 -6
  75. package/src/dtos/response.ts +5 -5
  76. package/src/index.ts +1 -1
  77. package/src/module/auth/auth.module.ts +49 -49
  78. package/src/module/auth/controller/auth.controller.ts +28 -28
  79. package/src/module/auth/guards/google-auth.guard.ts +9 -9
  80. package/src/module/auth/guards/jwt.guard.ts +22 -22
  81. package/src/module/auth/guards/role.guard.ts +68 -68
  82. package/src/module/auth/services/auth.service.ts +50 -50
  83. package/src/module/auth/services/jwt.service.ts +11 -11
  84. package/src/module/auth/strategies/google.strategy.ts +54 -54
  85. package/src/module/auth/strategies/jwt.strategy.ts +58 -58
  86. package/src/module/auth/strategies/local.strategy.ts +13 -13
  87. package/src/module/dashboard/controller/dashboard.controller.ts +36 -36
  88. package/src/module/dashboard/dashboard.module.ts +21 -21
  89. package/src/module/dashboard/entity/dashboard_page_data.entity.ts +27 -27
  90. package/src/module/dashboard/entity/widget_master.entity.ts +18 -18
  91. package/src/module/dashboard/repository/dashboard.repository.ts +42 -42
  92. package/src/module/dashboard/service/dashboard.service.ts +73 -73
  93. package/src/module/dev/dev.module.ts +12 -12
  94. package/src/module/dev/service/dev.service.ts +7 -7
  95. package/src/module/enterprise/controller/organization.controller.ts +36 -36
  96. package/src/module/enterprise/enterprise.module.ts +30 -30
  97. package/src/module/enterprise/entity/enterprise.entity.ts +37 -37
  98. package/src/module/enterprise/entity/organization-app-mapping.entity.ts +13 -13
  99. package/src/module/enterprise/entity/organization.entity.ts +92 -92
  100. package/src/module/enterprise/repository/enterprise.repository.ts +31 -31
  101. package/src/module/enterprise/repository/organization.repository.ts +26 -26
  102. package/src/module/enterprise/repository/school.repository.ts +281 -281
  103. package/src/module/enterprise/service/brand.service.ts +5 -5
  104. package/src/module/enterprise/service/enterprise.service.ts +16 -16
  105. package/src/module/enterprise/service/organization-app-mapping.service.ts +4 -4
  106. package/src/module/enterprise/service/organization.service.ts +145 -145
  107. package/src/module/filter/controller/filter.controller.ts +84 -84
  108. package/src/module/filter/dto/filter-request.dto.ts +38 -38
  109. package/src/module/filter/entity/saved-filter-detail.entity.ts +41 -41
  110. package/src/module/filter/entity/saved-filter-master.entity.ts +23 -23
  111. package/src/module/filter/filter.module.ts +31 -31
  112. package/src/module/filter/repository/saved-filter.repository.ts +168 -168
  113. package/src/module/filter/service/filter-evaluator.service.ts +86 -86
  114. package/src/module/filter/service/filter.service.ts +841 -841
  115. package/src/module/filter/service/saved-filter.service.ts +170 -170
  116. package/src/module/ics/controller/ics.controller.ts +21 -21
  117. package/src/module/ics/dto/ics.dto.ts +55 -55
  118. package/src/module/ics/ics.module.ts +13 -13
  119. package/src/module/ics/service/ics.service.ts +57 -57
  120. package/src/module/integration/controller/calender-event.controller.ts +31 -31
  121. package/src/module/integration/controller/integration.controller.ts +662 -662
  122. package/src/module/integration/controller/wrapper.controller.ts +37 -37
  123. package/src/module/integration/dto/create-config.dto.ts +526 -526
  124. package/src/module/integration/entity/integration-config.entity.ts +112 -112
  125. package/src/module/integration/entity/integration-entity-mapper.entity.ts +14 -14
  126. package/src/module/integration/entity/integration-source.entity.ts +17 -17
  127. package/src/module/integration/entity/user-integration.entity.ts +71 -71
  128. package/src/module/integration/examples/usage.example.ts +338 -338
  129. package/src/module/integration/factories/base.factory.ts +7 -7
  130. package/src/module/integration/factories/email.factory.ts +49 -49
  131. package/src/module/integration/factories/integration.factory.ts +121 -121
  132. package/src/module/integration/factories/sms.factory.ts +51 -51
  133. package/src/module/integration/factories/telephone.factory.ts +41 -41
  134. package/src/module/integration/factories/whatsapp.factory.ts +56 -56
  135. package/src/module/integration/integration.module.ts +110 -110
  136. package/src/module/integration/service/calendar-event.service.ts +118 -118
  137. package/src/module/integration/service/integration-entity-mapper.service.ts +17 -17
  138. package/src/module/integration/service/integration-queue.service.ts +229 -229
  139. package/src/module/integration/service/integration.service.ts +2572 -2572
  140. package/src/module/integration/service/oauth.service.ts +224 -224
  141. package/src/module/integration/service/wrapper.service.ts +457 -453
  142. package/src/module/integration/strategies/email/gmail-api.strategy.ts +280 -280
  143. package/src/module/integration/strategies/email/outlook-api.strategy.ts +44 -44
  144. package/src/module/integration/strategies/email/outlook.strategy.ts +64 -64
  145. package/src/module/integration/strategies/email/sendgrid-api.strategy.ts +260 -260
  146. package/src/module/integration/strategies/integration.strategy.ts +97 -97
  147. package/src/module/integration/strategies/sms/gupshup-sms.strategy.ts +146 -146
  148. package/src/module/integration/strategies/sms/msg91-sms.strategy.ts +164 -164
  149. package/src/module/integration/strategies/sms/tubelight-sms.strategy.ts +163 -163
  150. package/src/module/integration/strategies/telephone/ozonetel-voice.strategy.ts +238 -238
  151. package/src/module/integration/strategies/telephone/tubelight-voice.strategy.ts +210 -210
  152. package/src/module/integration/strategies/whatsapp/gupshup-whatsapp.strategy.ts +359 -359
  153. package/src/module/integration/strategies/whatsapp/tubelight-whatsapp.strategy.ts +372 -372
  154. package/src/module/integration/strategies/whatsapp/whatsapp-cloud.strategy.ts +403 -403
  155. package/src/module/integration/strategies/whatsapp/whatsapp.strategy.ts +57 -57
  156. package/src/module/layout/controller/layout.controller.ts +47 -47
  157. package/src/module/layout/entity/header-items.entity.ts +28 -28
  158. package/src/module/layout/entity/header-section.entity.ts +19 -19
  159. package/src/module/layout/layout.module.ts +21 -21
  160. package/src/module/layout/repository/header-items.repository.ts +18 -18
  161. package/src/module/layout/repository/header-section.repository.ts +22 -22
  162. package/src/module/layout/service/header-section.service.ts +25 -25
  163. package/src/module/layout_preference/controller/layout_preference.controller.ts +47 -47
  164. package/src/module/layout_preference/entity/layout_preference.entity.ts +28 -28
  165. package/src/module/layout_preference/layout_preference.module.ts +18 -18
  166. package/src/module/layout_preference/repository/layout_preference.repository.ts +30 -30
  167. package/src/module/layout_preference/service/layout_preference.service.ts +172 -172
  168. package/src/module/lead/controller/lead.controller.ts +30 -30
  169. package/src/module/lead/lead.module.ts +14 -14
  170. package/src/module/lead/repository/lead.repository.ts +41 -41
  171. package/src/module/lead/service/lead.service.ts +54 -54
  172. package/src/module/listmaster/controller/list-master.controller.ts +187 -187
  173. package/src/module/listmaster/entity/list-master-items.entity.ts +41 -41
  174. package/src/module/listmaster/entity/list-master.entity.ts +32 -32
  175. package/src/module/listmaster/listmaster.module.ts +44 -44
  176. package/src/module/listmaster/repository/list-master-items.repository.ts +169 -169
  177. package/src/module/listmaster/repository/list-master.repository.ts +46 -46
  178. package/src/module/listmaster/service/list-master-engine.ts +19 -19
  179. package/src/module/listmaster/service/list-master-extension.interface.ts +4 -4
  180. package/src/module/listmaster/service/list-master-item.service.ts +292 -292
  181. package/src/module/listmaster/service/list-master-registry.ts +15 -15
  182. package/src/module/listmaster/service/list-master.service.ts +424 -424
  183. package/src/module/mapper/controller/field-mapper.controller.ts +69 -69
  184. package/src/module/mapper/controller/mapper.controller.ts +14 -14
  185. package/src/module/mapper/dto/field-mapper.dto.ts +14 -14
  186. package/src/module/mapper/entity/field-lovs.entity.ts +19 -19
  187. package/src/module/mapper/entity/field-mapper.entity.ts +53 -53
  188. package/src/module/mapper/entity/mapper.entity.ts +16 -16
  189. package/src/module/mapper/mapper.module.ts +34 -34
  190. package/src/module/mapper/repository/field-lovs.repository.ts +35 -35
  191. package/src/module/mapper/repository/field-mapper.repository.ts +42 -42
  192. package/src/module/mapper/repository/mapper.repository.ts +15 -15
  193. package/src/module/mapper/service/field-mapper.service.ts +223 -223
  194. package/src/module/mapper/service/mapper.service.ts +72 -72
  195. package/src/module/master/controller/master.controller.ts +74 -74
  196. package/src/module/master/service/master.service.ts +483 -483
  197. package/src/module/meta/controller/app-master.controller.ts +38 -38
  198. package/src/module/meta/controller/attribute-master.controller.ts +66 -66
  199. package/src/module/meta/controller/entity-dynamic.controller.ts +125 -125
  200. package/src/module/meta/controller/entity-master.controller.ts +28 -28
  201. package/src/module/meta/controller/entity-relation.controller.ts +36 -36
  202. package/src/module/meta/controller/entity.controller.ts +385 -385
  203. package/src/module/meta/controller/media.controller.ts +82 -82
  204. package/src/module/meta/controller/meta.controller.ts +96 -96
  205. package/src/module/meta/controller/view-master.controller.ts +86 -86
  206. package/src/module/meta/dto/entity-list-data.dto.ts +6 -6
  207. package/src/module/meta/dto/entity-tab.dto.ts +4 -4
  208. package/src/module/meta/dto/entity-table.dto.ts +9 -9
  209. package/src/module/meta/entity/app-master.entity.ts +34 -34
  210. package/src/module/meta/entity/attribute-master.entity.ts +87 -87
  211. package/src/module/meta/entity/base-entity.entity.ts +75 -75
  212. package/src/module/meta/entity/entity-master.entity.ts +78 -78
  213. package/src/module/meta/entity/entity-relation-data.entity.ts +29 -29
  214. package/src/module/meta/entity/entity-relation.entity.ts +23 -23
  215. package/src/module/meta/entity/entity-table-column.entity.ts +61 -61
  216. package/src/module/meta/entity/entity-table.entity.ts +50 -50
  217. package/src/module/meta/entity/media-data.entity.ts +32 -32
  218. package/src/module/meta/entity/preference.entity.ts +62 -62
  219. package/src/module/meta/entity/view-master.entity.ts +41 -41
  220. package/src/module/meta/entity.module.ts +156 -156
  221. package/src/module/meta/repository/app-master.repository.ts +20 -20
  222. package/src/module/meta/repository/attribute-master.repository.ts +110 -110
  223. package/src/module/meta/repository/entity-master.repository.ts +69 -69
  224. package/src/module/meta/repository/entity-table-column.repository.ts +39 -39
  225. package/src/module/meta/repository/entity-table.repository.ts +53 -53
  226. package/src/module/meta/repository/media-data.repository.ts +50 -50
  227. package/src/module/meta/repository/preference.repository.ts +20 -20
  228. package/src/module/meta/repository/user-app-mapping.repository.ts +28 -28
  229. package/src/module/meta/repository/view-master.repository.ts +42 -42
  230. package/src/module/meta/service/app-master.service.ts +37 -37
  231. package/src/module/meta/service/attribute-master.service.ts +117 -117
  232. package/src/module/meta/service/common.service.ts +9 -9
  233. package/src/module/meta/service/entity-dynamic.service.ts +762 -762
  234. package/src/module/meta/service/entity-list.service.ts +205 -205
  235. package/src/module/meta/service/entity-master.service.ts +164 -164
  236. package/src/module/meta/service/entity-realation-data.service.ts +9 -9
  237. package/src/module/meta/service/entity-relation.service.ts +69 -69
  238. package/src/module/meta/service/entity-service-impl.service.ts +524 -524
  239. package/src/module/meta/service/entity-table-column.service.ts +39 -39
  240. package/src/module/meta/service/entity-table.service.ts +150 -150
  241. package/src/module/meta/service/entity-validation.service.ts +185 -185
  242. package/src/module/meta/service/entity.service.ts +67 -67
  243. package/src/module/meta/service/field-group.service.ts +103 -103
  244. package/src/module/meta/service/media-data.service.ts +149 -149
  245. package/src/module/meta/service/populate-meta.service.ts +173 -173
  246. package/src/module/meta/service/preference.service.ts +16 -16
  247. package/src/module/meta/service/resolver.service.ts +240 -240
  248. package/src/module/meta/service/section-master.service.ts +104 -104
  249. package/src/module/meta/service/update-form-json.service.ts +22 -22
  250. package/src/module/meta/service/user-app-mapping.service.ts +17 -17
  251. package/src/module/meta/service/view-master.service.ts +111 -111
  252. package/src/module/module/controller/menu.controller.ts +15 -15
  253. package/src/module/module/controller/module-access.controller.ts +132 -132
  254. package/src/module/module/entity/menu.entity.ts +43 -43
  255. package/src/module/module/entity/module-access.entity.ts +25 -25
  256. package/src/module/module/entity/module-action.entity.ts +17 -17
  257. package/src/module/module/entity/module.entity.ts +52 -52
  258. package/src/module/module/module.module.ts +42 -42
  259. package/src/module/module/repository/menu.repository.ts +184 -184
  260. package/src/module/module/repository/module-access.repository.ts +331 -331
  261. package/src/module/module/service/menu.service.ts +82 -82
  262. package/src/module/module/service/module-access.service.ts +209 -209
  263. package/src/module/notification/controller/notification.controller.ts +58 -58
  264. package/src/module/notification/controller/otp.controller.ts +117 -117
  265. package/src/module/notification/entity/notification.entity.ts +26 -26
  266. package/src/module/notification/entity/otp.entity.ts +28 -28
  267. package/src/module/notification/firebase-admin.config.ts +22 -22
  268. package/src/module/notification/notification.module.ts +69 -69
  269. package/src/module/notification/repository/otp.repository.ts +27 -27
  270. package/src/module/notification/service/email.service.ts +127 -127
  271. package/src/module/notification/service/notification.service.ts +138 -138
  272. package/src/module/notification/service/otp.service.ts +125 -125
  273. package/src/module/third-party-module/entity/third-party-api-registry.entity.ts +52 -52
  274. package/src/module/third-party-module/repository/third-party-api-registry.repository.ts +20 -20
  275. package/src/module/third-party-module/service/api-registry.service.ts +13 -13
  276. package/src/module/third-party-module/third-party.module.ts +12 -12
  277. package/src/module/user/controller/login.controller.ts +197 -197
  278. package/src/module/user/controller/user.controller.ts +40 -40
  279. package/src/module/user/dto/create-user.dto.ts +62 -62
  280. package/src/module/user/dto/update-user.dto.ts +4 -4
  281. package/src/module/user/entity/role.entity.ts +33 -33
  282. package/src/module/user/entity/user-role-mapping.entity.ts +38 -38
  283. package/src/module/user/entity/user-session.entity.ts +61 -61
  284. package/src/module/user/entity/user.entity.ts +68 -68
  285. package/src/module/user/repository/role.repository.ts +96 -96
  286. package/src/module/user/repository/user-role-mapping.repository.ts +126 -126
  287. package/src/module/user/repository/user.repository.ts +50 -50
  288. package/src/module/user/repository/userSession.repository.ts +33 -33
  289. package/src/module/user/service/login.service.ts +280 -280
  290. package/src/module/user/service/role.service.ts +189 -189
  291. package/src/module/user/service/user-role-mapping.service.ts +98 -98
  292. package/src/module/user/service/user-session.service.ts +168 -168
  293. package/src/module/user/service/user.service.ts +353 -353
  294. package/src/module/user/user.module.ts +65 -65
  295. package/src/module/workflow/controller/action-category.controller.ts +54 -54
  296. package/src/module/workflow/controller/action-resource-mapping.controller.ts +23 -23
  297. package/src/module/workflow/controller/action-template-mapping.controller.ts +35 -35
  298. package/src/module/workflow/controller/action.controller.ts +95 -95
  299. package/src/module/workflow/controller/activity-log.controller.ts +55 -55
  300. package/src/module/workflow/controller/comm-template.controller.ts +34 -34
  301. package/src/module/workflow/controller/entity-modification.controller.ts +35 -35
  302. package/src/module/workflow/controller/form-master.controller.ts +43 -43
  303. package/src/module/workflow/controller/stage-group.controller.ts +48 -48
  304. package/src/module/workflow/controller/stage.controller.ts +50 -50
  305. package/src/module/workflow/controller/task.controller.ts +77 -77
  306. package/src/module/workflow/controller/workflow-list-master.controller.ts +44 -44
  307. package/src/module/workflow/controller/workflow-meta.controller.ts +80 -80
  308. package/src/module/workflow/controller/workflow.controller.ts +67 -67
  309. package/src/module/workflow/entity/action-category.entity.ts +38 -38
  310. package/src/module/workflow/entity/action-data.entity.ts +55 -55
  311. package/src/module/workflow/entity/action-resources-mapping.entity.ts +29 -29
  312. package/src/module/workflow/entity/action-template-mapping.entity.ts +17 -17
  313. package/src/module/workflow/entity/action.entity.ts +50 -50
  314. package/src/module/workflow/entity/activity-log.entity.ts +43 -43
  315. package/src/module/workflow/entity/comm-template.entity.ts +43 -43
  316. package/src/module/workflow/entity/entity-modification.entity.ts +38 -38
  317. package/src/module/workflow/entity/form.entity.ts +25 -25
  318. package/src/module/workflow/entity/stage-action-mapping.entity.ts +17 -17
  319. package/src/module/workflow/entity/stage-group.entity.ts +23 -23
  320. package/src/module/workflow/entity/stage-movement-data.entity.ts +38 -38
  321. package/src/module/workflow/entity/stage.entity.ts +20 -20
  322. package/src/module/workflow/entity/task-data.entity.ts +88 -88
  323. package/src/module/workflow/entity/template-attach-mapper.entity.ts +30 -30
  324. package/src/module/workflow/entity/workflow-data.entity.ts +11 -11
  325. package/src/module/workflow/entity/workflow-level-mapping.entity.ts +18 -18
  326. package/src/module/workflow/entity/workflow.entity.ts +20 -20
  327. package/src/module/workflow/repository/action-category.repository.ts +79 -79
  328. package/src/module/workflow/repository/action-data.repository.ts +219 -219
  329. package/src/module/workflow/repository/action.repository.ts +277 -277
  330. package/src/module/workflow/repository/activity-log.repository.ts +121 -121
  331. package/src/module/workflow/repository/comm-template.repository.ts +142 -142
  332. package/src/module/workflow/repository/form-master.repository.ts +59 -59
  333. package/src/module/workflow/repository/stage-group.repository.ts +176 -176
  334. package/src/module/workflow/repository/stage-movement.repository.ts +227 -227
  335. package/src/module/workflow/repository/stage.repository.ts +172 -172
  336. package/src/module/workflow/repository/task.repository.ts +117 -117
  337. package/src/module/workflow/repository/workflow.repository.ts +42 -42
  338. package/src/module/workflow/service/action-category.service.ts +33 -33
  339. package/src/module/workflow/service/action-data.service.ts +62 -62
  340. package/src/module/workflow/service/action-resources-mapping.service.ts +10 -10
  341. package/src/module/workflow/service/action-template-mapping.service.ts +55 -55
  342. package/src/module/workflow/service/action.service.ts +263 -263
  343. package/src/module/workflow/service/activity-log.service.ts +107 -107
  344. package/src/module/workflow/service/comm-template.service.ts +121 -121
  345. package/src/module/workflow/service/entity-modification.service.ts +67 -67
  346. package/src/module/workflow/service/form-master.service.ts +35 -35
  347. package/src/module/workflow/service/populate-workflow.service.ts +303 -303
  348. package/src/module/workflow/service/stage-action-mapping.service.ts +5 -5
  349. package/src/module/workflow/service/stage-group.service.ts +300 -300
  350. package/src/module/workflow/service/stage.service.ts +199 -199
  351. package/src/module/workflow/service/task.service.ts +531 -504
  352. package/src/module/workflow/service/workflow-list-master.service.ts +60 -60
  353. package/src/module/workflow/service/workflow-meta.service.ts +581 -581
  354. package/src/module/workflow/service/workflow.service.ts +205 -205
  355. package/src/module/workflow/workflow.module.ts +172 -172
  356. package/src/module/workflow-automation/controller/workflow-automation.controller.ts +21 -21
  357. package/src/module/workflow-automation/entity/workflow-automation-action.entity.ts +26 -26
  358. package/src/module/workflow-automation/entity/workflow-automation.entity.ts +35 -35
  359. package/src/module/workflow-automation/interface/action.decorator.ts +7 -7
  360. package/src/module/workflow-automation/interface/action.interface.ts +5 -5
  361. package/src/module/workflow-automation/service/action-registery.service.ts +35 -35
  362. package/src/module/workflow-automation/service/workflow-automation-engine.service.ts +214 -214
  363. package/src/module/workflow-automation/service/workflow-automation.service.ts +345 -345
  364. package/src/module/workflow-automation/workflow-automation.module.ts +34 -34
  365. package/src/resources/dev.properties.yaml +30 -30
  366. package/src/resources/local.properties.yaml +27 -27
  367. package/src/resources/properties.module.ts +12 -12
  368. package/src/resources/properties.yaml.ts +11 -11
  369. package/src/resources/uat.properties.yaml +15 -15
  370. package/src/utils/dto/excel-data.dto.ts +14 -14
  371. package/src/utils/dto/excelsheet-data.dto.ts +5 -5
  372. package/src/utils/service/base64util.service.ts +18 -18
  373. package/src/utils/service/clockIDGenUtil.service.ts +21 -21
  374. package/src/utils/service/codeGenerator.service.ts +22 -22
  375. package/src/utils/service/dateUtil.service.ts +17 -17
  376. package/src/utils/service/encryptUtil.service.ts +97 -97
  377. package/src/utils/service/excel-helper.service.ts +72 -72
  378. package/src/utils/service/excelUtil.service.ts +15 -15
  379. package/src/utils/service/file-util.service.ts +11 -11
  380. package/src/utils/service/json-util.service.ts +23 -23
  381. package/src/utils/service/loggingUtil.service.ts +34 -34
  382. package/src/utils/service/reflection-helper.service.ts +62 -62
  383. package/src/utils/service/wbsCodeGen.service.ts +8 -8
  384. package/src/utils/utils.module.ts +25 -25
  385. package/tsconfig.build.json +4 -4
  386. package/tsconfig.json +24 -24
  387. package/.vscode/extensions.json +0 -5
@@ -1,504 +1,531 @@
1
- import { Inject, Injectable } from '@nestjs/common';
2
- import { EntityServiceImpl } from 'src/module/meta/service/entity-service-impl.service';
3
- import { UserData } from 'src/module/user/entity/user.entity';
4
- import { TaskRepository } from '../repository/task.repository';
5
- import { ActionDataService } from './action-data.service';
6
- import { DataSource, EntityManager } from 'typeorm';
7
- import { BaseEntity } from 'src/module/meta/entity/base-entity.entity';
8
- import { ActivityLogService } from './activity-log.service';
9
- import { ACTIVITY_CATEGORIES } from '../repository/activity-log.repository';
10
- import { MediaDataService } from 'src/module/meta/service/media-data.service';
11
- import { ActionHandler } from 'src/module/workflow-automation/interface/action.decorator';
12
-
13
- @Injectable()
14
- @ActionHandler('add_task')
15
- export class TaskService extends EntityServiceImpl {
16
- constructor(
17
- private readonly taskRepository: TaskRepository,
18
- private readonly actionDataService: ActionDataService,
19
- private readonly dataSource: DataSource,
20
- @Inject('ActivityLogService')
21
- private readonly activityLogService: ActivityLogService,
22
- private readonly mediaDataService: MediaDataService,
23
- ) {
24
- super();
25
- }
26
- name: string = 'add_task';
27
-
28
- async execute(payload: any): Promise<any> {
29
- const { entity, user, config } = payload;
30
-
31
- let toValue: string | null = null;
32
-
33
- // 2. Get current stage_id from cr_wf_stage_movement_data
34
- const stageRow = await this.dataSource.query(
35
- `SELECT stage_id
36
- FROM cr_wf_stage_movement_data
37
- WHERE mapped_entity_id = ?
38
- AND is_current = 'Y'
39
- LIMIT 1`,
40
- [entity.id],
41
- );
42
-
43
- const stageId = stageRow.length > 0 ? stageRow[0].stage_id : null;
44
-
45
- if (!stageId) {
46
- throw new Error(
47
- `No current stage found in cr_wf_stage_movement_data for entity_id=${entity.id}`,
48
- );
49
- }
50
-
51
- // 3. Build entityData
52
- const entityData = {
53
- ...config,
54
- mapped_entity_id: entity.id,
55
- mapped_entity_type: entity.entity_type,
56
- task_owner: config.task_owner,
57
- stage_id: stageId,
58
- status: config.status,
59
- due_date: config.due_date,
60
- due_time: config.due_time,
61
- reminder: config.reminder,
62
- description: config.description,
63
- is_mandatory: config.is_mandatory,
64
- };
65
-
66
- return await this.createEntity(entityData, user);
67
- }
68
-
69
- async createEntity(
70
- entityData: any,
71
- loggedInUser: any,
72
- manager?: EntityManager | null,
73
- appcode?: string,
74
- ): Promise<any> {
75
- if (entityData && typeof entityData['is_mandatory'] === 'string') {
76
- entityData['is_mandatory'] = entityData['is_mandatory'] === '1';
77
- }
78
- const createdEntity = await super.createEntity(
79
- entityData,
80
- loggedInUser,
81
- manager,
82
- appcode,
83
- );
84
-
85
- try {
86
- const logData = {
87
- mapped_entity_id: createdEntity.mapped_entity_id,
88
- mapped_entity_type: createdEntity.mapped_entity_type,
89
- title: `Task added`,
90
- description: `A new task ${createdEntity.name} was added`,
91
- category: ACTIVITY_CATEGORIES.TASK,
92
- action: 'add',
93
- appcode: loggedInUser.appcode,
94
- };
95
-
96
- await this.activityLogService.logActivity(logData, loggedInUser);
97
- } catch (error) {
98
- console.error(
99
- 'Failed to log activity for meeting:',
100
- error?.message || error,
101
- );
102
- // Logging should not block main flow
103
- }
104
-
105
- let relationData = await this.dataSource.query(
106
- `SELECT * FROM cr_entity_relation WHERE source_entity_type = ? AND target_entity_type = ?`,
107
- [createdEntity.mapped_entity_type, createdEntity.entity_type],
108
- );
109
-
110
- if (relationData) {
111
- await this.dataSource.query(
112
- `INSERT INTO cr_entity_relation_data (organization_id, source_entity_id, source_entity_type, target_entity_id, target_entity_type, relation_type) VALUES (?, ?, ?, ?, ? , ?)`,
113
- [
114
- loggedInUser.organization_id,
115
- createdEntity.mapped_entity_id,
116
- createdEntity.mapped_entity_type,
117
- createdEntity.id,
118
- createdEntity.entity_type,
119
- relationData[0]?.relation_type,
120
- ],
121
- );
122
- }
123
-
124
- return createdEntity;
125
- }
126
-
127
- async updateEntity(
128
- entityData,
129
- loggedInUser: UserData,
130
- appcode?: string,
131
- ): Promise<any> {
132
- const taskStatusQuery = `
133
- SELECT name
134
- FROM cr_list_master_items
135
- WHERE id = ?
136
- AND organization_id = ?
137
- AND listtype = 'TKST'
138
- LIMIT 1;
139
- `;
140
-
141
- const statusRows = await this.dataSource.query(taskStatusQuery, [
142
- entityData.status,
143
- loggedInUser.organization_id,
144
- ]);
145
-
146
- const isCompletedStatus =
147
- statusRows.length > 0 &&
148
- statusRows[0].name?.toLowerCase() === 'completed';
149
-
150
- // Sync flags based on status
151
- entityData.is_completed = isCompletedStatus;
152
- entityData.is_done = isCompletedStatus;
153
-
154
- const isMandatory =
155
- String(entityData.is_mandatory).toLowerCase() === 'true' ||
156
- entityData.is_mandatory === true ||
157
- entityData.is_mandatory === 1 ||
158
- entityData.is_mandatory === '1';
159
-
160
- const updatedEntity = await super.updateEntity(
161
- {
162
- ...entityData,
163
- is_mandatory: isMandatory,
164
- },
165
- loggedInUser,
166
- appcode,
167
- );
168
-
169
- // Convert boolean back to "1" / "0" for response
170
- if (updatedEntity && typeof updatedEntity['is_mandatory'] === 'boolean') {
171
- updatedEntity['is_mandatory'] = updatedEntity['is_mandatory'] ? '1' : '0';
172
- }
173
-
174
- try {
175
- // Always log edit
176
- const editLogData = {
177
- mapped_entity_id: updatedEntity.mapped_entity_id,
178
- mapped_entity_type: updatedEntity.mapped_entity_type,
179
- title: `Task edited`,
180
- description: `${updatedEntity.code} was edited`,
181
- category: ACTIVITY_CATEGORIES.TASK,
182
- action: 'edit',
183
- appcode: loggedInUser.appcode,
184
- };
185
-
186
- await this.activityLogService.logActivity(editLogData, loggedInUser);
187
-
188
- if (isCompletedStatus) {
189
- const completedLogData = {
190
- mapped_entity_id: updatedEntity.mapped_entity_id,
191
- mapped_entity_type: updatedEntity.mapped_entity_type,
192
- title: `Task completed`,
193
- description: `${updatedEntity.code} was marked as completed`,
194
- category: ACTIVITY_CATEGORIES.TASK,
195
- action: 'completed',
196
- appcode: loggedInUser.appcode,
197
- };
198
-
199
- await this.activityLogService.logActivity(
200
- completedLogData,
201
- loggedInUser,
202
- );
203
- }
204
- } catch (error) {
205
- console.error(
206
- 'Failed to log activity for task:',
207
- error?.message || error,
208
- );
209
- // Don't block main flow
210
- }
211
-
212
- return updatedEntity;
213
- }
214
-
215
- async getAllTaskByUserIdandStageId(
216
- loggedInUser: UserData,
217
- data,
218
- ): Promise<any> {
219
- const taskData = await this.taskRepository.getAllTaskByUserIdAndStageId({
220
- user_id: data.user_id,
221
- stage_id: data.stage_id,
222
- mapped_entity_type: data.mapped_entity_type,
223
- mapped_entity_id: data.mapped_entity_id,
224
- });
225
-
226
- const grouped: { mandatory: any[]; non_mandatory: any[] } = {
227
- mandatory: [],
228
- non_mandatory: [],
229
- };
230
-
231
- for (const task of taskData) {
232
- if (task && task.is_mandatory) {
233
- grouped.mandatory.push(task);
234
- } else {
235
- grouped.non_mandatory.push(task);
236
- }
237
- }
238
-
239
- return grouped;
240
- }
241
-
242
- async getAllTask(
243
- loggedInUser: UserData,
244
- data: {
245
- mapped_entity_type: string;
246
- mapped_entity_id: number;
247
- status?: string;
248
- mandatory?: boolean;
249
- overdue?: boolean;
250
- },
251
- ): Promise<any[]> {
252
- const { mapped_entity_type, mapped_entity_id, status, mandatory, overdue } =
253
- data;
254
-
255
- // Build dynamic WHERE clauses
256
- const whereClauses = [`t.mapped_entity_type = ?`, `t.mapped_entity_id = ?`];
257
- const params: any[] = [mapped_entity_type, mapped_entity_id];
258
-
259
- if (status) {
260
- whereClauses.push(`t.status = ?`);
261
- params.push(status);
262
- }
263
- if (mandatory) {
264
- whereClauses.push(`t.is_mandatory = ?`);
265
- params.push(mandatory ? 1 : 0);
266
- }
267
- if (overdue) {
268
- whereClauses.push(
269
- `(t.due_date < CURDATE() OR (t.due_date = CURDATE() AND t.due_time < CURTIME()))`,
270
- );
271
- // exclude tasks that are already completed
272
- whereClauses.push(`t.is_done = ?`);
273
- params.push(0); // Only include tasks that are not done
274
- }
275
-
276
- const sql = `
277
- SELECT
278
- t.*,
279
- sg.name AS stage_group_name,
280
- s.name AS stage_name,
281
- a.name AS action_name,
282
- u.name AS created_by_name,
283
- u2.name AS task_owner_name,
284
- u2.profile_image AS task_owner_profile
285
- FROM cr_wf_task_data t
286
- LEFT JOIN cr_wf_stage s ON t.stage_id = s.id
287
- LEFT JOIN cr_wf_stage_group sg ON s.stage_group_id = sg.id
288
- LEFT JOIN cr_wf_action a ON t.action_id = a.id
289
- LEFT JOIN sso_user u ON t.created_by = u.id
290
- LEFT JOIN eth_user_profile u2 ON t.task_owner = u2.parent_id
291
- WHERE ${whereClauses.join(' AND ')}
292
- ORDER BY t.created_date DESC
293
- `;
294
-
295
- const taskData = await this.dataSource.query(sql, params);
296
-
297
- if (taskData.length === 0) {
298
- return [];
299
- }
300
-
301
- // Fetch all TKST statuses in a single query
302
- const taskStatusQuery = `
303
- SELECT id, name
304
- FROM cr_list_master_items
305
- WHERE organization_id = ?
306
- AND listtype = 'TKST'
307
- `;
308
- const taskAllStatus = await this.dataSource.query(taskStatusQuery, [
309
- loggedInUser.organization_id,
310
- ]);
311
-
312
- // Build a hash map { id → name }
313
- const statusMap = new Map(
314
- taskAllStatus.map((row) => [String(row.id), row.name]),
315
- );
316
-
317
- // Assign task_status using the map
318
-
319
- const mediaCache = new Map<number, any>();
320
-
321
- for (const task of taskData) {
322
- // Map status name
323
- task.task_status = task.status
324
- ? statusMap.get(String(task.status)) || null
325
- : null;
326
-
327
- // Fix action_name for generic tasks
328
- task.action_name =
329
- task.action_id === '0' || task.action_id === 0
330
- ? 'Generic'
331
- : task.action_name;
332
-
333
- // Profile media (with caching like notes)
334
- if (task.task_owner_profile) {
335
- if (!mediaCache.has(task.task_owner_profile)) {
336
- const url = await this.mediaDataService.getMediaDownloadUrl(
337
- task.task_owner_profile,
338
- loggedInUser,
339
- );
340
- mediaCache.set(task.task_owner_profile, url);
341
- }
342
- task.task_owner_profile = mediaCache.get(task.task_owner_profile);
343
- } else {
344
- task.task_owner_profile = null;
345
- }
346
- }
347
-
348
- // Normalize is_mandatory to '0'/'1' as string
349
- return taskData.map((task) => ({
350
- ...task,
351
- is_mandatory: task.is_mandatory ? '1' : '0',
352
- }));
353
- }
354
-
355
- async getEntityData(entityType: string, id: number, loggedInUser: any) {
356
- const taskData = await super.getEntityData(entityType, id, loggedInUser);
357
-
358
- return taskData;
359
- }
360
-
361
- async saveActionData(
362
- action: any,
363
- loggedInUser: UserData,
364
- mapped_entity_id: number,
365
- mapped_entity_type: string,
366
- ): Promise<any> {
367
- await this.taskRepository.saveActionDataInTask(
368
- action,
369
- loggedInUser,
370
- mapped_entity_id,
371
- mapped_entity_type,
372
- );
373
- }
374
-
375
- async moveTask(
376
- loggedInUser: UserData,
377
- body: {
378
- mapped_entity_type: string;
379
- mapped_entity_id: number;
380
- stage_id: number;
381
- action_id: number;
382
- reason_code?: string | number;
383
- remark?: string;
384
- stage_group_id?: number;
385
- },
386
- ): Promise<any> {
387
- // Logic to move task based on the provided body parameters
388
- // This could involve updating the task's stage, action, etc.
389
-
390
- // update task status
391
- this.taskRepository.updateTaskStatus(
392
- loggedInUser,
393
- body.mapped_entity_type,
394
- body.mapped_entity_id,
395
- body.stage_id,
396
- body.action_id,
397
- );
398
-
399
- // update action status
400
- await this.actionDataService.updateActionStatus(
401
- loggedInUser,
402
- body.mapped_entity_type,
403
- body.mapped_entity_id,
404
- body.stage_id,
405
- body.action_id,
406
- );
407
-
408
- if (body.reason_code || body.remark) {
409
- await this.createSystemNote(
410
- {
411
- reason_code: body.reason_code!,
412
- remark: body.remark || '',
413
- mapped_entity_id: body.mapped_entity_id,
414
- stage_id: body.stage_id,
415
- action_id: body.action_id,
416
- stage_group_id: body.stage_group_id,
417
- },
418
- loggedInUser,
419
- );
420
- }
421
-
422
- return 'Task moved successfully';
423
- }
424
-
425
- async deleteEntity(
426
- entity_type: string,
427
- taskId: number,
428
- loggedInUser: UserData,
429
- ): Promise<any> {
430
- // Fetch the task before deleting
431
- const task: any = await super.getEntityData(
432
- entity_type,
433
- taskId,
434
- loggedInUser,
435
- );
436
-
437
- if (!task) {
438
- throw new Error('Task not found');
439
- }
440
-
441
- // Check if the task is system-generated
442
- if (task.is_system) {
443
- throw new Error('Cannot delete system-generated tasks');
444
- }
445
-
446
- // Perform the deletion
447
- await super.deleteEntity(entity_type, taskId, loggedInUser);
448
-
449
- // Try to log the delete activity
450
- try {
451
- const logData = {
452
- mapped_entity_id: task.mapped_entity_id,
453
- mapped_entity_type: task.mapped_entity_type,
454
- title: `Task deleted`,
455
- description: `${task.name} was deleted`,
456
- category: ACTIVITY_CATEGORIES.TASK,
457
- action: 'delete',
458
- appcode: loggedInUser.appcode,
459
- };
460
-
461
- await this.activityLogService.logActivity(logData, loggedInUser);
462
- } catch (error) {
463
- console.error(
464
- 'Failed to log activity for task deletion:',
465
- error?.message || error,
466
- );
467
- }
468
-
469
- return { message: 'Task deleted successfully' };
470
- }
471
-
472
- async createSystemNote(
473
- entity: {
474
- reason_code: string | number;
475
- remark: string;
476
- mapped_entity_id: number;
477
- stage_id: number;
478
- action_id: number;
479
- stage_group_id?: number;
480
- },
481
- loggedInUser: any,
482
- ) {
483
- if (!entity || !entity.mapped_entity_id || !entity.reason_code) return null;
484
-
485
- const [reason] = await this.dataSource.query(
486
- `SELECT name FROM cr_list_master_items WHERE id = ? AND organization_id = ?`,
487
- [entity.reason_code, loggedInUser.organization_id],
488
- );
489
-
490
- const notePayload = {
491
- note_title: reason ? reason.name : entity.reason_code,
492
- note: entity.remark,
493
- is_system: true,
494
- mapped_entity_type: 'LEAD',
495
- entity_type: 'NOTE',
496
- mapped_entity_id: entity.mapped_entity_id,
497
- stage_id: entity.stage_id,
498
- action_id: entity.action_id,
499
- stage_group_id: entity.stage_group_id,
500
- } as any;
501
-
502
- return await super.createEntity(notePayload, loggedInUser);
503
- }
504
- }
1
+ import { Inject, Injectable } from '@nestjs/common';
2
+ import { EntityServiceImpl } from 'src/module/meta/service/entity-service-impl.service';
3
+ import { UserData } from 'src/module/user/entity/user.entity';
4
+ import { TaskRepository } from '../repository/task.repository';
5
+ import { ActionDataService } from './action-data.service';
6
+ import { DataSource, EntityManager } from 'typeorm';
7
+ import { ActivityLogService } from './activity-log.service';
8
+ import { ACTIVITY_CATEGORIES } from '../repository/activity-log.repository';
9
+ import { MediaDataService } from 'src/module/meta/service/media-data.service';
10
+ import { ActionHandler } from 'src/module/workflow-automation/interface/action.decorator';
11
+ import * as moment from 'moment';
12
+
13
+ @Injectable()
14
+ @ActionHandler('add_task')
15
+ export class TaskService extends EntityServiceImpl {
16
+ constructor(
17
+ private readonly taskRepository: TaskRepository,
18
+ private readonly actionDataService: ActionDataService,
19
+ private readonly dataSource: DataSource,
20
+ @Inject('ActivityLogService')
21
+ private readonly activityLogService: ActivityLogService,
22
+ private readonly mediaDataService: MediaDataService,
23
+ ) {
24
+ super();
25
+ }
26
+ name: string = 'add_task';
27
+
28
+ async execute(payload: any): Promise<any> {
29
+ const { entity, user, config } = payload;
30
+
31
+ let toValue: string | null = null;
32
+
33
+ // 2. Get current stage_id from cr_wf_stage_movement_data
34
+ const stageRow = await this.dataSource.query(
35
+ `SELECT stage_id
36
+ FROM cr_wf_stage_movement_data
37
+ WHERE mapped_entity_id = ?
38
+ AND is_current = 'Y'
39
+ LIMIT 1`,
40
+ [entity.id],
41
+ );
42
+
43
+ const stageId = stageRow.length > 0 ? stageRow[0].stage_id : null;
44
+
45
+ if (!stageId) {
46
+ throw new Error(
47
+ `No current stage found in cr_wf_stage_movement_data for entity_id=${entity.id}`,
48
+ );
49
+ }
50
+
51
+ // 3. Build entityData
52
+ const entityData = {
53
+ ...config,
54
+ mapped_entity_id: entity.id,
55
+ mapped_entity_type: entity.entity_type,
56
+ task_owner: config.task_owner,
57
+ stage_id: stageId,
58
+ status: config.status,
59
+ due_date: config.due_date,
60
+ due_time: config.due_time,
61
+ reminder: config.reminder,
62
+ description: config.description,
63
+ is_mandatory: config.is_mandatory,
64
+ };
65
+
66
+ return await this.createEntity(entityData, user);
67
+ }
68
+
69
+ async createEntity(
70
+ entityData: any,
71
+ loggedInUser: any,
72
+ manager?: EntityManager | null,
73
+ appcode?: string,
74
+ ): Promise<any> {
75
+ if (entityData && typeof entityData['is_mandatory'] === 'string') {
76
+ entityData['is_mandatory'] = entityData['is_mandatory'] === '1';
77
+ }
78
+
79
+ // handling the date string for due_date and reminder_date
80
+ if (entityData?.due_date) {
81
+ // Interpret input 'YYYY-MM-DD' as local midnight (IST)
82
+ entityData.due_date = moment(entityData.due_date, 'YYYY-MM-DD')
83
+ .startOf('day') // 00:00 local time
84
+ .toDate(); // Convert to JS Date object for TypeORM
85
+ }
86
+
87
+ if (entityData?.reminder_date) {
88
+ entityData.reminder_date = moment(entityData.reminder_date, 'YYYY-MM-DD')
89
+ .startOf('day')
90
+ .toDate();
91
+ }
92
+
93
+ const createdEntity = await super.createEntity(
94
+ entityData,
95
+ loggedInUser,
96
+ manager,
97
+ appcode,
98
+ );
99
+
100
+ try {
101
+ const logData = {
102
+ mapped_entity_id: createdEntity.mapped_entity_id,
103
+ mapped_entity_type: createdEntity.mapped_entity_type,
104
+ title: `Task added`,
105
+ description: `A new task ${createdEntity.name} was added`,
106
+ category: ACTIVITY_CATEGORIES.TASK,
107
+ action: 'add',
108
+ appcode: loggedInUser.appcode,
109
+ };
110
+
111
+ await this.activityLogService.logActivity(logData, loggedInUser);
112
+ } catch (error) {
113
+ console.error(
114
+ 'Failed to log activity for meeting:',
115
+ error?.message || error,
116
+ );
117
+ // Logging should not block main flow
118
+ }
119
+
120
+ let relationData = await this.dataSource.query(
121
+ `SELECT * FROM cr_entity_relation WHERE source_entity_type = ? AND target_entity_type = ?`,
122
+ [createdEntity.mapped_entity_type, createdEntity.entity_type],
123
+ );
124
+
125
+ if (relationData) {
126
+ await this.dataSource.query(
127
+ `INSERT INTO cr_entity_relation_data (organization_id, source_entity_id, source_entity_type, target_entity_id, target_entity_type, relation_type) VALUES (?, ?, ?, ?, ? , ?)`,
128
+ [
129
+ loggedInUser.organization_id,
130
+ createdEntity.mapped_entity_id,
131
+ createdEntity.mapped_entity_type,
132
+ createdEntity.id,
133
+ createdEntity.entity_type,
134
+ relationData[0]?.relation_type,
135
+ ],
136
+ );
137
+ }
138
+
139
+ return createdEntity;
140
+ }
141
+
142
+ async updateEntity(
143
+ entityData,
144
+ loggedInUser: UserData,
145
+ appcode?: string,
146
+ ): Promise<any> {
147
+ const taskStatusQuery = `
148
+ SELECT name
149
+ FROM cr_list_master_items
150
+ WHERE id = ?
151
+ AND organization_id = ?
152
+ AND listtype = 'TKST'
153
+ LIMIT 1;
154
+ `;
155
+
156
+ const statusRows = await this.dataSource.query(taskStatusQuery, [
157
+ entityData.status,
158
+ loggedInUser.organization_id,
159
+ ]);
160
+
161
+ const isCompletedStatus =
162
+ statusRows.length > 0 &&
163
+ statusRows[0].name?.toLowerCase() === 'completed';
164
+
165
+ // Sync flags based on status
166
+ entityData.is_completed = isCompletedStatus;
167
+ entityData.is_done = isCompletedStatus;
168
+
169
+ const isMandatory =
170
+ String(entityData.is_mandatory).toLowerCase() === 'true' ||
171
+ entityData.is_mandatory === true ||
172
+ entityData.is_mandatory === 1 ||
173
+ entityData.is_mandatory === '1';
174
+
175
+ const updatedEntity = await super.updateEntity(
176
+ {
177
+ ...entityData,
178
+ is_mandatory: isMandatory,
179
+ },
180
+ loggedInUser,
181
+ appcode,
182
+ );
183
+
184
+ // Convert boolean back to "1" / "0" for response
185
+ if (updatedEntity && typeof updatedEntity['is_mandatory'] === 'boolean') {
186
+ updatedEntity['is_mandatory'] = updatedEntity['is_mandatory'] ? '1' : '0';
187
+ }
188
+
189
+ try {
190
+ // Always log edit
191
+ const editLogData = {
192
+ mapped_entity_id: updatedEntity.mapped_entity_id,
193
+ mapped_entity_type: updatedEntity.mapped_entity_type,
194
+ title: `Task edited`,
195
+ description: `${updatedEntity.code} was edited`,
196
+ category: ACTIVITY_CATEGORIES.TASK,
197
+ action: 'edit',
198
+ appcode: loggedInUser.appcode,
199
+ };
200
+
201
+ await this.activityLogService.logActivity(editLogData, loggedInUser);
202
+
203
+ if (isCompletedStatus) {
204
+ const completedLogData = {
205
+ mapped_entity_id: updatedEntity.mapped_entity_id,
206
+ mapped_entity_type: updatedEntity.mapped_entity_type,
207
+ title: `Task completed`,
208
+ description: `${updatedEntity.code} was marked as completed`,
209
+ category: ACTIVITY_CATEGORIES.TASK,
210
+ action: 'completed',
211
+ appcode: loggedInUser.appcode,
212
+ };
213
+
214
+ await this.activityLogService.logActivity(
215
+ completedLogData,
216
+ loggedInUser,
217
+ );
218
+ }
219
+ } catch (error) {
220
+ console.error(
221
+ 'Failed to log activity for task:',
222
+ error?.message || error,
223
+ );
224
+ // Don't block main flow
225
+ }
226
+
227
+ return updatedEntity;
228
+ }
229
+
230
+ async getAllTaskByUserIdandStageId(
231
+ loggedInUser: UserData,
232
+ data,
233
+ ): Promise<any> {
234
+ const taskData = await this.taskRepository.getAllTaskByUserIdAndStageId({
235
+ user_id: data.user_id,
236
+ stage_id: data.stage_id,
237
+ mapped_entity_type: data.mapped_entity_type,
238
+ mapped_entity_id: data.mapped_entity_id,
239
+ });
240
+
241
+ const grouped: { mandatory: any[]; non_mandatory: any[] } = {
242
+ mandatory: [],
243
+ non_mandatory: [],
244
+ };
245
+
246
+ for (const task of taskData) {
247
+ if (task && task.is_mandatory) {
248
+ grouped.mandatory.push(task);
249
+ } else {
250
+ grouped.non_mandatory.push(task);
251
+ }
252
+ }
253
+
254
+ return grouped;
255
+ }
256
+
257
+ async getAllTask(
258
+ loggedInUser: UserData,
259
+ data: {
260
+ mapped_entity_type: string;
261
+ mapped_entity_id: number;
262
+ status?: string;
263
+ mandatory?: boolean;
264
+ overdue?: boolean;
265
+ },
266
+ ): Promise<any[]> {
267
+ const { mapped_entity_type, mapped_entity_id, status, mandatory, overdue } =
268
+ data;
269
+
270
+ // Build dynamic WHERE clauses
271
+ const whereClauses = [`t.mapped_entity_type = ?`, `t.mapped_entity_id = ?`];
272
+ const params: any[] = [mapped_entity_type, mapped_entity_id];
273
+
274
+ if (status) {
275
+ whereClauses.push(`t.status = ?`);
276
+ params.push(status);
277
+ }
278
+ if (mandatory) {
279
+ whereClauses.push(`t.is_mandatory = ?`);
280
+ params.push(mandatory ? 1 : 0);
281
+ }
282
+ if (overdue) {
283
+ whereClauses.push(
284
+ `(t.due_date < CURDATE() OR (t.due_date = CURDATE() AND t.due_time < CURTIME()))`,
285
+ );
286
+ // exclude tasks that are already completed
287
+ whereClauses.push(`t.is_done = ?`);
288
+ params.push(0); // Only include tasks that are not done
289
+ }
290
+
291
+ const sql = `
292
+ SELECT
293
+ t.*,
294
+ sg.name AS stage_group_name,
295
+ s.name AS stage_name,
296
+ a.name AS action_name,
297
+ u.name AS created_by_name,
298
+ u2.name AS task_owner_name,
299
+ u2.profile_image AS task_owner_profile
300
+ FROM cr_wf_task_data t
301
+ LEFT JOIN cr_wf_stage s ON t.stage_id = s.id
302
+ LEFT JOIN cr_wf_stage_group sg ON s.stage_group_id = sg.id
303
+ LEFT JOIN cr_wf_action a ON t.action_id = a.id
304
+ LEFT JOIN sso_user u ON t.created_by = u.id
305
+ LEFT JOIN eth_user_profile u2 ON t.task_owner = u2.parent_id
306
+ WHERE ${whereClauses.join(' AND ')}
307
+ ORDER BY t.created_date DESC
308
+ `;
309
+
310
+ const taskData = await this.dataSource.query(sql, params);
311
+
312
+ if (taskData.length === 0) {
313
+ return [];
314
+ }
315
+
316
+ // Fetch all TKST statuses in a single query
317
+ const taskStatusQuery = `
318
+ SELECT id, name
319
+ FROM cr_list_master_items
320
+ WHERE organization_id = ?
321
+ AND listtype = 'TKST'
322
+ `;
323
+ const taskAllStatus = await this.dataSource.query(taskStatusQuery, [
324
+ loggedInUser.organization_id,
325
+ ]);
326
+
327
+ // Build a hash map { id → name }
328
+ const statusMap = new Map(
329
+ taskAllStatus.map((row) => [String(row.id), row.name]),
330
+ );
331
+
332
+ // Assign task_status using the map
333
+
334
+ const mediaCache = new Map<number, any>();
335
+
336
+ for (const task of taskData) {
337
+ // Map status name
338
+ task.task_status = task.status
339
+ ? statusMap.get(String(task.status)) || null
340
+ : null;
341
+
342
+ // Fix action_name for generic tasks
343
+ task.action_name =
344
+ task.action_id === '0' || task.action_id === 0
345
+ ? 'Generic'
346
+ : task.action_name;
347
+
348
+ // Profile media (with caching like notes)
349
+ if (task.task_owner_profile) {
350
+ if (!mediaCache.has(task.task_owner_profile)) {
351
+ const url = await this.mediaDataService.getMediaDownloadUrl(
352
+ task.task_owner_profile,
353
+ loggedInUser,
354
+ );
355
+ mediaCache.set(task.task_owner_profile, url);
356
+ }
357
+ task.task_owner_profile = mediaCache.get(task.task_owner_profile);
358
+ } else {
359
+ task.task_owner_profile = null;
360
+ }
361
+ }
362
+
363
+ // Normalize is_mandatory to '0'/'1' as string
364
+ return taskData.map((task) => ({
365
+ ...task,
366
+ is_mandatory: task.is_mandatory ? '1' : '0',
367
+ }));
368
+ }
369
+
370
+ async getEntityData(entityType: string, id: number, loggedInUser: any) {
371
+ const taskData = await super.getEntityData(entityType, id, loggedInUser);
372
+
373
+ if (taskData?.due_date) {
374
+ taskData.due_date = moment(taskData.due_date)
375
+ .local() // convert from UTC to local
376
+ .format('YYYY-MM-DD'); // return just the date string
377
+ }
378
+
379
+ if (taskData?.reminder_date) {
380
+ taskData.reminder_date = moment(taskData.reminder_date)
381
+ .local()
382
+ .format('YYYY-MM-DD');
383
+ }
384
+
385
+ return taskData;
386
+ }
387
+
388
+ async saveActionData(
389
+ action: any,
390
+ loggedInUser: UserData,
391
+ mapped_entity_id: number,
392
+ mapped_entity_type: string,
393
+ ): Promise<any> {
394
+ await this.taskRepository.saveActionDataInTask(
395
+ action,
396
+ loggedInUser,
397
+ mapped_entity_id,
398
+ mapped_entity_type,
399
+ );
400
+ }
401
+
402
+ async moveTask(
403
+ loggedInUser: UserData,
404
+ body: {
405
+ mapped_entity_type: string;
406
+ mapped_entity_id: number;
407
+ stage_id: number;
408
+ action_id: number;
409
+ reason_code?: string | number;
410
+ remark?: string;
411
+ stage_group_id?: number;
412
+ },
413
+ ): Promise<any> {
414
+ // Logic to move task based on the provided body parameters
415
+ // This could involve updating the task's stage, action, etc.
416
+
417
+ // update task status
418
+ this.taskRepository.updateTaskStatus(
419
+ loggedInUser,
420
+ body.mapped_entity_type,
421
+ body.mapped_entity_id,
422
+ body.stage_id,
423
+ body.action_id,
424
+ );
425
+
426
+ // update action status
427
+ await this.actionDataService.updateActionStatus(
428
+ loggedInUser,
429
+ body.mapped_entity_type,
430
+ body.mapped_entity_id,
431
+ body.stage_id,
432
+ body.action_id,
433
+ );
434
+
435
+ if (body.reason_code || body.remark) {
436
+ await this.createSystemNote(
437
+ {
438
+ reason_code: body.reason_code!,
439
+ remark: body.remark || '',
440
+ mapped_entity_id: body.mapped_entity_id,
441
+ stage_id: body.stage_id,
442
+ action_id: body.action_id,
443
+ stage_group_id: body.stage_group_id,
444
+ },
445
+ loggedInUser,
446
+ );
447
+ }
448
+
449
+ return 'Task moved successfully';
450
+ }
451
+
452
+ async deleteEntity(
453
+ entity_type: string,
454
+ taskId: number,
455
+ loggedInUser: UserData,
456
+ ): Promise<any> {
457
+ // Fetch the task before deleting
458
+ const task: any = await super.getEntityData(
459
+ entity_type,
460
+ taskId,
461
+ loggedInUser,
462
+ );
463
+
464
+ if (!task) {
465
+ throw new Error('Task not found');
466
+ }
467
+
468
+ // Check if the task is system-generated
469
+ if (task.is_system) {
470
+ throw new Error('Cannot delete system-generated tasks');
471
+ }
472
+
473
+ // Perform the deletion
474
+ await super.deleteEntity(entity_type, taskId, loggedInUser);
475
+
476
+ // Try to log the delete activity
477
+ try {
478
+ const logData = {
479
+ mapped_entity_id: task.mapped_entity_id,
480
+ mapped_entity_type: task.mapped_entity_type,
481
+ title: `Task deleted`,
482
+ description: `${task.name} was deleted`,
483
+ category: ACTIVITY_CATEGORIES.TASK,
484
+ action: 'delete',
485
+ appcode: loggedInUser.appcode,
486
+ };
487
+
488
+ await this.activityLogService.logActivity(logData, loggedInUser);
489
+ } catch (error) {
490
+ console.error(
491
+ 'Failed to log activity for task deletion:',
492
+ error?.message || error,
493
+ );
494
+ }
495
+
496
+ return { message: 'Task deleted successfully' };
497
+ }
498
+
499
+ async createSystemNote(
500
+ entity: {
501
+ reason_code: string | number;
502
+ remark: string;
503
+ mapped_entity_id: number;
504
+ stage_id: number;
505
+ action_id: number;
506
+ stage_group_id?: number;
507
+ },
508
+ loggedInUser: any,
509
+ ) {
510
+ if (!entity || !entity.mapped_entity_id || !entity.reason_code) return null;
511
+
512
+ const [reason] = await this.dataSource.query(
513
+ `SELECT name FROM cr_list_master_items WHERE id = ? AND organization_id = ?`,
514
+ [entity.reason_code, loggedInUser.organization_id],
515
+ );
516
+
517
+ const notePayload = {
518
+ note_title: reason ? reason.name : entity.reason_code,
519
+ note: entity.remark,
520
+ is_system: true,
521
+ mapped_entity_type: 'LEAD',
522
+ entity_type: 'NOTE',
523
+ mapped_entity_id: entity.mapped_entity_id,
524
+ stage_id: entity.stage_id,
525
+ action_id: entity.action_id,
526
+ stage_group_id: entity.stage_group_id,
527
+ } as any;
528
+
529
+ return await super.createEntity(notePayload, loggedInUser);
530
+ }
531
+ }