@things-factory/operato-wms 5.0.2 → 5.0.11

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 (127) hide show
  1. package/config.development.js +73 -0
  2. package/config.production.js +113 -0
  3. package/dist-server/graphql/index.js +3 -25
  4. package/dist-server/graphql/index.js.map +1 -1
  5. package/dist-server/graphql/resolvers/board-setting/board-settings.js.map +1 -1
  6. package/dist-server/graphql/resolvers/board-setting/index.js.map +1 -1
  7. package/dist-server/graphql/resolvers/custom/elccl/elccl-daily-collection-report.js.map +1 -1
  8. package/dist-server/graphql/resolvers/custom/elccl/elccl-daily-order-inventory-report.js.map +1 -1
  9. package/dist-server/graphql/resolvers/custom/elccl/elccl-inventory-history-pallet-detail-report.js.map +1 -1
  10. package/dist-server/graphql/resolvers/custom/elccl/elccl-inventory-history-report.js.map +1 -1
  11. package/dist-server/graphql/resolvers/custom/elccl/elccl-inventory-history-summary-report.js.map +1 -1
  12. package/dist-server/graphql/resolvers/custom/elccl/elccl-onhand-inventory-counter.js.map +1 -1
  13. package/dist-server/graphql/resolvers/custom/elccl/index.js.map +1 -1
  14. package/dist-server/graphql/resolvers/custom/kimeda/index.js.map +1 -1
  15. package/dist-server/graphql/resolvers/custom/kimeda/kimeda-onhand-inventory-counter.js.map +1 -1
  16. package/dist-server/graphql/resolvers/dashboard/arrival-notices-by-status.js.map +1 -1
  17. package/dist-server/graphql/resolvers/dashboard/collection-orders-by-status.js.map +1 -1
  18. package/dist-server/graphql/resolvers/dashboard/delivery-orders-by-status.js.map +1 -1
  19. package/dist-server/graphql/resolvers/dashboard/index.js.map +1 -1
  20. package/dist-server/graphql/resolvers/dashboard/inventory-expiry-monitor.js +2 -12
  21. package/dist-server/graphql/resolvers/dashboard/inventory-expiry-monitor.js.map +1 -1
  22. package/dist-server/graphql/resolvers/dashboard/outbound-order-by-status.js.map +1 -1
  23. package/dist-server/graphql/resolvers/dashboard/release-goods-by-status.js.map +1 -1
  24. package/dist-server/graphql/resolvers/extra/add-release-good-products.js.map +1 -1
  25. package/dist-server/graphql/resolvers/extra/index.js.map +1 -1
  26. package/dist-server/graphql/resolvers/index.js +11 -33
  27. package/dist-server/graphql/resolvers/index.js.map +1 -1
  28. package/dist-server/graphql/resolvers/inventory-comparison/index.js.map +1 -1
  29. package/dist-server/graphql/resolvers/inventory-comparison/inventory-comparison-list.js.map +1 -1
  30. package/dist-server/graphql/resolvers/opa-menu/index.js.map +1 -1
  31. package/dist-server/graphql/resolvers/opa-menu/opa-menus.js.map +1 -1
  32. package/dist-server/graphql/resolvers/reports/costing-report.js.map +1 -1
  33. package/dist-server/graphql/resolvers/reports/inbound-order-details-report.js.map +1 -1
  34. package/dist-server/graphql/resolvers/reports/inbound-serial-number-report.js.map +1 -1
  35. package/dist-server/graphql/resolvers/reports/index.js.map +1 -1
  36. package/dist-server/graphql/resolvers/reports/outbound-order-details-report.js.map +1 -1
  37. package/dist-server/graphql/resolvers/reports/outbound-serial-number-report.js.map +1 -1
  38. package/dist-server/graphql/resolvers/reports/product-label-report.js.map +1 -1
  39. package/dist-server/graphql/resolvers/shipping-provider/index.js.map +1 -1
  40. package/dist-server/graphql/resolvers/shipping-provider/shipping-providers.js.map +1 -1
  41. package/dist-server/graphql/resolvers/warehouse-inventory-adjustment/index.js.map +1 -1
  42. package/dist-server/graphql/resolvers/warehouse-inventory-adjustment/warehouse-intentory-adjustment.js.map +1 -1
  43. package/dist-server/graphql/types/board-setting/board-setting.js +2 -4
  44. package/dist-server/graphql/types/board-setting/board-setting.js.map +1 -1
  45. package/dist-server/graphql/types/board-setting/index.js.map +1 -1
  46. package/dist-server/graphql/types/custom/elccl/elccl-daily-collection-report-list.js +2 -4
  47. package/dist-server/graphql/types/custom/elccl/elccl-daily-collection-report-list.js.map +1 -1
  48. package/dist-server/graphql/types/custom/elccl/elccl-daily-collection-report.js +2 -4
  49. package/dist-server/graphql/types/custom/elccl/elccl-daily-collection-report.js.map +1 -1
  50. package/dist-server/graphql/types/custom/elccl/elccl-daily-order-inventory-report-list.js +2 -4
  51. package/dist-server/graphql/types/custom/elccl/elccl-daily-order-inventory-report-list.js.map +1 -1
  52. package/dist-server/graphql/types/custom/elccl/elccl-daily-order-inventory-report.js +2 -4
  53. package/dist-server/graphql/types/custom/elccl/elccl-daily-order-inventory-report.js.map +1 -1
  54. package/dist-server/graphql/types/custom/elccl/elccl-inventory-report.js +2 -4
  55. package/dist-server/graphql/types/custom/elccl/elccl-inventory-report.js.map +1 -1
  56. package/dist-server/graphql/types/custom/elccl/elccl-inventory-summary-report-list.js +2 -4
  57. package/dist-server/graphql/types/custom/elccl/elccl-inventory-summary-report-list.js.map +1 -1
  58. package/dist-server/graphql/types/custom/elccl/elccl-inventory-summary-report.js +2 -4
  59. package/dist-server/graphql/types/custom/elccl/elccl-inventory-summary-report.js.map +1 -1
  60. package/dist-server/graphql/types/custom/elccl/elccl-pallet-detail-report.js +2 -4
  61. package/dist-server/graphql/types/custom/elccl/elccl-pallet-detail-report.js.map +1 -1
  62. package/dist-server/graphql/types/custom/elccl/index.js.map +1 -1
  63. package/dist-server/graphql/types/custom/kimeda/index.js.map +1 -1
  64. package/dist-server/graphql/types/dashboard/index.js.map +1 -1
  65. package/dist-server/graphql/types/dashboard/inventory-expiry-counter.js +2 -4
  66. package/dist-server/graphql/types/dashboard/inventory-expiry-counter.js.map +1 -1
  67. package/dist-server/graphql/types/dashboard/inventory-expiry-status.js +2 -4
  68. package/dist-server/graphql/types/dashboard/inventory-expiry-status.js.map +1 -1
  69. package/dist-server/graphql/types/dashboard/order-status-counter.js +2 -4
  70. package/dist-server/graphql/types/dashboard/order-status-counter.js.map +1 -1
  71. package/dist-server/graphql/types/extra/index.js.map +1 -1
  72. package/dist-server/graphql/types/index.js +11 -33
  73. package/dist-server/graphql/types/index.js.map +1 -1
  74. package/dist-server/graphql/types/inventory-comparison/index.js.map +1 -1
  75. package/dist-server/graphql/types/inventory-comparison/inventory-comparison-list.js +2 -4
  76. package/dist-server/graphql/types/inventory-comparison/inventory-comparison-list.js.map +1 -1
  77. package/dist-server/graphql/types/inventory-comparison/inventory-comparison.js +2 -4
  78. package/dist-server/graphql/types/inventory-comparison/inventory-comparison.js.map +1 -1
  79. package/dist-server/graphql/types/opa-menu/index.js.map +1 -1
  80. package/dist-server/graphql/types/opa-menu/opa-menu.js +2 -4
  81. package/dist-server/graphql/types/opa-menu/opa-menu.js.map +1 -1
  82. package/dist-server/graphql/types/reports/costing-report-list.js +2 -4
  83. package/dist-server/graphql/types/reports/costing-report-list.js.map +1 -1
  84. package/dist-server/graphql/types/reports/costing-report.js +2 -4
  85. package/dist-server/graphql/types/reports/costing-report.js.map +1 -1
  86. package/dist-server/graphql/types/reports/inbound-order-details-report-list.js +2 -4
  87. package/dist-server/graphql/types/reports/inbound-order-details-report-list.js.map +1 -1
  88. package/dist-server/graphql/types/reports/inbound-order-details-report.js +2 -4
  89. package/dist-server/graphql/types/reports/inbound-order-details-report.js.map +1 -1
  90. package/dist-server/graphql/types/reports/inbound-serial-number-report-list.js +2 -4
  91. package/dist-server/graphql/types/reports/inbound-serial-number-report-list.js.map +1 -1
  92. package/dist-server/graphql/types/reports/inbound-serial-number-report.js +2 -4
  93. package/dist-server/graphql/types/reports/inbound-serial-number-report.js.map +1 -1
  94. package/dist-server/graphql/types/reports/index.js.map +1 -1
  95. package/dist-server/graphql/types/reports/outbound-order-details-report-list.js +2 -4
  96. package/dist-server/graphql/types/reports/outbound-order-details-report-list.js.map +1 -1
  97. package/dist-server/graphql/types/reports/outbound-order-details-report.js +2 -4
  98. package/dist-server/graphql/types/reports/outbound-order-details-report.js.map +1 -1
  99. package/dist-server/graphql/types/reports/outbound-serial-number-report-list.js +2 -4
  100. package/dist-server/graphql/types/reports/outbound-serial-number-report-list.js.map +1 -1
  101. package/dist-server/graphql/types/reports/outbound-serial-number-report.js +2 -4
  102. package/dist-server/graphql/types/reports/outbound-serial-number-report.js.map +1 -1
  103. package/dist-server/graphql/types/reports/product-label-report-list.js +2 -4
  104. package/dist-server/graphql/types/reports/product-label-report-list.js.map +1 -1
  105. package/dist-server/graphql/types/reports/product-label-report.js +2 -4
  106. package/dist-server/graphql/types/reports/product-label-report.js.map +1 -1
  107. package/dist-server/graphql/types/shipping-provider/index.js.map +1 -1
  108. package/dist-server/graphql/types/shipping-provider/shipping-provider-list.js +2 -4
  109. package/dist-server/graphql/types/shipping-provider/shipping-provider-list.js.map +1 -1
  110. package/dist-server/graphql/types/shipping-provider/shipping-provider.js +2 -4
  111. package/dist-server/graphql/types/shipping-provider/shipping-provider.js.map +1 -1
  112. package/dist-server/graphql/types/warehouse-inventory-adjustment/index.js.map +1 -1
  113. package/dist-server/index.js +3 -16
  114. package/dist-server/index.js.map +1 -1
  115. package/dist-server/migrations/1568858861188-SeedSetting.js.map +1 -1
  116. package/dist-server/migrations/1623308919899-SeedLocationRecommendSetting.js.map +1 -1
  117. package/dist-server/migrations/1623381200659-SeedStoringRule.js.map +1 -1
  118. package/dist-server/migrations/index.js.map +1 -1
  119. package/dist-server/opa-app-setting-constants.js.map +1 -1
  120. package/dist-server/routes.js +0 -1
  121. package/dist-server/routes.js.map +1 -1
  122. package/dist-server/tsconfig.tsbuildinfo +1 -0
  123. package/dist-server/utils/index.js +2 -15
  124. package/dist-server/utils/index.js.map +1 -1
  125. package/dist-server/utils/report-query-util.js.map +1 -1
  126. package/package.json +37 -37
  127. package/server/routes.ts +0 -2
@@ -0,0 +1,73 @@
1
+ module.exports = {
2
+ useVirtualHostBasedDomain: false,
3
+ ormconfig: {
4
+ name: 'default',
5
+ type: 'postgres',
6
+ host: 'operato-instance-1.cijhm4n1hbst.ap-southeast-1.rds.amazonaws.com',
7
+ database: 'operato',
8
+ username: 'operato',
9
+ password: 'abcd1234',
10
+ port: 55432,
11
+ synchronize: false,
12
+ logging: true
13
+ },
14
+ reportApiUrl: 'http://localhost:8090/rest/report/show_html',
15
+ storage: {
16
+ type: 's3',
17
+ accessKeyId: 'AKIAUQEOPWEJCDH6AR5H',
18
+ secretAccessKey: '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',
19
+ bucketName: 'opa-one'
20
+ },
21
+ port: 3000,
22
+ uploads: 'uploads',
23
+ attachmentsPath: 'attachments',
24
+ SECRET: '0xD58F835B69D207A76CC5F84a70a1D0d4C79dfC95',
25
+ logger: {
26
+ file: {
27
+ filename: 'logs/application-%DATE%.log',
28
+ datePattern: 'YYYY-MM-DD-HH',
29
+ zippedArchive: true,
30
+ maxSize: '200m',
31
+ maxFiles: '1m',
32
+ level: 'info'
33
+ }
34
+ },
35
+
36
+ email: {
37
+ host: 'smtp.office365.com',
38
+ port: 587,
39
+ secure: false, // true for 465, false for other ports
40
+ auth: {
41
+ user: 'no-reply@hatiolab.com', // generated ethereal user
42
+ pass: 'h@ti0LAB1008' // generated ethereal password
43
+ },
44
+ secureConnection: false,
45
+ tls: {
46
+ ciphers: 'SSLv3'
47
+ }
48
+ },
49
+
50
+ notification: {
51
+ fcm: {
52
+ serviceAccount: {
53
+ project_id: 'operato',
54
+ private_key:
55
+ '-----BEGIN PRIVATE KEY-----\nMIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQDYNOfyNjPMSeG9\nzU1qs0cpVK5cVfadcUaw5g+hkQZMOMlAA7uqW2eX4vkayj7MzbYUayH+sei8044Q\nJIyl6f26dNX1VT3UgTmSmCS0v48EBEZHCgusrUGFjduLRN6OS6uvrXW1xKA18k9q\nai1C2EHCXF2AE4PTvf239RC1UIOnVePcMtT7rMTdHRO4s8OKVuSDbzIt8k1cV3Zt\nES0YsJlkELqBisYpV//2/ZSILTt39J9JzrVef03X9kkoo9p+YnNyy6tWsfQPfgJO\nybiRGBNxiyJ/E2pxRo/WqU0go9OzYJlGaSUrUx09heNiRD1b0MAOmyPDJz/6AaTk\nkU/A+kLzAgMBAAECggEADQ5s2gtR53VSujk1V/Xe8e0Di99DwaWUj5w6YhcK7/wX\nPdQRN4Fw6RLeLjL7xeG/rCNSwzm6hKSrQJL5zLnWW7XbMdyQRk6jdmnVAEv3zACi\nFH9+eFK3e+Q214XfgWz/v4p/FZdRLCYni5VBNHcwyWxLLS/V1ynzB3KM1sDiTRmI\npcT7+uTtwrKgJq64sXtFE2pYrFxDdCiyqzkhv/2ed4YIowAjpKBbbcCDKeVxVkoz\nC1P4PAzs9EeUuKSWYrWaUjN17lqtRlYeT1ylR1PIJuWqd4cKfgoEgz+lHwRPDCEX\nAYbk3nofiJIPBhSfCHrXS755wK48mY8vMwFdfCPJeQKBgQDsz4tjYTHdat5A25n5\nekwMxZwFQ5OvMV4eulwZUDMypTAYSz1iB6sDlgwKDm5omZIfuneqCEIvrqxV/kx3\n5wV/DANHO3hYxdp/NV7rM23xmqlaKZhHQbDono1Fm/LP6DEmJiD7N2eFKsXYcPpR\nSAIdCv0X3zkDQ4zRi51yJlCXzQKBgQDpufJBxCoXngiQJ2j14lWVAeOOdQ6zh5Ip\nBcDwF0X67cNSN3Wl40bS4yLFdolhEAyj5m0WPuYYXpjzhHhZ0W3V3ItdBkrmwIvy\nWOWu26qN0ZbwxVS2qVpHuj6iHWJKHuDZZUkFtJg3BeeBSOUHSA8TvjnA0xd83xeb\n8ZJasWoFvwKBgQDFs/gQ/gIdcq0exLfluh5nw0qgcmyHpNWJHdjqITS9IX/nqFkU\n0IYLtmdStf2jQiLmbkydHcvz9wZVvLqml67VBHhwLcwpgPULoskd34/4V0Dvzy4c\nv1Esw8H5zVqIDLeLu+VpFjZMzQrjyl6RIWbyTExEc84rVWfpQYAu3qIGOQKBgAFr\nXatEk7TdAtRNSPflTfu/rTAaSeKROjQBkvBiU8x4US1YpOBDBxUUyAtG8wKh5FHC\nfnsaGq+fM3KXJVv2R6J62mXQOfg4xyDLpWlwcBK4aSBBMoiBcsjouqSlZQlqMpdf\nZBgixqHe6U8BsFJg/6ZxC0y+e3AIss4Bo4/lb+1lAoGAFOexvaBh21K6W3inmRW4\nLlkVYJaBJ20OwokXg5aXjBiHxqmk7VLAuFbkpb5LOKH2xPILRQ0OEkn51yVymS3T\n9lLpHOFTQXt5tF2/F7NW7kaQJNlLr/h5jPi3O9XHeFmuaN2z150ZB6zzgjeGKzr8\ni+1fgTsRfDtNw8xkSH9qL1Y=\n-----END PRIVATE KEY-----\n',
56
+ client_email: 'firebase-adminsdk-xmm2e@operato.iam.gserviceaccount.com'
57
+ },
58
+ appConfig: {
59
+ apiKey: 'AIzaSyDdTM2BTLHSt2LNS0G5QB8G0i4KBXFiG7U',
60
+ projectId: 'operato',
61
+ messagingSenderId: 79537064975,
62
+ appId: '1:79537064975:web:32f53119e9c8c6ee2a277a'
63
+ },
64
+ serverKey:
65
+ 'AAAAEoTHTA8:APA91bGwt-4HT82Dfwf_VwbQaKT0_qHd0Y3tuW41udjWz5Lz0Ko0mEMD6WbHHSILvQpa6yuoGGKCMsrU7VW2qWRrUm3CYpyG9oSwshNm1tIhljAnOuUfwHCoawbVLwf9qlWpHt4dwCoc'
66
+ },
67
+ vapidKey: {
68
+ subject: 'mailto:heartyoh@hatiolab.com',
69
+ publicKey: 'BAkVkITsCXBIsYL1yeaBmx5_dn57we-ZXMjirPPHzC2dan82cdEnAio_53PQ-1_w3ykWCBPrrFAWQ_d9N4cFF0o',
70
+ privateKey: '4pmlt3Wk019u7nqU3Q_oGZE6LbUDjjf8DpmAcn9-iss'
71
+ }
72
+ }
73
+ }
@@ -0,0 +1,113 @@
1
+ module.exports = {
2
+ useVirtualHostBasedDomain: false,
3
+
4
+ ormconfig: {
5
+ name: 'default',
6
+
7
+ type: 'postgres',
8
+
9
+ host: 'operato-instance-1.cijhm4n1hbst.ap-southeast-1.rds.amazonaws.com',
10
+
11
+ database: 'operato',
12
+
13
+ username: 'operato',
14
+
15
+ password: 'abcd1234',
16
+
17
+ port: 55432,
18
+
19
+ synchronize: false,
20
+
21
+ logging: true
22
+ },
23
+
24
+ reportApiUrl: 'http://localhost:8090/rest/report/show_html',
25
+
26
+ storage: {
27
+ type: 's3',
28
+
29
+ accessKeyId: 'AKIAUQEOPWEJCDH6AR5H',
30
+
31
+ secretAccessKey: 'AuDAgmODf9EJNB24OveRhTSLV/OJy6IFFoRxe8k2',
32
+
33
+ bucketName: 'opa-one'
34
+ },
35
+
36
+ port: 3000,
37
+
38
+ uploads: 'uploads',
39
+
40
+ attachmentsPath: 'attachments',
41
+
42
+ SECRET: '0xD58F835B69D207A76CC5F84a70a1D0d4C79dfC95',
43
+
44
+ logger: {
45
+ file: {
46
+ filename: 'logs/application-%DATE%.log',
47
+
48
+ datePattern: 'YYYY-MM-DD-HH',
49
+
50
+ zippedArchive: true,
51
+
52
+ maxSize: '200m',
53
+
54
+ maxFiles: '1m',
55
+
56
+ level: 'info'
57
+ }
58
+ },
59
+
60
+ email: {
61
+ host: 'smtp.office365.com',
62
+
63
+ port: 587,
64
+
65
+ secure: false, // true for 465, false for other ports
66
+
67
+ auth: {
68
+ user: 'no-reply@hatiolab.com', // generated ethereal user
69
+
70
+ pass: 'h@ti0LAB1008' // generated ethereal password
71
+ },
72
+
73
+ secureConnection: false,
74
+
75
+ tls: {
76
+ ciphers: 'SSLv3'
77
+ }
78
+ },
79
+
80
+ notification: {
81
+ fcm: {
82
+ serviceAccount: {
83
+ project_id: 'operato',
84
+
85
+ private_key:
86
+ '-----BEGIN PRIVATE KEY-----\nMIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQDYNOfyNjPMSeG9\nzU1qs0cpVK5cVfadcUaw5g+hkQZMOMlAA7uqW2eX4vkayj7MzbYUayH+sei8044Q\nJIyl6f26dNX1VT3UgTmSmCS0v48EBEZHCgusrUGFjduLRN6OS6uvrXW1xKA18k9q\nai1C2EHCXF2AE4PTvf239RC1UIOnVePcMtT7rMTdHRO4s8OKVuSDbzIt8k1cV3Zt\nES0YsJlkELqBisYpV//2/ZSILTt39J9JzrVef03X9kkoo9p+YnNyy6tWsfQPfgJO\nybiRGBNxiyJ/E2pxRo/WqU0go9OzYJlGaSUrUx09heNiRD1b0MAOmyPDJz/6AaTk\nkU/A+kLzAgMBAAECggEADQ5s2gtR53VSujk1V/Xe8e0Di99DwaWUj5w6YhcK7/wX\nPdQRN4Fw6RLeLjL7xeG/rCNSwzm6hKSrQJL5zLnWW7XbMdyQRk6jdmnVAEv3zACi\nFH9+eFK3e+Q214XfgWz/v4p/FZdRLCYni5VBNHcwyWxLLS/V1ynzB3KM1sDiTRmI\npcT7+uTtwrKgJq64sXtFE2pYrFxDdCiyqzkhv/2ed4YIowAjpKBbbcCDKeVxVkoz\nC1P4PAzs9EeUuKSWYrWaUjN17lqtRlYeT1ylR1PIJuWqd4cKfgoEgz+lHwRPDCEX\nAYbk3nofiJIPBhSfCHrXS755wK48mY8vMwFdfCPJeQKBgQDsz4tjYTHdat5A25n5\nekwMxZwFQ5OvMV4eulwZUDMypTAYSz1iB6sDlgwKDm5omZIfuneqCEIvrqxV/kx3\n5wV/DANHO3hYxdp/NV7rM23xmqlaKZhHQbDono1Fm/LP6DEmJiD7N2eFKsXYcPpR\nSAIdCv0X3zkDQ4zRi51yJlCXzQKBgQDpufJBxCoXngiQJ2j14lWVAeOOdQ6zh5Ip\nBcDwF0X67cNSN3Wl40bS4yLFdolhEAyj5m0WPuYYXpjzhHhZ0W3V3ItdBkrmwIvy\nWOWu26qN0ZbwxVS2qVpHuj6iHWJKHuDZZUkFtJg3BeeBSOUHSA8TvjnA0xd83xeb\n8ZJasWoFvwKBgQDFs/gQ/gIdcq0exLfluh5nw0qgcmyHpNWJHdjqITS9IX/nqFkU\n0IYLtmdStf2jQiLmbkydHcvz9wZVvLqml67VBHhwLcwpgPULoskd34/4V0Dvzy4c\nv1Esw8H5zVqIDLeLu+VpFjZMzQrjyl6RIWbyTExEc84rVWfpQYAu3qIGOQKBgAFr\nXatEk7TdAtRNSPflTfu/rTAaSeKROjQBkvBiU8x4US1YpOBDBxUUyAtG8wKh5FHC\nfnsaGq+fM3KXJVv2R6J62mXQOfg4xyDLpWlwcBK4aSBBMoiBcsjouqSlZQlqMpdf\nZBgixqHe6U8BsFJg/6ZxC0y+e3AIss4Bo4/lb+1lAoGAFOexvaBh21K6W3inmRW4\nLlkVYJaBJ20OwokXg5aXjBiHxqmk7VLAuFbkpb5LOKH2xPILRQ0OEkn51yVymS3T\n9lLpHOFTQXt5tF2/F7NW7kaQJNlLr/h5jPi3O9XHeFmuaN2z150ZB6zzgjeGKzr8\ni+1fgTsRfDtNw8xkSH9qL1Y=\n-----END PRIVATE KEY-----\n',
87
+
88
+ client_email: 'firebase-adminsdk-xmm2e@operato.iam.gserviceaccount.com'
89
+ },
90
+
91
+ appConfig: {
92
+ apiKey: 'AIzaSyDdTM2BTLHSt2LNS0G5QB8G0i4KBXFiG7U',
93
+
94
+ projectId: 'operato',
95
+
96
+ messagingSenderId: 79537064975,
97
+
98
+ appId: '1:79537064975:web:32f53119e9c8c6ee2a277a'
99
+ },
100
+
101
+ serverKey:
102
+ 'AAAAEoTHTA8:APA91bGwt-4HT82Dfwf_VwbQaKT0_qHd0Y3tuW41udjWz5Lz0Ko0mEMD6WbHHSILvQpa6yuoGGKCMsrU7VW2qWRrUm3CYpyG9oSwshNm1tIhljAnOuUfwHCoawbVLwf9qlWpHt4dwCoc'
103
+ },
104
+
105
+ vapidKey: {
106
+ subject: 'mailto:heartyoh@hatiolab.com',
107
+
108
+ publicKey: 'BAkVkITsCXBIsYL1yeaBmx5_dn57we-ZXMjirPPHzC2dan82cdEnAio_53PQ-1_w3ykWCBPrrFAWQ_d9N4cFF0o',
109
+
110
+ privateKey: '4pmlt3Wk019u7nqU3Q_oGZE6LbUDjjf8DpmAcn9-iss'
111
+ }
112
+ }
113
+ }
@@ -1,31 +1,9 @@
1
1
  "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
2
  Object.defineProperty(exports, "__esModule", { value: true });
26
3
  exports.schema = void 0;
27
- const typeDefs = __importStar(require("./types"));
28
- const resolvers = __importStar(require("./resolvers"));
4
+ const tslib_1 = require("tslib");
5
+ const typeDefs = tslib_1.__importStar(require("./types"));
6
+ const resolvers = tslib_1.__importStar(require("./resolvers"));
29
7
  exports.schema = {
30
8
  typeDefs,
31
9
  resolvers
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../server/graphql/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,kDAAmC;AACnC,uDAAwC;AAE3B,QAAA,MAAM,GAAG;IACpB,QAAQ;IACR,SAAS;CACV,CAAA"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../server/graphql/index.ts"],"names":[],"mappings":";;;;AAAA,0DAAmC;AACnC,+DAAwC;AAE3B,QAAA,MAAM,GAAG;IACpB,QAAQ;IACR,SAAS;CACV,CAAA","sourcesContent":["import * as typeDefs from './types'\nimport * as resolvers from './resolvers'\n\nexport const schema = {\n typeDefs,\n resolvers\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"board-settings.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/board-setting/board-settings.ts"],"names":[],"mappings":";;;AAAA,qCAAuC;AAEvC,yDAAgD;AAChD,iEAAqD;AACrD,+DAAsD;AAGtD,kFAU2C;AAE9B,QAAA,qBAAqB,GAAG;IACnC,KAAK,CAAC,aAAa,CAAC,CAAM,EAAE,MAAW,EAAE,OAAY;QACnD,MAAM,EAAE,MAAM,EAAE,GAAuB,OAAO,CAAC,KAAK,CAAA;QAEpD;;6FAEqF;QACrF,MAAM,IAAI,GAAS,MAAM,IAAA,uBAAa,EAAC,gBAAI,CAAC;aACzC,kBAAkB,CAAC,MAAM,CAAC;aAC1B,iBAAiB,CAAC,YAAY,EAAE,OAAO,CAAC;aACxC,iBAAiB,CAAC,cAAc,EAAE,cAAc,CAAC;aACjD,KAAK,CAAC,mBAAmB,EAAE,EAAE,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC;aAC7D,QAAQ,CAAC,6BAA6B,EAAE,EAAE,QAAQ,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC;aAChE,MAAM,EAAE,CAAA;QAEX,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAA;QAC3E,oFAAoF;QAEpF,MAAM,UAAU,GAAG,GAAG,iDAAqB,IAAI,QAAQ,EAAE,CAAA;QACzD,+EAA+E;QAE/E,MAAM,YAAY,GAAG,IAAA,uBAAa,EAAC,sBAAO,CAAC,CAAC,kBAAkB,EAAE,CAAA;QAChE,MAAM,KAAK,GAAG;YACZ,sDAA0B;YAC1B,qDAAyB;YACzB,oDAAwB;YACxB,6DAAiC;YACjC,UAAU;YACV,oDAAwB;YACxB,uDAA2B;YAC3B,mDAAuB;YACvB,kDAAsB;SACvB,CAAA;QAED,IAAI,EAAE,GAAG,YAAY;YACnB,uEAAuE;aACtE,SAAS,CAAC,qBAAK,EAAE,OAAO,EAAE,4CAA4C,CAAC;YACxE,yDAAyD;aACxD,MAAM,CAAC;YACN,kBAAkB;YAClB,sBAAsB;YACtB,wBAAwB;YACxB,qBAAqB;YACrB,yBAAyB;YACzB,uCAAuC;YACvC,mCAAmC;SACpC,CAAC;aACD,KAAK,CAAC,6BAA6B,EAAE,EAAE,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,CAAA;QAE5E,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM;YAAE,EAAE,CAAC,QAAQ,CAAC,6BAA6B,EAAE,EAAE,KAAK,EAAE,CAAC,CAAA;QAEhF,IAAI,gBAAgB,GAAG,MAAM,EAAE,CAAC,UAAU,EAAE,CAAA;QAE5C,OAAO,gBAAgB,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE;YACzC,IAAI,OAAO,GAAQ;gBACjB,KAAK,EAAE,EAAE;aACV,CAAA;YAED,KAAK,IAAI,GAAG,IAAI,YAAY,EAAE;gBAC5B,IAAI,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;oBACzB,IAAI,SAAS,GAAG,GAAG,CAAA;oBACnB,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,WAAW,EAAE,CAAA;oBAC5C,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,YAAY,CAAC,SAAS,CAAC,CAAA;iBAC7C;qBAAM;oBACL,OAAO,CAAC,GAAG,CAAC,GAAG,YAAY,CAAC,GAAG,CAAC,CAAA;iBACjC;aACF;YAED,IAAI,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,iDAAqB,CAAC,IAAI,CAAC,EAAE;gBACpD,OAAO,CAAC,IAAI,GAAG,iDAAqB,CAAA;aACrC;YAED,OAAO,OAAO,CAAA;QAChB,CAAC,CAAC,CAAA;IACJ,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"board-settings.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/board-setting/board-settings.ts"],"names":[],"mappings":"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","sourcesContent":["import { getRepository } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { Board } from '@things-factory/board-service'\nimport { Setting } from '@things-factory/setting-base'\nimport { Domain } from '@things-factory/shell'\n\nimport {\n CARTON_LABEL_SETTING_KEY,\n HOME_DASHBOARD_PREFIX,\n LOCATION_LABEL_SETTING_KEY,\n PALLET_LABEL_SETTING_KEY,\n PRODUCT_LABEL_SETTING_KEY,\n REUSABLE_PALLET_LABEL_SETTING_KEY,\n INTENALIZED_AWB_SETTING_KEY,\n ROUTE_LABEL_SETTING_KEY,\n TOTE_LABEL_SETTING_KEY\n} from '../../../opa-app-setting-constants'\n\nexport const boardSettingsResolver = {\n async boardSettings(_: any, params: any, context: any) {\n const { domain }: { domain: Domain } = context.state\n\n /***********************************************************************************\n * Temporary solution for dashboard user type\n ***********************************************************************************/\n const user: User = await getRepository(User)\n .createQueryBuilder('USER')\n .leftJoinAndSelect('USER.roles', 'ROLES')\n .leftJoinAndSelect('ROLES.domain', 'ROLES_DOMAIN')\n .where('USER.id = :userId', { userId: context.state.user.id })\n .andWhere('ROLES_DOMAIN.id = :domainId', { domainId: domain.id })\n .getOne()\n\n const userType = user.roles.filter(role => role.description)[0].description\n /**********************************************************************************/\n\n const HOME_BOARD = `${HOME_DASHBOARD_PREFIX}:${userType}`\n // const HOME_BOARD = `${HOME_DASHBOARD_PREFIX}:${context.state.user.userType}`\n\n const queryBuilder = getRepository(Setting).createQueryBuilder()\n const names = [\n LOCATION_LABEL_SETTING_KEY,\n PRODUCT_LABEL_SETTING_KEY,\n PALLET_LABEL_SETTING_KEY,\n REUSABLE_PALLET_LABEL_SETTING_KEY,\n HOME_BOARD,\n CARTON_LABEL_SETTING_KEY,\n INTENALIZED_AWB_SETTING_KEY,\n ROUTE_LABEL_SETTING_KEY,\n TOTE_LABEL_SETTING_KEY\n ]\n\n var qb = queryBuilder\n // .innerJoin(Board, 'Board', 'Board.id = CAST(Setting.value AS uuid)')\n .innerJoin(Board, 'Board', 'Setting.value = CAST(Board.id AS char(36))')\n // .innerJoin(Board, 'Board', 'Board.id = Setting.value')\n .select([\n 'Setting.id as id',\n 'Setting.name as name',\n 'Setting.value as value',\n 'Board.id as boardId',\n 'Board.name as boardName',\n 'Board.description as boardDescription',\n 'Board.thumbnail as boardThumbnail'\n ])\n .where('Setting.domain_id = :domain', { domain: context.state.domain.id })\n\n if (names && names.length) qb.andWhere('Setting.name IN (:...names)', { names })\n\n var boardSettingList = await qb.getRawMany()\n\n return boardSettingList.map(boardSetting => {\n var setting: any = {\n board: {}\n }\n\n for (let key in boardSetting) {\n if (key.includes('board')) {\n let originKey = key\n key = key.replace('board', '').toLowerCase()\n setting.board[key] = boardSetting[originKey]\n } else {\n setting[key] = boardSetting[key]\n }\n }\n\n if (setting.name.indexOf(HOME_DASHBOARD_PREFIX) == 0) {\n setting.name = HOME_DASHBOARD_PREFIX\n }\n\n return setting\n })\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/board-setting/index.ts"],"names":[],"mappings":";;;AAAA,qDAAwD;AAE3C,QAAA,KAAK,qBACb,sCAAqB,EACzB"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/board-setting/index.ts"],"names":[],"mappings":";;;AAAA,qDAAwD;AAE3C,QAAA,KAAK,qBACb,sCAAqB,EACzB","sourcesContent":["import { boardSettingsResolver } from './board-settings'\n\nexport const Query = {\n ...boardSettingsResolver\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"elccl-daily-collection-report.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/custom/elccl/elccl-daily-collection-report.ts"],"names":[],"mappings":";;;AAAA,uDAAmD;AAEnD,qCAAsD;AAEzC,QAAA,0BAA0B,GAAG;IACxC,KAAK,CAAC,0BAA0B,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QACtE,IAAI;YACF,MAAM,EAAE,EAAE,EAAE,GAA0B,OAAO,CAAC,KAAK,CAAA;YAEnD,IAAI,aAAa,GAAG,EAAE,CAAA;YACtB,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAW,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,UAAU,CAAC,EAAE;gBACpE,MAAM,QAAQ,GAAa,MAAM,IAAA,uBAAa,EAAC,mBAAQ,CAAC,CAAC,OAAO,CAAC;oBAC/D,EAAE,EAAE,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC,KAAK;iBAChE,CAAC,CAAA;gBACF,aAAa,GAAG,wBAAwB,GAAG,QAAQ,CAAC,EAAE,GAAG,GAAG,CAAA;aAC7D;YAED,IAAI,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAA;YACpE,IAAI,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAA;YAChE,IAAI,aAAa,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,eAAe,CAAC,CAAA;YAC9E,IAAI,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC,KAAK,GAAG,UAAU,CAAA;YAEvF,IAAI,CAAC,QAAQ,IAAI,CAAC,MAAM;gBAAE,MAAM,eAAe,CAAA;YAE/C,IAAI,kBAAkB,GAAG,EAAE,CAAA;YAC3B,IAAI,aAAa,EAAE;gBACjB,kBAAkB;oBAChB,0CAA0C;wBAC1C,aAAa,CAAC,KAAK;6BAChB,KAAK,CAAC,GAAG,CAAC;6BACV,GAAG,CAAC,EAAE,CAAC,EAAE;4BACR,OAAO,IAAI,GAAG,EAAE,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,IAAI,CAAA;wBACpD,CAAC,CAAC;6BACD,IAAI,CAAC,GAAG,CAAC;wBACZ,IAAI,CAAA;aACP;YAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAC3B;;;;;;;;;;;;;;;YAeI,aAAa;;;;;;;;;;;;;;;;;;;;;;cAsBX,kBAAkB;;;;;;SAMvB,EACD,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,EAAE,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,CAClE,CAAA;YAED,IAAI,KAAK,GAAG,MAAa,CAAA;YAEzB,OAAO,KAAK,CAAA;SACb;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,KAAK,CAAA;SACZ;IACH,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"elccl-daily-collection-report.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/custom/elccl/elccl-daily-collection-report.ts"],"names":[],"mappings":";;;AAAA,uDAAmD;AAEnD,qCAAsD;AAEzC,QAAA,0BAA0B,GAAG;IACxC,KAAK,CAAC,0BAA0B,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QACtE,IAAI;YACF,MAAM,EAAE,EAAE,EAAE,GAA0B,OAAO,CAAC,KAAK,CAAA;YAEnD,IAAI,aAAa,GAAG,EAAE,CAAA;YACtB,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAW,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,UAAU,CAAC,EAAE;gBACpE,MAAM,QAAQ,GAAa,MAAM,IAAA,uBAAa,EAAC,mBAAQ,CAAC,CAAC,OAAO,CAAC;oBAC/D,EAAE,EAAE,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC,KAAK;iBAChE,CAAC,CAAA;gBACF,aAAa,GAAG,wBAAwB,GAAG,QAAQ,CAAC,EAAE,GAAG,GAAG,CAAA;aAC7D;YAED,IAAI,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAA;YACpE,IAAI,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAA;YAChE,IAAI,aAAa,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,eAAe,CAAC,CAAA;YAC9E,IAAI,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC,KAAK,GAAG,UAAU,CAAA;YAEvF,IAAI,CAAC,QAAQ,IAAI,CAAC,MAAM;gBAAE,MAAM,eAAe,CAAA;YAE/C,IAAI,kBAAkB,GAAG,EAAE,CAAA;YAC3B,IAAI,aAAa,EAAE;gBACjB,kBAAkB;oBAChB,0CAA0C;wBAC1C,aAAa,CAAC,KAAK;6BAChB,KAAK,CAAC,GAAG,CAAC;6BACV,GAAG,CAAC,EAAE,CAAC,EAAE;4BACR,OAAO,IAAI,GAAG,EAAE,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,IAAI,CAAA;wBACpD,CAAC,CAAC;6BACD,IAAI,CAAC,GAAG,CAAC;wBACZ,IAAI,CAAA;aACP;YAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAC3B;;;;;;;;;;;;;;;YAeI,aAAa;;;;;;;;;;;;;;;;;;;;;;cAsBX,kBAAkB;;;;;;SAMvB,EACD,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,EAAE,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,CAClE,CAAA;YAED,IAAI,KAAK,GAAG,MAAa,CAAA;YAEzB,OAAO,KAAK,CAAA;SACb;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,KAAK,CAAA;SACZ;IACH,CAAC;CACF,CAAA","sourcesContent":["import { Bizplace } from '@things-factory/biz-base'\nimport { ListParam } from '@things-factory/shell'\nimport { EntityManager, getRepository } from 'typeorm'\n\nexport const elcclDailyCollectionReport = {\n async elcclDailyCollectionReport(_: any, params: ListParam, context: any) {\n try {\n const { tx }: { tx: EntityManager } = context.state\n\n let bizplaceQuery = ''\n if (params.filters.find((filter: any) => filter.name === 'bizplace')) {\n const bizplace: Bizplace = await getRepository(Bizplace).findOne({\n id: params.filters.find(data => data.name === 'bizplace').value\n })\n bizplaceQuery = \"AND rg.bizplace_id = '\" + bizplace.id + \"'\"\n }\n\n let fromDate = params.filters.find(data => data.name === 'fromDate')\n let toDate = params.filters.find(data => data.name === 'toDate')\n let arrivalNotice = params.filters.find(data => data.name === 'arrivalNotice')\n let tzoffset = params.filters.find(data => data.name === 'tzoffset').value + ' seconds'\n\n if (!fromDate || !toDate) throw 'Invalid input'\n\n let arrivalNoticeQuery = ''\n if (arrivalNotice) {\n arrivalNoticeQuery =\n 'AND arrival_notice_name ILIKE ANY(ARRAY[' +\n arrivalNotice.value\n .split(',')\n .map(an => {\n return \"'%\" + an.trim().replace(/'/g, \"''\") + \"%'\"\n })\n .join(',') +\n '])'\n }\n\n const result = await tx.query(\n `\n with src as (\n select ar.name as release_good_name, COALESCE(ar.name, 'MIGRATE') as arrival_notice_name, bz.name as bizplace_name, \n ws.ended_at::date, delord.own_collection, delord.name as delivery_order_name, inv.pallet_id, inv.batch_id\n from release_goods rg\n inner join bizplaces bz on bz.id = rg.bizplace_id\n inner join worksheets ws on ws.release_good_id = rg.id and ws.type = 'LOADING'\n inner join order_inventories oi on oi.release_good_id = rg.id\n inner join inventories inv on inv.id = oi.inventory_id\n inner join delivery_orders delord on delord.id = oi.delivery_order_id \n left join order_inventories inbound_oi on inbound_oi.inventory_id = inv.id and inbound_oi.type = 'ARRIVAL_NOTICE'\n left join arrival_notices ar on ar.id = inbound_oi.arrival_notice_id\n where rg.domain_id = $1\n and ws.ended_at >= $2::timestamp + $4::interval\n and ws.ended_at <= $3::timestamp + $4::interval\n ${bizplaceQuery}\n )\n select bizplace_name, arrival_notice_name, ended_at, batch_id, \n trim(trailing ', ' from self_collect) as self_collect, trim(trailing ', ' from delivery) as delivery,\n trim(trailing ', ' from self_collect_summary) as self_collect_summary, trim(trailing ', ' from delivery_summary) as delivery_summary,\n total_self_collect, total_delivery\n from(\n select bizplace_name, arrival_notice_name, ended_at, batch_id,\n string_agg(self_collect, '') as self_collect,\n string_agg(delivery, '') delivery,\n string_agg(self_collect_summary, '') as self_collect_summary,\n string_agg(delivery_summary, '') delivery_summary,\n COUNT(case when own_collection = true then 1 end) as total_self_collect,\n COUNT(case when own_collection = false then 1 end) as total_delivery\n from (\n select arrival_notice_name, delivery_order_name, bizplace_name, ended_at::varchar, own_collection, batch_id,\n case when own_collection = 'true' then concat(delivery_order_name, ' (', string_agg(pallet_id, ', ' ORDER BY pallet_id), '), ') else '' end as self_collect,\n case when own_collection = 'false' then concat(delivery_order_name, ' (', string_agg(pallet_id, ', ' ORDER BY pallet_id), '), ') else '' end as delivery,\n case when own_collection = 'true' then concat(delivery_order_name, ' (', count(*), '), ') else '' end as self_collect_summary,\n case when own_collection = 'false' then concat(delivery_order_name, ' (', count(*), '), ') else '' end as delivery_summary\n from src\n where 1 = 1\n ${arrivalNoticeQuery}\n group by bizplace_name, arrival_notice_name, ended_at, delivery_order_name, own_collection, batch_id\n ) src\n group by bizplace_name, arrival_notice_name, ended_at, batch_id\n order by bizplace_name, ended_at, arrival_notice_name\n ) src\n `,\n [context.state.domain.id, fromDate.value, toDate.value, tzoffset]\n )\n\n let items = result as any\n\n return items\n } catch (error) {\n throw error\n }\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"elccl-daily-order-inventory-report.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/custom/elccl/elccl-daily-order-inventory-report.ts"],"names":[],"mappings":";;;AAGA,uDAAiE;AAEpD,QAAA,8BAA8B,GAAG;IAC5C,KAAK,CAAC,8BAA8B,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QAC1E,IAAI;YACF,MAAM,EAAE,EAAE,EAAE,GAA0B,OAAO,CAAC,KAAK,CAAA;YAEnD,IAAI,cAAc,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAA;YAE1E,IAAI,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,KAAK,GAAG,KAAK,CAAA;YAC5E,IAAI,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC,KAAK,GAAG,UAAU,CAAA;YAEvF,IAAI,CAAC,cAAc,IAAI,CAAC,KAAK;gBAAE,MAAM,eAAe,CAAA;YAEpD,MAAM,QAAQ,GAAa,MAAM,EAAE,CAAC,aAAa,CAAC,mBAAQ,CAAC,CAAC,OAAO,CAAC;gBAClE,EAAE,EAAE,cAAc,CAAC,KAAK;aACzB,CAAC,CAAA;YAEF,MAAM,EAAE,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;SAsBZ,EACD,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,EAAE,QAAQ,CAAC,EAAE,EAAE,KAAK,EAAE,QAAQ,CAAC,CACxD,CAAA;YAED,MAAM,EAAE,CAAC,KAAK,CAAC;;;;;;;;;;;;;OAad,CAAC,CAAA;YAEF,MAAM,MAAM,GAAQ,MAAM,EAAE,CAAC,KAAK,CAAC;;;;;;;;;;8CAUK,KAAK,4CAA4C,KAAK;;;4BAGxE,KAAK;;;;;;wCAMO,KAAK;;;4BAGjB,KAAK;;;;wCAIO,KAAK;;;;;;;;;;;;;2CAaF,KAAK;;;;;;;;;;;yCAWP,KAAK;;;;;;OAMvC,CAAC,CAAA;YAEF,EAAE,CAAC,KAAK,CAAC;;OAER,CAAC,CAAA;YAEF,IAAI,KAAK,GAAG,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;gBAC3B,OAAO;oBACL,GAAG,EAAE,GAAG,CAAC,GAAG;oBACZ,QAAQ,EAAE,QAAQ;oBAClB,eAAe,EAAE,GAAG,CAAC,iBAAiB;oBACtC,MAAM,EAAE,GAAG,CAAC,MAAM;oBAClB,kBAAkB,EAAE,GAAG,CAAC,oBAAoB;oBAC5C,MAAM,EAAE,GAAG,CAAC,MAAM;oBAClB,kBAAkB,EAAE,GAAG,CAAC,oBAAoB;oBAC5C,SAAS,EAAE,GAAG,CAAC,UAAU;oBACzB,OAAO,EAAE,GAAG,CAAC,SAAS;oBACtB,OAAO,EAAE,GAAG,CAAC,QAAQ;oBACrB,UAAU,EAAE,GAAG,CAAC,YAAY;oBAC5B,MAAM,EAAE,GAAG,CAAC,MAAM;oBAClB,kBAAkB,EAAE,GAAG,CAAC,oBAAoB;iBAC7C,CAAA;YACH,CAAC,CAAC,CAAA;YAEF,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,MAAM,EAAC,CAAA;SACrC;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,KAAK,CAAA;SACZ;IACH,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"elccl-daily-order-inventory-report.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/custom/elccl/elccl-daily-order-inventory-report.ts"],"names":[],"mappings":";;;AAGA,uDAAiE;AAEpD,QAAA,8BAA8B,GAAG;IAC5C,KAAK,CAAC,8BAA8B,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QAC1E,IAAI;YACF,MAAM,EAAE,EAAE,EAAE,GAA0B,OAAO,CAAC,KAAK,CAAA;YAEnD,IAAI,cAAc,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAA;YAE1E,IAAI,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,KAAK,GAAG,KAAK,CAAA;YAC5E,IAAI,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC,KAAK,GAAG,UAAU,CAAA;YAEvF,IAAI,CAAC,cAAc,IAAI,CAAC,KAAK;gBAAE,MAAM,eAAe,CAAA;YAEpD,MAAM,QAAQ,GAAa,MAAM,EAAE,CAAC,aAAa,CAAC,mBAAQ,CAAC,CAAC,OAAO,CAAC;gBAClE,EAAE,EAAE,cAAc,CAAC,KAAK;aACzB,CAAC,CAAA;YAEF,MAAM,EAAE,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;SAsBZ,EACD,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,EAAE,QAAQ,CAAC,EAAE,EAAE,KAAK,EAAE,QAAQ,CAAC,CACxD,CAAA;YAED,MAAM,EAAE,CAAC,KAAK,CAAC;;;;;;;;;;;;;OAad,CAAC,CAAA;YAEF,MAAM,MAAM,GAAQ,MAAM,EAAE,CAAC,KAAK,CAAC;;;;;;;;;;8CAUK,KAAK,4CAA4C,KAAK;;;4BAGxE,KAAK;;;;;;wCAMO,KAAK;;;4BAGjB,KAAK;;;;wCAIO,KAAK;;;;;;;;;;;;;2CAaF,KAAK;;;;;;;;;;;yCAWP,KAAK;;;;;;OAMvC,CAAC,CAAA;YAEF,EAAE,CAAC,KAAK,CAAC;;OAER,CAAC,CAAA;YAEF,IAAI,KAAK,GAAG,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;gBAC3B,OAAO;oBACL,GAAG,EAAE,GAAG,CAAC,GAAG;oBACZ,QAAQ,EAAE,QAAQ;oBAClB,eAAe,EAAE,GAAG,CAAC,iBAAiB;oBACtC,MAAM,EAAE,GAAG,CAAC,MAAM;oBAClB,kBAAkB,EAAE,GAAG,CAAC,oBAAoB;oBAC5C,MAAM,EAAE,GAAG,CAAC,MAAM;oBAClB,kBAAkB,EAAE,GAAG,CAAC,oBAAoB;oBAC5C,SAAS,EAAE,GAAG,CAAC,UAAU;oBACzB,OAAO,EAAE,GAAG,CAAC,SAAS;oBACtB,OAAO,EAAE,GAAG,CAAC,QAAQ;oBACrB,UAAU,EAAE,GAAG,CAAC,YAAY;oBAC5B,MAAM,EAAE,GAAG,CAAC,MAAM;oBAClB,kBAAkB,EAAE,GAAG,CAAC,oBAAoB;iBAC7C,CAAA;YACH,CAAC,CAAC,CAAA;YAEF,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,MAAM,EAAC,CAAA;SACrC;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,KAAK,CAAA;SACZ;IACH,CAAC;CACF,CAAA","sourcesContent":["import { ListParam } from '@things-factory/shell'\nimport { getManager, EntityManager, getRepository } from 'typeorm'\nimport { User } from '@things-factory/auth-base'\nimport { Bizplace, BizplaceUser } from '@things-factory/biz-base'\n\nexport const elcclDailyOrderInventoryReport = {\n async elcclDailyOrderInventoryReport(_: any, params: ListParam, context: any) {\n try {\n const { tx }: { tx: EntityManager } = context.state\n \n let bizplaceFilter = params.filters.find(data => data.name === 'bizplace') \n\n let month = params.filters.find(data => data.name === 'month').value + '-01'\n let tzoffset = params.filters.find(data => data.name === 'tzoffset').value + ' seconds'\n\n if (!bizplaceFilter || !month) throw 'Invalid input'\n\n const bizplace: Bizplace = await tx.getRepository(Bizplace).findOne({\n id: bizplaceFilter.value\n })\n\n await tx.query(`\n create temp table temp_invHistory as (\n select rih.pallet_id, rih.seq, \n coalesce(grn.name, do2.name, rih.order_no) as order_no , rih.order_ref_no , an.delivery_order_no as do_ref_no, \n rih.bizplace_id, rih.ref_order_id, \n coalesce(grn.created_at, rg.created_at, rih.created_at) as created_at, \n CASE WHEN rih.transaction_type = 'PICKING' THEN COALESCE(-oi.release_qty,rih.qty) ELSE rih.qty END AS qty,\n inv.packing_type, inv.reusable_pallet_id, rih.transaction_type, \n case when rih.status = 'TERMINATED' then rih.status else 'STORED' end as status,\n (case when lag(case when rih.status = 'TERMINATED' then 0 else 1 end) over (partition by rih.pallet_id order by rih.seq) = (case when rih.status = 'TERMINATED' then 0 else 1 end) \n then 0 else 1 end) as startflag\n from reduced_inventory_histories rih\n inner join inventories inv on inv.domain_id =rih.domain_id and inv.pallet_id =rih.pallet_id \n left join arrival_notices an on an.id = rih.ref_order_id::uuid and an.domain_id =rih.domain_id \n left join goods_receival_notes grn on grn.arrival_notice_id = an.id\n left join release_goods rg on rg.id = rih.ref_order_id::uuid and rg.domain_id =rih.domain_id \n left join order_inventories oi on oi.release_good_id = rih.ref_order_id::uuid and oi.inventory_id = inv.id\n left join delivery_orders do2 on do2.id = oi.delivery_order_id\n where ((rih.transaction_type <> 'PUTAWAY' and rih.transaction_type <> 'ADJUSTMENT' and rih.transaction_type <> 'RELOCATE') or rih.qty <> 0)\n and rih.domain_id =$1 and rih.bizplace_id = $2\n and coalesce(grn.created_at, rg.created_at, rih.created_at) < $3::timestamp + '1 month' + $4::interval\n )\n `,\n [context.state.domain.id, bizplace.id, month, tzoffset]\n )\n\n await tx.query(`\n create temp table temp_invByPallet as (\n select grp.*, ivh.order_no, ivh.order_ref_no, ivh.do_ref_no from (\n select pallet_id, packing_type, min(created_at) as started_at, max(created_at) as ended_at, min(seq) as min_seq, max(seq) as max_seq, status from (\n select startData.*, sum(startflag) over (partition by pallet_id order by seq) as grp from (\n select * from temp_invHistory s\n ) startData\n ) endData\n group by pallet_id, grp, status, packing_type\n order by pallet_id, min_seq\n ) grp\n inner join temp_invHistory ivh on ivh.pallet_id = grp.pallet_id and ivh.seq = grp.min_seq \n )\n `)\n\n const result: any = await tx.query(` \n select monthDays.created_at, order_no, order_ref_no, do_ref_no,\n coalesce(carton,0) as carton, \n coalesce(bag,0) as bag, \n coalesce(basket,0) as basket, \n coalesce(pallet,0) as pallet,\n sum(carton_running_total + carton) over (order by monthDays.created_at, src.rn) as carton_running_total, \n sum(bag_running_total + bag) over (order by monthDays.created_at, src.rn) as bag_running_total, \n sum(basket_running_total + basket) over (order by monthDays.created_at, src.rn) as basket_running_total, \n sum(pallet_running_total + pallet) over (order by monthDays.created_at, src.rn) as pallet_running_total\n from (select generate_series((date '${month}')::timestamp, date_trunc('month',(date '${month}')::timestamp) + '1 month' - '1 day'::interval, interval '1 day')::date as created_at) monthDays\n left join (\n select 0 as rn, loose.*, pallet.pallet, pallet.pallet_running_total from (\n select (date '${month}')::timestamp as created_at, 'NA' as order_no, 'NA' as order_ref_no, 'NA' as do_ref_no, \n 0 as carton, 0 as bag, 0 as basket,\n coalesce(sum(case when packing_type = 'CARTON' then qty else 0 end),0) as carton_running_total, \n coalesce(sum(case when packing_type = 'BAG' then qty else 0 end),0) as bag_running_total, \n coalesce(sum(case when packing_type = 'BASKET' then qty else 0 end),0) as basket_running_total\n from temp_invHistory\n where created_at < (date '${month}')::timestamp and qty <> 0\n ) loose\n left join (\n select (date '${month}')::timestamp as created_at,\n 0 as pallet,\n coalesce(sum(case when status = 'STORED' then 1 else -1 end),0) as pallet_running_total\n from temp_invByPallet ivp\n where started_at < (date '${month}')::timestamp\n ) pallet on pallet.created_at = loose.created_at\n union\n select row_number() over (order by loose.created_at) as rn,\n loose.*, pallet.pallet, pallet.pallet_running_total from (\n select MIN(created_at) as created_at, order_no, order_ref_no, do_ref_no,\n sum(case when packing_type = 'CARTON' then qty else 0 end) as carton, \n sum(case when packing_type = 'BAG' then qty else 0 end) as bag, \n sum(case when packing_type = 'BASKET' then qty else 0 end) as basket,\n 0 as carton_running_total, 0 as bag_running_total, 0 as basket_running_total\n from \n (\n SELECT pallet_id, packing_type, created_at, order_no, order_ref_no, do_ref_no, min(qty) AS qty FROM temp_invHistory \n where created_at >= (date '${month}')::timestamp and qty <> 0\n group by pallet_id, packing_type, created_at, order_no, order_ref_no, do_ref_no\n order by pallet_id, created_at, order_no, order_ref_no, do_ref_no\n ) foo\n group by created_at, order_no, order_ref_no, do_ref_no\n ) loose\n left join (\n select MIN(started_at) as created_at, order_no, order_ref_no, do_ref_no,\n sum(case when status = 'STORED' then 1 else -1 end) as pallet, \n 0 as pallet_running_total\n from temp_invByPallet ivp\n where started_at >= (date '${month}')::timestamp\n group by started_at::date, order_no, order_ref_no, do_ref_no\n ) pallet on pallet.created_at::date = loose.created_at::date and pallet.order_no = loose.order_no\n order by rn\n ) as src on src.created_at::date = monthDays.created_at::date \n order by monthDays.created_at, src.rn\n `)\n\n tx.query(`\n drop table temp_invHistory, temp_invByPallet\n `)\n\n let items = result.map(itm => {\n return {\n bag: itm.bag,\n bizplace: bizplace,\n bagRunningTotal: itm.bag_running_total,\n basket: itm.basket,\n basketRunningTotal: itm.basket_running_total,\n carton: itm.carton,\n cartonRunningTotal: itm.carton_running_total,\n createdAt: itm.created_at,\n doRefNo: itm.do_ref_no,\n orderNo: itm.order_no,\n orderRefNo: itm.order_ref_no,\n pallet: itm.pallet,\n palletRunningTotal: itm.pallet_running_total\n }\n })\n\n return { items, total: items.length}\n } catch (error) {\n throw error\n }\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"elccl-inventory-history-pallet-detail-report.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/custom/elccl/elccl-inventory-history-pallet-detail-report.ts"],"names":[],"mappings":";;;AAAA,uDAAmD;AAEnD,qCAAsD;AAEzC,QAAA,uCAAuC,GAAG;IACrD,KAAK,CAAC,uCAAuC,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QACnF,IAAI;YACF,MAAM,EAAE,EAAE,EAAE,GAA0B,OAAO,CAAC,KAAK,CAAA;YAEnD,IAAI,cAAc,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAA;YAE1E,IAAI,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAA;YACpE,IAAI,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAA;YAEhE,IAAI,CAAC,cAAc,IAAI,CAAC,QAAQ,IAAI,CAAC,MAAM;gBAAE,MAAM,eAAe,CAAA;YAElE,IAAI,aAAa,GAAG,EAAE,CAAA;YACtB,IAAI,cAAc,EAAE;gBAClB,MAAM,QAAQ,GAAa,MAAM,IAAA,uBAAa,EAAC,mBAAQ,CAAC,CAAC,OAAO,CAAC;oBAC/D,EAAE,EAAE,cAAc,CAAC,KAAK;iBACzB,CAAC,CAAA;gBAEF,IAAI,QAAQ,EAAE;oBACZ,aAAa,GAAG,wBAAwB,GAAG,QAAQ,CAAC,EAAE,GAAG,GAAG,CAAA;iBAC7D;qBAAM;oBACL,MAAM,eAAe,CAAA;iBACtB;aACF;YAED,MAAM,EAAE,CAAC,KAAK,CACZ;;;;;;;;;;;;;;;;;YAiBI,aAAa;;UAEf,EACF,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,CAC1B,CAAA;YAED,MAAM,EAAE,CAAC,KAAK,CAAC;;;;;;;;;;;;;;OAcd,CAAC,CAAA;YAEF,MAAM,MAAM,GAAQ,MAAM,EAAE,CAAC,KAAK,CAChC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAwCD,EACC,CAAC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC,CAC/B,CAAA;YAED,MAAM,EAAE,CAAC,KAAK,CAAC,iDAAiD,CAAC,CAAA;YAEjE,IAAI,KAAK,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;gBAC5B,OAAO;oBACL,QAAQ,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,aAAa,EAAE;oBACtC,QAAQ,EAAE,IAAI,CAAC,SAAS;oBACxB,OAAO,EAAE,IAAI,CAAC,QAAQ;oBACtB,cAAc,EAAE,IAAI,CAAC,eAAe;oBACpC,SAAS,EAAE,IAAI,CAAC,UAAU;oBAC1B,UAAU,EAAE,IAAI,CAAC,WAAW;oBAC5B,cAAc,EAAE,IAAI,CAAC,eAAe;oBACpC,gBAAgB,EAAE,IAAI,CAAC,kBAAkB;oBACzC,aAAa,EAAE,IAAI,CAAC,cAAc;iBACnC,CAAA;YACH,CAAC,CAAC,CAAA;YAEF,OAAO,KAAK,CAAA;SACb;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,KAAK,CAAA;SACZ;IACH,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"elccl-inventory-history-pallet-detail-report.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/custom/elccl/elccl-inventory-history-pallet-detail-report.ts"],"names":[],"mappings":";;;AAAA,uDAAmD;AAEnD,qCAAsD;AAEzC,QAAA,uCAAuC,GAAG;IACrD,KAAK,CAAC,uCAAuC,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QACnF,IAAI;YACF,MAAM,EAAE,EAAE,EAAE,GAA0B,OAAO,CAAC,KAAK,CAAA;YAEnD,IAAI,cAAc,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAA;YAE1E,IAAI,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAA;YACpE,IAAI,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAA;YAEhE,IAAI,CAAC,cAAc,IAAI,CAAC,QAAQ,IAAI,CAAC,MAAM;gBAAE,MAAM,eAAe,CAAA;YAElE,IAAI,aAAa,GAAG,EAAE,CAAA;YACtB,IAAI,cAAc,EAAE;gBAClB,MAAM,QAAQ,GAAa,MAAM,IAAA,uBAAa,EAAC,mBAAQ,CAAC,CAAC,OAAO,CAAC;oBAC/D,EAAE,EAAE,cAAc,CAAC,KAAK;iBACzB,CAAC,CAAA;gBAEF,IAAI,QAAQ,EAAE;oBACZ,aAAa,GAAG,wBAAwB,GAAG,QAAQ,CAAC,EAAE,GAAG,GAAG,CAAA;iBAC7D;qBAAM;oBACL,MAAM,eAAe,CAAA;iBACtB;aACF;YAED,MAAM,EAAE,CAAC,KAAK,CACZ;;;;;;;;;;;;;;;;;YAiBI,aAAa;;UAEf,EACF,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,CAC1B,CAAA;YAED,MAAM,EAAE,CAAC,KAAK,CAAC;;;;;;;;;;;;;;OAcd,CAAC,CAAA;YAEF,MAAM,MAAM,GAAQ,MAAM,EAAE,CAAC,KAAK,CAChC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAwCD,EACC,CAAC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC,CAC/B,CAAA;YAED,MAAM,EAAE,CAAC,KAAK,CAAC,iDAAiD,CAAC,CAAA;YAEjE,IAAI,KAAK,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;gBAC5B,OAAO;oBACL,QAAQ,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,aAAa,EAAE;oBACtC,QAAQ,EAAE,IAAI,CAAC,SAAS;oBACxB,OAAO,EAAE,IAAI,CAAC,QAAQ;oBACtB,cAAc,EAAE,IAAI,CAAC,eAAe;oBACpC,SAAS,EAAE,IAAI,CAAC,UAAU;oBAC1B,UAAU,EAAE,IAAI,CAAC,WAAW;oBAC5B,cAAc,EAAE,IAAI,CAAC,eAAe;oBACpC,gBAAgB,EAAE,IAAI,CAAC,kBAAkB;oBACzC,aAAa,EAAE,IAAI,CAAC,cAAc;iBACnC,CAAA;YACH,CAAC,CAAC,CAAA;YAEF,OAAO,KAAK,CAAA;SACb;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,KAAK,CAAA;SACZ;IACH,CAAC;CACF,CAAA","sourcesContent":["import { Bizplace } from '@things-factory/biz-base'\nimport { ListParam } from '@things-factory/shell'\nimport { EntityManager, getRepository } from 'typeorm'\n\nexport const elcclInventoryHistoryPalletDetailReport = {\n async elcclInventoryHistoryPalletDetailReport(_: any, params: ListParam, context: any) {\n try {\n const { tx }: { tx: EntityManager } = context.state\n\n let bizplaceFilter = params.filters.find(data => data.name === 'bizplace')\n\n let fromDate = params.filters.find(data => data.name === 'fromDate')\n let toDate = params.filters.find(data => data.name === 'toDate')\n\n if (!bizplaceFilter || !fromDate || !toDate) throw 'Invalid input'\n\n let bizplaceQuery = ''\n if (bizplaceFilter) {\n const bizplace: Bizplace = await getRepository(Bizplace).findOne({\n id: bizplaceFilter.value\n })\n\n if (bizplace) {\n bizplaceQuery = \"AND i2.bizplace_id = '\" + bizplace.id + \"'\"\n } else {\n throw 'Invalid input'\n }\n }\n\n await tx.query(\n `\n CREATE TEMP TABLE invHistory as (\n select COALESCE(js.name, ar.name, 'NEW') as job_sheet,\n COALESCE(js.container_size, '') as container_size,\n i2.batch_id,\n bzp.name as bizplace_name,\n coalesce(plt.name, i2.pallet_id) as pallet_id, ih.seq, ih.status, ih.transaction_type, i2.product_id, \n ih.id as inventory_history_id, ih.packing_type, ih.qty, ih.opening_qty,\n ih.uom_value, ih.opening_uom_value, ih.created_at\n from inventories i2 \n inner join reduced_inventory_histories ih on ih.pallet_id = i2.pallet_id and ih.domain_id = $1\n inner join bizplaces bzp on bzp.id = ih.bizplace_id\n left join order_inventories oi on oi.inventory_id = i2.id and oi.arrival_notice_id is not null\n left join arrival_notices ar on ar.id = oi.arrival_notice_id\n left join job_sheets js on js.arrival_notice_ref_no = ar.name\n left join pallets plt on plt.id = i2.reusable_pallet_id\n where i2.domain_id = $1\n ${bizplaceQuery}\n and i2.ref_inventory_id is null\n )`,\n [context.state.domain.id]\n )\n\n await tx.query(`\n CREATE TEMP TABLE inventoryHistoryMovement AS (\n select bizplace_name, container_size, pallet_id, seq, status, transaction_type, batch_id,\n inventory_history_id, packing_type, qty, opening_qty, uom_value, opening_uom_value, created_at, job_sheet from (\n select row_number() over(partition by job_sheet, pallet_id order by created_at asc) as rn, * from invHistory where \n status = 'STORED' and (transaction_type = 'NEW' or transaction_type = 'CANCEL_ORDER' or transaction_type = 'RETURN' or transaction_type = 'PUTAWAY')\n )as invIn where rn = 1\n union all\n select bizplace_name, container_size, pallet_id, seq, status, transaction_type, batch_id,\n inventory_history_id, packing_type, qty, opening_qty, uom_value, opening_uom_value, created_at, job_sheet from (\n select row_number() over(partition by job_sheet, pallet_id order by created_at desc) as rn, * from invHistory ih1\n where (ih1.status = 'TERMINATED')\n ) as invOut where rn = 1 and invOut.transaction_type <> 'RETURN'\n );\n `)\n\n const result: any = await tx.query(\n ` \n with inventoryHistoriesByPallet as (\n select invHistory.bizplace_name, invHistory.container_size, invHistory.job_sheet, invHistory.batch_id,\n SUM(case when invHistory.created_at < $1 then \n case when invHistory.status = 'STORED' then 1 else -1 end\n else 0 end) as opening_balance,\n SUM(case when invHistory.created_at >= $1 \n and invHistory.created_at <= $2 then \n case when invHistory.status = 'STORED' then 1 else 0 end\n else 0 end) as in_balance,\n SUM(case when invHistory.created_at >= $1 \n and invHistory.created_at <= $2 then \n case when invHistory.status = 'TERMINATED' then 1 else 0 end\n else 0 end) as out_balance\n from(\n select * from inventoryHistoryMovement\n ) as invHistory group by bizplace_name, container_size, job_sheet, batch_id\n )\n select invh.*, invh.opening_balance + invh.in_balance - invh.out_balance as closing_balance \n , (\n select json_agg(json_build_object('created_at', created_at, 'in_balance', in_balance, 'out_balance', out_balance)) as jsonData from \n (\n select bizplace_name, batch_id, job_sheet, created_at::date,\n SUM(case when status = 'STORED' then 1 else 0 end) as in_balance,\n SUM(case when status = 'TERMINATED' then 1 else 0 end) as out_balance\n from inventoryHistoryMovement\n where created_at >= $1 and \n created_at <= $2 and \n bizplace_name = invh.bizplace_name and\n batch_id = invh.batch_id and job_sheet = invh.job_sheet\n group by bizplace_name, batch_id, job_sheet, created_at::date\n order by created_at\n ) \n as t\n )::varchar as json_date_movement\n from inventoryHistoriesByPallet invh\n where (invh.opening_balance > 0\n or invh.in_balance > 0\n or invh.out_balance > 0)\n order by invh.bizplace_name, invh.batch_id;\n `,\n [fromDate.value, toDate.value]\n )\n\n await tx.query(`drop table inventoryHistoryMovement, invHistory`)\n\n let items = result.map(item => {\n return {\n bizplace: { name: item.bizplace_name },\n jobSheet: item.job_sheet,\n batchId: item.batch_id,\n openingBalance: item.opening_balance,\n inBalance: item.in_balance,\n outBalance: item.out_balance,\n closingBalance: item.closing_balance,\n jsonDateMovement: item.json_date_movement,\n containerSize: item.container_size\n }\n })\n\n return items\n } catch (error) {\n throw error\n }\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"elccl-inventory-history-report.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/custom/elccl/elccl-inventory-history-report.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"elccl-inventory-history-report.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/custom/elccl/elccl-inventory-history-report.ts"],"names":[],"mappings":"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","sourcesContent":["import { EntityManager } from 'typeorm'\n\nimport { Bizplace } from '@things-factory/biz-base'\nimport { ListParam } from '@things-factory/shell'\n\nexport const elcclInventoryHistoryReport = {\n async elcclInventoryHistoryReport(_: any, params: ListParam, context: any) {\n try {\n // const convertedParams = convertListParams(params)\n const { tx }: { tx: EntityManager } = context.state\n\n let bizplaceFilter = params.filters.find(data => data.name === 'bizplace')\n\n let fromDate = params.filters.find(data => data.name === 'fromDate')\n let toDate = params.filters.find(data => data.name === 'toDate')\n let batchNo = params.filters.find(data => data.name === 'batch_no')\n let product = params.filters.find(data => data.name === 'product')\n\n if (!bizplaceFilter || !fromDate || !toDate) throw 'Invalid input'\n\n const bizplace: Bizplace = await tx.getRepository(Bizplace).findOne({\n id: bizplaceFilter.value\n })\n\n let batchNoQuery = ''\n if (batchNo) {\n batchNoQuery =\n 'AND invh.batch_id ILIKE ANY(ARRAY[' +\n batchNo.value\n .split(',')\n .map(prod => {\n return \"'%\" + prod.trim().replace(/'/g, \"''\") + \"%'\"\n })\n .join(',') +\n '])'\n }\n\n let productQuery = ''\n if (product) {\n let productValue =\n product.value\n .toLowerCase()\n .split(',')\n .map(prod => {\n return \"'%\" + prod.trim().replace(/'/g, \"''\") + \"%'\"\n })\n .join(',') + ']) '\n productQuery =\n 'AND prd.name ILIKE ANY(ARRAY[' +\n productValue +\n 'OR prd.sku ILIKE ANY(ARRAY[' +\n productValue +\n 'OR prd.description ILIKE ANY(ARRAY[' +\n productValue\n }\n\n await tx.query(\n `\n create temp table temp_data_src AS\n (\n SELECT prd.sku AS product_sku, prd.name AS product_name, prd.description AS product_description, trim(invh.batch_id) as batch_id, invh.product_id,\n invh.packing_type, invh.bizplace_id, invh.domain_id,\n invh.ref_order_id, invh.order_no, invh.order_ref_no, invh.transaction_type, invh.created_at,\n invh.qty, invh.opening_qty, invh.uom_value, invh.opening_uom_value\n FROM reduced_inventory_histories invh\n INNER JOIN products prd ON prd.id = invh.product_id\n WHERE invh.domain_id = $1\n AND invh.bizplace_id = $2\n AND invh.created_at <= $3\n ${batchNoQuery}\n ${productQuery}\n ) \n `,\n [context.state.domain.id, bizplace.id, toDate.value]\n )\n\n await tx.query(\n `\n create temp table temp_inv_history as (\n SELECT src.product_sku, src.product_name, src.product_description, src.batch_id, src.product_id, src.packing_type, \n src.bizplace_id, src.domain_id,\n SUM(COALESCE(invh.qty,0)) AS qty,\n 0 AS opening_qty,\n SUM(COALESCE(invh.uom_value,0)) AS uom_value,\n 0 AS opening_uom_value,\n 'Opening Balance' AS order_name,\n '-' AS ref_no,\n 0 AS rn,\n $1 AS created_at\n FROM (\n SELECT src.product_sku, src.product_name, src.product_description, src.batch_id, src.product_id, src.packing_type, src.bizplace_id, \n src.domain_id\n FROM temp_data_src src\n GROUP BY src.product_sku, src.product_name, src.product_description, src.batch_id, src.product_id, src.packing_type, src.bizplace_id, \n src.domain_id\n ) AS src \n LEFT JOIN inventory_histories invh ON src.batch_id = trim(invh.batch_id) AND \n src.product_id = invh.product_id AND \n src.packing_type = invh.packing_type AND \n src.bizplace_id = invh.bizplace_id AND \n src.domain_id = invh.domain_id AND\n invh.created_at < $1::timestamp AND\n invh.transaction_type IN ('NEW', 'ADJUSTMENT', 'UNLOADING', 'PICKING', 'LOADING', 'UNDO_UNLOADING', 'CANCEL_ORDER', 'RETURN')\n GROUP BY src.product_sku, src.product_name, src.product_description, src.batch_id, src.product_id, src.packing_type, src.bizplace_id, \n src.domain_id\n UNION ALL\n SELECT product_sku, product_name, product_description, batch_id, product_id, packing_type, bizplace_id, \n domain_id, sum(qty) as qty, sum(opening_qty) as opening_qty, sum(uom_value) as uom_value, sum(opening_uom_value) as opening_uom_value, order_name, ref_no, rn, MIN(created_at) as created_at\n FROM (\n SELECT invh.product_sku, invh.product_name, invh.product_description, invh.batch_id, invh.product_id, invh.packing_type, invh.bizplace_id, \n invh.domain_id,\n invh.qty, invh.opening_qty,\tinvh.uom_value, invh.opening_uom_value,\n CASE WHEN invh.transaction_type = 'ADJUSTMENT' THEN 'ADJUSTMENT'\n WHEN invh.transaction_type = 'NEW' THEN 'NEW'\n ELSE COALESCE(order_no, '-') END AS order_name,\n CASE WHEN invh.transaction_type = 'ADJUSTMENT' THEN 'ADJUSTMENT' \n WHEN invh.transaction_type = 'NEW' THEN 'NEW'\n ELSE COALESCE(order_ref_no, '-') END AS ref_no,\n 1 AS rn, invh.created_at\n FROM temp_data_src invh\n LEFT JOIN arrival_notices arrNo ON cast(arrNo.id AS VARCHAR) = invh.ref_order_id AND (invh.transaction_type = 'UNLOADING' OR \n invh.transaction_type = 'UNDO_UNLOADING')\n LEFT JOIN worksheets wks ON cast(wks.id AS VARCHAR) = invh.ref_order_id AND invh.transaction_type = 'PICKING'\n LEFT JOIN release_goods rel ON cast(rel.id AS VARCHAR) = cast(wks.release_good_id AS VARCHAR) AND \n invh.transaction_type = 'PICKING'\n WHERE (invh.qty <> 0 OR invh.uom_value <> 0)\n AND invh.created_at BETWEEN $1::timestamp AND $2::timestamp\n ) AS inv_movement \n GROUP BY product_sku, product_name, product_description, batch_id, product_id, packing_type, bizplace_id, \n domain_id, order_name, ref_no, rn\n )`,\n [fromDate.value, toDate.value]\n )\n\n const result: any = await tx.query(\n ` \n select product_sku, product_name, product_description, batch_id, product_id, packing_type, bizplace_id, \n domain_id, qty, opening_qty, uom_value, opening_uom_value, order_name, ref_no, created_at::date\n from temp_inv_history invh where\n exists (\n select * from (\n select batch_id, product_name, packing_type, sum(qty) as totalQty, count(*) as totalRow from temp_inv_history ih2 group by batch_id, product_name, packing_type\n ) src where src.batch_id = invh.batch_id and src.product_name = invh.product_name and src.packing_type = invh.packing_type and (src.totalRow > 1 or src.totalQty <> 0)\n )\n ORDER BY invh.batch_id asc, invh.product_name asc, invh.product_description asc, invh.packing_type asc, invh.rn asc, invh.created_at asc\n `\n )\n\n tx.query(\n `\n drop table temp_data_src, temp_inv_history\n `\n )\n\n let items = result.map(itm => {\n return {\n batchId: itm.batch_id,\n packingType: itm.packing_type,\n product: {\n id: itm.product_id,\n sku: itm.product_sku,\n name: itm.product_name,\n description: itm.product_description\n },\n refNo: itm.ref_no,\n qty: itm.qty,\n uomValue: itm.uom_value,\n openingQty: itm.opening_qty,\n openingUomValue: itm.opening_uom_value,\n orderNo: itm.order_name,\n createdAt: itm.created_at\n }\n })\n\n return items\n } catch (error) {\n throw error\n }\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"elccl-inventory-history-summary-report.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/custom/elccl/elccl-inventory-history-summary-report.ts"],"names":[],"mappings":";;;AAAA,qCAAsD;AAEtD,uDAAmD;AAGtC,QAAA,kCAAkC,GAAG;IAChD,KAAK,CAAC,kCAAkC,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QAC9E,IAAI;YACF,MAAM,EAAE,EAAE,EAAE,GAA0B,OAAO,CAAC,KAAK,CAAA;YAEnD,MAAM,kCAAkC,CAAC,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,CAAA;YAE5D,MAAM,KAAK,GAAQ,MAAM,EAAE,CAAC,KAAK,CAAC,6CAA6C,CAAC,CAAA;YAEhF,MAAM,MAAM,GAAQ,MAAM,EAAE,CAAC,KAAK,CAChC;;OAED,EACC,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,MAAM,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAClF,CAAA;YAED,IAAI,KAAK,GAAG,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;gBAC3B,uCACK,GAAG,KACN,OAAO,EAAE,GAAG,CAAC,QAAQ,EACrB,WAAW,EAAE,GAAG,CAAC,YAAY,EAC7B,UAAU,EAAE,GAAG,CAAC,WAAW,EAC3B,aAAa,EAAE,GAAG,CAAC,cAAc,EACjC,UAAU,EAAE,GAAG,CAAC,WAAW,EAC3B,UAAU,EAAE,GAAG,CAAC,YAAY,EAC5B,WAAW,EAAE,GAAG,CAAC,aAAa,EAC9B,cAAc,EAAE,GAAG,CAAC,gBAAgB,EACpC,UAAU,EAAE,GAAG,CAAC,WAAW,EAC3B,WAAW,EAAE,GAAG,CAAC,YAAY,EAC7B,OAAO,EAAE;wBACP,EAAE,EAAE,GAAG,CAAC,UAAU;wBAClB,GAAG,EAAE,GAAG,CAAC,WAAW;wBACpB,IAAI,EAAE,GAAG,CAAC,YAAY;wBACtB,WAAW,EAAE,GAAG,CAAC,mBAAmB;qBACrC,IACF;YACH,CAAC,CAAC,CAAA;YAEF,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,CAAA;SACxC;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,KAAK,CAAA;SACZ;IACH,CAAC;CACF,CAAA;AAEM,KAAK,UAAU,kCAAkC,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;IAC9F,IAAI;QACF,MAAM,EAAE,EAAE,EAAE,GAA0B,OAAO,CAAC,KAAK,CAAA;QAEnD,IAAI,iBAAiB,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,aAAa,CAAC,CAAA;QAEhF,IAAI,cAAc,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAA;QAE1E,IAAI,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAA;QACpE,IAAI,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAA;QAEhE,IAAI,CAAC,cAAc,IAAI,CAAC,QAAQ,IAAI,CAAC,MAAM;YAAE,MAAM,eAAe,CAAA;QAElE,MAAM,QAAQ,GAAa,MAAM,IAAA,uBAAa,EAAC,mBAAQ,CAAC,CAAC,OAAO,CAAC;YAC/D,EAAE,EAAE,cAAc,CAAC,KAAK;SACzB,CAAC,CAAA;QAEF,IAAI,gBAAgB,GAAG,EAAE,CAAA;QACzB,IAAI,iBAAiB,IAAI,iBAAiB,CAAC,KAAK,EAAE;YAChD,gBAAgB,GAAG,2FAA2F,CAAA;SAC/G;QAED,MAAM,EAAE,CAAC,KAAK,CACZ;;;;;;;;;;;;KAYD,EACC,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,EAAE,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC,KAAK,CAAC,CACrD,CAAA;QAED,MAAM,EAAE,CAAC,KAAK,CACZ;;;;;;;;;;;;;;;;;;;;;;UAsBI,gBAAgB;;KAErB,EACC,CAAC,QAAQ,CAAC,KAAK,CAAC,CACjB,CAAA;KACF;IAAC,OAAO,KAAK,EAAE;QACd,MAAM,KAAK,CAAA;KACZ;AACH,CAAC;AAtED,gFAsEC"}
1
+ {"version":3,"file":"elccl-inventory-history-summary-report.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/custom/elccl/elccl-inventory-history-summary-report.ts"],"names":[],"mappings":";;;AAAA,qCAAsD;AAEtD,uDAAmD;AAGtC,QAAA,kCAAkC,GAAG;IAChD,KAAK,CAAC,kCAAkC,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QAC9E,IAAI;YACF,MAAM,EAAE,EAAE,EAAE,GAA0B,OAAO,CAAC,KAAK,CAAA;YAEnD,MAAM,kCAAkC,CAAC,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,CAAA;YAE5D,MAAM,KAAK,GAAQ,MAAM,EAAE,CAAC,KAAK,CAAC,6CAA6C,CAAC,CAAA;YAEhF,MAAM,MAAM,GAAQ,MAAM,EAAE,CAAC,KAAK,CAChC;;OAED,EACC,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,MAAM,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAClF,CAAA;YAED,IAAI,KAAK,GAAG,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;gBAC3B,uCACK,GAAG,KACN,OAAO,EAAE,GAAG,CAAC,QAAQ,EACrB,WAAW,EAAE,GAAG,CAAC,YAAY,EAC7B,UAAU,EAAE,GAAG,CAAC,WAAW,EAC3B,aAAa,EAAE,GAAG,CAAC,cAAc,EACjC,UAAU,EAAE,GAAG,CAAC,WAAW,EAC3B,UAAU,EAAE,GAAG,CAAC,YAAY,EAC5B,WAAW,EAAE,GAAG,CAAC,aAAa,EAC9B,cAAc,EAAE,GAAG,CAAC,gBAAgB,EACpC,UAAU,EAAE,GAAG,CAAC,WAAW,EAC3B,WAAW,EAAE,GAAG,CAAC,YAAY,EAC7B,OAAO,EAAE;wBACP,EAAE,EAAE,GAAG,CAAC,UAAU;wBAClB,GAAG,EAAE,GAAG,CAAC,WAAW;wBACpB,IAAI,EAAE,GAAG,CAAC,YAAY;wBACtB,WAAW,EAAE,GAAG,CAAC,mBAAmB;qBACrC,IACF;YACH,CAAC,CAAC,CAAA;YAEF,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,CAAA;SACxC;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,KAAK,CAAA;SACZ;IACH,CAAC;CACF,CAAA;AAEM,KAAK,UAAU,kCAAkC,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;IAC9F,IAAI;QACF,MAAM,EAAE,EAAE,EAAE,GAA0B,OAAO,CAAC,KAAK,CAAA;QAEnD,IAAI,iBAAiB,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,aAAa,CAAC,CAAA;QAEhF,IAAI,cAAc,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAA;QAE1E,IAAI,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAA;QACpE,IAAI,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAA;QAEhE,IAAI,CAAC,cAAc,IAAI,CAAC,QAAQ,IAAI,CAAC,MAAM;YAAE,MAAM,eAAe,CAAA;QAElE,MAAM,QAAQ,GAAa,MAAM,IAAA,uBAAa,EAAC,mBAAQ,CAAC,CAAC,OAAO,CAAC;YAC/D,EAAE,EAAE,cAAc,CAAC,KAAK;SACzB,CAAC,CAAA;QAEF,IAAI,gBAAgB,GAAG,EAAE,CAAA;QACzB,IAAI,iBAAiB,IAAI,iBAAiB,CAAC,KAAK,EAAE;YAChD,gBAAgB,GAAG,2FAA2F,CAAA;SAC/G;QAED,MAAM,EAAE,CAAC,KAAK,CACZ;;;;;;;;;;;;KAYD,EACC,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,EAAE,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC,KAAK,CAAC,CACrD,CAAA;QAED,MAAM,EAAE,CAAC,KAAK,CACZ;;;;;;;;;;;;;;;;;;;;;;UAsBI,gBAAgB;;KAErB,EACC,CAAC,QAAQ,CAAC,KAAK,CAAC,CACjB,CAAA;KACF;IAAC,OAAO,KAAK,EAAE;QACd,MAAM,KAAK,CAAA;KACZ;AACH,CAAC;AAtED,gFAsEC","sourcesContent":["import { EntityManager, getRepository } from 'typeorm'\n\nimport { Bizplace } from '@things-factory/biz-base'\nimport { ListParam } from '@things-factory/shell'\n\nexport const elcclInventoryHistorySummaryReport = {\n async elcclInventoryHistorySummaryReport(_: any, params: ListParam, context: any) {\n try {\n const { tx }: { tx: EntityManager } = context.state\n\n await inventoryHistorySummaryReportQuery(_, params, context)\n\n const total: any = await tx.query(`select count(*) from temp_inventory_summary`)\n\n const result: any = await tx.query(\n ` \n select * from temp_inventory_summary ORDER BY initial_date OFFSET $1 LIMIT $2\n `,\n [(params.pagination.page - 1) * params.pagination.limit, params.pagination.limit]\n )\n\n let items = result.map(itm => {\n return {\n ...itm,\n batchId: itm.batch_id,\n packingType: itm.packing_type,\n openingQty: itm.opening_qty,\n adjustmentQty: itm.adjustment_qty,\n closingQty: itm.closing_qty,\n totalInQty: itm.total_in_qty,\n totalOutQty: itm.total_out_qty,\n totalReturnQty: itm.total_return_qty,\n initialQty: itm.initial_qty,\n initialDate: itm.initial_date,\n product: {\n id: itm.product_id,\n sku: itm.product_sku,\n name: itm.product_name,\n description: itm.product_description\n }\n }\n })\n\n return { items, total: total[0].count }\n } catch (error) {\n throw error\n }\n }\n}\n\nexport async function inventoryHistorySummaryReportQuery(_: any, params: ListParam, context: any): Promise<void> {\n try {\n const { tx }: { tx: EntityManager } = context.state\n\n let balanceOnlyFilter = params.filters.find(data => data.name === 'balanceOnly')\n\n let bizplaceFilter = params.filters.find(data => data.name === 'bizplace')\n\n let fromDate = params.filters.find(data => data.name === 'fromDate')\n let toDate = params.filters.find(data => data.name === 'toDate')\n\n if (!bizplaceFilter || !fromDate || !toDate) throw 'Invalid input'\n\n const bizplace: Bizplace = await getRepository(Bizplace).findOne({\n id: bizplaceFilter.value\n })\n\n let balanceOnlyQuery = ''\n if (balanceOnlyFilter && balanceOnlyFilter.value) {\n balanceOnlyQuery = 'and (opening_qty + adjustment_qty + total_in_qty + total_out_qty + total_return_qty) > 0 '\n }\n\n await tx.query(\n `\n create temp table temp_inv_history on commit drop as (\n select i2.pallet_id, ih.product_id::uuid, ih.packing_type, ih.batch_id,\n ih.id as inventory_history_id, ih.seq, ih.status, ih.transaction_type, ih.qty, ih.opening_qty, ih.created_at,\n ih.ref_order_id::uuid as ref_order_id\n from inventories i2\n inner join reduced_inventory_histories ih on ih.pallet_id = i2.pallet_id and ih.domain_id = i2.domain_id\n where\n i2.domain_id = $1\n and i2.bizplace_id = $2\n and ih.created_at <= $3\n )\n `,\n [context.state.domain.id, bizplace.id, toDate.value]\n )\n\n await tx.query(\n `\n create temp table temp_inventory_summary on commit drop as (\n select src.*,\n opening_qty + adjustment_qty + total_in_qty + total_out_qty + total_return_qty as closing_qty,\n prd.name as product_name, prd.sku as product_sku, prd.description as product_description \n from (\n select ih.batch_id, ih.packing_type,\n min(ih.created_at) as initial_date,\n sum(case when (ih.transaction_type = 'UNLOADING' or ih.transaction_type = 'NEW') and rtn.id is null then qty else 0 end) as initial_qty,\n sum(case when ih.created_at > $1 and ih.transaction_type = 'ADJUSTMENT' then ih.qty else 0 end) as adjustment_qty,\n sum(case when ih.created_at < $1 then ih.qty else 0 end) as opening_qty,\n sum(case when ih.created_at > $1 then case when ih.qty > 0 and ih.transaction_type <> 'ADJUSTMENT' and ih.transaction_type <> 'RETURN' and rtn.id is null then ih.qty else 0 end else 0 end) as total_in_qty,\n sum(case when ih.created_at > $1 then case when (ih.qty < 0 and ih.transaction_type <> 'ADJUSTMENT') or ih.transaction_type = 'RETURN' then ih.qty else 0 end else 0 end) as total_out_qty,\n ih.product_id,\n sum(case when rtn.id is not null and ih.transaction_type <> 'ADJUSTMENT' and ih.created_at > $1 then qty else 0 end) as total_return_qty\n from temp_inv_history ih\n left join return_orders rtn on rtn.id = ih.ref_order_id\n group by ih.batch_id, ih.product_id, ih.packing_type\n order by batch_id\n ) src\n inner join products prd on prd.id = src.product_id\n where (opening_qty > 0 or total_in_qty > 0 or adjustment_qty > 0)\n ${balanceOnlyQuery}\n )\n `,\n [fromDate.value]\n )\n } catch (error) {\n throw error\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"elccl-onhand-inventory-counter.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/custom/elccl/elccl-onhand-inventory-counter.ts"],"names":[],"mappings":";;;AACA,uDAAkE;AAClE,qCAAuC;AACvC,mEAA0D;AAE7C,QAAA,mCAAmC,GAAG;IACjD,KAAK,CAAC,2BAA2B,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QACvE,IAAI,SAAS,GAAG,MAAM,IAAA,kCAAuB,EAAC,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;QACvF,SAAS,GAAG,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;YACvB,OAAO,GAAG,GAAG,QAAQ,CAAC,IAAI,EAAE,GAAG,GAAG,CAAA;QACpC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;QAExB,MAAM,MAAM,GAAG,MAAM,IAAA,uBAAa,EAAC,0BAAS,CAAC,CAAC,KAAK,CAAC;;;;;gCAKxB,SAAS;6BACZ,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;;;;;;gCAMpB,SAAS;6BACZ,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;;;KAG/C,CACA,CAAA;QAED,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAA;QAEvC,OAAO,KAAK,CAAA;IACd,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"elccl-onhand-inventory-counter.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/custom/elccl/elccl-onhand-inventory-counter.ts"],"names":[],"mappings":";;;AACA,uDAAkE;AAClE,qCAAuC;AACvC,mEAA0D;AAE7C,QAAA,mCAAmC,GAAG;IACjD,KAAK,CAAC,2BAA2B,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QACvE,IAAI,SAAS,GAAG,MAAM,IAAA,kCAAuB,EAAC,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;QACvF,SAAS,GAAG,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;YACvB,OAAO,GAAG,GAAG,QAAQ,CAAC,IAAI,EAAE,GAAG,GAAG,CAAA;QACpC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;QAExB,MAAM,MAAM,GAAG,MAAM,IAAA,uBAAa,EAAC,0BAAS,CAAC,CAAC,KAAK,CAAC;;;;;gCAKxB,SAAS;6BACZ,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;;;;;;gCAMpB,SAAS;6BACZ,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;;;KAG/C,CACA,CAAA;QAED,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAA;QAEvC,OAAO,KAAK,CAAA;IACd,CAAC;CACF,CAAA","sourcesContent":["import { ListParam } from '@things-factory/shell'\nimport { getPermittedBizplaceIds } from '@things-factory/biz-base'\nimport { getRepository } from 'typeorm'\nimport { Inventory } from '@things-factory/warehouse-base'\n\nexport const elcclOnhandInventoryCounterResolver = {\n async elcclOnhandInventoryCounter(_: any, params: ListParam, context: any) {\n let bizplaces = await getPermittedBizplaceIds(context.state.domain, context.state.user)\n bizplaces = bizplaces.map(bizplace => {\n return \"'\" + bizplace.trim() + \"'\"\n }).join(',')\n\n const result = await getRepository(Inventory).query(`\n select sum(qty) as total from (\n select count(pallet_id) as qty from inventories i2\n where status not in ('INTRANSIT', 'TERMINATED', 'DELETED')\n and reusable_pallet_id is null\n and bizplace_id in (${bizplaces})\n and domain_id = '${context.state.domain.id}'\n union all\n select count(distinct ref_order_id) as qty from inventories i2\n where status not in ('INTRANSIT', 'TERMINATED', 'DELETED')\n and reusable_pallet_id notnull\n and ref_order_id notnull\n and bizplace_id in (${bizplaces})\n and domain_id = '${context.state.domain.id}'\n group by reusable_pallet_id\n ) as foo\n `\n )\n \n const total = parseInt(result[0].total)\n\n return total\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/custom/elccl/index.ts"],"names":[],"mappings":";;;AAAA,qGAA6F;AAC7F,mFAA4E;AAC5E,qFAA8E;AAC9E,iHAAwG;AACxG,qFAAsF;AACtF,6FAAqF;AAExE,QAAA,KAAK,2FACb,2EAAkC,GAClC,0DAA0B,GAC1B,4DAA2B,GAC3B,sFAAuC,GACvC,oEAAmC,GACnC,mEAA8B,EAClC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/custom/elccl/index.ts"],"names":[],"mappings":";;;AAAA,qGAA6F;AAC7F,mFAA4E;AAC5E,qFAA8E;AAC9E,iHAAwG;AACxG,qFAAsF;AACtF,6FAAqF;AAExE,QAAA,KAAK,2FACb,2EAAkC,GAClC,0DAA0B,GAC1B,4DAA2B,GAC3B,sFAAuC,GACvC,oEAAmC,GACnC,mEAA8B,EAClC","sourcesContent":["import { elcclInventoryHistorySummaryReport } from './elccl-inventory-history-summary-report'\nimport { elcclDailyCollectionReport } from './elccl-daily-collection-report'\nimport { elcclInventoryHistoryReport } from './elccl-inventory-history-report'\nimport { elcclInventoryHistoryPalletDetailReport } from './elccl-inventory-history-pallet-detail-report'\nimport { elcclOnhandInventoryCounterResolver } from './elccl-onhand-inventory-counter'\nimport { elcclDailyOrderInventoryReport } from './elccl-daily-order-inventory-report'\n\nexport const Query = {\n ...elcclInventoryHistorySummaryReport,\n ...elcclDailyCollectionReport,\n ...elcclInventoryHistoryReport,\n ...elcclInventoryHistoryPalletDetailReport,\n ...elcclOnhandInventoryCounterResolver,\n ...elcclDailyOrderInventoryReport\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/custom/kimeda/index.ts"],"names":[],"mappings":";;;AAAA,uFAAwF;AAE3E,QAAA,KAAK,qBACb,sEAAoC,EACxC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/custom/kimeda/index.ts"],"names":[],"mappings":";;;AAAA,uFAAwF;AAE3E,QAAA,KAAK,qBACb,sEAAoC,EACxC","sourcesContent":["import { kimedaOnhandInventoryCounterResolver } from './kimeda-onhand-inventory-counter'\n\nexport const Query = {\n ...kimedaOnhandInventoryCounterResolver\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"kimeda-onhand-inventory-counter.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/custom/kimeda/kimeda-onhand-inventory-counter.ts"],"names":[],"mappings":";;;AACA,uDAAkE;AAClE,qCAAuC;AACvC,mEAA0D;AAE7C,QAAA,oCAAoC,GAAG;IAClD,KAAK,CAAC,4BAA4B,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QACxE,IAAI,SAAS,GAAG,MAAM,IAAA,kCAAuB,EAAC,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;QACvF,SAAS,GAAG,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;YACvB,OAAO,GAAG,GAAG,QAAQ,CAAC,IAAI,EAAE,GAAG,GAAG,CAAA;QACpC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;QAExB,MAAM,MAAM,GAAG,MAAM,IAAA,uBAAa,EAAC,0BAAS,CAAC,CAAC,KAAK,CAAC;;;;;;;8BAO1B,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;iCACpB,SAAS;;;;;;;;;8BASZ,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;iCACpB,SAAS;;;;KAIrC,CACA,CAAA;QAED,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAA;QAEvC,OAAO,KAAK,CAAA;IACd,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"kimeda-onhand-inventory-counter.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/custom/kimeda/kimeda-onhand-inventory-counter.ts"],"names":[],"mappings":";;;AACA,uDAAkE;AAClE,qCAAuC;AACvC,mEAA0D;AAE7C,QAAA,oCAAoC,GAAG;IAClD,KAAK,CAAC,4BAA4B,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QACxE,IAAI,SAAS,GAAG,MAAM,IAAA,kCAAuB,EAAC,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;QACvF,SAAS,GAAG,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;YACvB,OAAO,GAAG,GAAG,QAAQ,CAAC,IAAI,EAAE,GAAG,GAAG,CAAA;QACpC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;QAExB,MAAM,MAAM,GAAG,MAAM,IAAA,uBAAa,EAAC,0BAAS,CAAC,CAAC,KAAK,CAAC;;;;;;;8BAO1B,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;iCACpB,SAAS;;;;;;;;;8BASZ,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;iCACpB,SAAS;;;;KAIrC,CACA,CAAA;QAED,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAA;QAEvC,OAAO,KAAK,CAAA;IACd,CAAC;CACF,CAAA","sourcesContent":["import { ListParam } from '@things-factory/shell'\nimport { getPermittedBizplaceIds } from '@things-factory/biz-base'\nimport { getRepository } from 'typeorm'\nimport { Inventory } from '@things-factory/warehouse-base'\n\nexport const kimedaOnhandInventoryCounterResolver = {\n async kimedaOnhandInventoryCounter(_: any, params: ListParam, context: any) {\n let bizplaces = await getPermittedBizplaceIds(context.state.domain, context.state.user)\n bizplaces = bizplaces.map(bizplace => {\n return \"'\" + bizplace.trim() + \"'\"\n }).join(',')\n\n const result = await getRepository(Inventory).query(`\n select sum(qty) as total from (\n select l2.name, count(distinct i2.location_id) as qty, string_agg(i2.pallet_id, ', ')\n from inventories i2\n inner join locations l2 on i2.location_id = l2.id\n and i2.domain_id = l2.domain_id\n where i2.status not in ('INTRANSIT', 'TERMINATED', 'DELETED')\n and i2.domain_id = '${context.state.domain.id}'\n and i2.bizplace_id in (${bizplaces})\n and l2.type = 'SHELF'\n group by l2.name\n union all\n select l2.name, count(i2.pallet_id) as qty, string_agg(i2.pallet_id, ', ')\n from inventories i2\n inner join locations l2 on i2.location_id = l2.id\n and i2.domain_id = l2.domain_id\n where i2.status not in ('INTRANSIT', 'TERMINATED', 'DELETED')\n and i2.domain_id = '${context.state.domain.id}'\n and i2.bizplace_id in (${bizplaces})\n and l2.type = 'FLOOR'\n group by l2.name\n ) as foo\n `\n )\n \n const total = parseInt(result[0].total)\n\n return total\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"arrival-notices-by-status.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/dashboard/arrival-notices-by-status.ts"],"names":[],"mappings":";;;AAAA,qCAA2D;AAG3D,uDAAkE;AAClE,2DAA0D;AAC1D,iDAAqE;AAExD,QAAA,8BAA8B,GAAG;IAC5C,KAAK,CAAC,sBAAsB,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QAClE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAmC,OAAO,CAAC,KAAK,CAAA;QAEtE,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAW,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,UAAU,CAAC,EAAE;YACrE,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC;gBAClB,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,IAAI;gBACd,KAAK,EAAE,MAAM,IAAA,kCAAuB,EAAC,MAAM,EAAE,IAAI,CAAC;gBAClD,QAAQ,EAAE,KAAK;aAChB,CAAC,CAAA;SACH;QAED,MAAM,EAAE,GAAsC,IAAA,uBAAa,EAAC,0BAAa,CAAC,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAA;QACnG,IAAA,kBAAU,EAAC,EAAE,EAAE,MAAM,EAAE,OAAO,CAAC,CAAA;QAC/B,OAAO,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,UAAU,EAAE,CAAA;IAC1G,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"arrival-notices-by-status.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/dashboard/arrival-notices-by-status.ts"],"names":[],"mappings":";;;AAAA,qCAA2D;AAG3D,uDAAkE;AAClE,2DAA0D;AAC1D,iDAAqE;AAExD,QAAA,8BAA8B,GAAG;IAC5C,KAAK,CAAC,sBAAsB,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QAClE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAmC,OAAO,CAAC,KAAK,CAAA;QAEtE,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAW,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,UAAU,CAAC,EAAE;YACrE,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC;gBAClB,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,IAAI;gBACd,KAAK,EAAE,MAAM,IAAA,kCAAuB,EAAC,MAAM,EAAE,IAAI,CAAC;gBAClD,QAAQ,EAAE,KAAK;aAChB,CAAC,CAAA;SACH;QAED,MAAM,EAAE,GAAsC,IAAA,uBAAa,EAAC,0BAAa,CAAC,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAA;QACnG,IAAA,kBAAU,EAAC,EAAE,EAAE,MAAM,EAAE,OAAO,CAAC,CAAA;QAC/B,OAAO,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,UAAU,EAAE,CAAA;IAC1G,CAAC;CACF,CAAA","sourcesContent":["import { getRepository, SelectQueryBuilder } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { getPermittedBizplaceIds } from '@things-factory/biz-base'\nimport { ArrivalNotice } from '@things-factory/sales-base'\nimport { buildQuery, Domain, ListParam } from '@things-factory/shell'\n\nexport const arrivalNoticesByStatusResolver = {\n async arrivalNoticesByStatus(_: any, params: ListParam, context: any) {\n const { domain, user }: { domain: Domain; user: User } = context.state\n\n if (!params.filters.find((filter: any) => filter.name === 'bizplace')) {\n params.filters.push({\n name: 'bizplaceId',\n operator: 'in',\n value: await getPermittedBizplaceIds(domain, user),\n relation: false\n })\n }\n\n const qb: SelectQueryBuilder<ArrivalNotice> = getRepository(ArrivalNotice).createQueryBuilder('an')\n buildQuery(qb, params, context)\n return qb.select('an.status', 'status').addSelect('COUNT(*) AS count').groupBy('an.status').getRawMany()\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"collection-orders-by-status.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/dashboard/collection-orders-by-status.ts"],"names":[],"mappings":";;;AAAA,qCAA2D;AAG3D,uDAAkE;AAClE,2DAA4D;AAC5D,iDAAqE;AAExD,QAAA,gCAAgC,GAAG;IAC9C,KAAK,CAAC,wBAAwB,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QACpE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAmC,OAAO,CAAC,KAAK,CAAA;QAEtE,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAW,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,UAAU,CAAC,EAAE;YACrE,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC;gBAClB,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,IAAI;gBACd,KAAK,EAAE,MAAM,IAAA,kCAAuB,EAAC,MAAM,EAAE,IAAI,CAAC;gBAClD,QAAQ,EAAE,KAAK;aAChB,CAAC,CAAA;SACH;QAED,MAAM,EAAE,GAAwC,IAAA,uBAAa,EAAC,4BAAe,CAAC,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAA;QACvG,IAAA,kBAAU,EAAC,EAAE,EAAE,MAAM,EAAE,OAAO,CAAC,CAAA;QAC/B,OAAO,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,UAAU,EAAE,CAAA;IAC1G,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"collection-orders-by-status.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/dashboard/collection-orders-by-status.ts"],"names":[],"mappings":";;;AAAA,qCAA2D;AAG3D,uDAAkE;AAClE,2DAA4D;AAC5D,iDAAqE;AAExD,QAAA,gCAAgC,GAAG;IAC9C,KAAK,CAAC,wBAAwB,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QACpE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAmC,OAAO,CAAC,KAAK,CAAA;QAEtE,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAW,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,UAAU,CAAC,EAAE;YACrE,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC;gBAClB,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,IAAI;gBACd,KAAK,EAAE,MAAM,IAAA,kCAAuB,EAAC,MAAM,EAAE,IAAI,CAAC;gBAClD,QAAQ,EAAE,KAAK;aAChB,CAAC,CAAA;SACH;QAED,MAAM,EAAE,GAAwC,IAAA,uBAAa,EAAC,4BAAe,CAAC,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAA;QACvG,IAAA,kBAAU,EAAC,EAAE,EAAE,MAAM,EAAE,OAAO,CAAC,CAAA;QAC/B,OAAO,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,UAAU,EAAE,CAAA;IAC1G,CAAC;CACF,CAAA","sourcesContent":["import { getRepository, SelectQueryBuilder } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { getPermittedBizplaceIds } from '@things-factory/biz-base'\nimport { CollectionOrder } from '@things-factory/sales-base'\nimport { buildQuery, Domain, ListParam } from '@things-factory/shell'\n\nexport const collectionOrdersByStatusResolver = {\n async collectionOrdersByStatus(_: any, params: ListParam, context: any) {\n const { domain, user }: { domain: Domain; user: User } = context.state\n\n if (!params.filters.find((filter: any) => filter.name === 'bizplace')) {\n params.filters.push({\n name: 'bizplaceId',\n operator: 'in',\n value: await getPermittedBizplaceIds(domain, user),\n relation: false\n })\n }\n\n const qb: SelectQueryBuilder<CollectionOrder> = getRepository(CollectionOrder).createQueryBuilder('co')\n buildQuery(qb, params, context)\n return qb.select('co.status', 'status').addSelect('COUNT(*) AS count').groupBy('co.status').getRawMany()\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"delivery-orders-by-status.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/dashboard/delivery-orders-by-status.ts"],"names":[],"mappings":";;;AAAA,qCAA2D;AAG3D,uDAAkE;AAClE,2DAA0D;AAC1D,iDAAqE;AAExD,QAAA,8BAA8B,GAAG;IAC5C,KAAK,CAAC,sBAAsB,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QAClE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAmC,OAAO,CAAC,KAAK,CAAA;QAEtE,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAW,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,UAAU,CAAC,EAAE;YACrE,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC;gBAClB,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,IAAI;gBACd,KAAK,EAAE,MAAM,IAAA,kCAAuB,EAAC,MAAM,EAAE,IAAI,CAAC;gBAClD,QAAQ,EAAE,KAAK;aAChB,CAAC,CAAA;SACH;QAED,MAAM,EAAE,GAAsC,IAAA,uBAAa,EAAC,0BAAa,CAAC,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAA;QACnG,IAAA,kBAAU,EAAC,EAAE,EAAE,MAAM,EAAE,OAAO,CAAC,CAAA;QAC/B,OAAO,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,UAAU,EAAE,CAAA;IAC1G,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"delivery-orders-by-status.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/dashboard/delivery-orders-by-status.ts"],"names":[],"mappings":";;;AAAA,qCAA2D;AAG3D,uDAAkE;AAClE,2DAA0D;AAC1D,iDAAqE;AAExD,QAAA,8BAA8B,GAAG;IAC5C,KAAK,CAAC,sBAAsB,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QAClE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAmC,OAAO,CAAC,KAAK,CAAA;QAEtE,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAW,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,UAAU,CAAC,EAAE;YACrE,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC;gBAClB,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,IAAI;gBACd,KAAK,EAAE,MAAM,IAAA,kCAAuB,EAAC,MAAM,EAAE,IAAI,CAAC;gBAClD,QAAQ,EAAE,KAAK;aAChB,CAAC,CAAA;SACH;QAED,MAAM,EAAE,GAAsC,IAAA,uBAAa,EAAC,0BAAa,CAAC,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAA;QACnG,IAAA,kBAAU,EAAC,EAAE,EAAE,MAAM,EAAE,OAAO,CAAC,CAAA;QAC/B,OAAO,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,UAAU,EAAE,CAAA;IAC1G,CAAC;CACF,CAAA","sourcesContent":["import { getRepository, SelectQueryBuilder } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { getPermittedBizplaceIds } from '@things-factory/biz-base'\nimport { DeliveryOrder } from '@things-factory/sales-base'\nimport { buildQuery, Domain, ListParam } from '@things-factory/shell'\n\nexport const deliveryOrdersByStatusResolver = {\n async deliveryOrdersByStatus(_: any, params: ListParam, context: any) {\n const { domain, user }: { domain: Domain; user: User } = context.state\n\n if (!params.filters.find((filter: any) => filter.name === 'bizplace')) {\n params.filters.push({\n name: 'bizplaceId',\n operator: 'in',\n value: await getPermittedBizplaceIds(domain, user),\n relation: false\n })\n }\n\n const qb: SelectQueryBuilder<DeliveryOrder> = getRepository(DeliveryOrder).createQueryBuilder('do')\n buildQuery(qb, params, context)\n return qb.select('do.status', 'status').addSelect('COUNT(*) AS count').groupBy('do.status').getRawMany()\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/dashboard/index.ts"],"names":[],"mappings":";;;AAAA,2EAA4E;AAC5E,+EAAgF;AAChF,2EAA4E;AAC5E,yEAA2E;AAC3E,yEAA0E;AAC1E,uEAAwE;AAE3D,QAAA,KAAK,2FACb,0DAA8B,GAC9B,8DAAgC,GAChC,0DAA8B,GAC9B,sDAA4B,GAC5B,wDAA6B,GAC7B,yDAA8B,EAClC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/dashboard/index.ts"],"names":[],"mappings":";;;AAAA,2EAA4E;AAC5E,+EAAgF;AAChF,2EAA4E;AAC5E,yEAA2E;AAC3E,yEAA0E;AAC1E,uEAAwE;AAE3D,QAAA,KAAK,2FACb,0DAA8B,GAC9B,8DAAgC,GAChC,0DAA8B,GAC9B,sDAA4B,GAC5B,wDAA6B,GAC7B,yDAA8B,EAClC","sourcesContent":["import { arrivalNoticesByStatusResolver } from './arrival-notices-by-status'\nimport { collectionOrdersByStatusResolver } from './collection-orders-by-status'\nimport { deliveryOrdersByStatusResolver } from './delivery-orders-by-status'\nimport { inventoryExpiryMonitorResolver } from './inventory-expiry-monitor'\nimport { outboundOrderByStatusResolver } from './outbound-order-by-status'\nimport { releaseGoodsByStatusResolver } from './release-goods-by-status'\n\nexport const Query = {\n ...arrivalNoticesByStatusResolver,\n ...collectionOrdersByStatusResolver,\n ...deliveryOrdersByStatusResolver,\n ...releaseGoodsByStatusResolver,\n ...outboundOrderByStatusResolver,\n ...inventoryExpiryMonitorResolver\n}\n"]}
@@ -1,17 +1,7 @@
1
1
  "use strict";
2
- var __rest = (this && this.__rest) || function (s, e) {
3
- var t = {};
4
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
5
- t[p] = s[p];
6
- if (s != null && typeof Object.getOwnPropertySymbols === "function")
7
- for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
8
- if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
9
- t[p[i]] = s[p[i]];
10
- }
11
- return t;
12
- };
13
2
  Object.defineProperty(exports, "__esModule", { value: true });
14
3
  exports.inventoryExpiryMonitorResolver = void 0;
4
+ const tslib_1 = require("tslib");
15
5
  exports.inventoryExpiryMonitorResolver = {
16
6
  async inventoryExpiryMonitor(_, params, context) {
17
7
  const { domain, tx } = context.state;
@@ -41,7 +31,7 @@ function getExpiryCountByStatus(expInventories, location) {
41
31
  let matchedInv = expInventories.find(inv => inv.location == location);
42
32
  if (matchedInv)
43
33
  return ((_a) => {
44
- var { location } = _a, inv = __rest(_a, ["location"]);
34
+ var { location } = _a, inv = tslib_1.__rest(_a, ["location"]);
45
35
  return inv;
46
36
  })(matchedInv);
47
37
  else
@@ -1 +1 @@
1
- {"version":3,"file":"inventory-expiry-monitor.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/dashboard/inventory-expiry-monitor.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAKa,QAAA,8BAA8B,GAAG;IAC5C,KAAK,CAAC,sBAAsB,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QAClE,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,GAAsD,OAAO,CAAC,KAAK,CAAA;QAEvF,MAAM,cAAc,GAMd,MAAM,EAAE,CAAC,KAAK,CAClB;;;;;;;;;;;;;;;KAeD,EACC,CAAC,MAAM,CAAC,EAAE,CAAC,CACZ,CAAA;QAED,OAAO;YACL,WAAW,EAAE,sBAAsB,CAAC,cAAc,EAAE,aAAa,CAAC;YAClE,OAAO,EAAE,sBAAsB,CAAC,cAAc,EAAE,UAAU,CAAC;SAC5D,CAAA;IACH,CAAC;CACF,CAAA;AAED,SAAS,sBAAsB,CAAC,cAAc,EAAE,QAAQ;IACtD,IAAI,UAAU,GAAQ,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,QAAQ,IAAI,QAAQ,CAAC,CAAA;IAE1E,IAAI,UAAU;QAAE,OAAO,CAAC,CAAC,EAAoB,EAAE,EAAE;gBAAxB,EAAE,QAAQ,OAAU,EAAL,GAAG,cAAlB,YAAoB,CAAF;YAAO,OAAA,GAAG,CAAA;SAAA,CAAC,CAAC,UAAU,CAAC,CAAA;;QAC7D,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE,UAAU,EAAE,CAAC,EAAE,CAAA;AACzD,CAAC"}
1
+ {"version":3,"file":"inventory-expiry-monitor.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/dashboard/inventory-expiry-monitor.ts"],"names":[],"mappings":";;;;AAKa,QAAA,8BAA8B,GAAG;IAC5C,KAAK,CAAC,sBAAsB,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QAClE,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,GAAsD,OAAO,CAAC,KAAK,CAAA;QAEvF,MAAM,cAAc,GAMd,MAAM,EAAE,CAAC,KAAK,CAClB;;;;;;;;;;;;;;;KAeD,EACC,CAAC,MAAM,CAAC,EAAE,CAAC,CACZ,CAAA;QAED,OAAO;YACL,WAAW,EAAE,sBAAsB,CAAC,cAAc,EAAE,aAAa,CAAC;YAClE,OAAO,EAAE,sBAAsB,CAAC,cAAc,EAAE,UAAU,CAAC;SAC5D,CAAA;IACH,CAAC;CACF,CAAA;AAED,SAAS,sBAAsB,CAAC,cAAc,EAAE,QAAQ;IACtD,IAAI,UAAU,GAAQ,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,QAAQ,IAAI,QAAQ,CAAC,CAAA;IAE1E,IAAI,UAAU;QAAE,OAAO,CAAC,CAAC,EAAoB,EAAE,EAAE;gBAAxB,EAAE,QAAQ,OAAU,EAAL,GAAG,sBAAlB,YAAoB,CAAF;YAAO,OAAA,GAAG,CAAA;SAAA,CAAC,CAAC,UAAU,CAAC,CAAA;;QAC7D,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE,UAAU,EAAE,CAAC,EAAE,CAAA;AACzD,CAAC","sourcesContent":["import { EntityManager } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { Domain, ListParam } from '@things-factory/shell'\n\nexport const inventoryExpiryMonitorResolver = {\n async inventoryExpiryMonitor(_: any, params: ListParam, context: any) {\n const { domain, tx }: { domain: Domain; user: User; tx: EntityManager } = context.state\n\n const expInventories: {\n location: string\n expired: number\n thirtyDays: number\n fortyFiveDays: number\n sixtyDays: number\n }[] = await tx.query(\n `\n SELECT \"location\", sum(\"expired\") AS \"expired\", sum(\"sixMonths\") AS \"sixMonths\", sum(\"nineMonths\") AS \"nineMonths\" FROM (\n SELECT \n CASE WHEN l.TYPE IN ('QUARANTINE','RESERVE') THEN 'QUARANTINED' ELSE 'IN SHELF' END AS \"location\",\n CASE WHEN i.expiration_date - now()::date <= 0 THEN 1 ELSE 0 END AS \"expired\",\n CASE WHEN i.expiration_date - now()::date > 0 AND i.expiration_date - now()::date <= 180 THEN 1 ELSE 0 END AS \"sixMonths\",\n CASE WHEN i.expiration_date - now()::date > 180 AND i.expiration_date - now()::date <= 270 THEN 1 ELSE 0 END AS \"nineMonths\"\n FROM inventories i\n INNER JOIN locations l ON i.location_id = l.id\n WHERE i.expiration_date - now()::date <= 270\n AND i.expiration_date NOTNULL\n AND i.status = 'STORED'\n AND i.domain_id = $1\n ) AS foo\n GROUP BY \"location\"\n `,\n [domain.id]\n )\n\n return {\n quarantined: getExpiryCountByStatus(expInventories, 'QUARANTINED'),\n inShelf: getExpiryCountByStatus(expInventories, 'IN SHELF')\n }\n }\n}\n\nfunction getExpiryCountByStatus(expInventories, location) {\n let matchedInv: any = expInventories.find(inv => inv.location == location)\n\n if (matchedInv) return (({ location, ...inv }) => inv)(matchedInv)\n else return { expired: 0, sixMonths: 0, nineMonths: 0 }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"outbound-order-by-status.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/dashboard/outbound-order-by-status.ts"],"names":[],"mappings":";;;AAKa,QAAA,6BAA6B,GAAG;IAC3C,KAAK,CAAC,qBAAqB,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QACjE,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,GAAsD,OAAO,CAAC,KAAK,CAAA;QAEvF,MAAM,WAAW,GAAwC,MAAM,EAAE,CAAC,KAAK,CACrE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA0DD,EACC,CAAC,MAAM,CAAC,EAAE,CAAC,CACZ,CAAA;QAED,MAAM,UAAU,GAAa;YAC3B,oBAAoB;YACpB,kBAAkB;YAClB,SAAS;YACT,mBAAmB;YACnB,oBAAoB;YACpB,WAAW;YACX,MAAM;YACN,cAAc;SACf,CAAA;QAED,OAAO,UAAU,CAAC,MAAM,CAAC,CAAC,YAAiD,EAAE,MAAc,EAAE,EAAE;YAC7F,IAAI,SAAS,GAAG,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,IAAI,MAAM,CAAC,CAAA;YAEjE,IAAI,SAAS;gBAAE,YAAY,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,CAAC,KAAK,EAAE,CAAC,CAAA;;gBAC/D,YAAY,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAA;YAE5C,OAAO,YAAY,CAAA;QACrB,CAAC,EAAE,EAAE,CAAC,CAAA;IACR,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"outbound-order-by-status.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/dashboard/outbound-order-by-status.ts"],"names":[],"mappings":";;;AAKa,QAAA,6BAA6B,GAAG;IAC3C,KAAK,CAAC,qBAAqB,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QACjE,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,GAAsD,OAAO,CAAC,KAAK,CAAA;QAEvF,MAAM,WAAW,GAAwC,MAAM,EAAE,CAAC,KAAK,CACrE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA0DD,EACC,CAAC,MAAM,CAAC,EAAE,CAAC,CACZ,CAAA;QAED,MAAM,UAAU,GAAa;YAC3B,oBAAoB;YACpB,kBAAkB;YAClB,SAAS;YACT,mBAAmB;YACnB,oBAAoB;YACpB,WAAW;YACX,MAAM;YACN,cAAc;SACf,CAAA;QAED,OAAO,UAAU,CAAC,MAAM,CAAC,CAAC,YAAiD,EAAE,MAAc,EAAE,EAAE;YAC7F,IAAI,SAAS,GAAG,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,IAAI,MAAM,CAAC,CAAA;YAEjE,IAAI,SAAS;gBAAE,YAAY,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,CAAC,KAAK,EAAE,CAAC,CAAA;;gBAC/D,YAAY,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAA;YAE5C,OAAO,YAAY,CAAA;QACrB,CAAC,EAAE,EAAE,CAAC,CAAA;IACR,CAAC;CACF,CAAA","sourcesContent":["import { EntityManager } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { Domain, ListParam } from '@things-factory/shell'\n\nexport const outboundOrderByStatusResolver = {\n async outboundOrderByStatus(_: any, params: ListParam, context: any) {\n const { domain, tx }: { domain: Domain; user: User; tx: EntityManager } = context.state\n\n const orderStatus: { status: string; count: number }[] = await tx.query(\n `\n WITH cte_list (\"status\", \"count\") as (\n select 'DONE' as status, 0 as \"count\"\n union\n select 'CANCELLED' as status, 0 as \"count\"\n union\n select 'PICKING UNASSIGNED' as status, 0 as \"count\"\n union\n select 'PACKING' as status, 0 as \"count\"\n union\n select 'AWAITING DISPATCH' as status, 0 as \"count\"\n union\n select 'OUT FROM WAREHOUSE' as status, 0 as \"count\"\n union\n select 'PICKING ASSIGNED' as status, 0 as \"count\"\n union\n select 'OTHERS' as status, 0 as \"count\"\n ) select l.\"status\", coalesce(src.\"count\", l.\"count\") as \"count\" \n from cte_list l\n left join (\n SELECT \"status\", COUNT(*) AS \"count\" FROM (\n SELECT \n CASE WHEN \"status\" = 'DONE' and rg.updated_at::date = CURRENT_DATE THEN 'DONE' \n WHEN \"status\" = 'CANCELLED' THEN 'CANCELLED' \n WHEN \"status\" IN('PENDING_RECEIVE', 'PENDING_WORKSHEET') THEN 'PICKING UNASSIGNED'\n END AS \"status\" \n FROM release_goods rg\n WHERE \"domain_id\" = $1\n AND rg.\"status\" IN ('CANCELLED','PENDING', 'PENDING_RECEIVE', 'PENDING_WORKSHEET', 'READY_TO_PICK', 'PICKING', 'READY_TO_PACK', 'PACKING', 'DONE')\n ) AS foo \n GROUP BY \"status\"\n UNION ALL \n SELECT \"status\", COUNT(*) AS \"count\" FROM (\n SELECT \n CASE WHEN \"dispatchment_status\" = 'DISPATCHED' THEN 'OUT FROM WAREHOUSE' \n END AS \"status\" \n FROM release_goods rg\n WHERE \"domain_id\" = $1\n AND rg.\"dispatchment_status\" IN ('READY_TO_DISPATCH', 'DISPATCHED')\n AND rg.\"status\" NOT IN ('CANCELLED', 'PENDING_CANCEL')\n AND rg.\"tracking_no\" NOTNULL\n ) AS foo \n GROUP BY \"status\"\t\t\n union all \n select 'AWAITING DISPATCH' as \"status\", count(*) from manifests m \n inner join release_goods rg ON rg.manifest_id = m.id\n where m.\"status\" = 'OPEN' and m.\"domain_id\" = $1\n union all\n select 'PICKING ASSIGNED' as \"status\", count(*) from worksheets w \n where w.\"domain_id\" = $1 and w.\"type\" ='PICKING' \n and w.\"status\" in ('DEACTIVATED','EXECUTING','PENDING_CANCEL')\n group by w.\"status\"\n union all\n select 'PACKING' as \"status\", count(*) from worksheets w \n where w.\"domain_id\" = $1 and w.\"type\" ='PACKING' \n and w.\"status\" in ('DEACTIVATED','EXECUTING','PENDING_CANCEL')\n group by w.\"status\"\n ) src on src.\"status\" = l.\"status\"\n `,\n [domain.id]\n )\n\n const statusList: string[] = [\n 'PICKING UNASSIGNED',\n 'PICKING ASSIGNED',\n 'PACKING',\n 'AWAITING DISPATCH',\n 'OUT FROM WAREHOUSE',\n 'CANCELLED',\n 'DONE',\n 'OUT OF STOCK'\n ]\n\n return statusList.reduce((statusCounts: { status: string; count: number }[], status: string) => {\n let foundItem = orderStatus.find(order => order.status == status)\n\n if (foundItem) statusCounts.push({ status, count: foundItem.count })\n else statusCounts.push({ status, count: 0 })\n\n return statusCounts\n }, [])\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"release-goods-by-status.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/dashboard/release-goods-by-status.ts"],"names":[],"mappings":";;;AAAA,qCAA2D;AAG3D,uDAAkE;AAClE,2DAAwD;AACxD,iDAAqE;AAExD,QAAA,4BAA4B,GAAG;IAC1C,KAAK,CAAC,oBAAoB,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QAChE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAmC,OAAO,CAAC,KAAK,CAAA;QAEtE,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAW,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,UAAU,CAAC,EAAE;YACrE,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC;gBAClB,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,IAAI;gBACd,KAAK,EAAE,MAAM,IAAA,kCAAuB,EAAC,MAAM,EAAE,IAAI,CAAC;gBAClD,QAAQ,EAAE,KAAK;aAChB,CAAC,CAAA;SACH;QAED,MAAM,EAAE,GAAoC,IAAA,uBAAa,EAAC,wBAAW,CAAC,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAA;QAC/F,IAAA,kBAAU,EAAC,EAAE,EAAE,MAAM,EAAE,OAAO,CAAC,CAAA;QAC/B,OAAO,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,UAAU,EAAE,CAAA;IAC1G,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"release-goods-by-status.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/dashboard/release-goods-by-status.ts"],"names":[],"mappings":";;;AAAA,qCAA2D;AAG3D,uDAAkE;AAClE,2DAAwD;AACxD,iDAAqE;AAExD,QAAA,4BAA4B,GAAG;IAC1C,KAAK,CAAC,oBAAoB,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QAChE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAmC,OAAO,CAAC,KAAK,CAAA;QAEtE,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAW,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,UAAU,CAAC,EAAE;YACrE,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC;gBAClB,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,IAAI;gBACd,KAAK,EAAE,MAAM,IAAA,kCAAuB,EAAC,MAAM,EAAE,IAAI,CAAC;gBAClD,QAAQ,EAAE,KAAK;aAChB,CAAC,CAAA;SACH;QAED,MAAM,EAAE,GAAoC,IAAA,uBAAa,EAAC,wBAAW,CAAC,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAA;QAC/F,IAAA,kBAAU,EAAC,EAAE,EAAE,MAAM,EAAE,OAAO,CAAC,CAAA;QAC/B,OAAO,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,UAAU,EAAE,CAAA;IAC1G,CAAC;CACF,CAAA","sourcesContent":["import { getRepository, SelectQueryBuilder } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { getPermittedBizplaceIds } from '@things-factory/biz-base'\nimport { ReleaseGood } from '@things-factory/sales-base'\nimport { buildQuery, Domain, ListParam } from '@things-factory/shell'\n\nexport const releaseGoodsByStatusResolver = {\n async releaseGoodsByStatus(_: any, params: ListParam, context: any) {\n const { domain, user }: { domain: Domain; user: User } = context.state\n\n if (!params.filters.find((filter: any) => filter.name === 'bizplace')) {\n params.filters.push({\n name: 'bizplaceId',\n operator: 'in',\n value: await getPermittedBizplaceIds(domain, user),\n relation: false\n })\n }\n\n const qb: SelectQueryBuilder<ReleaseGood> = getRepository(ReleaseGood).createQueryBuilder('rg')\n buildQuery(qb, params, context)\n return qb.select('rg.status', 'status').addSelect('COUNT(*) AS count').groupBy('rg.status').getRawMany()\n }\n}\n"]}