rez_core 6.1.4 → 6.1.6

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 (427) hide show
  1. package/.prettierrc +3 -3
  2. package/README.md +99 -99
  3. package/dist/migrations/1732612800000-AddEntityJsonGinIndex.js +10 -10
  4. package/dist/module/auth/guards/role.guard.js +3 -3
  5. package/dist/module/enterprise/service/organization.service.d.ts +1 -1
  6. package/dist/module/enterprise/service/organization.service.js +3 -4
  7. package/dist/module/enterprise/service/organization.service.js.map +1 -1
  8. package/dist/module/filter/repository/saved-filter.repository.js +2 -0
  9. package/dist/module/filter/repository/saved-filter.repository.js.map +1 -1
  10. package/dist/module/filter/service/filter.service.js +25 -21
  11. package/dist/module/filter/service/filter.service.js.map +1 -1
  12. package/dist/module/filter/service/flatjson-filter.service.js +5 -5
  13. package/dist/module/integration/examples/usage.example.js +9 -9
  14. package/dist/module/integration/service/integration.service.d.ts +5 -1
  15. package/dist/module/integration/service/integration.service.js +11 -1
  16. package/dist/module/integration/service/integration.service.js.map +1 -1
  17. package/dist/module/integration/service/oauth.service.js +2 -0
  18. package/dist/module/integration/service/oauth.service.js.map +1 -1
  19. package/dist/module/integration/strategies/email/gmail-api.strategy.js +23 -7
  20. package/dist/module/integration/strategies/email/gmail-api.strategy.js.map +1 -1
  21. package/dist/module/integration/strategies/email/sendgrid-api.strategy.js +8 -5
  22. package/dist/module/integration/strategies/email/sendgrid-api.strategy.js.map +1 -1
  23. package/dist/module/meta/controller/media.controller.d.ts +6 -0
  24. package/dist/module/meta/controller/media.controller.js +27 -0
  25. package/dist/module/meta/controller/media.controller.js.map +1 -1
  26. package/dist/module/meta/entity/media-data.entity.d.ts +2 -0
  27. package/dist/module/meta/entity/media-data.entity.js +8 -0
  28. package/dist/module/meta/entity/media-data.entity.js.map +1 -1
  29. package/dist/module/meta/repository/attribute-master.repository.js +8 -8
  30. package/dist/module/meta/service/entity-dynamic.service.js +18 -18
  31. package/dist/module/meta/service/entity-dynamic.service.js.map +1 -1
  32. package/dist/module/meta/service/media-data.service.d.ts +3 -0
  33. package/dist/module/meta/service/media-data.service.js +16 -6
  34. package/dist/module/meta/service/media-data.service.js.map +1 -1
  35. package/dist/module/meta/service/populate-meta.service.js +8 -2
  36. package/dist/module/meta/service/populate-meta.service.js.map +1 -1
  37. package/dist/module/meta/service/resolver.service.js +39 -15
  38. package/dist/module/meta/service/resolver.service.js.map +1 -1
  39. package/dist/module/module/repository/menu.repository.js +4 -4
  40. package/dist/module/user/controller/login.controller.js +19 -19
  41. package/dist/module/user/controller/login.controller.js.map +1 -1
  42. package/dist/module/user/service/user-session.service.js +1 -0
  43. package/dist/module/user/service/user-session.service.js.map +1 -1
  44. package/dist/module/workflow/repository/action.repository.js +2 -2
  45. package/dist/module/workflow/repository/stage.repository.js +8 -8
  46. package/dist/module/workflow/service/action-template-mapping.service.js +2 -2
  47. package/dist/module/workflow/service/action.service.js +5 -5
  48. package/dist/module/workflow/service/entity-modification.service.js +2 -2
  49. package/dist/module/workflow/service/populate-workflow.service.js +5 -0
  50. package/dist/module/workflow/service/populate-workflow.service.js.map +1 -1
  51. package/dist/module/workflow/service/task.service.js +8 -8
  52. package/dist/module/workflow-automation/service/schedule-handler.service.js +9 -9
  53. package/dist/tsconfig.build.tsbuildinfo +1 -1
  54. package/dist/utils/service/reflection-helper.service.js +2 -2
  55. package/docs/modules/event-driven-integration-design.md +91 -91
  56. package/docs/modules/integration.md +250 -250
  57. package/eslint.config.mjs +34 -34
  58. package/nest-cli.json +14 -14
  59. package/package.json +125 -125
  60. package/src/app.controller.ts +13 -13
  61. package/src/app.module.ts +68 -68
  62. package/src/app.service.ts +8 -8
  63. package/src/config/bull.config.ts +69 -69
  64. package/src/config/config.module.ts +17 -17
  65. package/src/config/database.config.ts +48 -48
  66. package/src/constant/global.constant.ts +67 -67
  67. package/src/core.module.ts +94 -94
  68. package/src/decorators/roles.decorator.ts +7 -7
  69. package/src/dtos/response.dto.ts +6 -6
  70. package/src/dtos/response.ts +5 -5
  71. package/src/index.ts +1 -1
  72. package/src/migrations/1732612800000-AddEntityJsonGinIndex.ts +41 -41
  73. package/src/module/auth/auth.module.ts +49 -49
  74. package/src/module/auth/controller/auth.controller.ts +28 -28
  75. package/src/module/auth/guards/google-auth.guard.ts +9 -9
  76. package/src/module/auth/guards/jwt.guard.ts +22 -22
  77. package/src/module/auth/guards/role.guard.ts +68 -68
  78. package/src/module/auth/services/auth.service.ts +56 -56
  79. package/src/module/auth/services/jwt.service.ts +11 -11
  80. package/src/module/auth/strategies/google.strategy.ts +54 -54
  81. package/src/module/auth/strategies/jwt.strategy.ts +58 -58
  82. package/src/module/auth/strategies/local.strategy.ts +13 -13
  83. package/src/module/dashboard/controller/dashboard.controller.ts +38 -38
  84. package/src/module/dashboard/dashboard.module.ts +21 -21
  85. package/src/module/dashboard/entity/dashboard_page_data.entity.ts +27 -27
  86. package/src/module/dashboard/entity/widget_master.entity.ts +18 -18
  87. package/src/module/dashboard/repository/dashboard.repository.ts +49 -49
  88. package/src/module/dashboard/service/dashboard.service.ts +72 -72
  89. package/src/module/enterprise/controller/organization.controller.ts +36 -36
  90. package/src/module/enterprise/enterprise.module.ts +45 -45
  91. package/src/module/enterprise/entity/enterprise.entity.ts +37 -37
  92. package/src/module/enterprise/entity/organization-app-mapping.entity.ts +13 -13
  93. package/src/module/enterprise/entity/organization.entity.ts +92 -92
  94. package/src/module/enterprise/repository/enterprise.repository.ts +31 -31
  95. package/src/module/enterprise/repository/organization.repository.ts +26 -26
  96. package/src/module/enterprise/repository/school.repository.ts +289 -289
  97. package/src/module/enterprise/service/brand.service.ts +5 -5
  98. package/src/module/enterprise/service/enterprise.service.ts +16 -16
  99. package/src/module/enterprise/service/organization-app-mapping.service.ts +4 -4
  100. package/src/module/enterprise/service/organization.service.ts +146 -145
  101. package/src/module/entity_json/controller/entity_json.controller.ts +60 -60
  102. package/src/module/entity_json/docs/FlatJson_Filterin_System.md +2803 -2803
  103. package/src/module/entity_json/entity/entityJson.entity.ts +42 -42
  104. package/src/module/entity_json/entity_json.module.ts +22 -22
  105. package/src/module/entity_json/service/entityJson.repository.ts +37 -37
  106. package/src/module/entity_json/service/entity_json.service.ts +486 -486
  107. package/src/module/export/controller/export.controller.ts +83 -83
  108. package/src/module/export/export.module.ts +14 -14
  109. package/src/module/export/service/export.service.ts +105 -105
  110. package/src/module/filter/controller/filter.controller.ts +87 -87
  111. package/src/module/filter/dto/filter-request.dto.ts +39 -39
  112. package/src/module/filter/entity/saved-filter-detail.entity.ts +41 -41
  113. package/src/module/filter/entity/saved-filter-master.entity.ts +35 -35
  114. package/src/module/filter/filter.module.ts +41 -41
  115. package/src/module/filter/repository/saved-filter.repository.ts +249 -247
  116. package/src/module/filter/repository/saved.filter-detail.repository.ts +19 -19
  117. package/src/module/filter/service/filter-evaluator.service.ts +82 -82
  118. package/src/module/filter/service/filter.service.ts +1406 -1370
  119. package/src/module/filter/service/flatjson-filter.service.ts +903 -903
  120. package/src/module/filter/service/saved-filter.service.ts +154 -154
  121. package/src/module/filter/test/flatjson-filter.service.spec.ts +415 -415
  122. package/src/module/ics/controller/ics.controller.ts +21 -21
  123. package/src/module/ics/dto/ics.dto.ts +55 -55
  124. package/src/module/ics/ics.module.ts +13 -13
  125. package/src/module/ics/service/ics.service.ts +57 -57
  126. package/src/module/integration/controller/calender-event.controller.ts +31 -31
  127. package/src/module/integration/controller/integration.controller.ts +662 -662
  128. package/src/module/integration/controller/wrapper.controller.ts +37 -37
  129. package/src/module/integration/dto/create-config.dto.ts +526 -526
  130. package/src/module/integration/entity/integration-config.entity.ts +112 -112
  131. package/src/module/integration/entity/integration-entity-mapper.entity.ts +14 -14
  132. package/src/module/integration/entity/integration-source.entity.ts +17 -17
  133. package/src/module/integration/entity/user-integration.entity.ts +71 -71
  134. package/src/module/integration/examples/usage.example.ts +338 -338
  135. package/src/module/integration/factories/base.factory.ts +7 -7
  136. package/src/module/integration/factories/email.factory.ts +49 -49
  137. package/src/module/integration/factories/integration.factory.ts +121 -121
  138. package/src/module/integration/factories/sms.factory.ts +51 -51
  139. package/src/module/integration/factories/telephone.factory.ts +41 -41
  140. package/src/module/integration/factories/whatsapp.factory.ts +56 -56
  141. package/src/module/integration/integration.module.ts +110 -110
  142. package/src/module/integration/service/calendar-event.service.ts +118 -118
  143. package/src/module/integration/service/integration-entity-mapper.service.ts +17 -17
  144. package/src/module/integration/service/integration-queue.service.ts +229 -229
  145. package/src/module/integration/service/integration.service.ts +2653 -2639
  146. package/src/module/integration/service/oauth.service.ts +226 -224
  147. package/src/module/integration/service/wrapper.service.ts +754 -754
  148. package/src/module/integration/strategies/email/gmail-api.strategy.ts +307 -281
  149. package/src/module/integration/strategies/email/outlook-api.strategy.ts +44 -44
  150. package/src/module/integration/strategies/email/outlook.strategy.ts +64 -64
  151. package/src/module/integration/strategies/email/sendgrid-api.strategy.ts +263 -260
  152. package/src/module/integration/strategies/integration.strategy.ts +97 -97
  153. package/src/module/integration/strategies/sms/gupshup-sms.strategy.ts +146 -146
  154. package/src/module/integration/strategies/sms/msg91-sms.strategy.ts +164 -164
  155. package/src/module/integration/strategies/sms/tubelight-sms.strategy.ts +163 -163
  156. package/src/module/integration/strategies/telephone/ozonetel-voice.strategy.ts +238 -238
  157. package/src/module/integration/strategies/telephone/tubelight-voice.strategy.ts +210 -210
  158. package/src/module/integration/strategies/whatsapp/gupshup-whatsapp.strategy.ts +359 -359
  159. package/src/module/integration/strategies/whatsapp/tubelight-whatsapp.strategy.ts +372 -372
  160. package/src/module/integration/strategies/whatsapp/whatsapp-cloud.strategy.ts +403 -403
  161. package/src/module/integration/strategies/whatsapp/whatsapp.strategy.ts +57 -57
  162. package/src/module/layout/controller/layout.controller.ts +47 -47
  163. package/src/module/layout/entity/header-items.entity.ts +28 -28
  164. package/src/module/layout/entity/header-section.entity.ts +19 -19
  165. package/src/module/layout/layout.module.ts +21 -21
  166. package/src/module/layout/repository/header-items.repository.ts +18 -18
  167. package/src/module/layout/repository/header-section.repository.ts +22 -22
  168. package/src/module/layout/service/header-section.service.ts +25 -25
  169. package/src/module/layout_preference/controller/layout_preference.controller.ts +76 -76
  170. package/src/module/layout_preference/entity/layout_preference.entity.ts +28 -28
  171. package/src/module/layout_preference/layout_preference.module.ts +22 -22
  172. package/src/module/layout_preference/repository/layout_preference.repository.ts +65 -65
  173. package/src/module/layout_preference/service/layout_preference.service.ts +191 -191
  174. package/src/module/lead/controller/lead.controller.ts +30 -30
  175. package/src/module/lead/lead.module.ts +14 -14
  176. package/src/module/lead/repository/lead.repository.ts +41 -41
  177. package/src/module/lead/service/lead.service.ts +54 -54
  178. package/src/module/linked_attributes/controller/linked_attributes.controller.ts +137 -137
  179. package/src/module/linked_attributes/dto/create-linked-attribute-smart.dto.ts +54 -54
  180. package/src/module/linked_attributes/entity/linked_attribute.entity.ts +51 -51
  181. package/src/module/linked_attributes/linked_attributes.module.ts +23 -23
  182. package/src/module/linked_attributes/repository/linked_attribute.repository.ts +12 -12
  183. package/src/module/linked_attributes/service/linked_attributes.service.ts +648 -648
  184. package/src/module/linked_attributes/test/linked-attributes.service.spec.ts +244 -244
  185. package/src/module/listmaster/controller/list-master.controller.ts +230 -230
  186. package/src/module/listmaster/entity/list-master-items.entity.ts +43 -43
  187. package/src/module/listmaster/entity/list-master.entity.ts +33 -33
  188. package/src/module/listmaster/listmaster.module.ts +46 -46
  189. package/src/module/listmaster/repository/list-master-items.repository.ts +173 -173
  190. package/src/module/listmaster/repository/list-master.repository.ts +56 -56
  191. package/src/module/listmaster/service/list-master-engine.ts +19 -19
  192. package/src/module/listmaster/service/list-master-extension.interface.ts +4 -4
  193. package/src/module/listmaster/service/list-master-item.service.ts +280 -280
  194. package/src/module/listmaster/service/list-master-registry.ts +15 -15
  195. package/src/module/listmaster/service/list-master.service.ts +527 -527
  196. package/src/module/mapper/controller/field-mapper.controller.ts +76 -76
  197. package/src/module/mapper/controller/mapper.controller.ts +20 -20
  198. package/src/module/mapper/dto/field-mapper.dto.ts +14 -14
  199. package/src/module/mapper/entity/field-lovs.entity.ts +19 -19
  200. package/src/module/mapper/entity/field-mapper.entity.ts +53 -53
  201. package/src/module/mapper/entity/mapper.entity.ts +16 -16
  202. package/src/module/mapper/mapper.module.ts +35 -35
  203. package/src/module/mapper/repository/field-lovs.repository.ts +35 -35
  204. package/src/module/mapper/repository/field-mapper.repository.ts +42 -42
  205. package/src/module/mapper/repository/mapper.repository.ts +32 -32
  206. package/src/module/mapper/service/field-mapper.service.ts +269 -269
  207. package/src/module/mapper/service/mapper.service.ts +80 -80
  208. package/src/module/master/controller/master.controller.ts +74 -74
  209. package/src/module/master/service/master.service.ts +484 -484
  210. package/src/module/meta/controller/app-master.controller.ts +38 -38
  211. package/src/module/meta/controller/attribute-master.controller.ts +96 -96
  212. package/src/module/meta/controller/entity-dynamic.controller.ts +125 -125
  213. package/src/module/meta/controller/entity-master.controller.ts +41 -41
  214. package/src/module/meta/controller/entity-relation.controller.ts +36 -36
  215. package/src/module/meta/controller/entity.controller.ts +308 -308
  216. package/src/module/meta/controller/entity.public.controller.ts +75 -75
  217. package/src/module/meta/controller/media.controller.ts +167 -135
  218. package/src/module/meta/controller/meta.controller.ts +101 -101
  219. package/src/module/meta/controller/view-master.controller.ts +79 -79
  220. package/src/module/meta/dto/entity-list-data.dto.ts +6 -6
  221. package/src/module/meta/dto/entity-tab.dto.ts +4 -4
  222. package/src/module/meta/dto/entity-table.dto.ts +12 -12
  223. package/src/module/meta/entity/app-master.entity.ts +37 -37
  224. package/src/module/meta/entity/attribute-master.entity.ts +92 -92
  225. package/src/module/meta/entity/base-entity.entity.ts +75 -75
  226. package/src/module/meta/entity/entity-master.entity.ts +91 -91
  227. package/src/module/meta/entity/entity-relation-data.entity.ts +29 -29
  228. package/src/module/meta/entity/entity-relation.entity.ts +23 -23
  229. package/src/module/meta/entity/entity-table-column.entity.ts +61 -61
  230. package/src/module/meta/entity/entity-table.entity.ts +50 -50
  231. package/src/module/meta/entity/media-data.entity.ts +38 -32
  232. package/src/module/meta/entity/preference.entity.ts +62 -62
  233. package/src/module/meta/entity/view-master.entity.ts +41 -41
  234. package/src/module/meta/entity.module.ts +165 -165
  235. package/src/module/meta/repository/app-master.repository.ts +20 -20
  236. package/src/module/meta/repository/attribute-master.repository.ts +164 -164
  237. package/src/module/meta/repository/entity-attribute-update.repository.ts +48 -48
  238. package/src/module/meta/repository/entity-master.repository.ts +120 -120
  239. package/src/module/meta/repository/entity-relation.repository.ts +22 -22
  240. package/src/module/meta/repository/entity-table-column.repository.ts +39 -39
  241. package/src/module/meta/repository/entity-table.repository.ts +53 -53
  242. package/src/module/meta/repository/media-data.repository.ts +50 -50
  243. package/src/module/meta/repository/preference.repository.ts +20 -20
  244. package/src/module/meta/repository/user-app-mapping.repository.ts +28 -28
  245. package/src/module/meta/repository/view-master.repository.ts +42 -42
  246. package/src/module/meta/service/app-master.service.ts +37 -37
  247. package/src/module/meta/service/attribute-master.service.ts +160 -160
  248. package/src/module/meta/service/common.service.ts +9 -9
  249. package/src/module/meta/service/entity-attribute-update.service.ts +26 -26
  250. package/src/module/meta/service/entity-dynamic.service.ts +835 -824
  251. package/src/module/meta/service/entity-master.service.ts +172 -172
  252. package/src/module/meta/service/entity-realation-data.service.ts +9 -9
  253. package/src/module/meta/service/entity-relation.service.ts +78 -78
  254. package/src/module/meta/service/entity-service-impl.service.ts +389 -389
  255. package/src/module/meta/service/entity-table-column.service.ts +26 -26
  256. package/src/module/meta/service/entity-table.service.ts +171 -171
  257. package/src/module/meta/service/entity-validation.service.ts +188 -188
  258. package/src/module/meta/service/entity.service.ts +48 -48
  259. package/src/module/meta/service/field-group.service.ts +103 -103
  260. package/src/module/meta/service/media-data.service.ts +610 -591
  261. package/src/module/meta/service/populate-meta.service.ts +228 -222
  262. package/src/module/meta/service/preference.service.ts +16 -16
  263. package/src/module/meta/service/resolver.service.ts +347 -319
  264. package/src/module/meta/service/section-master.service.ts +104 -104
  265. package/src/module/meta/service/update-form-json.service.ts +22 -22
  266. package/src/module/meta/service/user-app-mapping.service.ts +17 -17
  267. package/src/module/meta/service/view-master.service.ts +127 -127
  268. package/src/module/microservice-client/microservice-clients.module.ts +13 -13
  269. package/src/module/microservice-client/service/microservice-client-factory.ts +37 -37
  270. package/src/module/microservice-client/service/microservice-clients.ts +4 -4
  271. package/src/module/module/controller/menu.controller.ts +15 -15
  272. package/src/module/module/controller/module-access.controller.ts +133 -133
  273. package/src/module/module/entity/menu.entity.ts +43 -43
  274. package/src/module/module/entity/module-access.entity.ts +25 -25
  275. package/src/module/module/entity/module-action.entity.ts +17 -17
  276. package/src/module/module/entity/module.entity.ts +52 -52
  277. package/src/module/module/module.module.ts +42 -42
  278. package/src/module/module/repository/menu.repository.ts +186 -186
  279. package/src/module/module/repository/module-access.repository.ts +344 -344
  280. package/src/module/module/service/menu.service.ts +82 -82
  281. package/src/module/module/service/module-access.service.ts +189 -189
  282. package/src/module/notification/controller/notification.controller.ts +58 -58
  283. package/src/module/notification/controller/otp.controller.ts +117 -117
  284. package/src/module/notification/entity/notification.entity.ts +26 -26
  285. package/src/module/notification/entity/otp.entity.ts +28 -28
  286. package/src/module/notification/firebase-admin.config.ts +22 -22
  287. package/src/module/notification/notification.module.ts +71 -71
  288. package/src/module/notification/repository/notification.repository.ts +33 -33
  289. package/src/module/notification/repository/otp.repository.ts +27 -27
  290. package/src/module/notification/service/email.service.ts +127 -127
  291. package/src/module/notification/service/notification.service.ts +146 -146
  292. package/src/module/notification/service/otp.service.ts +133 -133
  293. package/src/module/third-party-module/entity/third-party-api-registry.entity.ts +52 -52
  294. package/src/module/third-party-module/repository/third-party-api-registry.repository.ts +20 -20
  295. package/src/module/third-party-module/service/api-registry.service.ts +13 -13
  296. package/src/module/third-party-module/third-party.module.ts +12 -12
  297. package/src/module/user/controller/login.controller.ts +199 -198
  298. package/src/module/user/controller/user.controller.ts +40 -40
  299. package/src/module/user/dto/create-user.dto.ts +62 -62
  300. package/src/module/user/dto/update-user.dto.ts +4 -4
  301. package/src/module/user/entity/role.entity.ts +33 -33
  302. package/src/module/user/entity/user-role-mapping.entity.ts +38 -38
  303. package/src/module/user/entity/user-session.entity.ts +73 -73
  304. package/src/module/user/entity/user.entity.ts +62 -62
  305. package/src/module/user/repository/role.repository.ts +96 -96
  306. package/src/module/user/repository/user-role-mapping.repository.ts +126 -126
  307. package/src/module/user/repository/user.repository.ts +50 -50
  308. package/src/module/user/repository/userSession.repository.ts +33 -33
  309. package/src/module/user/service/login.service.ts +326 -326
  310. package/src/module/user/service/role.service.ts +197 -197
  311. package/src/module/user/service/user-role-mapping.service.ts +98 -98
  312. package/src/module/user/service/user-session.service.ts +201 -200
  313. package/src/module/user/service/user.service.ts +368 -368
  314. package/src/module/user/user.module.ts +65 -65
  315. package/src/module/workflow/controller/action-category.controller.ts +54 -54
  316. package/src/module/workflow/controller/action-resource-mapping.controller.ts +23 -23
  317. package/src/module/workflow/controller/action-template-mapping.controller.ts +35 -35
  318. package/src/module/workflow/controller/action.controller.ts +111 -111
  319. package/src/module/workflow/controller/activity-log.controller.ts +55 -55
  320. package/src/module/workflow/controller/comm-template.controller.ts +43 -43
  321. package/src/module/workflow/controller/entity-modification.controller.ts +35 -35
  322. package/src/module/workflow/controller/form-master.controller.ts +43 -43
  323. package/src/module/workflow/controller/stage-group.controller.ts +49 -49
  324. package/src/module/workflow/controller/stage.controller.ts +51 -51
  325. package/src/module/workflow/controller/task.controller.ts +77 -77
  326. package/src/module/workflow/controller/workflow-list-master.controller.ts +44 -44
  327. package/src/module/workflow/controller/workflow-meta.controller.ts +80 -80
  328. package/src/module/workflow/controller/workflow.controller.ts +67 -67
  329. package/src/module/workflow/entity/action-category.entity.ts +38 -38
  330. package/src/module/workflow/entity/action-data.entity.ts +55 -55
  331. package/src/module/workflow/entity/action-resources-mapping.entity.ts +29 -29
  332. package/src/module/workflow/entity/action-template-mapping.entity.ts +17 -17
  333. package/src/module/workflow/entity/action.entity.ts +53 -53
  334. package/src/module/workflow/entity/activity-log.entity.ts +43 -43
  335. package/src/module/workflow/entity/comm-template.entity.ts +43 -43
  336. package/src/module/workflow/entity/entity-modification.entity.ts +38 -38
  337. package/src/module/workflow/entity/form.entity.ts +25 -25
  338. package/src/module/workflow/entity/stage-action-mapping.entity.ts +17 -17
  339. package/src/module/workflow/entity/stage-group.entity.ts +23 -23
  340. package/src/module/workflow/entity/stage-movement-data.entity.ts +38 -38
  341. package/src/module/workflow/entity/stage.entity.ts +20 -20
  342. package/src/module/workflow/entity/task-data.entity.ts +88 -88
  343. package/src/module/workflow/entity/template-attach-mapper.entity.ts +30 -30
  344. package/src/module/workflow/entity/workflow-data.entity.ts +11 -11
  345. package/src/module/workflow/entity/workflow-level-mapping.entity.ts +18 -18
  346. package/src/module/workflow/entity/workflow.entity.ts +20 -20
  347. package/src/module/workflow/repository/action-category.repository.ts +79 -79
  348. package/src/module/workflow/repository/action-data.repository.ts +354 -354
  349. package/src/module/workflow/repository/action.repository.ts +339 -339
  350. package/src/module/workflow/repository/activity-log.repository.ts +148 -148
  351. package/src/module/workflow/repository/comm-template.repository.ts +157 -157
  352. package/src/module/workflow/repository/form-master.repository.ts +50 -50
  353. package/src/module/workflow/repository/stage-group.repository.ts +186 -186
  354. package/src/module/workflow/repository/stage-movement.repository.ts +217 -217
  355. package/src/module/workflow/repository/stage.repository.ts +160 -160
  356. package/src/module/workflow/repository/task.repository.ts +156 -156
  357. package/src/module/workflow/repository/workflow.repository.ts +42 -42
  358. package/src/module/workflow/service/action-category.service.ts +33 -33
  359. package/src/module/workflow/service/action-data.service.ts +62 -62
  360. package/src/module/workflow/service/action-resources-mapping.service.ts +10 -10
  361. package/src/module/workflow/service/action-template-mapping.service.ts +137 -137
  362. package/src/module/workflow/service/action.service.ts +302 -302
  363. package/src/module/workflow/service/activity-log.service.ts +107 -107
  364. package/src/module/workflow/service/comm-template.service.ts +181 -181
  365. package/src/module/workflow/service/entity-modification.service.ts +61 -61
  366. package/src/module/workflow/service/form-master.service.ts +35 -35
  367. package/src/module/workflow/service/populate-workflow.service.ts +325 -320
  368. package/src/module/workflow/service/stage-action-mapping.service.ts +5 -5
  369. package/src/module/workflow/service/stage-group.service.ts +325 -325
  370. package/src/module/workflow/service/stage.service.ts +197 -197
  371. package/src/module/workflow/service/task.service.ts +551 -551
  372. package/src/module/workflow/service/workflow-list-master.service.ts +68 -68
  373. package/src/module/workflow/service/workflow-meta.service.ts +640 -640
  374. package/src/module/workflow/service/workflow.service.ts +213 -213
  375. package/src/module/workflow/workflow.module.ts +180 -180
  376. package/src/module/workflow-automation/SCHEDULING_GUIDE.md +145 -145
  377. package/src/module/workflow-automation/controller/workflow-automation.controller.ts +43 -43
  378. package/src/module/workflow-automation/entity/workflow-automation-action.entity.ts +26 -26
  379. package/src/module/workflow-automation/entity/workflow-automation.entity.ts +40 -40
  380. package/src/module/workflow-automation/interface/action.decorator.ts +7 -7
  381. package/src/module/workflow-automation/interface/action.interface.ts +5 -5
  382. package/src/module/workflow-automation/service/action-registery.service.ts +35 -35
  383. package/src/module/workflow-automation/service/schedule-handler.service.ts +168 -168
  384. package/src/module/workflow-automation/service/workflow-automation-engine.service.ts +219 -219
  385. package/src/module/workflow-automation/service/workflow-automation.service.ts +474 -474
  386. package/src/module/workflow-automation/workflow-automation.module.ts +54 -54
  387. package/src/module/workflow-schedule/INSTALLATION.md +244 -244
  388. package/src/module/workflow-schedule/MULTI_PROJECT_GUIDE.md +196 -196
  389. package/src/module/workflow-schedule/README.md +422 -422
  390. package/src/module/workflow-schedule/constants/schedule.constants.ts +48 -48
  391. package/src/module/workflow-schedule/controller/workflow-schedule.controller.ts +253 -253
  392. package/src/module/workflow-schedule/docs/CLAUDE_CODE_GUIDE.md +510 -510
  393. package/src/module/workflow-schedule/docs/CLAUDE_CODE_PROMPT.md +362 -362
  394. package/src/module/workflow-schedule/docs/RUN_CLAUDE_CODE.sh +68 -68
  395. package/src/module/workflow-schedule/dto/create-schedule.dto.ts +147 -147
  396. package/src/module/workflow-schedule/dto/get-execution-logs.dto.ts +119 -119
  397. package/src/module/workflow-schedule/dto/update-schedule.dto.ts +96 -96
  398. package/src/module/workflow-schedule/entities/scheduled-workflow.entity.ts +148 -148
  399. package/src/module/workflow-schedule/entities/workflow-execution-log.entity.ts +154 -154
  400. package/src/module/workflow-schedule/interfaces/schedule-job-data.interface.ts +53 -53
  401. package/src/module/workflow-schedule/interfaces/workflow-schedule-options.interface.ts +12 -12
  402. package/src/module/workflow-schedule/processors/schedule.processor.ts +620 -620
  403. package/src/module/workflow-schedule/service/workflow-schedule.service.ts +597 -597
  404. package/src/module/workflow-schedule/workflow-schedule.module.ts +67 -67
  405. package/src/resources/dev.properties.yaml +31 -31
  406. package/src/resources/local.properties.yaml +27 -27
  407. package/src/resources/properties.module.ts +12 -12
  408. package/src/resources/properties.yaml.ts +11 -11
  409. package/src/resources/uat.properties.yaml +31 -31
  410. package/src/table.config.ts +135 -135
  411. package/src/utils/dto/excel-data.dto.ts +14 -14
  412. package/src/utils/dto/excelsheet-data.dto.ts +5 -5
  413. package/src/utils/service/base64util.service.ts +18 -18
  414. package/src/utils/service/clockIDGenUtil.service.ts +21 -21
  415. package/src/utils/service/codeGenerator.service.ts +22 -22
  416. package/src/utils/service/dateUtil.service.ts +17 -17
  417. package/src/utils/service/encryptUtil.service.ts +97 -97
  418. package/src/utils/service/excel-helper.service.ts +72 -72
  419. package/src/utils/service/excelUtil.service.ts +15 -15
  420. package/src/utils/service/file-util.service.ts +11 -11
  421. package/src/utils/service/json-util.service.ts +23 -23
  422. package/src/utils/service/loggingUtil.service.ts +88 -88
  423. package/src/utils/service/reflection-helper.service.ts +62 -62
  424. package/src/utils/service/wbsCodeGen.service.ts +8 -8
  425. package/src/utils/utils.module.ts +27 -27
  426. package/tsconfig.build.json +4 -4
  427. package/tsconfig.json +24 -24
@@ -1,551 +1,551 @@
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 { ActionHandler } from 'src/module/workflow-automation/interface/action.decorator';
10
- import * as moment from 'moment';
11
- import { ConfigService } from '@nestjs/config';
12
- import axios from 'axios';
13
-
14
- @Injectable()
15
- @ActionHandler('add_task')
16
- export class TaskService extends EntityServiceImpl {
17
- constructor(
18
- private readonly taskRepository: TaskRepository,
19
- private readonly actionDataService: ActionDataService,
20
- @Inject('ActivityLogService')
21
- private readonly activityLogService: ActivityLogService,
22
- private readonly configService: ConfigService,
23
- ) {
24
- super();
25
- }
26
-
27
- name: string = 'add_task';
28
-
29
- async execute(payload: any): Promise<any> {
30
- let { entity, user, config } = payload;
31
-
32
- const { organization_id, level_id, level_type } = entity;
33
-
34
- if (entity.entity_type !== 'LEAD') {
35
- entity = await this.getEntityData('LEAD', entity.parent_id, user);
36
- }
37
-
38
- // 3. Build entityData
39
- const entityData = {
40
- mapped_entity_id: entity.id,
41
- mapped_entity_type: entity.entity_type,
42
- task_owner: entity.lead_owner,
43
- stage_id: entity.stageId,
44
- status: config.status,
45
- due_date: Date.now() + 2,
46
- due_time: Date.now(),
47
- description: config.description,
48
- is_mandatory: config.is_mandatory,
49
- name: config.name,
50
- entity_type: 'TASK',
51
- };
52
-
53
- return await this.createEntity(entityData, user);
54
- }
55
-
56
- async createEntity(
57
- entityData: any,
58
- loggedInUser: any,
59
- manager?: EntityManager | null,
60
- appcode?: string,
61
- ): Promise<any> {
62
- if (entityData && typeof entityData['is_mandatory'] === 'string') {
63
- entityData['is_mandatory'] = entityData['is_mandatory'] === '1';
64
- }
65
-
66
- // handling the date string for due_date and reminder_date
67
- if (entityData?.due_date) {
68
- // Interpret input 'YYYY-MM-DD' as local midnight (IST)
69
- entityData.due_date = moment(entityData.due_date, 'YYYY-MM-DD')
70
- .startOf('day') // 00:00 local time
71
- .toDate(); // Convert to JS Date object for TypeORM
72
- }
73
-
74
- if (entityData?.reminder_date) {
75
- entityData.reminder_date = moment(entityData.reminder_date, 'YYYY-MM-DD')
76
- .startOf('day')
77
- .toDate();
78
- }
79
-
80
- const createdEntity = await super.createEntity(
81
- entityData,
82
- loggedInUser,
83
- manager,
84
- appcode,
85
- );
86
-
87
- try {
88
- const logData = {
89
- mapped_entity_id: createdEntity.mapped_entity_id,
90
- mapped_entity_type: createdEntity.mapped_entity_type,
91
- title: `Task added`,
92
- description: `A new task ${createdEntity.name} was added`,
93
- category: ACTIVITY_CATEGORIES.TASK,
94
- action: 'add',
95
- appcode: loggedInUser.appcode,
96
- };
97
-
98
- await this.activityLogService.logActivity(logData, loggedInUser);
99
- } catch (error) {
100
- console.error(
101
- 'Failed to log activity for meeting:',
102
- error?.message || error,
103
- );
104
- // Logging should not block main flow
105
- }
106
-
107
- const entityRelationRepo =
108
- this.reflectionHelper.getRepoService('EntityRelationData');
109
-
110
- let relationData = await entityRelationRepo.findOne({
111
- where: {
112
- source_entity_type: createdEntity.mapped_entity_type,
113
- target_entity_type: createdEntity.entity_type,
114
- },
115
- });
116
-
117
- if (relationData) {
118
- await entityRelationRepo.save({
119
- organization_id: loggedInUser.organization_id,
120
- enterprise_id: loggedInUser.enterprise_id,
121
- source_entity_id: createdEntity.mapped_entity_id,
122
- source_entity_type: createdEntity.mapped_entity_type,
123
- target_entity_id: createdEntity.id,
124
- target_entity_type: createdEntity.entity_type,
125
- relation_type: relationData?.relation_type,
126
- });
127
- }
128
-
129
- return createdEntity;
130
- }
131
-
132
- async updateEntity(
133
- entityData,
134
- loggedInUser: UserData,
135
- appcode?: string,
136
- ): Promise<any> {
137
- const listRepo = this.reflectionHelper.getRepoService('ListMasterItems');
138
- const taskRepo = this.reflectionHelper.getRepoService('TaskDataEntity');
139
-
140
- const statusRows = await listRepo.find({
141
- where: {
142
- id: entityData.status,
143
- enterprise_id: loggedInUser.enterprise_id,
144
- listtype: 'TKST',
145
- },
146
- take: 1,
147
- });
148
-
149
- const oldRow = await taskRepo.findOne({
150
- where: {
151
- id: entityData.id,
152
- enterprise_id: loggedInUser.enterprise_id,
153
- },
154
- });
155
-
156
- const oldStatusRows = oldRow
157
- ? await listRepo.find({
158
- where: {
159
- id: oldRow.status,
160
- enterprise_id: loggedInUser.enterprise_id,
161
- listtype: 'TKST',
162
- },
163
- take: 1,
164
- })
165
- : [];
166
-
167
- const isStatusChanged =
168
- statusRows.length > 0 &&
169
- oldStatusRows.length > 0 &&
170
- statusRows[0].name !== oldStatusRows[0].name;
171
-
172
- const isCompletedStatus =
173
- statusRows.length > 0 &&
174
- statusRows[0].name?.toLowerCase() === 'completed';
175
-
176
- entityData.is_completed = isCompletedStatus;
177
- entityData.is_done = isCompletedStatus;
178
-
179
- const isMandatory =
180
- String(entityData.is_mandatory).toLowerCase() === 'true' ||
181
- entityData.is_mandatory === true ||
182
- entityData.is_mandatory === 1 ||
183
- entityData.is_mandatory === '1';
184
-
185
- const updatedEntity = await super.updateEntity(
186
- {
187
- ...entityData,
188
- is_mandatory: isMandatory,
189
- },
190
- loggedInUser,
191
- appcode,
192
- );
193
-
194
- // Convert boolean → "1"/"0"
195
- if (updatedEntity && typeof updatedEntity['is_mandatory'] === 'boolean') {
196
- updatedEntity['is_mandatory'] = updatedEntity['is_mandatory'] ? '1' : '0';
197
- }
198
-
199
- // -------------------------------
200
- // Logging Activity
201
- // -------------------------------
202
- try {
203
- if (isCompletedStatus && isStatusChanged) {
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
- } else {
219
- const editLogData = {
220
- mapped_entity_id: updatedEntity.mapped_entity_id,
221
- mapped_entity_type: updatedEntity.mapped_entity_type,
222
- title: `Task edited`,
223
- description: `${updatedEntity.code} was edited`,
224
- category: ACTIVITY_CATEGORIES.TASK,
225
- action: 'edit',
226
- appcode: loggedInUser.appcode,
227
- };
228
-
229
- await this.activityLogService.logActivity(editLogData, loggedInUser);
230
- }
231
- } catch (error) {
232
- console.error(
233
- 'Failed to log activity for task:',
234
- error?.message || error,
235
- );
236
- }
237
-
238
- return updatedEntity;
239
- }
240
-
241
- async getAllTaskByUserIdandStageId(
242
- loggedInUser: UserData,
243
- data,
244
- ): Promise<any> {
245
- const taskData = await this.taskRepository.getAllTaskByUserIdAndStageId({
246
- user_id: data.user_id,
247
- stage_id: data.stage_id,
248
- mapped_entity_type: data.mapped_entity_type,
249
- mapped_entity_id: data.mapped_entity_id,
250
- });
251
-
252
- const grouped: { mandatory: any[]; non_mandatory: any[] } = {
253
- mandatory: [],
254
- non_mandatory: [],
255
- };
256
-
257
- for (const task of taskData) {
258
- if (task && task.is_mandatory) {
259
- grouped.mandatory.push(task);
260
- } else {
261
- grouped.non_mandatory.push(task);
262
- }
263
- }
264
-
265
- return grouped;
266
- }
267
-
268
- async getAllTask(
269
- loggedInUser: UserData,
270
- data: {
271
- mapped_entity_type: string;
272
- mapped_entity_id: number;
273
- status?: string;
274
- mandatory?: boolean;
275
- overdue?: boolean;
276
- },
277
- ): Promise<any[]> {
278
- const { mapped_entity_type, mapped_entity_id, status, mandatory, overdue } =
279
- data;
280
- const taskRepo = this.reflectionHelper.getRepoService('TaskDataEntity');
281
-
282
- const qb = taskRepo
283
- .createQueryBuilder('t')
284
- .select('t.*')
285
- .addSelect('sg.name', 'stage_group_name')
286
- .addSelect('s.name', 'stage_name')
287
- .addSelect('a.name', 'action_name')
288
- .leftJoin('frm_wf_stage', 's', 't.stage_id::text = s.id::text')
289
- .leftJoin('frm_wf_stage_group', 'sg', 's.stage_group_id = sg.id')
290
- .leftJoin('frm_wf_action', 'a', 't.action_id::text = a.id::text')
291
- .where('t.mapped_entity_type = :mapped_entity_type', {
292
- mapped_entity_type,
293
- })
294
- .andWhere('t.mapped_entity_id::text = :mapped_entity_id', {
295
- mapped_entity_id: String(mapped_entity_id),
296
- });
297
-
298
- // ---------------------------
299
- // OPTIONAL FILTERS
300
- // ---------------------------
301
-
302
- if (status) {
303
- qb.andWhere('t.status::text = :status', { status: String(status) });
304
- }
305
-
306
- if (mandatory !== undefined) {
307
- qb.andWhere('t.is_mandatory = :mandatory', {
308
- mandatory: mandatory,
309
- });
310
- }
311
-
312
- if (overdue) {
313
- qb.andWhere(
314
- `
315
- (
316
- t.due_date < CURRENT_DATE
317
- OR (
318
- t.due_date = CURRENT_DATE
319
- AND t.due_time::time < CURRENT_TIME
320
- )
321
- )
322
- `,
323
- ).andWhere('t.is_done = :is_done', { is_done: false });
324
- }
325
-
326
- qb.orderBy('t.created_date', 'DESC');
327
-
328
- const taskData = await qb.getRawMany();
329
-
330
- // ------------------------------------------------
331
- // PROFILE IMAGE LOGIC (same as your code)
332
- // ------------------------------------------------
333
-
334
- if (taskData?.length) {
335
- for (const task of taskData) {
336
- try {
337
- const baseUrl = this.configService.get<string>('REDIRECT_BE_URL');
338
- const queryParams = new URLSearchParams({
339
- loggedInUser: JSON.stringify(loggedInUser),
340
- }).toString();
341
-
342
- const response = await axios.get(
343
- `${baseUrl}/users/profile-image-url/${task.task_owner}?entity_type=USR&${queryParams}`,
344
- { headers: { 'Content-Type': 'application/json' } },
345
- );
346
-
347
- task.created_by_name = response.data.name;
348
- task.task_owner_name = response.data.name;
349
- task.task_owner_profile = response.data.profile_image;
350
- } catch (err) {
351
- console.error('⚠ Error fetching profile:', err.message);
352
- }
353
- }
354
- }
355
-
356
- if (!taskData.length) return [];
357
-
358
- // ------------------------------------------------
359
- // STATUS LOOKUP
360
- // ------------------------------------------------
361
- const listMasterRepo =
362
- this.reflectionHelper.getRepoService('ListMasterItems');
363
-
364
- const statuses = await listMasterRepo.find({
365
- where: {
366
- enterprise_id: loggedInUser.enterprise_id,
367
- listtype: 'TKST',
368
- },
369
- select: ['id', 'name'],
370
- });
371
-
372
- const statusMap = new Map(
373
- statuses.map((row) => [String(row.id), row.name]),
374
- );
375
-
376
- return taskData.map((task) => ({
377
- ...task,
378
- task_status: statusMap.get(String(task.status)) || null,
379
- action_name:
380
- task.action_id === '0' || task.action_id === 0
381
- ? 'Generic'
382
- : task.action_name,
383
- is_mandatory: task.is_mandatory,
384
- }));
385
- }
386
-
387
- async getEntityData(entityType: string, id: number, loggedInUser: any) {
388
- const taskData = await super.getEntityData(entityType, id, loggedInUser);
389
-
390
- if (taskData?.due_date) {
391
- taskData.due_date = moment(taskData.due_date)
392
- .local() // convert from UTC to local
393
- .format('YYYY-MM-DD'); // return just the date string
394
- }
395
-
396
- if (taskData?.reminder_date) {
397
- taskData.reminder_date = moment(taskData.reminder_date)
398
- .local()
399
- .format('YYYY-MM-DD');
400
- }
401
-
402
- return taskData;
403
- }
404
-
405
- async saveActionData(
406
- action: any,
407
- loggedInUser: UserData,
408
- mapped_entity_id: number,
409
- mapped_entity_type: string,
410
- ): Promise<any> {
411
- await this.taskRepository.saveActionDataInTask(
412
- action,
413
- loggedInUser,
414
- mapped_entity_id,
415
- mapped_entity_type,
416
- );
417
- }
418
-
419
- async moveTask(
420
- loggedInUser: UserData,
421
- body: {
422
- mapped_entity_type: string;
423
- mapped_entity_id: number;
424
- stage_id: number;
425
- action_id: number;
426
- reason_code?: string | number;
427
- remark?: string;
428
- stage_group_id?: number;
429
- },
430
- ): Promise<any> {
431
- // Logic to move task based on the provided body parameters
432
- // This could involve updating the task's stage, action, etc.
433
-
434
- // update task status
435
- await this.taskRepository.updateTaskStatus(
436
- loggedInUser,
437
- body.mapped_entity_type,
438
- body.mapped_entity_id,
439
- body.stage_id,
440
- body.action_id,
441
- );
442
-
443
- // update action status
444
- await this.actionDataService.updateActionStatus(
445
- loggedInUser,
446
- body.mapped_entity_type,
447
- body.mapped_entity_id,
448
- body.stage_id,
449
- body.action_id,
450
- );
451
-
452
- if (body.reason_code || body.remark) {
453
- await this.createSystemNote(
454
- {
455
- reason_code: body.reason_code!,
456
- remark: body.remark || '',
457
- mapped_entity_id: body.mapped_entity_id,
458
- stage_id: body.stage_id,
459
- action_id: body.action_id,
460
- stage_group_id: body.stage_group_id,
461
- },
462
- loggedInUser,
463
- );
464
- }
465
-
466
- return 'Task moved successfully';
467
- }
468
-
469
- async deleteEntity(
470
- entity_type: string,
471
- taskId: number,
472
- loggedInUser: UserData,
473
- ): Promise<any> {
474
- // Fetch the task before deleting
475
- const task: any = await super.getEntityData(
476
- entity_type,
477
- taskId,
478
- loggedInUser,
479
- );
480
-
481
- if (!task) {
482
- throw new Error('Task not found');
483
- }
484
-
485
- // Check if the task is system-generated
486
- if (task.is_system) {
487
- throw new Error('Cannot delete system-generated tasks');
488
- }
489
-
490
- // Perform the deletion
491
- await super.deleteEntity(entity_type, taskId, loggedInUser);
492
-
493
- // Try to log the delete activity
494
- try {
495
- const logData = {
496
- mapped_entity_id: task.mapped_entity_id,
497
- mapped_entity_type: task.mapped_entity_type,
498
- title: `Task deleted`,
499
- description: `${task.name} was deleted`,
500
- category: ACTIVITY_CATEGORIES.TASK,
501
- action: 'delete',
502
- appcode: loggedInUser.appcode,
503
- };
504
-
505
- await this.activityLogService.logActivity(logData, loggedInUser);
506
- } catch (error) {
507
- console.error(
508
- 'Failed to log activity for task deletion:',
509
- error?.message || error,
510
- );
511
- }
512
-
513
- return { message: 'Task deleted successfully' };
514
- }
515
-
516
- async createSystemNote(
517
- entity: {
518
- reason_code: string | number;
519
- remark: string;
520
- mapped_entity_id: number;
521
- stage_id: number;
522
- action_id: number;
523
- stage_group_id?: number;
524
- },
525
- loggedInUser: any,
526
- ) {
527
- if (!entity || !entity.mapped_entity_id || !entity.reason_code) return null;
528
- const listMasterItemRepo =
529
- this.reflectionHelper.getRepoService('ListMasterItems');
530
- const reason = await listMasterItemRepo.findOne({
531
- where: {
532
- id: entity.reason_code,
533
- enterprise_id: loggedInUser.enterprise_id,
534
- },
535
- });
536
-
537
- const notePayload = {
538
- note_title: reason ? reason.name : entity.reason_code,
539
- note: entity.remark,
540
- is_system: true,
541
- mapped_entity_type: 'LEAD',
542
- entity_type: 'NOTE',
543
- mapped_entity_id: entity.mapped_entity_id,
544
- stage_id: entity.stage_id,
545
- action_id: entity.action_id,
546
- stage_group_id: entity.stage_group_id,
547
- } as any;
548
-
549
- return await super.createEntity(notePayload, loggedInUser);
550
- }
551
- }
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 { ActionHandler } from 'src/module/workflow-automation/interface/action.decorator';
10
+ import * as moment from 'moment';
11
+ import { ConfigService } from '@nestjs/config';
12
+ import axios from 'axios';
13
+
14
+ @Injectable()
15
+ @ActionHandler('add_task')
16
+ export class TaskService extends EntityServiceImpl {
17
+ constructor(
18
+ private readonly taskRepository: TaskRepository,
19
+ private readonly actionDataService: ActionDataService,
20
+ @Inject('ActivityLogService')
21
+ private readonly activityLogService: ActivityLogService,
22
+ private readonly configService: ConfigService,
23
+ ) {
24
+ super();
25
+ }
26
+
27
+ name: string = 'add_task';
28
+
29
+ async execute(payload: any): Promise<any> {
30
+ let { entity, user, config } = payload;
31
+
32
+ const { organization_id, level_id, level_type } = entity;
33
+
34
+ if (entity.entity_type !== 'LEAD') {
35
+ entity = await this.getEntityData('LEAD', entity.parent_id, user);
36
+ }
37
+
38
+ // 3. Build entityData
39
+ const entityData = {
40
+ mapped_entity_id: entity.id,
41
+ mapped_entity_type: entity.entity_type,
42
+ task_owner: entity.lead_owner,
43
+ stage_id: entity.stageId,
44
+ status: config.status,
45
+ due_date: Date.now() + 2,
46
+ due_time: Date.now(),
47
+ description: config.description,
48
+ is_mandatory: config.is_mandatory,
49
+ name: config.name,
50
+ entity_type: 'TASK',
51
+ };
52
+
53
+ return await this.createEntity(entityData, user);
54
+ }
55
+
56
+ async createEntity(
57
+ entityData: any,
58
+ loggedInUser: any,
59
+ manager?: EntityManager | null,
60
+ appcode?: string,
61
+ ): Promise<any> {
62
+ if (entityData && typeof entityData['is_mandatory'] === 'string') {
63
+ entityData['is_mandatory'] = entityData['is_mandatory'] === '1';
64
+ }
65
+
66
+ // handling the date string for due_date and reminder_date
67
+ if (entityData?.due_date) {
68
+ // Interpret input 'YYYY-MM-DD' as local midnight (IST)
69
+ entityData.due_date = moment(entityData.due_date, 'YYYY-MM-DD')
70
+ .startOf('day') // 00:00 local time
71
+ .toDate(); // Convert to JS Date object for TypeORM
72
+ }
73
+
74
+ if (entityData?.reminder_date) {
75
+ entityData.reminder_date = moment(entityData.reminder_date, 'YYYY-MM-DD')
76
+ .startOf('day')
77
+ .toDate();
78
+ }
79
+
80
+ const createdEntity = await super.createEntity(
81
+ entityData,
82
+ loggedInUser,
83
+ manager,
84
+ appcode,
85
+ );
86
+
87
+ try {
88
+ const logData = {
89
+ mapped_entity_id: createdEntity.mapped_entity_id,
90
+ mapped_entity_type: createdEntity.mapped_entity_type,
91
+ title: `Task added`,
92
+ description: `A new task ${createdEntity.name} was added`,
93
+ category: ACTIVITY_CATEGORIES.TASK,
94
+ action: 'add',
95
+ appcode: loggedInUser.appcode,
96
+ };
97
+
98
+ await this.activityLogService.logActivity(logData, loggedInUser);
99
+ } catch (error) {
100
+ console.error(
101
+ 'Failed to log activity for meeting:',
102
+ error?.message || error,
103
+ );
104
+ // Logging should not block main flow
105
+ }
106
+
107
+ const entityRelationRepo =
108
+ this.reflectionHelper.getRepoService('EntityRelationData');
109
+
110
+ let relationData = await entityRelationRepo.findOne({
111
+ where: {
112
+ source_entity_type: createdEntity.mapped_entity_type,
113
+ target_entity_type: createdEntity.entity_type,
114
+ },
115
+ });
116
+
117
+ if (relationData) {
118
+ await entityRelationRepo.save({
119
+ organization_id: loggedInUser.organization_id,
120
+ enterprise_id: loggedInUser.enterprise_id,
121
+ source_entity_id: createdEntity.mapped_entity_id,
122
+ source_entity_type: createdEntity.mapped_entity_type,
123
+ target_entity_id: createdEntity.id,
124
+ target_entity_type: createdEntity.entity_type,
125
+ relation_type: relationData?.relation_type,
126
+ });
127
+ }
128
+
129
+ return createdEntity;
130
+ }
131
+
132
+ async updateEntity(
133
+ entityData,
134
+ loggedInUser: UserData,
135
+ appcode?: string,
136
+ ): Promise<any> {
137
+ const listRepo = this.reflectionHelper.getRepoService('ListMasterItems');
138
+ const taskRepo = this.reflectionHelper.getRepoService('TaskDataEntity');
139
+
140
+ const statusRows = await listRepo.find({
141
+ where: {
142
+ id: entityData.status,
143
+ enterprise_id: loggedInUser.enterprise_id,
144
+ listtype: 'TKST',
145
+ },
146
+ take: 1,
147
+ });
148
+
149
+ const oldRow = await taskRepo.findOne({
150
+ where: {
151
+ id: entityData.id,
152
+ enterprise_id: loggedInUser.enterprise_id,
153
+ },
154
+ });
155
+
156
+ const oldStatusRows = oldRow
157
+ ? await listRepo.find({
158
+ where: {
159
+ id: oldRow.status,
160
+ enterprise_id: loggedInUser.enterprise_id,
161
+ listtype: 'TKST',
162
+ },
163
+ take: 1,
164
+ })
165
+ : [];
166
+
167
+ const isStatusChanged =
168
+ statusRows.length > 0 &&
169
+ oldStatusRows.length > 0 &&
170
+ statusRows[0].name !== oldStatusRows[0].name;
171
+
172
+ const isCompletedStatus =
173
+ statusRows.length > 0 &&
174
+ statusRows[0].name?.toLowerCase() === 'completed';
175
+
176
+ entityData.is_completed = isCompletedStatus;
177
+ entityData.is_done = isCompletedStatus;
178
+
179
+ const isMandatory =
180
+ String(entityData.is_mandatory).toLowerCase() === 'true' ||
181
+ entityData.is_mandatory === true ||
182
+ entityData.is_mandatory === 1 ||
183
+ entityData.is_mandatory === '1';
184
+
185
+ const updatedEntity = await super.updateEntity(
186
+ {
187
+ ...entityData,
188
+ is_mandatory: isMandatory,
189
+ },
190
+ loggedInUser,
191
+ appcode,
192
+ );
193
+
194
+ // Convert boolean → "1"/"0"
195
+ if (updatedEntity && typeof updatedEntity['is_mandatory'] === 'boolean') {
196
+ updatedEntity['is_mandatory'] = updatedEntity['is_mandatory'] ? '1' : '0';
197
+ }
198
+
199
+ // -------------------------------
200
+ // Logging Activity
201
+ // -------------------------------
202
+ try {
203
+ if (isCompletedStatus && isStatusChanged) {
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
+ } else {
219
+ const editLogData = {
220
+ mapped_entity_id: updatedEntity.mapped_entity_id,
221
+ mapped_entity_type: updatedEntity.mapped_entity_type,
222
+ title: `Task edited`,
223
+ description: `${updatedEntity.code} was edited`,
224
+ category: ACTIVITY_CATEGORIES.TASK,
225
+ action: 'edit',
226
+ appcode: loggedInUser.appcode,
227
+ };
228
+
229
+ await this.activityLogService.logActivity(editLogData, loggedInUser);
230
+ }
231
+ } catch (error) {
232
+ console.error(
233
+ 'Failed to log activity for task:',
234
+ error?.message || error,
235
+ );
236
+ }
237
+
238
+ return updatedEntity;
239
+ }
240
+
241
+ async getAllTaskByUserIdandStageId(
242
+ loggedInUser: UserData,
243
+ data,
244
+ ): Promise<any> {
245
+ const taskData = await this.taskRepository.getAllTaskByUserIdAndStageId({
246
+ user_id: data.user_id,
247
+ stage_id: data.stage_id,
248
+ mapped_entity_type: data.mapped_entity_type,
249
+ mapped_entity_id: data.mapped_entity_id,
250
+ });
251
+
252
+ const grouped: { mandatory: any[]; non_mandatory: any[] } = {
253
+ mandatory: [],
254
+ non_mandatory: [],
255
+ };
256
+
257
+ for (const task of taskData) {
258
+ if (task && task.is_mandatory) {
259
+ grouped.mandatory.push(task);
260
+ } else {
261
+ grouped.non_mandatory.push(task);
262
+ }
263
+ }
264
+
265
+ return grouped;
266
+ }
267
+
268
+ async getAllTask(
269
+ loggedInUser: UserData,
270
+ data: {
271
+ mapped_entity_type: string;
272
+ mapped_entity_id: number;
273
+ status?: string;
274
+ mandatory?: boolean;
275
+ overdue?: boolean;
276
+ },
277
+ ): Promise<any[]> {
278
+ const { mapped_entity_type, mapped_entity_id, status, mandatory, overdue } =
279
+ data;
280
+ const taskRepo = this.reflectionHelper.getRepoService('TaskDataEntity');
281
+
282
+ const qb = taskRepo
283
+ .createQueryBuilder('t')
284
+ .select('t.*')
285
+ .addSelect('sg.name', 'stage_group_name')
286
+ .addSelect('s.name', 'stage_name')
287
+ .addSelect('a.name', 'action_name')
288
+ .leftJoin('frm_wf_stage', 's', 't.stage_id::text = s.id::text')
289
+ .leftJoin('frm_wf_stage_group', 'sg', 's.stage_group_id = sg.id')
290
+ .leftJoin('frm_wf_action', 'a', 't.action_id::text = a.id::text')
291
+ .where('t.mapped_entity_type = :mapped_entity_type', {
292
+ mapped_entity_type,
293
+ })
294
+ .andWhere('t.mapped_entity_id::text = :mapped_entity_id', {
295
+ mapped_entity_id: String(mapped_entity_id),
296
+ });
297
+
298
+ // ---------------------------
299
+ // OPTIONAL FILTERS
300
+ // ---------------------------
301
+
302
+ if (status) {
303
+ qb.andWhere('t.status::text = :status', { status: String(status) });
304
+ }
305
+
306
+ if (mandatory !== undefined) {
307
+ qb.andWhere('t.is_mandatory = :mandatory', {
308
+ mandatory: mandatory,
309
+ });
310
+ }
311
+
312
+ if (overdue) {
313
+ qb.andWhere(
314
+ `
315
+ (
316
+ t.due_date < CURRENT_DATE
317
+ OR (
318
+ t.due_date = CURRENT_DATE
319
+ AND t.due_time::time < CURRENT_TIME
320
+ )
321
+ )
322
+ `,
323
+ ).andWhere('t.is_done = :is_done', { is_done: false });
324
+ }
325
+
326
+ qb.orderBy('t.created_date', 'DESC');
327
+
328
+ const taskData = await qb.getRawMany();
329
+
330
+ // ------------------------------------------------
331
+ // PROFILE IMAGE LOGIC (same as your code)
332
+ // ------------------------------------------------
333
+
334
+ if (taskData?.length) {
335
+ for (const task of taskData) {
336
+ try {
337
+ const baseUrl = this.configService.get<string>('REDIRECT_BE_URL');
338
+ const queryParams = new URLSearchParams({
339
+ loggedInUser: JSON.stringify(loggedInUser),
340
+ }).toString();
341
+
342
+ const response = await axios.get(
343
+ `${baseUrl}/users/profile-image-url/${task.task_owner}?entity_type=USR&${queryParams}`,
344
+ { headers: { 'Content-Type': 'application/json' } },
345
+ );
346
+
347
+ task.created_by_name = response.data.name;
348
+ task.task_owner_name = response.data.name;
349
+ task.task_owner_profile = response.data.profile_image;
350
+ } catch (err) {
351
+ console.error('⚠ Error fetching profile:', err.message);
352
+ }
353
+ }
354
+ }
355
+
356
+ if (!taskData.length) return [];
357
+
358
+ // ------------------------------------------------
359
+ // STATUS LOOKUP
360
+ // ------------------------------------------------
361
+ const listMasterRepo =
362
+ this.reflectionHelper.getRepoService('ListMasterItems');
363
+
364
+ const statuses = await listMasterRepo.find({
365
+ where: {
366
+ enterprise_id: loggedInUser.enterprise_id,
367
+ listtype: 'TKST',
368
+ },
369
+ select: ['id', 'name'],
370
+ });
371
+
372
+ const statusMap = new Map(
373
+ statuses.map((row) => [String(row.id), row.name]),
374
+ );
375
+
376
+ return taskData.map((task) => ({
377
+ ...task,
378
+ task_status: statusMap.get(String(task.status)) || null,
379
+ action_name:
380
+ task.action_id === '0' || task.action_id === 0
381
+ ? 'Generic'
382
+ : task.action_name,
383
+ is_mandatory: task.is_mandatory,
384
+ }));
385
+ }
386
+
387
+ async getEntityData(entityType: string, id: number, loggedInUser: any) {
388
+ const taskData = await super.getEntityData(entityType, id, loggedInUser);
389
+
390
+ if (taskData?.due_date) {
391
+ taskData.due_date = moment(taskData.due_date)
392
+ .local() // convert from UTC to local
393
+ .format('YYYY-MM-DD'); // return just the date string
394
+ }
395
+
396
+ if (taskData?.reminder_date) {
397
+ taskData.reminder_date = moment(taskData.reminder_date)
398
+ .local()
399
+ .format('YYYY-MM-DD');
400
+ }
401
+
402
+ return taskData;
403
+ }
404
+
405
+ async saveActionData(
406
+ action: any,
407
+ loggedInUser: UserData,
408
+ mapped_entity_id: number,
409
+ mapped_entity_type: string,
410
+ ): Promise<any> {
411
+ await this.taskRepository.saveActionDataInTask(
412
+ action,
413
+ loggedInUser,
414
+ mapped_entity_id,
415
+ mapped_entity_type,
416
+ );
417
+ }
418
+
419
+ async moveTask(
420
+ loggedInUser: UserData,
421
+ body: {
422
+ mapped_entity_type: string;
423
+ mapped_entity_id: number;
424
+ stage_id: number;
425
+ action_id: number;
426
+ reason_code?: string | number;
427
+ remark?: string;
428
+ stage_group_id?: number;
429
+ },
430
+ ): Promise<any> {
431
+ // Logic to move task based on the provided body parameters
432
+ // This could involve updating the task's stage, action, etc.
433
+
434
+ // update task status
435
+ await this.taskRepository.updateTaskStatus(
436
+ loggedInUser,
437
+ body.mapped_entity_type,
438
+ body.mapped_entity_id,
439
+ body.stage_id,
440
+ body.action_id,
441
+ );
442
+
443
+ // update action status
444
+ await this.actionDataService.updateActionStatus(
445
+ loggedInUser,
446
+ body.mapped_entity_type,
447
+ body.mapped_entity_id,
448
+ body.stage_id,
449
+ body.action_id,
450
+ );
451
+
452
+ if (body.reason_code || body.remark) {
453
+ await this.createSystemNote(
454
+ {
455
+ reason_code: body.reason_code!,
456
+ remark: body.remark || '',
457
+ mapped_entity_id: body.mapped_entity_id,
458
+ stage_id: body.stage_id,
459
+ action_id: body.action_id,
460
+ stage_group_id: body.stage_group_id,
461
+ },
462
+ loggedInUser,
463
+ );
464
+ }
465
+
466
+ return 'Task moved successfully';
467
+ }
468
+
469
+ async deleteEntity(
470
+ entity_type: string,
471
+ taskId: number,
472
+ loggedInUser: UserData,
473
+ ): Promise<any> {
474
+ // Fetch the task before deleting
475
+ const task: any = await super.getEntityData(
476
+ entity_type,
477
+ taskId,
478
+ loggedInUser,
479
+ );
480
+
481
+ if (!task) {
482
+ throw new Error('Task not found');
483
+ }
484
+
485
+ // Check if the task is system-generated
486
+ if (task.is_system) {
487
+ throw new Error('Cannot delete system-generated tasks');
488
+ }
489
+
490
+ // Perform the deletion
491
+ await super.deleteEntity(entity_type, taskId, loggedInUser);
492
+
493
+ // Try to log the delete activity
494
+ try {
495
+ const logData = {
496
+ mapped_entity_id: task.mapped_entity_id,
497
+ mapped_entity_type: task.mapped_entity_type,
498
+ title: `Task deleted`,
499
+ description: `${task.name} was deleted`,
500
+ category: ACTIVITY_CATEGORIES.TASK,
501
+ action: 'delete',
502
+ appcode: loggedInUser.appcode,
503
+ };
504
+
505
+ await this.activityLogService.logActivity(logData, loggedInUser);
506
+ } catch (error) {
507
+ console.error(
508
+ 'Failed to log activity for task deletion:',
509
+ error?.message || error,
510
+ );
511
+ }
512
+
513
+ return { message: 'Task deleted successfully' };
514
+ }
515
+
516
+ async createSystemNote(
517
+ entity: {
518
+ reason_code: string | number;
519
+ remark: string;
520
+ mapped_entity_id: number;
521
+ stage_id: number;
522
+ action_id: number;
523
+ stage_group_id?: number;
524
+ },
525
+ loggedInUser: any,
526
+ ) {
527
+ if (!entity || !entity.mapped_entity_id || !entity.reason_code) return null;
528
+ const listMasterItemRepo =
529
+ this.reflectionHelper.getRepoService('ListMasterItems');
530
+ const reason = await listMasterItemRepo.findOne({
531
+ where: {
532
+ id: entity.reason_code,
533
+ enterprise_id: loggedInUser.enterprise_id,
534
+ },
535
+ });
536
+
537
+ const notePayload = {
538
+ note_title: reason ? reason.name : entity.reason_code,
539
+ note: entity.remark,
540
+ is_system: true,
541
+ mapped_entity_type: 'LEAD',
542
+ entity_type: 'NOTE',
543
+ mapped_entity_id: entity.mapped_entity_id,
544
+ stage_id: entity.stage_id,
545
+ action_id: entity.action_id,
546
+ stage_group_id: entity.stage_group_id,
547
+ } as any;
548
+
549
+ return await super.createEntity(notePayload, loggedInUser);
550
+ }
551
+ }