rez_core 7.1.1 → 7.1.3

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