@rytass/wms-module-core 0.1.0

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 (199) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +80 -0
  3. package/index.cjs.js +6479 -0
  4. package/index.d.ts +5 -0
  5. package/index.js +74 -0
  6. package/lib/constants/index.d.ts +1 -0
  7. package/lib/constants/stock-status.d.ts +30 -0
  8. package/lib/constants/stock-status.js +51 -0
  9. package/lib/core.module.d.ts +7 -0
  10. package/lib/core.module.js +102 -0
  11. package/lib/models/extensions/allocate-inventory-order/allocate-inventory-order-change.entity.d.ts +10 -0
  12. package/lib/models/extensions/allocate-inventory-order/allocate-inventory-order-change.entity.js +40 -0
  13. package/lib/models/extensions/allocate-inventory-order/allocate-inventory-order-item.entity.d.ts +20 -0
  14. package/lib/models/extensions/allocate-inventory-order/allocate-inventory-order-item.entity.js +103 -0
  15. package/lib/models/extensions/allocate-inventory-order/allocate-inventory-order.entity.d.ts +8 -0
  16. package/lib/models/extensions/allocate-inventory-order/allocate-inventory-order.entity.js +33 -0
  17. package/lib/models/extensions/hold-inventory-order/hold-inventory-order-change.entity.d.ts +10 -0
  18. package/lib/models/extensions/hold-inventory-order/hold-inventory-order-change.entity.js +40 -0
  19. package/lib/models/extensions/hold-inventory-order/hold-inventory-order-item.entity.d.ts +19 -0
  20. package/lib/models/extensions/hold-inventory-order/hold-inventory-order-item.entity.js +97 -0
  21. package/lib/models/extensions/hold-inventory-order/hold-inventory-order.entity.d.ts +10 -0
  22. package/lib/models/extensions/hold-inventory-order/hold-inventory-order.entity.js +43 -0
  23. package/lib/models/extensions/index.d.ts +37 -0
  24. package/lib/models/extensions/merge-batch-order/merge-batch-order-change.entity.d.ts +10 -0
  25. package/lib/models/extensions/merge-batch-order/merge-batch-order-change.entity.js +40 -0
  26. package/lib/models/extensions/merge-batch-order/merge-batch-order-item.entity.d.ts +15 -0
  27. package/lib/models/extensions/merge-batch-order/merge-batch-order-item.entity.js +74 -0
  28. package/lib/models/extensions/merge-batch-order/merge-batch-order.entity.d.ts +8 -0
  29. package/lib/models/extensions/merge-batch-order/merge-batch-order.entity.js +33 -0
  30. package/lib/models/extensions/quality-inspection-order/quality-inspection-order-change.entity.d.ts +11 -0
  31. package/lib/models/extensions/quality-inspection-order/quality-inspection-order-change.entity.js +45 -0
  32. package/lib/models/extensions/quality-inspection-order/quality-inspection-order-item.entity.d.ts +18 -0
  33. package/lib/models/extensions/quality-inspection-order/quality-inspection-order-item.entity.js +93 -0
  34. package/lib/models/extensions/quality-inspection-order/quality-inspection-order.entity.d.ts +9 -0
  35. package/lib/models/extensions/quality-inspection-order/quality-inspection-order.entity.js +38 -0
  36. package/lib/models/extensions/receive-inventory-order/receive-inventory-order-change.entity.d.ts +12 -0
  37. package/lib/models/extensions/receive-inventory-order/receive-inventory-order-change.entity.js +46 -0
  38. package/lib/models/extensions/receive-inventory-order/receive-inventory-order-item.entity.d.ts +19 -0
  39. package/lib/models/extensions/receive-inventory-order/receive-inventory-order-item.entity.js +89 -0
  40. package/lib/models/extensions/receive-inventory-order/receive-inventory-order.entity.d.ts +13 -0
  41. package/lib/models/extensions/receive-inventory-order/receive-inventory-order.entity.js +57 -0
  42. package/lib/models/extensions/reclassify-inventory-order/reclassify-inventory-order-change.entity.d.ts +10 -0
  43. package/lib/models/extensions/reclassify-inventory-order/reclassify-inventory-order-change.entity.js +40 -0
  44. package/lib/models/extensions/reclassify-inventory-order/reclassify-inventory-order-item.entity.d.ts +15 -0
  45. package/lib/models/extensions/reclassify-inventory-order/reclassify-inventory-order-item.entity.js +74 -0
  46. package/lib/models/extensions/reclassify-inventory-order/reclassify-inventory-order.entity.d.ts +8 -0
  47. package/lib/models/extensions/reclassify-inventory-order/reclassify-inventory-order.entity.js +33 -0
  48. package/lib/models/extensions/scrape-order/scrape-order-change.entity.d.ts +10 -0
  49. package/lib/models/extensions/scrape-order/scrape-order-change.entity.js +40 -0
  50. package/lib/models/extensions/scrape-order/scrape-order-item.entity.d.ts +18 -0
  51. package/lib/models/extensions/scrape-order/scrape-order-item.entity.js +93 -0
  52. package/lib/models/extensions/scrape-order/scrape-order.entity.d.ts +8 -0
  53. package/lib/models/extensions/scrape-order/scrape-order.entity.js +33 -0
  54. package/lib/models/extensions/ship-inventory-order/ship-inventory-order-change.entity.d.ts +12 -0
  55. package/lib/models/extensions/ship-inventory-order/ship-inventory-order-change.entity.js +46 -0
  56. package/lib/models/extensions/ship-inventory-order/ship-inventory-order-item.entity.d.ts +19 -0
  57. package/lib/models/extensions/ship-inventory-order/ship-inventory-order-item.entity.js +90 -0
  58. package/lib/models/extensions/ship-inventory-order/ship-inventory-order-reference.entity.d.ts +13 -0
  59. package/lib/models/extensions/ship-inventory-order/ship-inventory-order-reference.entity.js +65 -0
  60. package/lib/models/extensions/ship-inventory-order/ship-inventory-order.entity.d.ts +13 -0
  61. package/lib/models/extensions/ship-inventory-order/ship-inventory-order.entity.js +56 -0
  62. package/lib/models/extensions/split-batch-order/split-batch-order-change.entity.d.ts +10 -0
  63. package/lib/models/extensions/split-batch-order/split-batch-order-change.entity.js +40 -0
  64. package/lib/models/extensions/split-batch-order/split-batch-order-item.entity.d.ts +15 -0
  65. package/lib/models/extensions/split-batch-order/split-batch-order-item.entity.js +74 -0
  66. package/lib/models/extensions/split-batch-order/split-batch-order.entity.d.ts +8 -0
  67. package/lib/models/extensions/split-batch-order/split-batch-order.entity.js +33 -0
  68. package/lib/models/extensions/transfer-customer-order/transfer-customer-order-change.entity.d.ts +10 -0
  69. package/lib/models/extensions/transfer-customer-order/transfer-customer-order-change.entity.js +40 -0
  70. package/lib/models/extensions/transfer-customer-order/transfer-customer-order-item.entity.d.ts +19 -0
  71. package/lib/models/extensions/transfer-customer-order/transfer-customer-order-item.entity.js +98 -0
  72. package/lib/models/extensions/transfer-customer-order/transfer-customer-order.entity.d.ts +8 -0
  73. package/lib/models/extensions/transfer-customer-order/transfer-customer-order.entity.js +33 -0
  74. package/lib/models/extensions/transfer-order/transfer-order-change.entity.d.ts +10 -0
  75. package/lib/models/extensions/transfer-order/transfer-order-change.entity.js +40 -0
  76. package/lib/models/extensions/transfer-order/transfer-order-item.entity.d.ts +21 -0
  77. package/lib/models/extensions/transfer-order/transfer-order-item.entity.js +108 -0
  78. package/lib/models/extensions/transfer-order/transfer-order.entity.d.ts +12 -0
  79. package/lib/models/extensions/transfer-order/transfer-order.entity.js +53 -0
  80. package/lib/models/extensions/transfer-vendor-order/transfer-vendor-order-change.entity.d.ts +10 -0
  81. package/lib/models/extensions/transfer-vendor-order/transfer-vendor-order-change.entity.js +40 -0
  82. package/lib/models/extensions/transfer-vendor-order/transfer-vendor-order-item.entity.d.ts +19 -0
  83. package/lib/models/extensions/transfer-vendor-order/transfer-vendor-order-item.entity.js +98 -0
  84. package/lib/models/extensions/transfer-vendor-order/transfer-vendor-order.entity.d.ts +8 -0
  85. package/lib/models/extensions/transfer-vendor-order/transfer-vendor-order.entity.js +33 -0
  86. package/lib/models/index.d.ts +2 -0
  87. package/lib/models/metadata/batch-group.entity.d.ts +8 -0
  88. package/lib/models/metadata/batch-group.entity.js +31 -0
  89. package/lib/models/metadata/batch.entity.d.ts +15 -0
  90. package/lib/models/metadata/batch.entity.js +73 -0
  91. package/lib/models/metadata/index.d.ts +11 -0
  92. package/lib/models/metadata/loader-type.entity.d.ts +9 -0
  93. package/lib/models/metadata/loader-type.entity.js +43 -0
  94. package/lib/models/metadata/loader-unit.entity.d.ts +5 -0
  95. package/lib/models/metadata/loader-unit.entity.js +21 -0
  96. package/lib/models/metadata/loader.entity.d.ts +21 -0
  97. package/lib/models/metadata/loader.entity.js +98 -0
  98. package/lib/models/metadata/location.entity.d.ts +8 -0
  99. package/lib/models/metadata/location.entity.js +28 -0
  100. package/lib/models/metadata/material-unit.entity.d.ts +11 -0
  101. package/lib/models/metadata/material-unit.entity.js +51 -0
  102. package/lib/models/metadata/material.entity.d.ts +7 -0
  103. package/lib/models/metadata/material.entity.js +28 -0
  104. package/lib/models/metadata/sale-order.entity.d.ts +5 -0
  105. package/lib/models/metadata/sale-order.entity.js +21 -0
  106. package/lib/models/metadata/stock.entity.d.ts +8 -0
  107. package/lib/models/metadata/stock.entity.js +29 -0
  108. package/lib/models/metadata/unit.entity.d.ts +5 -0
  109. package/lib/models/metadata/unit.entity.js +21 -0
  110. package/lib/models/models.module.d.ts +6 -0
  111. package/lib/models/models.module.js +122 -0
  112. package/lib/services/allocate-inventory-order.service.d.ts +29 -0
  113. package/lib/services/allocate-inventory-order.service.js +299 -0
  114. package/lib/services/base-order.service.d.ts +41 -0
  115. package/lib/services/batch.service.d.ts +30 -0
  116. package/lib/services/batch.service.js +218 -0
  117. package/lib/services/helper.service.d.ts +6 -0
  118. package/lib/services/helper.service.js +28 -0
  119. package/lib/services/hold-inventory-order.service.d.ts +29 -0
  120. package/lib/services/hold-inventory-order.service.js +285 -0
  121. package/lib/services/index.d.ts +22 -0
  122. package/lib/services/loader.service.d.ts +43 -0
  123. package/lib/services/loader.service.js +282 -0
  124. package/lib/services/location.service.d.ts +13 -0
  125. package/lib/services/location.service.js +130 -0
  126. package/lib/services/material.service.d.ts +27 -0
  127. package/lib/services/material.service.js +172 -0
  128. package/lib/services/merge-batch-order.service.d.ts +19 -0
  129. package/lib/services/merge-batch-order.service.js +195 -0
  130. package/lib/services/quality-inspection-order.service.d.ts +19 -0
  131. package/lib/services/quality-inspection-order.service.js +135 -0
  132. package/lib/services/receive-inventory-order.service.d.ts +41 -0
  133. package/lib/services/receive-inventory-order.service.js +407 -0
  134. package/lib/services/reclassify-inventory-order.service.d.ts +19 -0
  135. package/lib/services/reclassify-inventory-order.service.js +181 -0
  136. package/lib/services/sale-order.service.d.ts +7 -0
  137. package/lib/services/sale-order.service.js +20 -0
  138. package/lib/services/scrape.service.d.ts +18 -0
  139. package/lib/services/scrape.service.js +139 -0
  140. package/lib/services/ship-inventory-order.service.d.ts +60 -0
  141. package/lib/services/ship-inventory-order.service.js +599 -0
  142. package/lib/services/split-batch-order.service.d.ts +19 -0
  143. package/lib/services/split-batch-order.service.js +161 -0
  144. package/lib/services/stock.service.d.ts +38 -0
  145. package/lib/services/stock.service.js +477 -0
  146. package/lib/services/transfer-customer-order.service.d.ts +35 -0
  147. package/lib/services/transfer-customer-order.service.js +279 -0
  148. package/lib/services/transfer-order.service.d.ts +44 -0
  149. package/lib/services/transfer-order.service.js +632 -0
  150. package/lib/services/transfer-vendor-order.service.d.ts +35 -0
  151. package/lib/services/transfer-vendor-order.service.js +279 -0
  152. package/lib/services/unit.service.d.ts +7 -0
  153. package/lib/services/unit.service.js +67 -0
  154. package/lib/services/warehouse-map.service.d.ts +10 -0
  155. package/lib/services/warehouse-map.service.js +38 -0
  156. package/lib/typings/aggregated-stock.d.ts +22 -0
  157. package/lib/typings/cancel-ship-inventory-order.input.d.ts +4 -0
  158. package/lib/typings/cancel-transfer-order.input.d.ts +4 -0
  159. package/lib/typings/core-module-options.d.ts +8 -0
  160. package/lib/typings/core-module-options.js +3 -0
  161. package/lib/typings/create-allocate-inventory-order.input.d.ts +25 -0
  162. package/lib/typings/create-hold-inventory-order.input.d.ts +21 -0
  163. package/lib/typings/create-inspection-order.input.d.ts +14 -0
  164. package/lib/typings/create-loader-type.input.d.ts +9 -0
  165. package/lib/typings/create-loader.input.d.ts +15 -0
  166. package/lib/typings/create-location.input.d.ts +12 -0
  167. package/lib/typings/create-material-unit.input.d.ts +5 -0
  168. package/lib/typings/create-material.input.d.ts +11 -0
  169. package/lib/typings/create-receive-inventory-order.input.d.ts +26 -0
  170. package/lib/typings/create-ship-inventory-order.input.d.ts +46 -0
  171. package/lib/typings/create-transfer-customer-order.input.d.ts +25 -0
  172. package/lib/typings/create-transfer-order.input.d.ts +25 -0
  173. package/lib/typings/create-transfer-vendor-order.input.d.ts +25 -0
  174. package/lib/typings/deallocate-inventory-order.d.ts +8 -0
  175. package/lib/typings/find-allocate-inventory-order.input.d.ts +13 -0
  176. package/lib/typings/find-batch.input.d.ts +8 -0
  177. package/lib/typings/find-hold-inventory-order.input.d.ts +13 -0
  178. package/lib/typings/find-loader.input.d.ts +33 -0
  179. package/lib/typings/find-location.input.d.ts +10 -0
  180. package/lib/typings/find-material.input.d.ts +10 -0
  181. package/lib/typings/find-receive-inventory-order.input.d.ts +26 -0
  182. package/lib/typings/find-receive-inventory-order.input.js +9 -0
  183. package/lib/typings/find-ship-inventory-order.input.d.ts +26 -0
  184. package/lib/typings/find-ship-inventory-order.input.js +9 -0
  185. package/lib/typings/find-stock.input.d.ts +21 -0
  186. package/lib/typings/find-transfer-order.input.d.ts +21 -0
  187. package/lib/typings/get-batch.input.d.ts +14 -0
  188. package/lib/typings/index.d.ts +18 -0
  189. package/lib/typings/merge-batch.input.d.ts +11 -0
  190. package/lib/typings/paginations.d.ts +4 -0
  191. package/lib/typings/receive-inventory-order.input.d.ts +8 -0
  192. package/lib/typings/reclassify-inventory-order.input.d.ts +11 -0
  193. package/lib/typings/release-inventory-order.input.d.ts +8 -0
  194. package/lib/typings/scrape.input.d.ts +8 -0
  195. package/lib/typings/ship-inventory-order.input.d.ts +4 -0
  196. package/lib/typings/split-batch.input.d.ts +10 -0
  197. package/lib/typings/transfer-order.input.d.ts +4 -0
  198. package/package.json +52 -0
  199. package/src/lib/models/extensions/README.md +219 -0
@@ -0,0 +1,219 @@
1
+ # Order Management Entities
2
+
3
+ This directory contains all order-related entities for the WMS system. Each order type follows a consistent three-entity pattern to manage inventory operations.
4
+
5
+ ## Entity Pattern
6
+
7
+ Each order group consists of three interconnected entities:
8
+
9
+ ### 1. `*.order.entity.ts` - Order Master
10
+
11
+ **Purpose**: Groups order items together, representing a single user-initiated order operation.
12
+
13
+ **Characteristics**:
14
+
15
+ - Represents a creation event from the user
16
+ - Contains metadata like `key`, `description`, `createdAt`
17
+ - Has a one-to-many relationship with items
18
+ - May include specific fields depending on order type (e.g., `vendor`, `customer`, `reason`, `inspector`)
19
+
20
+ **Example**: `HoldInventoryOrderEntityClass`
21
+
22
+ - Groups multiple items that need to be held together
23
+ - Single order can affect multiple locations/batches
24
+
25
+ ---
26
+
27
+ ### 2. `*.order-item.entity.ts` - Order Item (Line Item)
28
+
29
+ **Purpose**: Defines which material will be manipulated, by which batch, at which location, with which loader, and what quantity.
30
+
31
+ **Characteristics**:
32
+
33
+ - Many-to-one relationship with the order
34
+ - References metadata: `Location`, `Loader`, `Material` (implied through usage)
35
+ - Specifies the target quantity for the action (e.g., `targetHeldQuantity`, `targetTransferredQuantity`)
36
+ - May be partially or fully executed
37
+
38
+ **Structure**:
39
+
40
+ ```
41
+ - material (via external reference)
42
+ - batch (via external reference)
43
+ - location (uuid reference)
44
+ - loader (uuid reference)
45
+ - targetQuantity (numeric)
46
+ - order (reference to parent order)
47
+ ```
48
+
49
+ **Example**: `HoldInventoryOrderItemEntityClass`
50
+
51
+ - Specifies that 100 units of Material X in Batch Y at Location Z should be held
52
+ - May use Loader A for the operation
53
+
54
+ ---
55
+
56
+ ### 3. `*.order-change.entity.ts` - Order Change (Execution Record)
57
+
58
+ **Purpose**: Records the actual execution of an item, which may be partial or complete.
59
+
60
+ **Characteristics**:
61
+
62
+ - Many-to-one relationship with order items
63
+ - One-to-one relationship with system `Order` (from base module)
64
+ - Records `quantityChanged` - the actual quantity executed
65
+ - Triggers the creation of corresponding stock records
66
+
67
+ **Key Logic**:
68
+ When an `order-change` is created, it automatically creates one or more `Stock` records based on the order type.
69
+
70
+ ---
71
+
72
+ ## Stock Records Created by Order Changes
73
+
74
+ Different order types create different stock records:
75
+
76
+ ### Single Stock Record
77
+
78
+ - **receive-inventory-order**: Creates **+n** quantity record
79
+ - **ship-inventory-order**: Creates **-n** quantity record
80
+ - **transfer-order**: Creates **-n** (from source) and **+n** (at destination)
81
+
82
+ ### Multiple Stock Records (Inventory Status Change)
83
+
84
+ - **hold-inventory-order**: Creates **2** records
85
+ 1. **+n** quantity with status: `HELD`
86
+ 2. **-n** quantity from status: `FREE`
87
+
88
+ - **release-inventory-order**: Creates **2** records
89
+ 1. **-n** quantity from status: `HELD`
90
+ 2. **+n** quantity with status: `FREE`
91
+
92
+ - **allocate-inventory-order**: Creates **2** records
93
+ 1. **+n** quantity with status: `ALLOCATED`
94
+ 2. **-n** quantity from status: `FREE`
95
+
96
+ - **deallocate-inventory-order**: Creates **2** records
97
+ 1. **-n** quantity from status: `ALLOCATED`
98
+ 2. **+n** quantity with status: `FREE`
99
+
100
+ - **quality-inspection-order**: Creates **1-2** records
101
+ - Full pass: **-n** from `FREE` or current status
102
+ - Partial fail: **-n** failed, **+n** defective
103
+
104
+ - **Other order types**: Follow similar patterns based on inventory flow
105
+
106
+ ---
107
+
108
+ ## Actual Inventory Calculation
109
+
110
+ The actual inventory is determined by aggregating and summing all stock records:
111
+
112
+ ```
113
+ SELECT
114
+ material_id,
115
+ batch_id,
116
+ location_id,
117
+ loader_id,
118
+ status,
119
+ SUM(quantity) as total_quantity
120
+ FROM stocks
121
+ GROUP BY material_id, batch_id, location_id, loader_id, status
122
+ HAVING SUM(quantity) > 0
123
+ ```
124
+
125
+ **Dimensions**:
126
+
127
+ - `material`: Which product
128
+ - `batch`: Which batch/lot
129
+ - `location`: Where it is stored
130
+ - `loader`: Which loader/container holds it
131
+ - `status`: Inventory classification (FREE, HELD, ALLOCATED, DEFECTIVE, etc.)
132
+
133
+ ---
134
+
135
+ ## Order Type Examples
136
+
137
+ ### Hold Inventory Order
138
+
139
+ ```
140
+ Order → Items → Changes → 2 Stock Records
141
+ Item: 100 units at Location A
142
+
143
+ Change: Execute 100 units
144
+
145
+ Stocks:
146
+ 1. +100 (HELD) at Location A
147
+ 2. -100 (FREE) at Location A
148
+ ```
149
+
150
+ ### Transfer Inventory Order
151
+
152
+ ```
153
+ Order → Items → Changes → Multiple Stock Records
154
+ Item: 50 units from Location A to Location B
155
+
156
+ Change: Execute 50 units
157
+
158
+ Stocks:
159
+ 1. -50 at Location A
160
+ 2. +50 at Location B
161
+ ```
162
+
163
+ ---
164
+
165
+ ## Data Flow Summary
166
+
167
+ ```
168
+ User Action
169
+
170
+ Order Created (*.order.entity)
171
+
172
+ Order Items Added (*.order-item.entity)
173
+
174
+ Order Execution (*.order-change.entity)
175
+
176
+ Stock Records Created
177
+
178
+ Inventory Available for Query
179
+ (Grouped by: material + batch + location + loader + status)
180
+ ```
181
+
182
+ ---
183
+
184
+ ## File Organization
185
+
186
+ ```
187
+ extensions/
188
+ ├── README.md (this file)
189
+ ├── receive-inventory-order/
190
+ │ ├── receive-inventory-order.entity.ts
191
+ │ ├── receive-inventory-order-item.entity.ts
192
+ │ └── receive-inventory-order-change.entity.ts
193
+ ├── ship-inventory-order/
194
+ ├── transfer-order/
195
+ ├── hold-inventory-order/
196
+ ├── release-inventory-order/
197
+ ├── allocate-inventory-order/
198
+ ├── deallocate-inventory-order/
199
+ ├── split-batch-order/
200
+ ├── merge-batch-order/
201
+ ├── reclassify-inventory-order/
202
+ ├── transfer-vendor-order/
203
+ ├── return-vendor-order/
204
+ ├── quality-inspection-order/
205
+ ├── transfer-customer-order/
206
+ ├── return-customer-order/
207
+ └── index.ts (exports all entities)
208
+ ```
209
+
210
+ ---
211
+
212
+ ## Key Design Principles
213
+
214
+ 1. **Three-Layer Model**: Order → Items → Changes ensures traceability
215
+ 2. **Immutable History**: All changes are recorded as new records, never modified
216
+ 3. **Stock-Based Inventory**: No direct quantity fields; inventory is calculated from stocks
217
+ 4. **Status Tracking**: Stock records track material status through its lifecycle
218
+ 5. **Flexibility**: Partial execution supported through quantity-based changes
219
+ 6. **Auditability**: Every stock movement is traceable to an order and change record