@things-factory/operato-pms 6.2.101 → 6.2.102

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 (456) hide show
  1. package/package.json +5 -5
  2. package/dist-server/constants/block.js +0 -8
  3. package/dist-server/constants/block.js.map +0 -1
  4. package/dist-server/constants/index.js +0 -12
  5. package/dist-server/constants/index.js.map +0 -1
  6. package/dist-server/constants/inventory.js +0 -12
  7. package/dist-server/constants/inventory.js.map +0 -1
  8. package/dist-server/constants/master.js +0 -12
  9. package/dist-server/constants/master.js.map +0 -1
  10. package/dist-server/constants/organization.js +0 -9
  11. package/dist-server/constants/organization.js.map +0 -1
  12. package/dist-server/constants/ramp.js +0 -12
  13. package/dist-server/constants/ramp.js.map +0 -1
  14. package/dist-server/constants/record.js +0 -8
  15. package/dist-server/constants/record.js.map +0 -1
  16. package/dist-server/constants/template.js +0 -7
  17. package/dist-server/constants/template.js.map +0 -1
  18. package/dist-server/constants/transaction.js +0 -13
  19. package/dist-server/constants/transaction.js.map +0 -1
  20. package/dist-server/controllers/index.js +0 -5
  21. package/dist-server/controllers/index.js.map +0 -1
  22. package/dist-server/controllers/render-dispatchment.js +0 -51
  23. package/dist-server/controllers/render-dispatchment.js.map +0 -1
  24. package/dist-server/entities/block-detail.js +0 -82
  25. package/dist-server/entities/block-detail.js.map +0 -1
  26. package/dist-server/entities/block.js +0 -70
  27. package/dist-server/entities/block.js.map +0 -1
  28. package/dist-server/entities/daily-block-detail.js +0 -70
  29. package/dist-server/entities/daily-block-detail.js.map +0 -1
  30. package/dist-server/entities/daily-dispatch-detail.js +0 -84
  31. package/dist-server/entities/daily-dispatch-detail.js.map +0 -1
  32. package/dist-server/entities/daily-dispatch.js +0 -108
  33. package/dist-server/entities/daily-dispatch.js.map +0 -1
  34. package/dist-server/entities/daily-harvest-detail.js +0 -72
  35. package/dist-server/entities/daily-harvest-detail.js.map +0 -1
  36. package/dist-server/entities/daily-harvest.js +0 -108
  37. package/dist-server/entities/daily-harvest.js.map +0 -1
  38. package/dist-server/entities/daily-loading-detail.js +0 -86
  39. package/dist-server/entities/daily-loading-detail.js.map +0 -1
  40. package/dist-server/entities/daily-loading-ramp.js +0 -70
  41. package/dist-server/entities/daily-loading-ramp.js.map +0 -1
  42. package/dist-server/entities/daily-loading.js +0 -82
  43. package/dist-server/entities/daily-loading.js.map +0 -1
  44. package/dist-server/entities/index.js +0 -57
  45. package/dist-server/entities/index.js.map +0 -1
  46. package/dist-server/entities/organization-staff.js +0 -76
  47. package/dist-server/entities/organization-staff.js.map +0 -1
  48. package/dist-server/entities/organization.js +0 -61
  49. package/dist-server/entities/organization.js.map +0 -1
  50. package/dist-server/entities/plantation-inventory.js +0 -72
  51. package/dist-server/entities/plantation-inventory.js.map +0 -1
  52. package/dist-server/entities/plantation-setting.js +0 -67
  53. package/dist-server/entities/plantation-setting.js.map +0 -1
  54. package/dist-server/entities/ramp.js +0 -66
  55. package/dist-server/entities/ramp.js.map +0 -1
  56. package/dist-server/entities/record-transaction.js +0 -99
  57. package/dist-server/entities/record-transaction.js.map +0 -1
  58. package/dist-server/entities/truck.js +0 -68
  59. package/dist-server/entities/truck.js.map +0 -1
  60. package/dist-server/graphql/index.js +0 -12
  61. package/dist-server/graphql/index.js.map +0 -1
  62. package/dist-server/graphql/resolvers/block/block-query.js +0 -33
  63. package/dist-server/graphql/resolvers/block/block-query.js.map +0 -1
  64. package/dist-server/graphql/resolvers/block/delete-blocks.js +0 -32
  65. package/dist-server/graphql/resolvers/block/delete-blocks.js.map +0 -1
  66. package/dist-server/graphql/resolvers/block/index.js +0 -11
  67. package/dist-server/graphql/resolvers/block/index.js.map +0 -1
  68. package/dist-server/graphql/resolvers/block/update-multiple-block.js +0 -47
  69. package/dist-server/graphql/resolvers/block/update-multiple-block.js.map +0 -1
  70. package/dist-server/graphql/resolvers/block-detail/block-detail-query.js +0 -45
  71. package/dist-server/graphql/resolvers/block-detail/block-detail-query.js.map +0 -1
  72. package/dist-server/graphql/resolvers/block-detail/delete-block-details.js +0 -18
  73. package/dist-server/graphql/resolvers/block-detail/delete-block-details.js.map +0 -1
  74. package/dist-server/graphql/resolvers/block-detail/index.js +0 -12
  75. package/dist-server/graphql/resolvers/block-detail/index.js.map +0 -1
  76. package/dist-server/graphql/resolvers/block-detail/update-multiple-block-detail.js +0 -39
  77. package/dist-server/graphql/resolvers/block-detail/update-multiple-block-detail.js.map +0 -1
  78. package/dist-server/graphql/resolvers/daily-block-detail/create-daily-block-detail.js +0 -11
  79. package/dist-server/graphql/resolvers/daily-block-detail/create-daily-block-detail.js.map +0 -1
  80. package/dist-server/graphql/resolvers/daily-block-detail/daily-block-detail-query.js +0 -33
  81. package/dist-server/graphql/resolvers/daily-block-detail/daily-block-detail-query.js.map +0 -1
  82. package/dist-server/graphql/resolvers/daily-block-detail/delete-daily-block-detail.js +0 -12
  83. package/dist-server/graphql/resolvers/daily-block-detail/delete-daily-block-detail.js.map +0 -1
  84. package/dist-server/graphql/resolvers/daily-block-detail/delete-daily-block-details.js +0 -16
  85. package/dist-server/graphql/resolvers/daily-block-detail/delete-daily-block-details.js.map +0 -1
  86. package/dist-server/graphql/resolvers/daily-block-detail/index.js +0 -14
  87. package/dist-server/graphql/resolvers/daily-block-detail/index.js.map +0 -1
  88. package/dist-server/graphql/resolvers/daily-block-detail/update-daily-block-detail.js +0 -14
  89. package/dist-server/graphql/resolvers/daily-block-detail/update-daily-block-detail.js.map +0 -1
  90. package/dist-server/graphql/resolvers/daily-block-detail/update-multiple-daily-block-detail.js +0 -30
  91. package/dist-server/graphql/resolvers/daily-block-detail/update-multiple-daily-block-detail.js.map +0 -1
  92. package/dist-server/graphql/resolvers/daily-dispatch/daily-dispatch-query.js +0 -45
  93. package/dist-server/graphql/resolvers/daily-dispatch/daily-dispatch-query.js.map +0 -1
  94. package/dist-server/graphql/resolvers/daily-dispatch/delete-daily-dispatch.js +0 -26
  95. package/dist-server/graphql/resolvers/daily-dispatch/delete-daily-dispatch.js.map +0 -1
  96. package/dist-server/graphql/resolvers/daily-dispatch/generate-daily-dispatch.js +0 -75
  97. package/dist-server/graphql/resolvers/daily-dispatch/generate-daily-dispatch.js.map +0 -1
  98. package/dist-server/graphql/resolvers/daily-dispatch/index.js +0 -12
  99. package/dist-server/graphql/resolvers/daily-dispatch/index.js.map +0 -1
  100. package/dist-server/graphql/resolvers/daily-dispatch/update-daily-dispatch.js +0 -23
  101. package/dist-server/graphql/resolvers/daily-dispatch/update-daily-dispatch.js.map +0 -1
  102. package/dist-server/graphql/resolvers/daily-dispatch-detail/daily-dispatch-detail-query.js +0 -34
  103. package/dist-server/graphql/resolvers/daily-dispatch-detail/daily-dispatch-detail-query.js.map +0 -1
  104. package/dist-server/graphql/resolvers/daily-dispatch-detail/index.js +0 -9
  105. package/dist-server/graphql/resolvers/daily-dispatch-detail/index.js.map +0 -1
  106. package/dist-server/graphql/resolvers/daily-harvest/daily-harvest-query.js +0 -44
  107. package/dist-server/graphql/resolvers/daily-harvest/daily-harvest-query.js.map +0 -1
  108. package/dist-server/graphql/resolvers/daily-harvest/delete-daily-harvest.js +0 -40
  109. package/dist-server/graphql/resolvers/daily-harvest/delete-daily-harvest.js.map +0 -1
  110. package/dist-server/graphql/resolvers/daily-harvest/generate-daily-harvest.js +0 -102
  111. package/dist-server/graphql/resolvers/daily-harvest/generate-daily-harvest.js.map +0 -1
  112. package/dist-server/graphql/resolvers/daily-harvest/index.js +0 -12
  113. package/dist-server/graphql/resolvers/daily-harvest/index.js.map +0 -1
  114. package/dist-server/graphql/resolvers/daily-harvest/update-daily-harvest.js +0 -98
  115. package/dist-server/graphql/resolvers/daily-harvest/update-daily-harvest.js.map +0 -1
  116. package/dist-server/graphql/resolvers/daily-harvest-detail/daily-harvest-detail-query.js +0 -32
  117. package/dist-server/graphql/resolvers/daily-harvest-detail/daily-harvest-detail-query.js.map +0 -1
  118. package/dist-server/graphql/resolvers/daily-harvest-detail/index.js +0 -9
  119. package/dist-server/graphql/resolvers/daily-harvest-detail/index.js.map +0 -1
  120. package/dist-server/graphql/resolvers/daily-loading/daily-loading-query.js +0 -40
  121. package/dist-server/graphql/resolvers/daily-loading/daily-loading-query.js.map +0 -1
  122. package/dist-server/graphql/resolvers/daily-loading/delete-daily-loading.js +0 -30
  123. package/dist-server/graphql/resolvers/daily-loading/delete-daily-loading.js.map +0 -1
  124. package/dist-server/graphql/resolvers/daily-loading/generate-daily-loading.js +0 -77
  125. package/dist-server/graphql/resolvers/daily-loading/generate-daily-loading.js.map +0 -1
  126. package/dist-server/graphql/resolvers/daily-loading/index.js +0 -12
  127. package/dist-server/graphql/resolvers/daily-loading/index.js.map +0 -1
  128. package/dist-server/graphql/resolvers/daily-loading/update-daily-loading.js +0 -92
  129. package/dist-server/graphql/resolvers/daily-loading/update-daily-loading.js.map +0 -1
  130. package/dist-server/graphql/resolvers/daily-loading-detail/daily-loading-detail-query.js +0 -32
  131. package/dist-server/graphql/resolvers/daily-loading-detail/daily-loading-detail-query.js.map +0 -1
  132. package/dist-server/graphql/resolvers/daily-loading-detail/index.js +0 -9
  133. package/dist-server/graphql/resolvers/daily-loading-detail/index.js.map +0 -1
  134. package/dist-server/graphql/resolvers/daily-loading-ramp/daily-loading-ramp-query.js +0 -29
  135. package/dist-server/graphql/resolvers/daily-loading-ramp/daily-loading-ramp-query.js.map +0 -1
  136. package/dist-server/graphql/resolvers/daily-loading-ramp/delete-daily-loading-ramp.js +0 -12
  137. package/dist-server/graphql/resolvers/daily-loading-ramp/delete-daily-loading-ramp.js.map +0 -1
  138. package/dist-server/graphql/resolvers/daily-loading-ramp/index.js +0 -11
  139. package/dist-server/graphql/resolvers/daily-loading-ramp/index.js.map +0 -1
  140. package/dist-server/graphql/resolvers/daily-loading-ramp/update-daily-loading-ramp.js +0 -15
  141. package/dist-server/graphql/resolvers/daily-loading-ramp/update-daily-loading-ramp.js.map +0 -1
  142. package/dist-server/graphql/resolvers/dashboard/dashboard-query.js +0 -198
  143. package/dist-server/graphql/resolvers/dashboard/dashboard-query.js.map +0 -1
  144. package/dist-server/graphql/resolvers/dashboard/index.js +0 -8
  145. package/dist-server/graphql/resolvers/dashboard/index.js.map +0 -1
  146. package/dist-server/graphql/resolvers/index.js +0 -23
  147. package/dist-server/graphql/resolvers/index.js.map +0 -1
  148. package/dist-server/graphql/resolvers/organization/delete-organizations.js +0 -32
  149. package/dist-server/graphql/resolvers/organization/delete-organizations.js.map +0 -1
  150. package/dist-server/graphql/resolvers/organization/index.js +0 -11
  151. package/dist-server/graphql/resolvers/organization/index.js.map +0 -1
  152. package/dist-server/graphql/resolvers/organization/organization-query.js +0 -32
  153. package/dist-server/graphql/resolvers/organization/organization-query.js.map +0 -1
  154. package/dist-server/graphql/resolvers/organization/update-multiple-organization.js +0 -33
  155. package/dist-server/graphql/resolvers/organization/update-multiple-organization.js.map +0 -1
  156. package/dist-server/graphql/resolvers/organization-staff/delete-organization-staffs.js +0 -18
  157. package/dist-server/graphql/resolvers/organization-staff/delete-organization-staffs.js.map +0 -1
  158. package/dist-server/graphql/resolvers/organization-staff/index.js +0 -11
  159. package/dist-server/graphql/resolvers/organization-staff/index.js.map +0 -1
  160. package/dist-server/graphql/resolvers/organization-staff/organization-staff-query.js +0 -37
  161. package/dist-server/graphql/resolvers/organization-staff/organization-staff-query.js.map +0 -1
  162. package/dist-server/graphql/resolvers/organization-staff/update-multiple-organization-staff.js +0 -44
  163. package/dist-server/graphql/resolvers/organization-staff/update-multiple-organization-staff.js.map +0 -1
  164. package/dist-server/graphql/resolvers/plantation-inventory/index.js +0 -9
  165. package/dist-server/graphql/resolvers/plantation-inventory/index.js.map +0 -1
  166. package/dist-server/graphql/resolvers/plantation-inventory/plantation-inventory-query.js +0 -35
  167. package/dist-server/graphql/resolvers/plantation-inventory/plantation-inventory-query.js.map +0 -1
  168. package/dist-server/graphql/resolvers/plantation-setting/create-plantation-setting.js +0 -12
  169. package/dist-server/graphql/resolvers/plantation-setting/create-plantation-setting.js.map +0 -1
  170. package/dist-server/graphql/resolvers/plantation-setting/delete-plantation-setting.js +0 -13
  171. package/dist-server/graphql/resolvers/plantation-setting/delete-plantation-setting.js.map +0 -1
  172. package/dist-server/graphql/resolvers/plantation-setting/delete-plantation-settings.js +0 -17
  173. package/dist-server/graphql/resolvers/plantation-setting/delete-plantation-settings.js.map +0 -1
  174. package/dist-server/graphql/resolvers/plantation-setting/index.js +0 -15
  175. package/dist-server/graphql/resolvers/plantation-setting/index.js.map +0 -1
  176. package/dist-server/graphql/resolvers/plantation-setting/plantation-setting-query.js +0 -32
  177. package/dist-server/graphql/resolvers/plantation-setting/plantation-setting-query.js.map +0 -1
  178. package/dist-server/graphql/resolvers/plantation-setting/update-multiple-plantation-setting.js +0 -31
  179. package/dist-server/graphql/resolvers/plantation-setting/update-multiple-plantation-setting.js.map +0 -1
  180. package/dist-server/graphql/resolvers/plantation-setting/update-plantation-setting.js +0 -16
  181. package/dist-server/graphql/resolvers/plantation-setting/update-plantation-setting.js.map +0 -1
  182. package/dist-server/graphql/resolvers/ramp/delete-ramps.js +0 -23
  183. package/dist-server/graphql/resolvers/ramp/delete-ramps.js.map +0 -1
  184. package/dist-server/graphql/resolvers/ramp/index.js +0 -11
  185. package/dist-server/graphql/resolvers/ramp/index.js.map +0 -1
  186. package/dist-server/graphql/resolvers/ramp/ramp-query.js +0 -32
  187. package/dist-server/graphql/resolvers/ramp/ramp-query.js.map +0 -1
  188. package/dist-server/graphql/resolvers/ramp/update-multiple-ramp.js +0 -45
  189. package/dist-server/graphql/resolvers/ramp/update-multiple-ramp.js.map +0 -1
  190. package/dist-server/graphql/resolvers/record-transaction/index.js +0 -9
  191. package/dist-server/graphql/resolvers/record-transaction/index.js.map +0 -1
  192. package/dist-server/graphql/resolvers/record-transaction/record-transaction-query.js +0 -30
  193. package/dist-server/graphql/resolvers/record-transaction/record-transaction-query.js.map +0 -1
  194. package/dist-server/graphql/resolvers/report/daily-ffb-dispatch-production-reports.js +0 -119
  195. package/dist-server/graphql/resolvers/report/daily-ffb-dispatch-production-reports.js.map +0 -1
  196. package/dist-server/graphql/resolvers/report/daily-production-reports.js +0 -146
  197. package/dist-server/graphql/resolvers/report/daily-production-reports.js.map +0 -1
  198. package/dist-server/graphql/resolvers/report/daily-staff-harvest-reports.js +0 -70
  199. package/dist-server/graphql/resolvers/report/daily-staff-harvest-reports.js.map +0 -1
  200. package/dist-server/graphql/resolvers/report/index.js +0 -16
  201. package/dist-server/graphql/resolvers/report/index.js.map +0 -1
  202. package/dist-server/graphql/resolvers/report/monthly-block-dispatch-reports.js +0 -94
  203. package/dist-server/graphql/resolvers/report/monthly-block-dispatch-reports.js.map +0 -1
  204. package/dist-server/graphql/resolvers/report/monthly-dispatch-summary-reports.js +0 -94
  205. package/dist-server/graphql/resolvers/report/monthly-dispatch-summary-reports.js.map +0 -1
  206. package/dist-server/graphql/resolvers/report/monthly-ffb-sale-reports.js +0 -92
  207. package/dist-server/graphql/resolvers/report/monthly-ffb-sale-reports.js.map +0 -1
  208. package/dist-server/graphql/resolvers/report/monthly-production-reports.js +0 -105
  209. package/dist-server/graphql/resolvers/report/monthly-production-reports.js.map +0 -1
  210. package/dist-server/graphql/resolvers/report/yearly-production-reports.js +0 -92
  211. package/dist-server/graphql/resolvers/report/yearly-production-reports.js.map +0 -1
  212. package/dist-server/graphql/resolvers/truck/delete-trucks.js +0 -18
  213. package/dist-server/graphql/resolvers/truck/delete-trucks.js.map +0 -1
  214. package/dist-server/graphql/resolvers/truck/index.js +0 -12
  215. package/dist-server/graphql/resolvers/truck/index.js.map +0 -1
  216. package/dist-server/graphql/resolvers/truck/truck-query.js +0 -45
  217. package/dist-server/graphql/resolvers/truck/truck-query.js.map +0 -1
  218. package/dist-server/graphql/resolvers/truck/update-multiple-truck.js +0 -40
  219. package/dist-server/graphql/resolvers/truck/update-multiple-truck.js.map +0 -1
  220. package/dist-server/graphql/types/block/block-list.js +0 -12
  221. package/dist-server/graphql/types/block/block-list.js.map +0 -1
  222. package/dist-server/graphql/types/block/block-patch.js +0 -17
  223. package/dist-server/graphql/types/block/block-patch.js.map +0 -1
  224. package/dist-server/graphql/types/block/block.js +0 -22
  225. package/dist-server/graphql/types/block/block.js.map +0 -1
  226. package/dist-server/graphql/types/block/index.js +0 -21
  227. package/dist-server/graphql/types/block/index.js.map +0 -1
  228. package/dist-server/graphql/types/block/new-block.js +0 -12
  229. package/dist-server/graphql/types/block/new-block.js.map +0 -1
  230. package/dist-server/graphql/types/block-detail/block-detail-list.js +0 -12
  231. package/dist-server/graphql/types/block-detail/block-detail-list.js.map +0 -1
  232. package/dist-server/graphql/types/block-detail/block-detail-patch.js +0 -20
  233. package/dist-server/graphql/types/block-detail/block-detail-patch.js.map +0 -1
  234. package/dist-server/graphql/types/block-detail/block-detail.js +0 -25
  235. package/dist-server/graphql/types/block-detail/block-detail.js.map +0 -1
  236. package/dist-server/graphql/types/block-detail/index.js +0 -21
  237. package/dist-server/graphql/types/block-detail/index.js.map +0 -1
  238. package/dist-server/graphql/types/block-detail/new-block-detail.js +0 -17
  239. package/dist-server/graphql/types/block-detail/new-block-detail.js.map +0 -1
  240. package/dist-server/graphql/types/daily-block-detail/daily-block-detail-list.js +0 -12
  241. package/dist-server/graphql/types/daily-block-detail/daily-block-detail-list.js.map +0 -1
  242. package/dist-server/graphql/types/daily-block-detail/daily-block-detail-patch.js +0 -14
  243. package/dist-server/graphql/types/daily-block-detail/daily-block-detail-patch.js.map +0 -1
  244. package/dist-server/graphql/types/daily-block-detail/daily-block-detail.js +0 -22
  245. package/dist-server/graphql/types/daily-block-detail/daily-block-detail.js.map +0 -1
  246. package/dist-server/graphql/types/daily-block-detail/index.js +0 -24
  247. package/dist-server/graphql/types/daily-block-detail/index.js.map +0 -1
  248. package/dist-server/graphql/types/daily-block-detail/new-daily-block-detail.js +0 -12
  249. package/dist-server/graphql/types/daily-block-detail/new-daily-block-detail.js.map +0 -1
  250. package/dist-server/graphql/types/daily-dispatch/daily-dispatch-list.js +0 -12
  251. package/dist-server/graphql/types/daily-dispatch/daily-dispatch-list.js.map +0 -1
  252. package/dist-server/graphql/types/daily-dispatch/daily-dispatch-patch.js +0 -26
  253. package/dist-server/graphql/types/daily-dispatch/daily-dispatch-patch.js.map +0 -1
  254. package/dist-server/graphql/types/daily-dispatch/daily-dispatch.js +0 -31
  255. package/dist-server/graphql/types/daily-dispatch/daily-dispatch.js.map +0 -1
  256. package/dist-server/graphql/types/daily-dispatch/index.js +0 -27
  257. package/dist-server/graphql/types/daily-dispatch/index.js.map +0 -1
  258. package/dist-server/graphql/types/daily-dispatch/new-daily-dispatch.js +0 -24
  259. package/dist-server/graphql/types/daily-dispatch/new-daily-dispatch.js.map +0 -1
  260. package/dist-server/graphql/types/daily-dispatch-detail/daily-dispatch-detail-list.js +0 -12
  261. package/dist-server/graphql/types/daily-dispatch-detail/daily-dispatch-detail-list.js.map +0 -1
  262. package/dist-server/graphql/types/daily-dispatch-detail/daily-dispatch-detail-patch.js +0 -20
  263. package/dist-server/graphql/types/daily-dispatch-detail/daily-dispatch-detail-patch.js.map +0 -1
  264. package/dist-server/graphql/types/daily-dispatch-detail/daily-dispatch-detail.js +0 -25
  265. package/dist-server/graphql/types/daily-dispatch-detail/daily-dispatch-detail.js.map +0 -1
  266. package/dist-server/graphql/types/daily-dispatch-detail/index.js +0 -17
  267. package/dist-server/graphql/types/daily-dispatch-detail/index.js.map +0 -1
  268. package/dist-server/graphql/types/daily-dispatch-detail/new-daily-dispatch-detail.js +0 -16
  269. package/dist-server/graphql/types/daily-dispatch-detail/new-daily-dispatch-detail.js.map +0 -1
  270. package/dist-server/graphql/types/daily-harvest/daily-harvest-list.js +0 -12
  271. package/dist-server/graphql/types/daily-harvest/daily-harvest-list.js.map +0 -1
  272. package/dist-server/graphql/types/daily-harvest/daily-harvest-patch.js +0 -21
  273. package/dist-server/graphql/types/daily-harvest/daily-harvest-patch.js.map +0 -1
  274. package/dist-server/graphql/types/daily-harvest/daily-harvest.js +0 -31
  275. package/dist-server/graphql/types/daily-harvest/daily-harvest.js.map +0 -1
  276. package/dist-server/graphql/types/daily-harvest/index.js +0 -22
  277. package/dist-server/graphql/types/daily-harvest/index.js.map +0 -1
  278. package/dist-server/graphql/types/daily-harvest/new-daily-harvest.js +0 -19
  279. package/dist-server/graphql/types/daily-harvest/new-daily-harvest.js.map +0 -1
  280. package/dist-server/graphql/types/daily-harvest-detail/daily-harvest-detail-list.js +0 -12
  281. package/dist-server/graphql/types/daily-harvest-detail/daily-harvest-detail-list.js.map +0 -1
  282. package/dist-server/graphql/types/daily-harvest-detail/daily-harvest-detail-patch.js +0 -15
  283. package/dist-server/graphql/types/daily-harvest-detail/daily-harvest-detail-patch.js.map +0 -1
  284. package/dist-server/graphql/types/daily-harvest-detail/daily-harvest-detail.js +0 -24
  285. package/dist-server/graphql/types/daily-harvest-detail/daily-harvest-detail.js.map +0 -1
  286. package/dist-server/graphql/types/daily-harvest-detail/index.js +0 -17
  287. package/dist-server/graphql/types/daily-harvest-detail/index.js.map +0 -1
  288. package/dist-server/graphql/types/daily-harvest-detail/new-daily-harvest-detail.js +0 -14
  289. package/dist-server/graphql/types/daily-harvest-detail/new-daily-harvest-detail.js.map +0 -1
  290. package/dist-server/graphql/types/daily-loading/daily-loading-list.js +0 -12
  291. package/dist-server/graphql/types/daily-loading/daily-loading-list.js.map +0 -1
  292. package/dist-server/graphql/types/daily-loading/daily-loading-patch.js +0 -12
  293. package/dist-server/graphql/types/daily-loading/daily-loading-patch.js.map +0 -1
  294. package/dist-server/graphql/types/daily-loading/daily-loading.js +0 -25
  295. package/dist-server/graphql/types/daily-loading/daily-loading.js.map +0 -1
  296. package/dist-server/graphql/types/daily-loading/index.js +0 -22
  297. package/dist-server/graphql/types/daily-loading/index.js.map +0 -1
  298. package/dist-server/graphql/types/daily-loading/new-daily-loading.js +0 -12
  299. package/dist-server/graphql/types/daily-loading/new-daily-loading.js.map +0 -1
  300. package/dist-server/graphql/types/daily-loading-detail/daily-loading-detail-list.js +0 -12
  301. package/dist-server/graphql/types/daily-loading-detail/daily-loading-detail-list.js.map +0 -1
  302. package/dist-server/graphql/types/daily-loading-detail/daily-loading-detail-patch.js +0 -18
  303. package/dist-server/graphql/types/daily-loading-detail/daily-loading-detail-patch.js.map +0 -1
  304. package/dist-server/graphql/types/daily-loading-detail/daily-loading-detail.js +0 -27
  305. package/dist-server/graphql/types/daily-loading-detail/daily-loading-detail.js.map +0 -1
  306. package/dist-server/graphql/types/daily-loading-detail/index.js +0 -17
  307. package/dist-server/graphql/types/daily-loading-detail/index.js.map +0 -1
  308. package/dist-server/graphql/types/daily-loading-detail/new-daily-loading-detail.js +0 -17
  309. package/dist-server/graphql/types/daily-loading-detail/new-daily-loading-detail.js.map +0 -1
  310. package/dist-server/graphql/types/daily-loading-ramp/daily-loading-ramp-list.js +0 -12
  311. package/dist-server/graphql/types/daily-loading-ramp/daily-loading-ramp-list.js.map +0 -1
  312. package/dist-server/graphql/types/daily-loading-ramp/daily-loading-ramp-patch.js +0 -17
  313. package/dist-server/graphql/types/daily-loading-ramp/daily-loading-ramp-patch.js.map +0 -1
  314. package/dist-server/graphql/types/daily-loading-ramp/daily-loading-ramp.js +0 -21
  315. package/dist-server/graphql/types/daily-loading-ramp/daily-loading-ramp.js.map +0 -1
  316. package/dist-server/graphql/types/daily-loading-ramp/index.js +0 -21
  317. package/dist-server/graphql/types/daily-loading-ramp/index.js.map +0 -1
  318. package/dist-server/graphql/types/daily-loading-ramp/new-daily-loading-ramp.js +0 -15
  319. package/dist-server/graphql/types/daily-loading-ramp/new-daily-loading-ramp.js.map +0 -1
  320. package/dist-server/graphql/types/dashboard/bunches-count.js +0 -13
  321. package/dist-server/graphql/types/dashboard/bunches-count.js.map +0 -1
  322. package/dist-server/graphql/types/dashboard/index.js +0 -20
  323. package/dist-server/graphql/types/dashboard/index.js.map +0 -1
  324. package/dist-server/graphql/types/dashboard/productions-overview.js +0 -13
  325. package/dist-server/graphql/types/dashboard/productions-overview.js.map +0 -1
  326. package/dist-server/graphql/types/dashboard/tonnage-bunches-inventories.js +0 -12
  327. package/dist-server/graphql/types/dashboard/tonnage-bunches-inventories.js.map +0 -1
  328. package/dist-server/graphql/types/dashboard/tonnage-production.js +0 -15
  329. package/dist-server/graphql/types/dashboard/tonnage-production.js.map +0 -1
  330. package/dist-server/graphql/types/dashboard/yield-production.js +0 -15
  331. package/dist-server/graphql/types/dashboard/yield-production.js.map +0 -1
  332. package/dist-server/graphql/types/index.js +0 -23
  333. package/dist-server/graphql/types/index.js.map +0 -1
  334. package/dist-server/graphql/types/organization/index.js +0 -21
  335. package/dist-server/graphql/types/organization/index.js.map +0 -1
  336. package/dist-server/graphql/types/organization/new-organization.js +0 -13
  337. package/dist-server/graphql/types/organization/new-organization.js.map +0 -1
  338. package/dist-server/graphql/types/organization/organization-list.js +0 -12
  339. package/dist-server/graphql/types/organization/organization-list.js.map +0 -1
  340. package/dist-server/graphql/types/organization/organization-patch.js +0 -15
  341. package/dist-server/graphql/types/organization/organization-patch.js.map +0 -1
  342. package/dist-server/graphql/types/organization/organization.js +0 -20
  343. package/dist-server/graphql/types/organization/organization.js.map +0 -1
  344. package/dist-server/graphql/types/organization-staff/index.js +0 -22
  345. package/dist-server/graphql/types/organization-staff/index.js.map +0 -1
  346. package/dist-server/graphql/types/organization-staff/new-organization-staff.js +0 -12
  347. package/dist-server/graphql/types/organization-staff/new-organization-staff.js.map +0 -1
  348. package/dist-server/graphql/types/organization-staff/organization-staff-list.js +0 -12
  349. package/dist-server/graphql/types/organization-staff/organization-staff-list.js.map +0 -1
  350. package/dist-server/graphql/types/organization-staff/organization-staff-patch.js +0 -19
  351. package/dist-server/graphql/types/organization-staff/organization-staff-patch.js.map +0 -1
  352. package/dist-server/graphql/types/organization-staff/organization-staff.js +0 -25
  353. package/dist-server/graphql/types/organization-staff/organization-staff.js.map +0 -1
  354. package/dist-server/graphql/types/plantation-inventory/index.js +0 -17
  355. package/dist-server/graphql/types/plantation-inventory/index.js.map +0 -1
  356. package/dist-server/graphql/types/plantation-inventory/new-plantation-inventory.js +0 -12
  357. package/dist-server/graphql/types/plantation-inventory/new-plantation-inventory.js.map +0 -1
  358. package/dist-server/graphql/types/plantation-inventory/plantation-inventory-list.js +0 -12
  359. package/dist-server/graphql/types/plantation-inventory/plantation-inventory-list.js.map +0 -1
  360. package/dist-server/graphql/types/plantation-inventory/plantation-inventory-patch.js +0 -14
  361. package/dist-server/graphql/types/plantation-inventory/plantation-inventory-patch.js.map +0 -1
  362. package/dist-server/graphql/types/plantation-inventory/plantation-inventory.js +0 -26
  363. package/dist-server/graphql/types/plantation-inventory/plantation-inventory.js.map +0 -1
  364. package/dist-server/graphql/types/plantation-setting/index.js +0 -24
  365. package/dist-server/graphql/types/plantation-setting/index.js.map +0 -1
  366. package/dist-server/graphql/types/plantation-setting/new-plantation-setting.js +0 -14
  367. package/dist-server/graphql/types/plantation-setting/new-plantation-setting.js.map +0 -1
  368. package/dist-server/graphql/types/plantation-setting/plantation-setting-list.js +0 -12
  369. package/dist-server/graphql/types/plantation-setting/plantation-setting-list.js.map +0 -1
  370. package/dist-server/graphql/types/plantation-setting/plantation-setting-patch.js +0 -16
  371. package/dist-server/graphql/types/plantation-setting/plantation-setting-patch.js.map +0 -1
  372. package/dist-server/graphql/types/plantation-setting/plantation-setting.js +0 -20
  373. package/dist-server/graphql/types/plantation-setting/plantation-setting.js.map +0 -1
  374. package/dist-server/graphql/types/ramp/index.js +0 -21
  375. package/dist-server/graphql/types/ramp/index.js.map +0 -1
  376. package/dist-server/graphql/types/ramp/new-ramp.js +0 -12
  377. package/dist-server/graphql/types/ramp/new-ramp.js.map +0 -1
  378. package/dist-server/graphql/types/ramp/ramp-list.js +0 -12
  379. package/dist-server/graphql/types/ramp/ramp-list.js.map +0 -1
  380. package/dist-server/graphql/types/ramp/ramp-patch.js +0 -16
  381. package/dist-server/graphql/types/ramp/ramp-patch.js.map +0 -1
  382. package/dist-server/graphql/types/ramp/ramp.js +0 -21
  383. package/dist-server/graphql/types/ramp/ramp.js.map +0 -1
  384. package/dist-server/graphql/types/record-transaction/index.js +0 -17
  385. package/dist-server/graphql/types/record-transaction/index.js.map +0 -1
  386. package/dist-server/graphql/types/record-transaction/new-record-transaction.js +0 -12
  387. package/dist-server/graphql/types/record-transaction/new-record-transaction.js.map +0 -1
  388. package/dist-server/graphql/types/record-transaction/record-transaction-list.js +0 -12
  389. package/dist-server/graphql/types/record-transaction/record-transaction-list.js.map +0 -1
  390. package/dist-server/graphql/types/record-transaction/record-transaction-patch.js +0 -14
  391. package/dist-server/graphql/types/record-transaction/record-transaction-patch.js.map +0 -1
  392. package/dist-server/graphql/types/record-transaction/record-transaction.js +0 -28
  393. package/dist-server/graphql/types/record-transaction/record-transaction.js.map +0 -1
  394. package/dist-server/graphql/types/report/daily-ffb-dispatch-production-report-list.js +0 -12
  395. package/dist-server/graphql/types/report/daily-ffb-dispatch-production-report-list.js.map +0 -1
  396. package/dist-server/graphql/types/report/daily-ffb-dispatch-production-report.js +0 -13
  397. package/dist-server/graphql/types/report/daily-ffb-dispatch-production-report.js.map +0 -1
  398. package/dist-server/graphql/types/report/daily-production-report-list.js +0 -12
  399. package/dist-server/graphql/types/report/daily-production-report-list.js.map +0 -1
  400. package/dist-server/graphql/types/report/daily-production-report.js +0 -27
  401. package/dist-server/graphql/types/report/daily-production-report.js.map +0 -1
  402. package/dist-server/graphql/types/report/daily-staff-harvest-report-list.js +0 -12
  403. package/dist-server/graphql/types/report/daily-staff-harvest-report-list.js.map +0 -1
  404. package/dist-server/graphql/types/report/daily-staff-harvest-report.js +0 -14
  405. package/dist-server/graphql/types/report/daily-staff-harvest-report.js.map +0 -1
  406. package/dist-server/graphql/types/report/index.js +0 -65
  407. package/dist-server/graphql/types/report/index.js.map +0 -1
  408. package/dist-server/graphql/types/report/monthly-block-dispatch-report-list.js +0 -12
  409. package/dist-server/graphql/types/report/monthly-block-dispatch-report-list.js.map +0 -1
  410. package/dist-server/graphql/types/report/monthly-block-dispatch-report.js +0 -17
  411. package/dist-server/graphql/types/report/monthly-block-dispatch-report.js.map +0 -1
  412. package/dist-server/graphql/types/report/monthly-dispatch-summary-report-list.js +0 -12
  413. package/dist-server/graphql/types/report/monthly-dispatch-summary-report-list.js.map +0 -1
  414. package/dist-server/graphql/types/report/monthly-dispatch-summary-report.js +0 -23
  415. package/dist-server/graphql/types/report/monthly-dispatch-summary-report.js.map +0 -1
  416. package/dist-server/graphql/types/report/monthly-ffb-sale-report-list.js +0 -12
  417. package/dist-server/graphql/types/report/monthly-ffb-sale-report-list.js.map +0 -1
  418. package/dist-server/graphql/types/report/monthly-ffb-sale-report.js +0 -22
  419. package/dist-server/graphql/types/report/monthly-ffb-sale-report.js.map +0 -1
  420. package/dist-server/graphql/types/report/monthly-production-report-list.js +0 -12
  421. package/dist-server/graphql/types/report/monthly-production-report-list.js.map +0 -1
  422. package/dist-server/graphql/types/report/monthly-production-report.js +0 -29
  423. package/dist-server/graphql/types/report/monthly-production-report.js.map +0 -1
  424. package/dist-server/graphql/types/report/yearly-production-report-list.js +0 -12
  425. package/dist-server/graphql/types/report/yearly-production-report-list.js.map +0 -1
  426. package/dist-server/graphql/types/report/yearly-production-report.js +0 -22
  427. package/dist-server/graphql/types/report/yearly-production-report.js.map +0 -1
  428. package/dist-server/graphql/types/truck/index.js +0 -21
  429. package/dist-server/graphql/types/truck/index.js.map +0 -1
  430. package/dist-server/graphql/types/truck/new-truck.js +0 -12
  431. package/dist-server/graphql/types/truck/new-truck.js.map +0 -1
  432. package/dist-server/graphql/types/truck/truck-list.js +0 -12
  433. package/dist-server/graphql/types/truck/truck-list.js.map +0 -1
  434. package/dist-server/graphql/types/truck/truck-patch.js +0 -15
  435. package/dist-server/graphql/types/truck/truck-patch.js.map +0 -1
  436. package/dist-server/graphql/types/truck/truck.js +0 -20
  437. package/dist-server/graphql/types/truck/truck.js.map +0 -1
  438. package/dist-server/index.js +0 -9
  439. package/dist-server/index.js.map +0 -1
  440. package/dist-server/middlewares/index.js +0 -8
  441. package/dist-server/middlewares/index.js.map +0 -1
  442. package/dist-server/migrations/index.js +0 -12
  443. package/dist-server/migrations/index.js.map +0 -1
  444. package/dist-server/routes.js +0 -9
  445. package/dist-server/routes.js.map +0 -1
  446. package/dist-server/tsconfig.tsbuildinfo +0 -1
  447. package/dist-server/utils/core-values.js +0 -91
  448. package/dist-server/utils/core-values.js.map +0 -1
  449. package/dist-server/utils/datetime-util.js +0 -36
  450. package/dist-server/utils/datetime-util.js.map +0 -1
  451. package/dist-server/utils/index.js +0 -8
  452. package/dist-server/utils/index.js.map +0 -1
  453. package/dist-server/utils/no-generator.js +0 -50
  454. package/dist-server/utils/no-generator.js.map +0 -1
  455. package/dist-server/utils/transaction-util.js +0 -67
  456. package/dist-server/utils/transaction-util.js.map +0 -1
@@ -1,75 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.generateDispatchTransaction = exports.addDailyDispatchDetail = exports.generateDailyDispatch = void 0;
4
- const shell_1 = require("@things-factory/shell");
5
- const constants_1 = require("../../../constants");
6
- const entities_1 = require("../../../entities");
7
- const utils_1 = require("../../../utils");
8
- exports.generateDailyDispatch = {
9
- async generateDailyDispatch(_, { dailyDispatch }, context) {
10
- const { domain, user, tx } = context.state;
11
- let dailyDispatchDetails = dailyDispatch.dailyDispatchDetails;
12
- let driver;
13
- let transport;
14
- let dispatchTo;
15
- if (dailyDispatch === null || dailyDispatch === void 0 ? void 0 : dailyDispatch.driver) {
16
- driver = await tx.getRepository(entities_1.OrganizationStaff).findOne({
17
- where: { id: dailyDispatch.driver.id }
18
- });
19
- }
20
- if (dailyDispatch === null || dailyDispatch === void 0 ? void 0 : dailyDispatch.transport) {
21
- transport = await tx.getRepository(entities_1.Truck).findOne({
22
- where: { id: dailyDispatch.transport.id }
23
- });
24
- }
25
- if (dailyDispatch === null || dailyDispatch === void 0 ? void 0 : dailyDispatch.dispatchTo) {
26
- dispatchTo = await tx.getRepository(entities_1.Organization).findOne({
27
- where: { id: dailyDispatch.dispatchTo.id }
28
- });
29
- }
30
- const totalTonnageRelease = dailyDispatchDetails.reduce(function (prev, cur) {
31
- return prev + cur.collectedRampWeight;
32
- }, 0);
33
- // 1. Create daily dispatchment
34
- let newDailyDispatch = new entities_1.DailyDispatch();
35
- newDailyDispatch.name = utils_1.NoGenerator.dailyDispatch();
36
- newDailyDispatch.domain = domain;
37
- newDailyDispatch.transport = transport;
38
- newDailyDispatch.transportNo = transport.name;
39
- newDailyDispatch.driver = driver;
40
- newDailyDispatch.driverIdentification = (driver === null || driver === void 0 ? void 0 : driver.idNumber) ? driver.idNumber : null;
41
- newDailyDispatch.externalDriver = (driver === null || driver === void 0 ? void 0 : driver.name) ? driver === null || driver === void 0 ? void 0 : driver.name : null;
42
- newDailyDispatch.totalTonnageRelease = totalTonnageRelease;
43
- newDailyDispatch.chitNo = dailyDispatch === null || dailyDispatch === void 0 ? void 0 : dailyDispatch.chitNo;
44
- newDailyDispatch.percentage = dailyDispatch === null || dailyDispatch === void 0 ? void 0 : dailyDispatch.percentage;
45
- newDailyDispatch.dispatchTo = dispatchTo;
46
- newDailyDispatch.dispatchAt = dailyDispatch.dispatchAt;
47
- newDailyDispatch.status = constants_1.RECORD_STATUS.STORED;
48
- newDailyDispatch.creator = user;
49
- newDailyDispatch = await tx.getRepository(entities_1.DailyDispatch).save(newDailyDispatch);
50
- // 2. Create daily dispatch detail
51
- dailyDispatchDetails = await addDailyDispatchDetail(domain, newDailyDispatch, dailyDispatchDetails.map((record) => {
52
- return Object.assign({}, record);
53
- }), user, tx);
54
- await generateDispatchTransaction(domain, newDailyDispatch, dailyDispatchDetails, user, tx);
55
- return newDailyDispatch;
56
- }
57
- };
58
- async function addDailyDispatchDetail(domain, newDailyDispatch, dailyDispatchDetails, user, tx) {
59
- const rampRepo = (tx === null || tx === void 0 ? void 0 : tx.getRepository(entities_1.Ramp)) || (0, shell_1.getRepository)(entities_1.Ramp);
60
- const dailyDispatchDetailRepo = (tx === null || tx === void 0 ? void 0 : tx.getRepository(entities_1.DailyDispatchDetail)) || (0, shell_1.getRepository)(entities_1.DailyDispatchDetail);
61
- dailyDispatchDetails = await Promise.all(dailyDispatchDetails.map(async (dailyDispatchDetail) => {
62
- return Object.assign(Object.assign({}, dailyDispatchDetail), { domain, name: utils_1.NoGenerator.dailyDispatchDetail(), ramp: await rampRepo.findOneBy({ id: dailyDispatchDetail.ramp.id }), dailyDispatch: newDailyDispatch, creator: user, updater: user });
63
- }));
64
- return await dailyDispatchDetailRepo.save(dailyDispatchDetails);
65
- }
66
- exports.addDailyDispatchDetail = addDailyDispatchDetail;
67
- async function generateDispatchTransaction(domain, newDailyDispatch, dailyDispatchDetails, user, tx) {
68
- await Promise.all(dailyDispatchDetails.map(async (record) => {
69
- const dispatchedTonnage = record.collectedRampWeight;
70
- const dispatchDate = newDailyDispatch.dispatchAt.toString().split('T')[0];
71
- await (0, utils_1.generateTransactionHistory)(null, domain, record.ramp, newDailyDispatch.id, newDailyDispatch.name, constants_1.TRANSACTION_TYPE.DISPATCHMENT, dispatchDate, 0, -dispatchedTonnage, user, tx);
72
- }));
73
- }
74
- exports.generateDispatchTransaction = generateDispatchTransaction;
75
- //# sourceMappingURL=generate-daily-dispatch.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"generate-daily-dispatch.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/daily-dispatch/generate-daily-dispatch.ts"],"names":[],"mappings":"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","sourcesContent":["import { EntityManager, Repository } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { Domain, getRepository } from '@things-factory/shell'\n\nimport { RECORD_STATUS, TRANSACTION_TYPE } from '../../../constants'\nimport { DailyDispatch, DailyDispatchDetail, Organization, OrganizationStaff, Ramp, Truck } from '../../../entities'\nimport { generateTransactionHistory, NoGenerator } from '../../../utils'\n\nexport const generateDailyDispatch = {\n async generateDailyDispatch(_: any, { dailyDispatch }, context: ResolverContext) {\n const { domain, user, tx } = context.state\n\n let dailyDispatchDetails: DailyDispatchDetail[] = dailyDispatch.dailyDispatchDetails\n let driver: OrganizationStaff\n let transport: Truck\n let dispatchTo: Organization\n\n if (dailyDispatch?.driver) {\n driver = await tx.getRepository(OrganizationStaff).findOne({\n where: { id: dailyDispatch.driver.id }\n })\n }\n\n if (dailyDispatch?.transport) {\n transport = await tx.getRepository(Truck).findOne({\n where: { id: dailyDispatch.transport.id }\n })\n }\n\n if (dailyDispatch?.dispatchTo) {\n dispatchTo = await tx.getRepository(Organization).findOne({\n where: { id: dailyDispatch.dispatchTo.id }\n })\n }\n\n const totalTonnageRelease: number = dailyDispatchDetails.reduce(function (prev, cur) {\n return prev + cur.collectedRampWeight\n }, 0)\n\n // 1. Create daily dispatchment\n let newDailyDispatch: DailyDispatch = new DailyDispatch()\n newDailyDispatch.name = NoGenerator.dailyDispatch()\n newDailyDispatch.domain = domain\n newDailyDispatch.transport = transport\n newDailyDispatch.transportNo = transport.name\n newDailyDispatch.driver = driver\n newDailyDispatch.driverIdentification = driver?.idNumber ? driver.idNumber : null\n newDailyDispatch.externalDriver = driver?.name ? driver?.name : null\n newDailyDispatch.totalTonnageRelease = totalTonnageRelease\n newDailyDispatch.chitNo = dailyDispatch?.chitNo\n newDailyDispatch.percentage = dailyDispatch?.percentage\n newDailyDispatch.dispatchTo = dispatchTo\n newDailyDispatch.dispatchAt = dailyDispatch.dispatchAt\n newDailyDispatch.status = RECORD_STATUS.STORED\n newDailyDispatch.creator = user\n newDailyDispatch = await tx.getRepository(DailyDispatch).save(newDailyDispatch)\n\n // 2. Create daily dispatch detail\n dailyDispatchDetails = await addDailyDispatchDetail(\n domain,\n newDailyDispatch,\n dailyDispatchDetails.map((record: DailyDispatchDetail) => {\n return { ...record }\n }),\n user,\n tx\n )\n\n await generateDispatchTransaction(domain, newDailyDispatch, dailyDispatchDetails, user, tx)\n\n return newDailyDispatch\n }\n}\n\nexport async function addDailyDispatchDetail(\n domain: Domain,\n newDailyDispatch: DailyDispatch,\n dailyDispatchDetails: DailyDispatchDetail[],\n user: User,\n tx?: EntityManager\n): Promise<DailyDispatchDetail[]> {\n const rampRepo: Repository<Ramp> = tx?.getRepository(Ramp) || getRepository(Ramp)\n const dailyDispatchDetailRepo: Repository<DailyDispatchDetail> =\n tx?.getRepository(DailyDispatchDetail) || getRepository(DailyDispatchDetail)\n\n dailyDispatchDetails = await Promise.all(\n dailyDispatchDetails.map(async (dailyDispatchDetail: DailyDispatchDetail) => {\n return {\n ...dailyDispatchDetail,\n domain,\n name: NoGenerator.dailyDispatchDetail(),\n ramp: await rampRepo.findOneBy({ id: dailyDispatchDetail.ramp.id }),\n dailyDispatch: newDailyDispatch,\n creator: user,\n updater: user\n }\n })\n )\n\n return await dailyDispatchDetailRepo.save(dailyDispatchDetails)\n}\n\nexport async function generateDispatchTransaction(\n domain: Domain,\n newDailyDispatch: DailyDispatch,\n dailyDispatchDetails: DailyDispatchDetail[],\n user: User,\n tx?: EntityManager\n): Promise<void> {\n await Promise.all(\n dailyDispatchDetails.map(async record => {\n const dispatchedTonnage: number = record.collectedRampWeight\n const dispatchDate: string = newDailyDispatch.dispatchAt.toString().split('T')[0]\n\n await generateTransactionHistory(\n null,\n domain,\n record.ramp,\n newDailyDispatch.id,\n newDailyDispatch.name,\n TRANSACTION_TYPE.DISPATCHMENT,\n dispatchDate,\n 0,\n -dispatchedTonnage,\n user,\n tx\n )\n })\n )\n}\n"]}
@@ -1,12 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.DailyDispatchResolver = void 0;
4
- const daily_dispatch_query_1 = require("./daily-dispatch-query");
5
- const generate_daily_dispatch_1 = require("./generate-daily-dispatch");
6
- const delete_daily_dispatch_1 = require("./delete-daily-dispatch");
7
- const update_daily_dispatch_1 = require("./update-daily-dispatch");
8
- exports.DailyDispatchResolver = {
9
- Query: daily_dispatch_query_1.Query,
10
- Mutation: Object.assign(Object.assign(Object.assign({}, generate_daily_dispatch_1.generateDailyDispatch), delete_daily_dispatch_1.deleteDailyDispatch), update_daily_dispatch_1.updateDailyDispatch)
11
- };
12
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/daily-dispatch/index.ts"],"names":[],"mappings":";;;AAAA,iEAA8C;AAE9C,uEAAiE;AACjE,mEAA6D;AAC7D,mEAA6D;AAEhD,QAAA,qBAAqB,GAAG;IACnC,KAAK,EAAL,4BAAK;IACL,QAAQ,gDACH,+CAAqB,GACrB,2CAAmB,GACnB,2CAAmB,CACvB;CACF,CAAA","sourcesContent":["import { Query } from './daily-dispatch-query'\n\nimport { generateDailyDispatch } from './generate-daily-dispatch'\nimport { deleteDailyDispatch } from './delete-daily-dispatch'\nimport { updateDailyDispatch } from './update-daily-dispatch'\n\nexport const DailyDispatchResolver = {\n Query,\n Mutation: {\n ...generateDailyDispatch,\n ...deleteDailyDispatch,\n ...updateDailyDispatch\n }\n}\n"]}
@@ -1,23 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.updateDailyDispatch = void 0;
4
- const entities_1 = require("../../../entities");
5
- exports.updateDailyDispatch = {
6
- async updateDailyDispatch(_, { name, chitNo, percentage, dailyDispatchDetails }, context) {
7
- const { domain, tx, user } = context.state;
8
- const repository = tx.getRepository(entities_1.DailyDispatch);
9
- const dailyDispatch = await repository.findOne({
10
- where: { domain: { id: domain.id }, name },
11
- relations: ['dailyDispatchDetails']
12
- });
13
- let foundDailyDispatchDetails = dailyDispatch.dailyDispatchDetails;
14
- foundDailyDispatchDetails = foundDailyDispatchDetails.map(record => {
15
- const matchedDispatchDetail = dailyDispatchDetails.find(dispatchDetail => dispatchDetail.name === record.name);
16
- return Object.assign(Object.assign(Object.assign({}, record), matchedDispatchDetail), { updater: user });
17
- });
18
- await tx.getRepository(entities_1.DailyDispatchDetail).save(foundDailyDispatchDetails);
19
- return await repository.save(Object.assign(Object.assign({}, dailyDispatch), { chitNo,
20
- percentage, updater: user }));
21
- }
22
- };
23
- //# sourceMappingURL=update-daily-dispatch.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"update-daily-dispatch.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/daily-dispatch/update-daily-dispatch.ts"],"names":[],"mappings":";;;AAAA,gDAAsE;AAEzD,QAAA,mBAAmB,GAAG;IACjC,KAAK,CAAC,mBAAmB,CAAC,CAAM,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,oBAAoB,EAAE,EAAE,OAAwB;QAC5G,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAE1C,MAAM,UAAU,GAAG,EAAE,CAAC,aAAa,CAAC,wBAAa,CAAC,CAAA;QAClD,MAAM,aAAa,GAAG,MAAM,UAAU,CAAC,OAAO,CAAC;YAC7C,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE;YAC1C,SAAS,EAAE,CAAC,sBAAsB,CAAC;SACpC,CAAC,CAAA;QAEF,IAAI,yBAAyB,GAA0B,aAAa,CAAC,oBAAoB,CAAA;QAEzF,yBAAyB,GAAG,yBAAyB,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE;YACjE,MAAM,qBAAqB,GAAQ,oBAAoB,CAAC,IAAI,CAC1D,cAAc,CAAC,EAAE,CAAC,cAAc,CAAC,IAAI,KAAK,MAAM,CAAC,IAAI,CACtD,CAAA;YAED,qDACK,MAAM,GACN,qBAAqB,KACxB,OAAO,EAAE,IAAI,IACd;QACH,CAAC,CAAC,CAAA;QAEF,MAAM,EAAE,CAAC,aAAa,CAAC,8BAAmB,CAAC,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAA;QAE3E,OAAO,MAAM,UAAU,CAAC,IAAI,iCACvB,aAAa,KAChB,MAAM;YACN,UAAU,EACV,OAAO,EAAE,IAAI,IACb,CAAA;IACJ,CAAC;CACF,CAAA","sourcesContent":["import { DailyDispatch, DailyDispatchDetail } from '../../../entities'\n\nexport const updateDailyDispatch = {\n async updateDailyDispatch(_: any, { name, chitNo, percentage, dailyDispatchDetails }, context: ResolverContext) {\n const { domain, tx, user } = context.state\n\n const repository = tx.getRepository(DailyDispatch)\n const dailyDispatch = await repository.findOne({\n where: { domain: { id: domain.id }, name },\n relations: ['dailyDispatchDetails']\n })\n\n let foundDailyDispatchDetails: DailyDispatchDetail[] = dailyDispatch.dailyDispatchDetails\n\n foundDailyDispatchDetails = foundDailyDispatchDetails.map(record => {\n const matchedDispatchDetail: any = dailyDispatchDetails.find(\n dispatchDetail => dispatchDetail.name === record.name\n )\n\n return {\n ...record,\n ...matchedDispatchDetail,\n updater: user\n }\n })\n\n await tx.getRepository(DailyDispatchDetail).save(foundDailyDispatchDetails)\n\n return await repository.save({\n ...dailyDispatch,\n chitNo,\n percentage,\n updater: user\n })\n }\n}\n"]}
@@ -1,34 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Query = void 0;
4
- const typeorm_1 = require("typeorm");
5
- const shell_1 = require("@things-factory/shell");
6
- const entities_1 = require("../../../entities");
7
- exports.Query = {
8
- async dailyDispatchDetail(_, { name }, context) {
9
- const { domain, tx } = context.state;
10
- return await tx.getRepository(entities_1.DailyDispatchDetail).findOne({
11
- where: { domain: { id: domain.id }, name, deletedAt: (0, typeorm_1.IsNull)() },
12
- relations: ['domain', 'dailyDispatch', 'ramp', 'creator', 'updater']
13
- });
14
- },
15
- async dailyDispatchDetails(_, params, context) {
16
- var _a;
17
- const { tx } = context.state;
18
- const queryBuilder = tx.getRepository(entities_1.DailyDispatchDetail).createQueryBuilder();
19
- (0, shell_1.buildQuery)(queryBuilder, params, context);
20
- queryBuilder
21
- .leftJoinAndSelect('DailyDispatchDetail.domain', 'Domain')
22
- .leftJoinAndSelect('DailyDispatchDetail.dailyDispatch', 'DailyDispatch')
23
- .leftJoinAndSelect('DailyDispatchDetail.ramp', 'Ramp')
24
- .leftJoinAndSelect('DailyDispatchDetail.creator', 'Creator')
25
- .leftJoinAndSelect('DailyDispatchDetail.updater', 'Updater');
26
- if (((_a = params.filters) === null || _a === void 0 ? void 0 : _a.length) > 0)
27
- queryBuilder.andWhere('DailyDispatchDetail.deletedAt IS NULL');
28
- else
29
- queryBuilder.where('DailyDispatchDetail.deletedAt IS NULL');
30
- const [items, total] = await queryBuilder.getManyAndCount();
31
- return { items, total };
32
- }
33
- };
34
- //# sourceMappingURL=daily-dispatch-detail-query.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"daily-dispatch-detail-query.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/daily-dispatch-detail/daily-dispatch-detail-query.ts"],"names":[],"mappings":";;;AAAA,qCAA+C;AAE/C,iDAAqE;AAErE,gDAAoF;AAEvE,QAAA,KAAK,GAAG;IACnB,KAAK,CAAC,mBAAmB,CAAC,CAAM,EAAE,EAAE,IAAI,EAAE,EAAE,OAAwB;QAClE,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAEpC,OAAO,MAAM,EAAE,CAAC,aAAa,CAAC,8BAAyB,CAAC,CAAC,OAAO,CAAC;YAC/D,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,IAAA,gBAAM,GAAE,EAAE;YAC/D,SAAS,EAAE,CAAC,QAAQ,EAAE,eAAe,EAAE,MAAM,EAAE,SAAS,EAAE,SAAS,CAAC;SACrE,CAAC,CAAA;IACJ,CAAC;IAED,KAAK,CAAC,oBAAoB,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAwB;;QAC5E,MAAM,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAE5B,MAAM,YAAY,GAAG,EAAE,CAAC,aAAa,CAAC,8BAAyB,CAAC,CAAC,kBAAkB,EAAE,CAAA;QACrF,IAAA,kBAAU,EAAC,YAAY,EAAE,MAAM,EAAE,OAAO,CAAC,CAAA;QAEzC,YAAY;aACT,iBAAiB,CAAC,4BAA4B,EAAE,QAAQ,CAAC;aACzD,iBAAiB,CAAC,mCAAmC,EAAE,eAAe,CAAC;aACvE,iBAAiB,CAAC,0BAA0B,EAAE,MAAM,CAAC;aACrD,iBAAiB,CAAC,6BAA6B,EAAE,SAAS,CAAC;aAC3D,iBAAiB,CAAC,6BAA6B,EAAE,SAAS,CAAC,CAAA;QAE9D,IAAI,CAAA,MAAA,MAAM,CAAC,OAAO,0CAAE,MAAM,IAAG,CAAC;YAAE,YAAY,CAAC,QAAQ,CAAC,uCAAuC,CAAC,CAAA;;YACzF,YAAY,CAAC,KAAK,CAAC,uCAAuC,CAAC,CAAA;QAEhE,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,MAAM,YAAY,CAAC,eAAe,EAAE,CAAA;QAE3D,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,CAAA;IACzB,CAAC;CACF,CAAA","sourcesContent":["import { EntityManager, IsNull } from 'typeorm'\n\nimport { buildQuery, Domain, ListParam } from '@things-factory/shell'\n\nimport { DailyDispatchDetail as DailyDispatchDetailEntity } from '../../../entities'\n\nexport const Query = {\n async dailyDispatchDetail(_: any, { name }, context: ResolverContext) {\n const { domain, tx } = context.state\n\n return await tx.getRepository(DailyDispatchDetailEntity).findOne({\n where: { domain: { id: domain.id }, name, deletedAt: IsNull() },\n relations: ['domain', 'dailyDispatch', 'ramp', 'creator', 'updater']\n })\n },\n\n async dailyDispatchDetails(_: any, params: ListParam, context: ResolverContext) {\n const { tx } = context.state\n\n const queryBuilder = tx.getRepository(DailyDispatchDetailEntity).createQueryBuilder()\n buildQuery(queryBuilder, params, context)\n\n queryBuilder\n .leftJoinAndSelect('DailyDispatchDetail.domain', 'Domain')\n .leftJoinAndSelect('DailyDispatchDetail.dailyDispatch', 'DailyDispatch')\n .leftJoinAndSelect('DailyDispatchDetail.ramp', 'Ramp')\n .leftJoinAndSelect('DailyDispatchDetail.creator', 'Creator')\n .leftJoinAndSelect('DailyDispatchDetail.updater', 'Updater')\n\n if (params.filters?.length > 0) queryBuilder.andWhere('DailyDispatchDetail.deletedAt IS NULL')\n else queryBuilder.where('DailyDispatchDetail.deletedAt IS NULL')\n\n const [items, total] = await queryBuilder.getManyAndCount()\n\n return { items, total }\n }\n}\n"]}
@@ -1,9 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.DailyDispatchDetailResolver = void 0;
4
- const daily_dispatch_detail_query_1 = require("./daily-dispatch-detail-query");
5
- exports.DailyDispatchDetailResolver = {
6
- Query: daily_dispatch_detail_query_1.Query,
7
- Mutation: {}
8
- };
9
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/daily-dispatch-detail/index.ts"],"names":[],"mappings":";;;AAAA,+EAAqD;AAExC,QAAA,2BAA2B,GAAG;IACzC,KAAK,EAAL,mCAAK;IACL,QAAQ,EAAE,EAAE;CACb,CAAA","sourcesContent":["import { Query } from './daily-dispatch-detail-query'\n\nexport const DailyDispatchDetailResolver = {\n Query,\n Mutation: {}\n}\n"]}
@@ -1,44 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Query = void 0;
4
- const typeorm_1 = require("typeorm");
5
- const shell_1 = require("@things-factory/shell");
6
- const entities_1 = require("../../../entities");
7
- exports.Query = {
8
- async dailyHarvest(_, { name }, context) {
9
- const { domain, tx } = context.state;
10
- const transaction = await tx
11
- .getRepository(entities_1.RecordTransaction)
12
- .findOne({ where: { domain: { id: domain.id } } });
13
- return await tx.getRepository(entities_1.DailyHarvest).findOne({
14
- where: { domain: { id: domain.id }, name, deletedAt: (0, typeorm_1.IsNull)() },
15
- relations: [
16
- 'domain',
17
- 'block',
18
- 'dailyHarvestDetails',
19
- 'dailyHarvestDetails.organizationStaff',
20
- 'dailyHarvestDetails.organizationStaff.organization',
21
- 'creator',
22
- 'updater'
23
- ]
24
- });
25
- },
26
- async dailyHarvests(_, params, context) {
27
- var _a;
28
- const { tx } = context.state;
29
- const queryBuilder = tx.getRepository(entities_1.DailyHarvest).createQueryBuilder();
30
- (0, shell_1.buildQuery)(queryBuilder, params, context);
31
- queryBuilder
32
- .leftJoinAndSelect('DailyHarvest.domain', 'Domain')
33
- .leftJoinAndSelect('DailyHarvest.block', 'Block')
34
- .leftJoinAndSelect('DailyHarvest.creator', 'Creator')
35
- .leftJoinAndSelect('DailyHarvest.updater', 'Updater');
36
- if (((_a = params.filters) === null || _a === void 0 ? void 0 : _a.length) > 0)
37
- queryBuilder.andWhere('DailyHarvest.deletedAt IS NULL');
38
- else
39
- queryBuilder.where('DailyHarvest.deletedAt IS NULL');
40
- const [items, total] = await queryBuilder.getManyAndCount();
41
- return { items, total };
42
- }
43
- };
44
- //# sourceMappingURL=daily-harvest-query.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"daily-harvest-query.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/daily-harvest/daily-harvest-query.ts"],"names":[],"mappings":";;;AAAA,qCAA+C;AAE/C,iDAAqE;AAErE,gDAAyF;AAE5E,QAAA,KAAK,GAAG;IACnB,KAAK,CAAC,YAAY,CAAC,CAAM,EAAE,EAAE,IAAI,EAAE,EAAE,OAAwB;QAC3D,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAEpC,MAAM,WAAW,GAAsB,MAAM,EAAE;aAC5C,aAAa,CAAC,4BAAiB,CAAC;aAChC,OAAO,CAAC,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAA;QAEpD,OAAO,MAAM,EAAE,CAAC,aAAa,CAAC,uBAAkB,CAAC,CAAC,OAAO,CAAC;YACxD,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,IAAA,gBAAM,GAAE,EAAE;YAC/D,SAAS,EAAE;gBACT,QAAQ;gBACR,OAAO;gBACP,qBAAqB;gBACrB,uCAAuC;gBACvC,oDAAoD;gBACpD,SAAS;gBACT,SAAS;aACV;SACF,CAAC,CAAA;IACJ,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAwB;;QACrE,MAAM,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAE5B,MAAM,YAAY,GAAG,EAAE,CAAC,aAAa,CAAC,uBAAkB,CAAC,CAAC,kBAAkB,EAAE,CAAA;QAC9E,IAAA,kBAAU,EAAC,YAAY,EAAE,MAAM,EAAE,OAAO,CAAC,CAAA;QAEzC,YAAY;aACT,iBAAiB,CAAC,qBAAqB,EAAE,QAAQ,CAAC;aAClD,iBAAiB,CAAC,oBAAoB,EAAE,OAAO,CAAC;aAChD,iBAAiB,CAAC,sBAAsB,EAAE,SAAS,CAAC;aACpD,iBAAiB,CAAC,sBAAsB,EAAE,SAAS,CAAC,CAAA;QAEvD,IAAI,CAAA,MAAA,MAAM,CAAC,OAAO,0CAAE,MAAM,IAAG,CAAC;YAAE,YAAY,CAAC,QAAQ,CAAC,gCAAgC,CAAC,CAAA;;YAClF,YAAY,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAA;QAEzD,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,MAAM,YAAY,CAAC,eAAe,EAAE,CAAA;QAE3D,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,CAAA;IACzB,CAAC;CACF,CAAA","sourcesContent":["import { EntityManager, IsNull } from 'typeorm'\n\nimport { buildQuery, Domain, ListParam } from '@things-factory/shell'\n\nimport { DailyHarvest as DailyHarvestEntity, RecordTransaction } from '../../../entities'\n\nexport const Query = {\n async dailyHarvest(_: any, { name }, context: ResolverContext) {\n const { domain, tx } = context.state\n\n const transaction: RecordTransaction = await tx\n .getRepository(RecordTransaction)\n .findOne({ where: { domain: { id: domain.id } } })\n\n return await tx.getRepository(DailyHarvestEntity).findOne({\n where: { domain: { id: domain.id }, name, deletedAt: IsNull() },\n relations: [\n 'domain',\n 'block',\n 'dailyHarvestDetails',\n 'dailyHarvestDetails.organizationStaff',\n 'dailyHarvestDetails.organizationStaff.organization',\n 'creator',\n 'updater'\n ]\n })\n },\n\n async dailyHarvests(_: any, params: ListParam, context: ResolverContext) {\n const { tx } = context.state\n\n const queryBuilder = tx.getRepository(DailyHarvestEntity).createQueryBuilder()\n buildQuery(queryBuilder, params, context)\n\n queryBuilder\n .leftJoinAndSelect('DailyHarvest.domain', 'Domain')\n .leftJoinAndSelect('DailyHarvest.block', 'Block')\n .leftJoinAndSelect('DailyHarvest.creator', 'Creator')\n .leftJoinAndSelect('DailyHarvest.updater', 'Updater')\n\n if (params.filters?.length > 0) queryBuilder.andWhere('DailyHarvest.deletedAt IS NULL')\n else queryBuilder.where('DailyHarvest.deletedAt IS NULL')\n\n const [items, total] = await queryBuilder.getManyAndCount()\n\n return { items, total }\n }\n}\n"]}
@@ -1,40 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.deleteDailyHarvest = void 0;
4
- const typeorm_1 = require("typeorm");
5
- const constants_1 = require("../../../constants");
6
- const entities_1 = require("../../../entities");
7
- const utils_1 = require("../../../utils");
8
- exports.deleteDailyHarvest = {
9
- async deleteDailyHarvest(_, { name }, context) {
10
- try {
11
- const { domain, user, tx } = context.state;
12
- const dailyHarvest = await tx
13
- .getRepository(entities_1.DailyHarvest)
14
- .findOneOrFail({ where: { name, deletedAt: (0, typeorm_1.IsNull)() }, relations: ['block'] });
15
- await tx.getRepository(entities_1.DailyHarvest).update({
16
- domain: { id: domain.id },
17
- name
18
- }, {
19
- deletedAt: new Date()
20
- });
21
- await tx.getRepository(entities_1.DailyHarvestDetail).update({
22
- domain: { id: domain.id },
23
- dailyHarvest: { id: dailyHarvest.id }
24
- }, {
25
- deletedAt: new Date()
26
- });
27
- const foundPlantationInv = await tx.getRepository(entities_1.PlantationInventory).findOne({
28
- where: { domain: { id: domain.id }, block: { id: dailyHarvest.block.id }, type: constants_1.INVENTORY_TYPE.FIELD_BUNCHES },
29
- relations: ['domain', 'block']
30
- });
31
- await tx.getRepository(entities_1.PlantationInventory).save(Object.assign(Object.assign({}, foundPlantationInv), { totalBunches: foundPlantationInv.totalBunches - dailyHarvest.totalBunchHarvested, updater: user }));
32
- await (0, utils_1.generateTransactionHistory)(dailyHarvest.block, domain, null, dailyHarvest.id, dailyHarvest.name, constants_1.TRANSACTION_TYPE.TERMINATED, dailyHarvest.harvestDate, -dailyHarvest.totalBunchHarvested, 0, user, tx);
33
- return true;
34
- }
35
- catch (error) {
36
- throw error;
37
- }
38
- }
39
- };
40
- //# sourceMappingURL=delete-daily-harvest.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"delete-daily-harvest.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/daily-harvest/delete-daily-harvest.ts"],"names":[],"mappings":";;;AAAA,qCAAgC;AAEhC,kDAAqE;AACrE,gDAAyF;AACzF,0CAA2D;AAE9C,QAAA,kBAAkB,GAAG;IAChC,KAAK,CAAC,kBAAkB,CAAC,CAAM,EAAE,EAAE,IAAI,EAAE,EAAE,OAAwB;QACjE,IAAI;YACF,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;YAC1C,MAAM,YAAY,GAAG,MAAM,EAAE;iBAC1B,aAAa,CAAC,uBAAY,CAAC;iBAC3B,aAAa,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,IAAA,gBAAM,GAAE,EAAE,EAAE,SAAS,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,CAAA;YAEhF,MAAM,EAAE,CAAC,aAAa,CAAC,uBAAY,CAAC,CAAC,MAAM,CACzC;gBACE,MAAM,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE;gBACzB,IAAI;aACL,EACD;gBACE,SAAS,EAAE,IAAI,IAAI,EAAE;aACtB,CACF,CAAA;YAED,MAAM,EAAE,CAAC,aAAa,CAAC,6BAAkB,CAAC,CAAC,MAAM,CAC/C;gBACE,MAAM,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE;gBACzB,YAAY,EAAE,EAAE,EAAE,EAAE,YAAY,CAAC,EAAE,EAAE;aACtC,EACD;gBACE,SAAS,EAAE,IAAI,IAAI,EAAE;aACtB,CACF,CAAA;YAED,MAAM,kBAAkB,GAAwB,MAAM,EAAE,CAAC,aAAa,CAAC,8BAAmB,CAAC,CAAC,OAAO,CAAC;gBAClG,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,YAAY,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,0BAAc,CAAC,aAAa,EAAE;gBAC9G,SAAS,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC;aAC/B,CAAC,CAAA;YAEF,MAAM,EAAE,CAAC,aAAa,CAAC,8BAAmB,CAAC,CAAC,IAAI,iCAC3C,kBAAkB,KACrB,YAAY,EAAE,kBAAkB,CAAC,YAAY,GAAG,YAAY,CAAC,mBAAmB,EAChF,OAAO,EAAE,IAAI,IACb,CAAA;YAEF,MAAM,IAAA,kCAA0B,EAC9B,YAAY,CAAC,KAAK,EAClB,MAAM,EACN,IAAI,EACJ,YAAY,CAAC,EAAE,EACf,YAAY,CAAC,IAAI,EACjB,4BAAgB,CAAC,UAAU,EAC3B,YAAY,CAAC,WAAW,EACxB,CAAC,YAAY,CAAC,mBAAmB,EACjC,CAAC,EACD,IAAI,EACJ,EAAE,CACH,CAAA;YAED,OAAO,IAAI,CAAA;SACZ;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,KAAK,CAAA;SACZ;IACH,CAAC;CACF,CAAA","sourcesContent":["import { IsNull } from 'typeorm'\n\nimport { INVENTORY_TYPE, TRANSACTION_TYPE } from '../../../constants'\nimport { DailyHarvest, DailyHarvestDetail, PlantationInventory } from '../../../entities'\nimport { generateTransactionHistory } from '../../../utils'\n\nexport const deleteDailyHarvest = {\n async deleteDailyHarvest(_: any, { name }, context: ResolverContext) {\n try {\n const { domain, user, tx } = context.state\n const dailyHarvest = await tx\n .getRepository(DailyHarvest)\n .findOneOrFail({ where: { name, deletedAt: IsNull() }, relations: ['block'] })\n\n await tx.getRepository(DailyHarvest).update(\n {\n domain: { id: domain.id },\n name\n },\n {\n deletedAt: new Date()\n }\n )\n\n await tx.getRepository(DailyHarvestDetail).update(\n {\n domain: { id: domain.id },\n dailyHarvest: { id: dailyHarvest.id }\n },\n {\n deletedAt: new Date()\n }\n )\n\n const foundPlantationInv: PlantationInventory = await tx.getRepository(PlantationInventory).findOne({\n where: { domain: { id: domain.id }, block: { id: dailyHarvest.block.id }, type: INVENTORY_TYPE.FIELD_BUNCHES },\n relations: ['domain', 'block']\n })\n\n await tx.getRepository(PlantationInventory).save({\n ...foundPlantationInv,\n totalBunches: foundPlantationInv.totalBunches - dailyHarvest.totalBunchHarvested,\n updater: user\n })\n\n await generateTransactionHistory(\n dailyHarvest.block,\n domain,\n null,\n dailyHarvest.id,\n dailyHarvest.name,\n TRANSACTION_TYPE.TERMINATED,\n dailyHarvest.harvestDate,\n -dailyHarvest.totalBunchHarvested,\n 0,\n user,\n tx\n )\n\n return true\n } catch (error) {\n throw error\n }\n }\n}\n"]}
@@ -1,102 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.addPlantationInventory = exports.addDailyHarvestDetail = exports.generateDailyHarvest = void 0;
4
- const typeorm_1 = require("typeorm");
5
- const shell_1 = require("@things-factory/shell");
6
- const constants_1 = require("../../../constants");
7
- const entities_1 = require("../../../entities");
8
- const utils_1 = require("../../../utils");
9
- exports.generateDailyHarvest = {
10
- async generateDailyHarvest(_, { dailyHarvest }, context) {
11
- const { domain, user, tx } = context.state;
12
- let dailyHarvestDetails = dailyHarvest.dailyHarvestDetails;
13
- const block = await tx.getRepository(entities_1.Block).findOne({
14
- where: { domain: { id: domain.id }, name: dailyHarvest.block, deletedAt: (0, typeorm_1.IsNull)() }
15
- });
16
- // get sum of bunch harvested from all staff
17
- const totalBunchHarvested = dailyHarvestDetails.reduce(function (prev, cur) {
18
- return prev + cur.totalBunchHarvested;
19
- }, 0);
20
- const collectedBunch = dailyHarvest.collectedBunch || 0;
21
- let yesterdayBalanceBunchInField = dailyHarvest.yesterdayBalanceBunchInField || 0;
22
- // 1. Create daily harvest
23
- let newDailyHarvest = new entities_1.DailyHarvest();
24
- newDailyHarvest.name = utils_1.NoGenerator.dailyHarvest();
25
- newDailyHarvest.domain = domain;
26
- newDailyHarvest.block = block;
27
- newDailyHarvest.harvestingRound = dailyHarvest.harvestingRound;
28
- newDailyHarvest.harvestDate = dailyHarvest.harvestDate;
29
- newDailyHarvest.coverage = dailyHarvest.coverage;
30
- newDailyHarvest.yesterdayBalanceBunchInField = yesterdayBalanceBunchInField;
31
- newDailyHarvest.totalBunchHarvested = totalBunchHarvested;
32
- newDailyHarvest.collectedBunch = collectedBunch;
33
- newDailyHarvest.balanceBunchInField = yesterdayBalanceBunchInField + totalBunchHarvested - collectedBunch;
34
- newDailyHarvest.status = constants_1.RECORD_STATUS.STORED;
35
- newDailyHarvest.creator = user;
36
- newDailyHarvest.updater = user;
37
- await tx.getRepository(entities_1.DailyHarvest).save(newDailyHarvest);
38
- // 2. Create daily harvest detail
39
- await addDailyHarvestDetail(domain, newDailyHarvest, dailyHarvestDetails.map((record) => {
40
- return Object.assign({}, record);
41
- }), user, tx);
42
- // 3. Create bunches inventory in field
43
- await addPlantationInventory(domain, newDailyHarvest, block, user, tx);
44
- return newDailyHarvest;
45
- }
46
- };
47
- async function addDailyHarvestDetail(domain, newDailyHarvest, dailyHarvestDetails, user, tx) {
48
- const organizationStaffRepo = (tx === null || tx === void 0 ? void 0 : tx.getRepository(entities_1.OrganizationStaff)) || (0, shell_1.getRepository)(entities_1.OrganizationStaff);
49
- const dailyHarvestDetailRepo = (tx === null || tx === void 0 ? void 0 : tx.getRepository(entities_1.DailyHarvestDetail)) || (0, shell_1.getRepository)(entities_1.DailyHarvestDetail);
50
- dailyHarvestDetails = await Promise.all(dailyHarvestDetails.map(async (record) => {
51
- return Object.assign(Object.assign({}, record), { domain, name: utils_1.NoGenerator.dailyHarvestDetail(), organizationStaff: await organizationStaffRepo.findOneBy({ id: record.organizationStaff.id }), dailyHarvest: newDailyHarvest, creator: user, updater: user });
52
- }));
53
- await dailyHarvestDetailRepo.save(dailyHarvestDetails);
54
- }
55
- exports.addDailyHarvestDetail = addDailyHarvestDetail;
56
- async function addPlantationInventory(domain, newDailyHarvest, block, user, tx) {
57
- const plantationInvRepo = (tx === null || tx === void 0 ? void 0 : tx.getRepository(entities_1.PlantationInventory)) || (0, shell_1.getRepository)(entities_1.PlantationInventory);
58
- let existingFieldBunch = await plantationInvRepo.findOne({
59
- where: { domain: { id: domain.id }, block: { id: block.id }, type: constants_1.INVENTORY_TYPE.FIELD_BUNCHES },
60
- relations: ['domain', 'block']
61
- });
62
- let newTotalBunches = 0;
63
- if (existingFieldBunch) {
64
- const totalBunches = existingFieldBunch.totalBunches;
65
- if (totalBunches < 0) {
66
- existingFieldBunch = await plantationInvRepo.save(Object.assign(Object.assign({}, existingFieldBunch), { totalBunches: 0 }));
67
- }
68
- newTotalBunches = existingFieldBunch.totalBunches + newDailyHarvest.totalBunchHarvested;
69
- existingFieldBunch.totalBunches = newTotalBunches;
70
- existingFieldBunch.updater = user;
71
- existingFieldBunch = await plantationInvRepo.save(existingFieldBunch);
72
- await (0, utils_1.generateTransactionHistory)(block, domain, null, newDailyHarvest.id, newDailyHarvest.name, constants_1.TRANSACTION_TYPE.HARVEST, newDailyHarvest.harvestDate, newDailyHarvest.totalBunchHarvested, 0, user, tx);
73
- if (newDailyHarvest.collectedBunch > 0) {
74
- existingFieldBunch.totalBunches -= newDailyHarvest.collectedBunch;
75
- existingFieldBunch.updater = user;
76
- existingFieldBunch = await plantationInvRepo.save(existingFieldBunch);
77
- await (0, utils_1.generateTransactionHistory)(block, domain, null, newDailyHarvest.id, newDailyHarvest.name, constants_1.TRANSACTION_TYPE.LOADING, newDailyHarvest.harvestDate, -newDailyHarvest.collectedBunch, 0, user, tx);
78
- }
79
- }
80
- else {
81
- newTotalBunches = newTotalBunches + newDailyHarvest.totalBunchHarvested;
82
- let plantationInventory = new entities_1.PlantationInventory();
83
- plantationInventory.domain = domain;
84
- plantationInventory.name = utils_1.NoGenerator.fieldBunchName();
85
- plantationInventory.block = block;
86
- plantationInventory.type = constants_1.INVENTORY_TYPE.FIELD_BUNCHES;
87
- plantationInventory.totalBunches = newTotalBunches;
88
- plantationInventory.status = constants_1.INVENTORY_STATUS.STORED;
89
- plantationInventory.creator = user;
90
- plantationInventory.updater = user;
91
- plantationInventory = await plantationInvRepo.save(plantationInventory);
92
- await (0, utils_1.generateTransactionHistory)(block, domain, null, newDailyHarvest.id, newDailyHarvest.name, constants_1.TRANSACTION_TYPE.HARVEST, newDailyHarvest.harvestDate, newDailyHarvest.totalBunchHarvested, 0, user, tx);
93
- if (newDailyHarvest.collectedBunch > 0) {
94
- plantationInventory.totalBunches -= newDailyHarvest.collectedBunch;
95
- plantationInventory.updater = user;
96
- plantationInventory = await plantationInvRepo.save(plantationInventory);
97
- await (0, utils_1.generateTransactionHistory)(block, domain, null, newDailyHarvest.id, newDailyHarvest.name, constants_1.TRANSACTION_TYPE.LOADING, newDailyHarvest.harvestDate, -newDailyHarvest.collectedBunch, 0, user, tx);
98
- }
99
- }
100
- }
101
- exports.addPlantationInventory = addPlantationInventory;
102
- //# sourceMappingURL=generate-daily-harvest.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"generate-daily-harvest.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/daily-harvest/generate-daily-harvest.ts"],"names":[],"mappings":"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","sourcesContent":["import { EntityManager, IsNull, Repository } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { Domain, getRepository } from '@things-factory/shell'\n\nimport { INVENTORY_STATUS, INVENTORY_TYPE, RECORD_STATUS, TRANSACTION_TYPE } from '../../../constants'\nimport { Block, DailyHarvest, DailyHarvestDetail, OrganizationStaff, PlantationInventory } from '../../../entities'\nimport { generateTransactionHistory, NoGenerator } from '../../../utils'\n\nexport const generateDailyHarvest = {\n async generateDailyHarvest(_: any, { dailyHarvest }, context: ResolverContext) {\n const { domain, user, tx } = context.state\n\n let dailyHarvestDetails: DailyHarvestDetail[] = dailyHarvest.dailyHarvestDetails\n\n const block: Block = await tx.getRepository(Block).findOne({\n where: { domain: { id: domain.id }, name: dailyHarvest.block, deletedAt: IsNull() }\n })\n\n // get sum of bunch harvested from all staff\n const totalBunchHarvested: number = dailyHarvestDetails.reduce(function (prev, cur) {\n return prev + cur.totalBunchHarvested\n }, 0)\n\n const collectedBunch: number = dailyHarvest.collectedBunch || 0\n let yesterdayBalanceBunchInField: number = dailyHarvest.yesterdayBalanceBunchInField || 0\n\n // 1. Create daily harvest\n let newDailyHarvest: DailyHarvest = new DailyHarvest()\n newDailyHarvest.name = NoGenerator.dailyHarvest()\n newDailyHarvest.domain = domain\n newDailyHarvest.block = block\n newDailyHarvest.harvestingRound = dailyHarvest.harvestingRound\n newDailyHarvest.harvestDate = dailyHarvest.harvestDate\n newDailyHarvest.coverage = dailyHarvest.coverage\n newDailyHarvest.yesterdayBalanceBunchInField = yesterdayBalanceBunchInField\n newDailyHarvest.totalBunchHarvested = totalBunchHarvested\n newDailyHarvest.collectedBunch = collectedBunch\n newDailyHarvest.balanceBunchInField = yesterdayBalanceBunchInField + totalBunchHarvested - collectedBunch\n newDailyHarvest.status = RECORD_STATUS.STORED\n newDailyHarvest.creator = user\n newDailyHarvest.updater = user\n\n await tx.getRepository(DailyHarvest).save(newDailyHarvest)\n\n // 2. Create daily harvest detail\n await addDailyHarvestDetail(\n domain,\n newDailyHarvest,\n dailyHarvestDetails.map((record: DailyHarvestDetail) => {\n return { ...record }\n }),\n user,\n tx\n )\n\n // 3. Create bunches inventory in field\n await addPlantationInventory(domain, newDailyHarvest, block, user, tx)\n\n return newDailyHarvest\n }\n}\n\nexport async function addDailyHarvestDetail(\n domain: Domain,\n newDailyHarvest: DailyHarvest,\n dailyHarvestDetails: DailyHarvestDetail[],\n user: User,\n tx?: EntityManager\n): Promise<void> {\n const organizationStaffRepo: Repository<OrganizationStaff> =\n tx?.getRepository(OrganizationStaff) || getRepository(OrganizationStaff)\n const dailyHarvestDetailRepo: Repository<DailyHarvestDetail> =\n tx?.getRepository(DailyHarvestDetail) || getRepository(DailyHarvestDetail)\n\n dailyHarvestDetails = await Promise.all(\n dailyHarvestDetails.map(async (record: DailyHarvestDetail) => {\n return {\n ...record,\n domain,\n name: NoGenerator.dailyHarvestDetail(),\n organizationStaff: await organizationStaffRepo.findOneBy({ id: record.organizationStaff.id }),\n dailyHarvest: newDailyHarvest,\n creator: user,\n updater: user\n }\n })\n )\n\n await dailyHarvestDetailRepo.save(dailyHarvestDetails)\n}\n\nexport async function addPlantationInventory(\n domain: Domain,\n newDailyHarvest: DailyHarvest,\n block: Block,\n user: User,\n tx?: EntityManager\n): Promise<void> {\n const plantationInvRepo: Repository<PlantationInventory> =\n tx?.getRepository(PlantationInventory) || getRepository(PlantationInventory)\n\n let existingFieldBunch: PlantationInventory = await plantationInvRepo.findOne({\n where: { domain: { id: domain.id }, block: { id: block.id }, type: INVENTORY_TYPE.FIELD_BUNCHES },\n relations: ['domain', 'block']\n })\n\n let newTotalBunches: number = 0\n\n if (existingFieldBunch) {\n const totalBunches: number = existingFieldBunch.totalBunches\n\n if (totalBunches < 0) {\n existingFieldBunch = await plantationInvRepo.save({ ...existingFieldBunch, totalBunches: 0 })\n }\n\n newTotalBunches = existingFieldBunch.totalBunches + newDailyHarvest.totalBunchHarvested\n\n existingFieldBunch.totalBunches = newTotalBunches\n existingFieldBunch.updater = user\n existingFieldBunch = await plantationInvRepo.save(existingFieldBunch)\n\n await generateTransactionHistory(\n block,\n domain,\n null,\n newDailyHarvest.id,\n newDailyHarvest.name,\n TRANSACTION_TYPE.HARVEST,\n newDailyHarvest.harvestDate,\n newDailyHarvest.totalBunchHarvested,\n 0,\n user,\n tx\n )\n\n if (newDailyHarvest.collectedBunch > 0) {\n existingFieldBunch.totalBunches -= newDailyHarvest.collectedBunch\n existingFieldBunch.updater = user\n existingFieldBunch = await plantationInvRepo.save(existingFieldBunch)\n\n await generateTransactionHistory(\n block,\n domain,\n null,\n newDailyHarvest.id,\n newDailyHarvest.name,\n TRANSACTION_TYPE.LOADING,\n newDailyHarvest.harvestDate,\n -newDailyHarvest.collectedBunch,\n 0,\n user,\n tx\n )\n }\n } else {\n newTotalBunches = newTotalBunches + newDailyHarvest.totalBunchHarvested\n\n let plantationInventory: PlantationInventory = new PlantationInventory()\n plantationInventory.domain = domain\n plantationInventory.name = NoGenerator.fieldBunchName()\n plantationInventory.block = block\n plantationInventory.type = INVENTORY_TYPE.FIELD_BUNCHES\n plantationInventory.totalBunches = newTotalBunches\n plantationInventory.status = INVENTORY_STATUS.STORED\n plantationInventory.creator = user\n plantationInventory.updater = user\n\n plantationInventory = await plantationInvRepo.save(plantationInventory)\n\n await generateTransactionHistory(\n block,\n domain,\n null,\n newDailyHarvest.id,\n newDailyHarvest.name,\n TRANSACTION_TYPE.HARVEST,\n newDailyHarvest.harvestDate,\n newDailyHarvest.totalBunchHarvested,\n 0,\n user,\n tx\n )\n\n if (newDailyHarvest.collectedBunch > 0) {\n plantationInventory.totalBunches -= newDailyHarvest.collectedBunch\n plantationInventory.updater = user\n plantationInventory = await plantationInvRepo.save(plantationInventory)\n\n await generateTransactionHistory(\n block,\n domain,\n null,\n newDailyHarvest.id,\n newDailyHarvest.name,\n TRANSACTION_TYPE.LOADING,\n newDailyHarvest.harvestDate,\n -newDailyHarvest.collectedBunch,\n 0,\n user,\n tx\n )\n }\n }\n}\n"]}
@@ -1,12 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.DailyHarvestResolver = void 0;
4
- const daily_harvest_query_1 = require("./daily-harvest-query");
5
- const generate_daily_harvest_1 = require("./generate-daily-harvest");
6
- const update_daily_harvest_1 = require("./update-daily-harvest");
7
- const delete_daily_harvest_1 = require("./delete-daily-harvest");
8
- exports.DailyHarvestResolver = {
9
- Query: daily_harvest_query_1.Query,
10
- Mutation: Object.assign(Object.assign(Object.assign({}, generate_daily_harvest_1.generateDailyHarvest), update_daily_harvest_1.updateDailyHarvest), delete_daily_harvest_1.deleteDailyHarvest)
11
- };
12
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/daily-harvest/index.ts"],"names":[],"mappings":";;;AAAA,+DAA6C;AAE7C,qEAA+D;AAC/D,iEAA2D;AAC3D,iEAA2D;AAE9C,QAAA,oBAAoB,GAAG;IAClC,KAAK,EAAL,2BAAK;IACL,QAAQ,gDACH,6CAAoB,GACpB,yCAAkB,GAClB,yCAAkB,CACtB;CACF,CAAA","sourcesContent":["import { Query } from './daily-harvest-query'\n\nimport { generateDailyHarvest } from './generate-daily-harvest'\nimport { updateDailyHarvest } from './update-daily-harvest'\nimport { deleteDailyHarvest } from './delete-daily-harvest'\n\nexport const DailyHarvestResolver = {\n Query,\n Mutation: {\n ...generateDailyHarvest,\n ...updateDailyHarvest,\n ...deleteDailyHarvest\n }\n}\n"]}
@@ -1,98 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.updatePlantationInventory = exports.updateDailyHarvest = void 0;
4
- const typeorm_1 = require("typeorm");
5
- const shell_1 = require("@things-factory/shell");
6
- const constants_1 = require("../../../constants");
7
- const entities_1 = require("../../../entities");
8
- const utils_1 = require("../../../utils");
9
- exports.updateDailyHarvest = {
10
- async updateDailyHarvest(_, { name, dailyHarvestPatch }, context) {
11
- const { domain, user, tx } = context.state;
12
- const dailyHarvestRepo = tx.getRepository(entities_1.DailyHarvest);
13
- const dailyHarvestDetailRepo = tx.getRepository(entities_1.DailyHarvestDetail);
14
- const organizationStaffRepo = tx.getRepository(entities_1.OrganizationStaff);
15
- let foundDailyHarvest = await dailyHarvestRepo.findOne({
16
- where: { name },
17
- relations: ['block', 'dailyHarvestDetails', 'dailyHarvestDetails.organizationStaff']
18
- });
19
- // for existing data row
20
- let foundDailyHarvestDetails = foundDailyHarvest.dailyHarvestDetails; // from DB
21
- let existingDailyHarvestDetails = dailyHarvestPatch.dailyHarvestDetails.filter(detail => detail.name !== null); // from client side
22
- // new row has been added
23
- let newDailyHarvestDetails = dailyHarvestPatch.dailyHarvestDetails.filter(detail => detail.name === null);
24
- const block = await tx.getRepository(entities_1.Block).findOne({
25
- where: { domain: { id: domain.id }, name: dailyHarvestPatch.block, deletedAt: (0, typeorm_1.IsNull)() }
26
- });
27
- const collectedBunch = dailyHarvestPatch.collectedBunch || 0;
28
- // get sum of bunch harvested from all staff
29
- var totalBunchHarvested = dailyHarvestPatch.dailyHarvestDetails.reduce(function (prev, cur) {
30
- return prev + cur.totalBunchHarvested;
31
- }, 0);
32
- foundDailyHarvest.block = block;
33
- foundDailyHarvest.coverage = dailyHarvestPatch.coverage;
34
- foundDailyHarvest.harvestingRound = dailyHarvestPatch.harvestingRound;
35
- foundDailyHarvest.yesterdayBalanceBunchInField = dailyHarvestPatch.yesterdayBalanceBunchInField;
36
- foundDailyHarvest.totalBunchHarvested = totalBunchHarvested;
37
- foundDailyHarvest.collectedBunch = collectedBunch;
38
- foundDailyHarvest.balanceBunchInField =
39
- foundDailyHarvest.yesterdayBalanceBunchInField + totalBunchHarvested - collectedBunch;
40
- foundDailyHarvest.harvestDate = dailyHarvestPatch.harvestDate;
41
- foundDailyHarvest.updater = user;
42
- await dailyHarvestRepo.save(foundDailyHarvest);
43
- if ((existingDailyHarvestDetails === null || existingDailyHarvestDetails === void 0 ? void 0 : existingDailyHarvestDetails.length) > 0) {
44
- await Promise.all(foundDailyHarvestDetails.map(async (record) => {
45
- if (record.totalBunchHarvested == 0) {
46
- await dailyHarvestDetailRepo.delete(record.id);
47
- }
48
- else {
49
- const foundDailyHarvestDetailPatch = dailyHarvestPatch.dailyHarvestDetails.find(detail => detail.name === record.name);
50
- const foundStaff = await organizationStaffRepo.findOne({
51
- where: { id: foundDailyHarvestDetailPatch.organizationStaff.id }
52
- });
53
- await dailyHarvestDetailRepo.save(Object.assign(Object.assign({}, record), { dailyHarvest: foundDailyHarvest, organizationStaff: foundStaff, totalBunchHarvested: foundDailyHarvestDetailPatch.totalBunchHarvested, totalTonnageHarvested: foundDailyHarvestDetailPatch.totalTonnageHarvested, remark: foundDailyHarvestDetailPatch.remark, updater: user }));
54
- }
55
- }));
56
- }
57
- // during edit user add new row
58
- if ((newDailyHarvestDetails === null || newDailyHarvestDetails === void 0 ? void 0 : newDailyHarvestDetails.length) > 0) {
59
- await Promise.all(newDailyHarvestDetails.map(async (dailyHarvestDetail) => {
60
- let newDailyHarvestDetail = new entities_1.DailyHarvestDetail();
61
- newDailyHarvestDetail.dailyHarvest = await dailyHarvestRepo.findOne({
62
- where: { domain: { id: domain.id }, name }
63
- });
64
- newDailyHarvestDetail.domain = domain;
65
- newDailyHarvestDetail.name = utils_1.NoGenerator.dailyHarvestDetail();
66
- newDailyHarvestDetail.organizationStaff = await organizationStaffRepo.findOneBy({
67
- id: dailyHarvestDetail.organizationStaff.id
68
- });
69
- newDailyHarvestDetail.totalBunchHarvested = dailyHarvestDetail.totalBunchHarvested;
70
- newDailyHarvestDetail.totalTonnageHarvested = dailyHarvestDetail.totalTonnageHarvested;
71
- newDailyHarvestDetail.remark = dailyHarvestDetail.remark;
72
- newDailyHarvestDetail.creator = user;
73
- newDailyHarvestDetail.updater = user;
74
- await dailyHarvestDetailRepo.save(newDailyHarvestDetail);
75
- }));
76
- }
77
- await updatePlantationInventory(domain, foundDailyHarvest, block, user, tx);
78
- return foundDailyHarvest;
79
- }
80
- };
81
- async function updatePlantationInventory(domain, foundDailyHarvest, block, user, tx) {
82
- const plantationInvRepo = (tx === null || tx === void 0 ? void 0 : tx.getRepository(entities_1.PlantationInventory)) || (0, shell_1.getRepository)(entities_1.PlantationInventory);
83
- let existingPlantationInventory = await plantationInvRepo.findOne({
84
- where: { domain: { id: domain.id }, block: { id: block.id }, type: constants_1.INVENTORY_TYPE.FIELD_BUNCHES },
85
- relations: ['domain', 'block', 'ramp']
86
- });
87
- if (!existingPlantationInventory)
88
- throw new Error('Unable to find plantation bunches inventory');
89
- let newTotalBunches = 0;
90
- let currentBunchInField = existingPlantationInventory.totalBunches;
91
- newTotalBunches = foundDailyHarvest.totalBunchHarvested - currentBunchInField;
92
- existingPlantationInventory.totalBunches = currentBunchInField + newTotalBunches;
93
- existingPlantationInventory.updater = user;
94
- await plantationInvRepo.save(existingPlantationInventory);
95
- await (0, utils_1.generateTransactionHistory)(block, domain, null, foundDailyHarvest.id, foundDailyHarvest.name, constants_1.TRANSACTION_TYPE.BUNCHES_ADJUSTMENT, foundDailyHarvest.harvestDate, newTotalBunches, 0, user, tx);
96
- }
97
- exports.updatePlantationInventory = updatePlantationInventory;
98
- //# sourceMappingURL=update-daily-harvest.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"update-daily-harvest.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/daily-harvest/update-daily-harvest.ts"],"names":[],"mappings":"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","sourcesContent":["import { EntityManager, IsNull, Repository } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { Domain, getRepository } from '@things-factory/shell'\n\nimport { INVENTORY_TYPE, TRANSACTION_TYPE } from '../../../constants'\nimport { Block, DailyHarvest, DailyHarvestDetail, OrganizationStaff, PlantationInventory } from '../../../entities'\nimport { generateTransactionHistory, NoGenerator } from '../../../utils'\n\nexport const updateDailyHarvest = {\n async updateDailyHarvest(_: any, { name, dailyHarvestPatch }, context: ResolverContext) {\n const { domain, user, tx } = context.state\n const dailyHarvestRepo = tx.getRepository(DailyHarvest)\n const dailyHarvestDetailRepo = tx.getRepository(DailyHarvestDetail)\n const organizationStaffRepo = tx.getRepository(OrganizationStaff)\n\n let foundDailyHarvest: DailyHarvest = await dailyHarvestRepo.findOne({\n where: { name },\n relations: ['block', 'dailyHarvestDetails', 'dailyHarvestDetails.organizationStaff']\n })\n\n // for existing data row\n let foundDailyHarvestDetails: DailyHarvestDetail[] = foundDailyHarvest.dailyHarvestDetails // from DB\n let existingDailyHarvestDetails: DailyHarvestDetail[] = dailyHarvestPatch.dailyHarvestDetails.filter(\n detail => detail.name !== null\n ) // from client side\n\n // new row has been added\n let newDailyHarvestDetails: DailyHarvestDetail[] = dailyHarvestPatch.dailyHarvestDetails.filter(\n detail => detail.name === null\n )\n\n const block: Block = await tx.getRepository(Block).findOne({\n where: { domain: { id: domain.id }, name: dailyHarvestPatch.block, deletedAt: IsNull() }\n })\n\n const collectedBunch: number = dailyHarvestPatch.collectedBunch || 0\n\n // get sum of bunch harvested from all staff\n var totalBunchHarvested = dailyHarvestPatch.dailyHarvestDetails.reduce(function (prev, cur) {\n return prev + cur.totalBunchHarvested\n }, 0)\n\n foundDailyHarvest.block = block\n foundDailyHarvest.coverage = dailyHarvestPatch.coverage\n foundDailyHarvest.harvestingRound = dailyHarvestPatch.harvestingRound\n foundDailyHarvest.yesterdayBalanceBunchInField = dailyHarvestPatch.yesterdayBalanceBunchInField\n foundDailyHarvest.totalBunchHarvested = totalBunchHarvested\n foundDailyHarvest.collectedBunch = collectedBunch\n foundDailyHarvest.balanceBunchInField =\n foundDailyHarvest.yesterdayBalanceBunchInField + totalBunchHarvested - collectedBunch\n foundDailyHarvest.harvestDate = dailyHarvestPatch.harvestDate\n foundDailyHarvest.updater = user\n await dailyHarvestRepo.save(foundDailyHarvest)\n\n if (existingDailyHarvestDetails?.length > 0) {\n await Promise.all(\n foundDailyHarvestDetails.map(async (record: DailyHarvestDetail) => {\n if (record.totalBunchHarvested == 0) {\n await dailyHarvestDetailRepo.delete(record.id)\n } else {\n const foundDailyHarvestDetailPatch = dailyHarvestPatch.dailyHarvestDetails.find(\n detail => detail.name === record.name\n )\n\n const foundStaff: OrganizationStaff = await organizationStaffRepo.findOne({\n where: { id: foundDailyHarvestDetailPatch.organizationStaff.id }\n })\n\n await dailyHarvestDetailRepo.save({\n ...record,\n dailyHarvest: foundDailyHarvest,\n organizationStaff: foundStaff,\n totalBunchHarvested: foundDailyHarvestDetailPatch.totalBunchHarvested,\n totalTonnageHarvested: foundDailyHarvestDetailPatch.totalTonnageHarvested,\n remark: foundDailyHarvestDetailPatch.remark,\n updater: user\n })\n }\n })\n )\n }\n\n // during edit user add new row\n if (newDailyHarvestDetails?.length > 0) {\n await Promise.all(\n newDailyHarvestDetails.map(async (dailyHarvestDetail: DailyHarvestDetail) => {\n let newDailyHarvestDetail: DailyHarvestDetail = new DailyHarvestDetail()\n newDailyHarvestDetail.dailyHarvest = await dailyHarvestRepo.findOne({\n where: { domain: { id: domain.id }, name }\n })\n newDailyHarvestDetail.domain = domain\n newDailyHarvestDetail.name = NoGenerator.dailyHarvestDetail()\n newDailyHarvestDetail.organizationStaff = await organizationStaffRepo.findOneBy({\n id: dailyHarvestDetail.organizationStaff.id\n })\n newDailyHarvestDetail.totalBunchHarvested = dailyHarvestDetail.totalBunchHarvested\n newDailyHarvestDetail.totalTonnageHarvested = dailyHarvestDetail.totalTonnageHarvested\n newDailyHarvestDetail.remark = dailyHarvestDetail.remark\n newDailyHarvestDetail.creator = user\n newDailyHarvestDetail.updater = user\n\n await dailyHarvestDetailRepo.save(newDailyHarvestDetail)\n })\n )\n }\n\n await updatePlantationInventory(domain, foundDailyHarvest, block, user, tx)\n\n return foundDailyHarvest\n }\n}\n\nexport async function updatePlantationInventory(\n domain: Domain,\n foundDailyHarvest: DailyHarvest,\n block: Block,\n user: User,\n tx?: EntityManager\n): Promise<void> {\n const plantationInvRepo: Repository<PlantationInventory> =\n tx?.getRepository(PlantationInventory) || getRepository(PlantationInventory)\n\n let existingPlantationInventory: PlantationInventory = await plantationInvRepo.findOne({\n where: { domain: { id: domain.id }, block: { id: block.id }, type: INVENTORY_TYPE.FIELD_BUNCHES },\n relations: ['domain', 'block', 'ramp']\n })\n\n if (!existingPlantationInventory) throw new Error('Unable to find plantation bunches inventory')\n\n let newTotalBunches: number = 0\n let currentBunchInField: number = existingPlantationInventory.totalBunches\n\n newTotalBunches = foundDailyHarvest.totalBunchHarvested - currentBunchInField\n\n existingPlantationInventory.totalBunches = currentBunchInField + newTotalBunches\n existingPlantationInventory.updater = user\n await plantationInvRepo.save(existingPlantationInventory)\n\n await generateTransactionHistory(\n block,\n domain,\n null,\n foundDailyHarvest.id,\n foundDailyHarvest.name,\n TRANSACTION_TYPE.BUNCHES_ADJUSTMENT,\n foundDailyHarvest.harvestDate,\n newTotalBunches,\n 0,\n user,\n tx\n )\n}\n"]}