@feedmepos/mf-inventory-portal 1.0.8 → 1.0.9-dev.2

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 (97) hide show
  1. package/dist/{App-DeBNx7kq.js → App-DfxhucPn.js} +50 -49
  2. package/dist/{ApprovalView-CYgDG4X-.js → ApprovalView-BUYgTb8S.js} +24 -24
  3. package/dist/{BindingsDialog-Bojdsd9h.js → BindingsDialog-Cbs9aVch.js} +2 -2
  4. package/dist/{BindingsPicker-TkiARkrC.js → BindingsPicker-BH9bil6g.js} +3 -3
  5. package/dist/{BindingsTable-BWYaPoFt.js → BindingsTable-DBsS_9yb.js} +1 -1
  6. package/dist/ClosingDraftView-CcQssDLY.js +1415 -0
  7. package/dist/{ClosingTemplateView-CUjkAFjw.js → ClosingTemplateView-BHPqi-bL.js} +10 -10
  8. package/dist/{DeliveryOrderPrintPreview-BOEKl7zP.js → DeliveryOrderPrintPreview-DlTLtZ1f.js} +1 -1
  9. package/dist/{FmFilterableMenuOptions.vue_vue_type_script_setup_true_lang-Bve5cng3.js → FmFilterableMenuOptions.vue_vue_type_script_setup_true_lang-CtJSPDCo.js} +32 -32
  10. package/dist/{FmUnitInput.vue_vue_type_script_setup_true_lang-1-G4gmCj.js → FmUnitInput.vue_vue_type_script_setup_true_lang-B-erI7fq.js} +51 -51
  11. package/dist/{IngredientBindedItem.vue_vue_type_script_setup_true_lang-Bl526zYj.js → IngredientBindedItem.vue_vue_type_script_setup_true_lang-DT4nyE8i.js} +1 -1
  12. package/dist/{IngredientGroupView-stli1Xiv.js → IngredientGroupView-DE15kdqH.js} +11 -11
  13. package/dist/{IngredientsView-jmDSRSkr.js → IngredientsView-BCEznLxB.js} +15 -14
  14. package/dist/{IntegrationView-BQZtDqlR.js → IntegrationView-COSJuqnB.js} +146 -145
  15. package/dist/{InventoryBindingForm-hHgB20dI.js → InventoryBindingForm-B3C8gktf.js} +1 -1
  16. package/dist/{InventoryBindingForm.vue_vue_type_script_setup_true_lang-BK36mlQE.js → InventoryBindingForm.vue_vue_type_script_setup_true_lang-Bn2X1jxB.js} +20 -20
  17. package/dist/{InventoryBindingSummary-JsAhd0Jm.js → InventoryBindingSummary-BF1OtGum.js} +1 -1
  18. package/dist/{NumberPrecisionInput.vue_vue_type_script_setup_true_lang-C4A6bDPB.js → NumberPrecisionInput.vue_vue_type_script_setup_true_lang-BMTXHa4I.js} +1 -1
  19. package/dist/{PremiumBadge.vue_vue_type_script_setup_true_lang-C6bND0mn.js → PremiumBadge.vue_vue_type_script_setup_true_lang-CZR7wF6-.js} +10 -10
  20. package/dist/{PublishView-BK7WwXeV.js → PublishView-Cp5tpVb0.js} +12 -12
  21. package/dist/{PurchaseOrderPrintPreview-CMnaZkzc.js → PurchaseOrderPrintPreview-DWOcxCH8.js} +4 -4
  22. package/dist/{ReceiveRequestView-Bb6RQyJ8.js → ReceiveRequestView-CRuhm8r1.js} +53 -52
  23. package/dist/{RecipeView-CZnElbJ8.js → RecipeView-BTS1LBKZ.js} +29 -29
  24. package/dist/{StockView-CDAHrTyi.js → StockView-CuK8s5rt.js} +73 -72
  25. package/dist/{SupplierView-WTgrwbJ_.js → SupplierView-Bwpe9RoM.js} +12 -11
  26. package/dist/TransferDetails.vue_vue_type_script_setup_true_lang-DDAZMTzq.js +1897 -0
  27. package/dist/{TransferTemplateView-26w6orAY.js → TransferTemplateView-BlluEiV-.js} +291 -290
  28. package/dist/{UnitView-DAl0OS01.js → UnitView-BWGQHOWP.js} +23 -23
  29. package/dist/{WarehouseView-Db2wXza_.js → WarehouseView-dOCu22dg.js} +26 -26
  30. package/dist/api/bill.d.ts +2 -2
  31. package/dist/api/food-market-hub.d.ts +1 -1
  32. package/dist/api/inventory.d.ts +44 -44
  33. package/dist/api/netsuite.d.ts +3 -3
  34. package/dist/api/purchase-order.d.ts +5 -1
  35. package/dist/api/stock.d.ts +1 -0
  36. package/dist/{app-Ch3IXeOL.js → app-BkIAyhP-.js} +16504 -16961
  37. package/dist/app.d.ts +7 -7
  38. package/dist/app.js +1 -1
  39. package/dist/components/inventory-binding/InventoryBinding.vue.d.ts +8 -8
  40. package/dist/components/shell/inventory/binding-dialog.vue.d.ts +2 -2
  41. package/dist/components/shell/inventory/binding-ui.vue.d.ts +5 -5
  42. package/dist/composable/usePromise.d.ts +41 -0
  43. package/dist/{decimal-BFWsfQmw.js → decimal-BiC7uGww.js} +1 -1
  44. package/dist/feature-CCDDWpq8.js +17319 -0
  45. package/dist/{format-unit-display-CyBzA_Ye.js → format-unit-display-CLa0op_h.js} +60 -60
  46. package/dist/{index-CKB7R0y2.js → index-BbFvsU1Z.js} +7 -6
  47. package/dist/{index-CSjhH3PC.js → index-UgbyiGok.js} +1 -1
  48. package/dist/{stock-BjY9UvKO.js → stock-SxO4bxTm.js} +29 -25
  49. package/dist/stores/feature.d.ts +5 -20
  50. package/dist/stores/integration/foodmarkethub.d.ts +1 -1
  51. package/dist/stores/integration/netsuite.d.ts +7 -7
  52. package/dist/stores/inventory.d.ts +44 -44
  53. package/dist/stores/location.d.ts +137 -137
  54. package/dist/{supplier-8x-ZFcOk.js → supplier-BVdCk7nI.js} +4 -4
  55. package/dist/tsconfig.app.tsbuildinfo +1 -1
  56. package/dist/{use-ingredient-select-dialog-CxZAaSGc.js → use-ingredient-select-dialog-CDeGXhur.js} +1 -1
  57. package/dist/{use-inventory-binding-dialog-Kmg24YiM.js → use-inventory-binding-dialog-CeRKqMy7.js} +1 -1
  58. package/dist/views/adjustment-template/wastage-template/actions.d.ts +228 -228
  59. package/dist/views/adjustment-template/wastage-template/form/WastageTemplateItemTable.vue.d.ts +2 -2
  60. package/dist/views/adjustment-template/wastage-template/form/useAdjustmentTemplateItems.d.ts +1 -1
  61. package/dist/views/adjustment-template/wastage-template/table.d.ts +234 -234
  62. package/dist/views/closing-draft/components/closing-draft-dialog/ClosingDraftDialog.vue.d.ts +780 -74
  63. package/dist/views/closing-draft/composables/use-closing-draft-table.d.ts +424 -409
  64. package/dist/views/closing-template/components/closing-template-form/composables/use-closing-template-items.d.ts +4 -4
  65. package/dist/views/closing-template/composables/use-closing-template-actions.d.ts +252 -252
  66. package/dist/views/closing-template/composables/use-closing-template-table.d.ts +252 -252
  67. package/dist/views/ingredient-group/composables/use-ingredient-group-table.d.ts +12 -12
  68. package/dist/views/ingredients/components/convert/ConvertForm.vue.d.ts +2 -2
  69. package/dist/views/ingredients/components/ingredient-form/IngredientForm.vue.d.ts +8 -8
  70. package/dist/views/ingredients/components/inventory-binding/InventoryBindingForm.vue.d.ts +3 -3
  71. package/dist/views/ingredients/composables/use-ingredient-table.d.ts +4 -4
  72. package/dist/views/integration/components/ApplyProduct.vue.d.ts +2 -2
  73. package/dist/views/integration/components/ApplyProductDialog.vue.d.ts +2 -2
  74. package/dist/views/integration/components/ApplyProductDialogV4.vue.d.ts +2 -2
  75. package/dist/views/integration/components/netsuite/AddLocationDialog.vue.d.ts +204 -204
  76. package/dist/views/integration/components/netsuite/LocationConfigurationDialog.vue.d.ts +2 -2
  77. package/dist/views/receive-request/components/transfer-form/TransferForm.vue.d.ts +665 -637
  78. package/dist/views/receive-request/components/transfer-form/components/ForecastStock.vue.d.ts +22 -22
  79. package/dist/views/receive-request/components/transfer-form/components/TransferItemTable.vue.d.ts +44 -44
  80. package/dist/views/receive-request/components/transfer-form/composables/use-transfer-items.d.ts +11 -11
  81. package/dist/views/receive-request/composables/use-process-purchase-order.d.ts +614 -0
  82. package/dist/views/receive-request/composables/use-receive-request-form.d.ts +1190 -1142
  83. package/dist/views/receive-request/composables/use-receive-request-table.d.ts +1192 -1144
  84. package/dist/views/receive-request/constants/po-action-to-ui-style.d.ts +6 -0
  85. package/dist/views/recipe/components/recipe-form/RecipeForm.vue.d.ts +2 -2
  86. package/dist/views/stock/components/StockRecordCard.vue.d.ts +1 -1
  87. package/dist/views/stock/components/dialog/AdjustedItemForm.vue.d.ts +14 -14
  88. package/dist/views/transfer-template/components/transfer-template-form/components/TransferTemplateItemTable.vue.d.ts +22 -22
  89. package/dist/views/transfer-template/components/transfer-template-form/composables/use-template-enabled-locations.d.ts +17 -17
  90. package/dist/views/transfer-template/components/transfer-template-form/composables/use-transfer-template-items.d.ts +11 -11
  91. package/dist/views/transfer-template/composables/use-transfer-template-actions.d.ts +805 -805
  92. package/dist/views/transfer-template/composables/use-transfer-template-table.d.ts +805 -805
  93. package/dist/views/transfer-template/composables/useTransferTemplateHelper.d.ts +33 -33
  94. package/dist/{vue-i18n-CXd9SF_G.js → vue-i18n-3Mh8tKq8.js} +341 -341
  95. package/package.json +3 -1
  96. package/dist/ClosingDraftView-C0ECZ9zi.js +0 -1394
  97. package/dist/TransferDetails.vue_vue_type_script_setup_true_lang-mHNmxBuV.js +0 -1746
@@ -1,1394 +0,0 @@
1
- import { defineComponent as Ce, ref as O, resolveComponent as E, openBlock as h, createBlock as W, withCtx as Y, createElementVNode as o, createTextVNode as we, toDisplayString as N, unref as y, createVNode as _, h as w, reactive as Ge, computed as H, onMounted as We, watch as qe, isRef as Pe, createElementBlock as $, Fragment as G, createCommentVNode as ee, normalizeClass as pe, renderList as ye, normalizeStyle as Me, Teleport as Ze, mergeProps as Je } from "vue";
2
- import { Y as Qe, u as je, ag as q, m as Xe, K as Se, j as P, t as et, L as ge, r as tt, s as at, v as nt, ah as Ie, ai as Ue, a4 as Ee, aj as oe, aa as ot, af as ne, W as He, D as Te, i as Ae, h as st, f as rt, a as lt, B as ct, _ as it, C as ut, E as dt, G as _e } from "./app-Ch3IXeOL.js";
3
- import { useCoreStore as mt, useI18n as Le } from "@feedmepos/mf-common";
4
- import { useSnackbar as Be, useDialog as ft, useProxiedModel as pt, components as fe, useBreakpoints as vt } from "@feedmepos/ui-library";
5
- import { defineStore as ze, storeToRefs as yt } from "pinia";
6
- import { a as Ne, u as Oe } from "./stock-BjY9UvKO.js";
7
- import { E as gt } from "./empty-placeholder-wf6-BWE8.js";
8
- const Fe = Qe((n, r) => {
9
- function e() {
10
- return je().currentLocation.dbName;
11
- }
12
- return {
13
- async getDraft(f) {
14
- const i = e(), g = `${n.inventoryBackendUrl}/${i}/closing-draft/${f}`;
15
- return r.get(g);
16
- },
17
- async readDrafts() {
18
- const f = e(), i = `${n.inventoryBackendUrl}/${f}/closing-draft`;
19
- return r.get(i);
20
- },
21
- async runOperation(f) {
22
- const i = e(), g = `${n.inventoryBackendUrl}/${i}/closing-draft/run-operation`;
23
- return r.post(g, f);
24
- },
25
- async sync(f) {
26
- const i = e(), g = `${n.inventoryBackendUrl}/${i}/closing-draft/sync`;
27
- return r.post(g, f);
28
- }
29
- };
30
- }), bt = { class: "fm-typo-en-body-lg-400" }, ht = { class: "fm-typo-en-body-lg-600" }, xt = { class: "flex gap-12 py-8 justify-end w-full" }, Re = /* @__PURE__ */ Ce({
31
- __name: "ClosingDraftAction",
32
- props: {
33
- draft: {},
34
- action: {},
35
- onCancel: { type: Function },
36
- onFinished: { type: Function }
37
- },
38
- setup(n) {
39
- const r = n, e = O(), f = Fe(), i = Be(), g = O(!1);
40
- async function x() {
41
- g.value = !0;
42
- try {
43
- await f.runOperation({
44
- _id: r.draft._id,
45
- _rev: r.draft._rev ?? "",
46
- action: r.action,
47
- data: {
48
- remark: e.value
49
- }
50
- }).delayed(500), i.open({
51
- title: "Success",
52
- message: "Action submitted",
53
- type: "success"
54
- }), r.onFinished();
55
- } catch (D) {
56
- i.open({
57
- title: "Something went wrong",
58
- message: "Unable to submit actino. Please try again",
59
- type: "error"
60
- }), console.error("error on submit closing draft aciont", D);
61
- } finally {
62
- g.value = !1;
63
- }
64
- }
65
- return (D, u) => {
66
- const C = E("FmTextField"), T = E("FmButton"), M = E("FmForm");
67
- return h(), W(M, {
68
- onValidationSuccess: x,
69
- class: "flex flex-col gap-32",
70
- disabled: g.value
71
- }, {
72
- default: Y(() => [
73
- o("div", bt, [
74
- u[2] || (u[2] = we(" You are about to ")),
75
- o("span", ht, N(D.action == y(q).enum.approveDraft ? "approve" : "reject"), 1),
76
- u[3] || (u[3] = we(" this draft. Please provider a remark to justify this action. "))
77
- ]),
78
- _(C, {
79
- modelValue: e.value,
80
- "onUpdate:modelValue": u[0] || (u[0] = (d) => e.value = d),
81
- label: "Remark",
82
- "label-mark": "required",
83
- rules: [y(Xe)()]
84
- }, null, 8, ["modelValue", "rules"]),
85
- o("div", xt, [
86
- _(T, {
87
- label: "Cancel",
88
- variant: "tertiary",
89
- onClick: u[1] || (u[1] = (d) => D.onCancel())
90
- }),
91
- _(T, {
92
- label: D.action == y(q).enum.approveDraft ? "Approve" : "Reject",
93
- type: "submit",
94
- variant: D.action == y(q).enum.approveDraft ? "primary" : "destructive",
95
- loading: g.value
96
- }, null, 8, ["label", "variant", "loading"])
97
- ])
98
- ]),
99
- _: 1
100
- }, 8, ["disabled"]);
101
- };
102
- }
103
- }), At = ge(0);
104
- function Ve(n) {
105
- const r = n.measurementsAmounts.groupBy((f) => f.measurement.id), e = n.sku.unit.measurements.reduce((f, i) => {
106
- var D, u;
107
- const g = ((u = (D = r.get(i.id)) == null ? void 0 : D[0]) == null ? void 0 : u.amount) ?? At, x = Se(i.conversion, g);
108
- return f + +P(x);
109
- }, +P(n.baseAmount));
110
- return et(e, n.baseAmount.precision);
111
- }
112
- const _t = ge(0), Dt = ge(100);
113
- function kt(n, r, e) {
114
- const f = Ve(n), i = Ie(f, r), g = r.amount === 0 ? null : Ue(i, {
115
- ...r,
116
- amount: Math.abs(r.amount)
117
- }), x = g ? Se(g, Dt) : null;
118
- return {
119
- code: n.sku.code,
120
- name: n.sku.name,
121
- baseUnit: n.sku.unit.abbrev,
122
- baseUnitAmount: +P(n.baseAmount),
123
- ...n.measurementsAmounts.filter(
124
- (u) => wt(u.measurement) && e.includes(u.measurement.id)
125
- ).reduce(
126
- (u, C, T) => (u[`measurementAbbrev${T}`] = `(${C.measurement.abbrev}) × ${P(C.measurement.conversion)}`, u[`measurementAmount${T}`] = +P(C.amount), u),
127
- {}
128
- ),
129
- systemBalance: +P(r),
130
- physicalBalance: +P(f),
131
- adjustedAmount: +P(i),
132
- adjustedDiffPercentage: x ? +P(Ee(x, 2)) : null
133
- };
134
- }
135
- function wt(n) {
136
- return !n.abbrev.toLocaleLowerCase().includes("inactive");
137
- }
138
- function Ct(n) {
139
- const r = Ye(n);
140
- return n.reduce(
141
- (e, f) => {
142
- var i;
143
- return Math.max(e, ((i = r == null ? void 0 : r.get(f.sku._id)) == null ? void 0 : i[0].length) ?? 0);
144
- },
145
- 0
146
- );
147
- }
148
- function Ye(n) {
149
- return n.groupBy(
150
- (r) => r.sku._id,
151
- (r) => r.measurementsAmounts.filter((e) => !e.measurement.abbrev.toLocaleLowerCase().includes("inactive")).map((e) => e.measurement.id)
152
- );
153
- }
154
- function jt(n) {
155
- return [
156
- {
157
- id: "code",
158
- name: "Code"
159
- },
160
- {
161
- id: "name",
162
- name: "Name"
163
- },
164
- {
165
- id: "systemBalance",
166
- name: "Balance"
167
- },
168
- {
169
- id: "physicalBalance",
170
- name: "Actual balance"
171
- },
172
- {
173
- id: "adjustedAmount",
174
- name: "Adjusted balance"
175
- },
176
- {
177
- id: "adjustedDiffPercentage",
178
- name: "Diff (%)"
179
- },
180
- {
181
- id: "baseUnitAmount",
182
- name: "Base unit amount"
183
- },
184
- {
185
- id: "baseUnit",
186
- name: "Base unit"
187
- },
188
- ...Array.from({ length: n }).flatMap((e, f) => [
189
- {
190
- id: `measurementAmount${f}`,
191
- name: `UOM amount ${f + 1}`
192
- },
193
- {
194
- id: `measurementAbbrev${f}`,
195
- name: `UOM ${f + 1}`
196
- }
197
- ])
198
- ];
199
- }
200
- function St(n, r) {
201
- var R, b, v, j, z, S, I;
202
- const e = r.groupBy(
203
- (k) => k.id,
204
- (k) => k.balance
205
- ), f = [...n.items, ...n.negativeStockItems ?? []], i = Ye(f), g = f.map((k) => {
206
- var J, Q;
207
- const Z = ((J = e.get(k.sku._id)) == null ? void 0 : J[0]) ?? _t, ce = ((Q = i == null ? void 0 : i.get(k.sku._id)) == null ? void 0 : Q[0]) ?? [];
208
- return kt(k, Z, ce);
209
- }), x = Ct(f), u = mt().currentBusiness.value, C = jt(x), T = [
210
- ["Business name:", u == null ? void 0 : u.name],
211
- ["Business ID:", u == null ? void 0 : u._id],
212
- ["Menu version", u == null ? void 0 : u.menuVersion],
213
- ["Created at", new Date(n.createdAt)],
214
- ["Created by", (R = n.createdBy) == null ? void 0 : R.name],
215
- ["Updated at", new Date(n.updatedAt)],
216
- ["Updated by", (b = n.updatedBy) == null ? void 0 : b.name],
217
- ["Recent action", n.approvedAt ? "Approve" : n.rejectionHistory ? "Reject" : ""],
218
- [
219
- "Action by",
220
- n.approvedAt ? (v = n.approvedBy) == null ? void 0 : v.name : n.rejectionHistory ? (z = (j = n.rejectionHistory[0]) == null ? void 0 : j.rejectedBy) == null ? void 0 : z.name : ""
221
- ],
222
- [
223
- "Action at",
224
- n.approvedAt ? new Date(n.approvedAt) : n.rejectionHistory ? new Date((S = n.rejectionHistory[0]) == null ? void 0 : S.rejectedAt) : ""
225
- ],
226
- [
227
- "Action remark",
228
- n.approvedAt ? n.approveRemark : n.rejectionHistory ? new Date((I = n.rejectionHistory[0]) == null ? void 0 : I.rejectRemark) : ""
229
- ],
230
- [],
231
- C.map((k) => k.name),
232
- ...g.map((k) => C.map((Z) => k[Z.id]))
233
- ], M = C.map((k) => `system:${k.id}`), d = tt(T, M), m = `[${u == null ? void 0 : u.name}] closing draft (${at(new Date(n.updatedAt))}).xlsx`;
234
- return nt(d, m), m;
235
- }
236
- const ke = ze(
237
- "closingDraftActions",
238
- function() {
239
- const r = ft(), e = Be(), f = Ne(), i = Fe(), g = Oe(), x = O(!1), D = O();
240
- function u(b) {
241
- const v = {
242
- draft: b
243
- };
244
- D.value = v, x.value = !0;
245
- }
246
- async function C(b) {
247
- var j;
248
- if (b.status === oe.enum.COMPLETED) {
249
- const z = b.closingAdjustmentId;
250
- if (!z)
251
- return e.open({
252
- title: "Something went wrong",
253
- message: "Closing draft is completed but closing document cannot be found.",
254
- type: "error"
255
- }), console.error("Closing draft is completed but closing document cannot be found.", {
256
- draftId: b._id
257
- }), [];
258
- const S = await f.readAdjustmentById(z);
259
- return ((S == null ? void 0 : S.skus) ?? []).map((k) => ({
260
- id: k.sku._id,
261
- balance: k.fromBalance,
262
- costs: k.fromCostBalances
263
- }));
264
- } else
265
- return await g.readStockBalance(), ((j = g.stockBalance) == null ? void 0 : j.skus) ?? [];
266
- }
267
- async function T(b, v) {
268
- v || (e.open({
269
- title: "Exporting",
270
- message: "Fetching data..."
271
- }), v = await C(b)), St(b, v);
272
- }
273
- function M(b, v) {
274
- r.open({
275
- title: "Approve draft",
276
- contentComponent: Re,
277
- contentComponentProps: {
278
- draft: b,
279
- action: q.enum.approveDraft,
280
- onFinished: () => {
281
- r.close(), v == null || v();
282
- },
283
- onCancel: () => r.close()
284
- }
285
- });
286
- }
287
- function d(b, v) {
288
- r.open({
289
- title: "Reject draft",
290
- contentComponent: Re,
291
- contentComponentProps: {
292
- draft: b,
293
- action: q.enum.rejectDraft,
294
- onFinished: () => {
295
- r.close(), v == null || v();
296
- },
297
- onCancel: () => r.close()
298
- }
299
- });
300
- }
301
- async function m(b, v) {
302
- await i.sync({
303
- _id: b._id,
304
- _rev: b._rev ?? "",
305
- action: q.enum.approveDraft,
306
- data: {
307
- remark: b.remark ?? ""
308
- }
309
- }).delayed(500), e.open({
310
- title: "Success",
311
- message: "Sync requested",
312
- type: "success"
313
- }), v == null || v();
314
- }
315
- function R() {
316
- x.value = !1;
317
- }
318
- return {
319
- viewDraft: u,
320
- closeDraftDialog: R,
321
- approveDraft: M,
322
- rejectDraft: d,
323
- syncDraft: m,
324
- exportDraft: T,
325
- viewClosingDraftShow: x,
326
- viewClosingDraftProps: D
327
- };
328
- }
329
- );
330
- function De(n) {
331
- switch (n) {
332
- case "DRAFT":
333
- return "fm-status-badge-draft";
334
- case "PROCESSING":
335
- return "fm-status-badge-processing";
336
- case "FAILED":
337
- return "fm-status-badge-cancel";
338
- case "COMPLETED":
339
- return "fm-status-badge-complete";
340
- }
341
- }
342
- const Bt = ze(
343
- "closingDraftTable",
344
- function() {
345
- const { t: r } = Le(), e = ke(), f = O(new Array()), i = O(!1), g = je(), x = Fe();
346
- async function D() {
347
- if (f.value = [], !!g._currentLocation) {
348
- i.value = !0;
349
- try {
350
- const [d] = await Promise.all([x.readDrafts()]).delayed(1e3);
351
- f.value = d.reverse();
352
- } catch (d) {
353
- console.log("Something went wrong when fetching drafts:", d);
354
- } finally {
355
- i.value = !1;
356
- }
357
- }
358
- }
359
- async function u(d) {
360
- if (!f.value.find((m) => m._id) && g._currentLocation) {
361
- i.value = !0;
362
- try {
363
- const [m] = await Promise.all([
364
- x.getDraft(d),
365
- new Promise((R) => setTimeout(R, 1e3))
366
- ]);
367
- f.value = [m];
368
- } catch (m) {
369
- console.log("Something went wrong when fetching drafts:", m);
370
- } finally {
371
- i.value = !1;
372
- }
373
- }
374
- }
375
- function C() {
376
- e.closeDraftDialog(), D();
377
- }
378
- function T(d, m) {
379
- switch (m = rt(m), d) {
380
- case Ae.Details:
381
- return e.viewDraft(m);
382
- case Ae.Export:
383
- return e.exportDraft(m);
384
- case q.enum.approveDraft:
385
- return e.approveDraft(m, C);
386
- case q.enum.rejectDraft:
387
- return e.rejectDraft(m, C);
388
- }
389
- }
390
- return {
391
- columnDefs: [
392
- {
393
- id: "_id",
394
- accessorKey: "_id",
395
- header: () => r("inventory.closing.table.createdAt"),
396
- cell(d) {
397
- return ot(`${d.getValue()}`);
398
- },
399
- enableSorting: !0
400
- },
401
- {
402
- id: "updatedAt",
403
- accessorFn: (d) => ne(d.updatedAt),
404
- header: () => "Updated at",
405
- enableSorting: !0,
406
- size: 200
407
- },
408
- {
409
- id: "updatedBy",
410
- accessorKey: "updatedBy.name",
411
- header: () => "Last update by",
412
- enableSorting: !0,
413
- size: 200
414
- },
415
- {
416
- id: "noOfItems",
417
- accessorFn: (d) => {
418
- var m;
419
- return d.items.length + (((m = d.negativeStockItems) == null ? void 0 : m.length) ?? 0);
420
- },
421
- header: () => r("inventory.closing.table.noOfItems"),
422
- enableSorting: !1,
423
- meta: {
424
- width: "10rem",
425
- textAlign: "right"
426
- }
427
- },
428
- {
429
- id: "recentRemark",
430
- accessorFn: (d) => {
431
- var m;
432
- return (d == null ? void 0 : d.approveRemark) ?? ((m = d == null ? void 0 : d.rejectionHistory) == null ? void 0 : m.computeFirst((R) => R.rejectRemark)) ?? d.remark;
433
- },
434
- header: () => "Recent remark"
435
- },
436
- {
437
- id: "status",
438
- accessorFn: (d) => d.status,
439
- header: () => r("inventory.closing.table.status"),
440
- enableSorting: !1,
441
- cell(d) {
442
- var z;
443
- const m = d.row.original, R = m.status, b = new Date(m.updatedAt), v = (z = m == null ? void 0 : m.rejectionHistory) == null ? void 0 : z.computeFirst((S) => S.rejectedAt), j = v ? new Date(v) : null;
444
- return R === "DRAFT" && j ? j.getTime() > b.getTime() ? w(
445
- "div",
446
- {
447
- class: "flex"
448
- },
449
- w(
450
- "div",
451
- {
452
- class: ["fm-status-badge", De("FAILED")]
453
- },
454
- "Rejected"
455
- )
456
- ) : w(
457
- "div",
458
- {
459
- class: "flex"
460
- },
461
- w(
462
- "div",
463
- {
464
- class: ["fm-status-badge", De("PROCESSING")]
465
- },
466
- "Updated"
467
- )
468
- ) : w(
469
- "div",
470
- {
471
- class: "flex"
472
- },
473
- w(
474
- "div",
475
- {
476
- class: ["fm-status-badge", De(R)]
477
- },
478
- He(R)
479
- )
480
- );
481
- }
482
- },
483
- {
484
- id: "action",
485
- cell(d) {
486
- const m = d.row.original, R = [
487
- Te[Ae.Details],
488
- Te[Ae.Export]
489
- ], b = [
490
- {
491
- translationKey: "inventory.closing.draft.approveDraft",
492
- color: "text-fm-color-typo-primary",
493
- value: q.enum.approveDraft
494
- },
495
- {
496
- translationKey: "inventory.closing.draft.rejectDraft",
497
- color: "text-fm-color-typo-error",
498
- value: q.enum.rejectDraft
499
- }
500
- ];
501
- return st(
502
- [
503
- ...R,
504
- ...m.status === oe.enum.DRAFT ? b : []
505
- ],
506
- (v) => T(v, m)
507
- );
508
- },
509
- enableSorting: !1,
510
- size: 40,
511
- meta: {
512
- cellClass: "",
513
- headerClass: ""
514
- }
515
- }
516
- ],
517
- drafts: f,
518
- loading: i,
519
- fetchDrafts: D,
520
- loadDraft: u
521
- };
522
- }
523
- ), Ft = { class: "w-full flex flex-col gap-32" }, $t = { class: "flex justify-between" }, Tt = { class: "flex" }, Rt = { class: "grid grid-cols-[repeat(4,1fr)] xs:flex xs:flex-col sm:flex sm:flex-col gap-8" }, Pt = { class: "fm-typo-en-body-md-400 text-fm-color-typo-secondary" }, Mt = { class: "flex gap-1" }, It = { class: "fm-typo-en-body-lg-600" }, Ut = { class: "flex flex-col gap-16" }, Et = { class: "flex items-center" }, Ht = {
524
- key: 0,
525
- class: "flex gap-8"
526
- }, Lt = {
527
- key: 0,
528
- class: "w-full flex flex-col items-center"
529
- }, zt = { class: "flex items-center gap-8" }, Nt = {
530
- key: 0,
531
- class: "flex gap-8"
532
- }, Ot = { class: "overflow-x-auto" }, Vt = {
533
- key: 1,
534
- class: "flex-1 xs:w-screen xs:max-w-full"
535
- }, Yt = {
536
- key: 0,
537
- class: "flex flex-col items-center gap-8 h-full"
538
- }, Kt = ["src"], Gt = {
539
- key: 1,
540
- class: "px-4 flex flex-col"
541
- }, Wt = { class: "flex gap-12 content-stretch" }, qt = {
542
- class: "flex flex-col w-24",
543
- name: "circles"
544
- }, Zt = { class: "flex-1 flex flex-col items-center" }, Jt = { class: "flex-1 flex flex-col items-center" }, Qt = {
545
- class: "py-12 flex flex-col gap-4",
546
- name: "received-at header"
547
- }, Xt = { class: "fm-typo-en-body-lg-400" }, ea = { class: "fm-typo-en-body-lg-400 text-fm-color-typo-secondary" }, ta = { class: "flex gap-12 content-stretch" }, aa = {
548
- class: "flex flex-col w-24",
549
- name: "circles"
550
- }, na = { class: "flex-1 flex flex-col items-center" }, oa = {
551
- class: "py-12 flex flex-col gap-4 flex-1",
552
- name: "delivery details"
553
- }, sa = { class: "flex flex-col gap-8" }, ra = { class: "fm-typo-en-body-lg-400 text-fm-color-typo-secondary" }, la = { class: "flex flex-col gap-4" }, ca = { class: "flex gap-8" }, ia = /* @__PURE__ */ Ce({
554
- __name: "ClosingDraftDialog",
555
- props: {
556
- show: { type: Boolean },
557
- draft: {}
558
- },
559
- emits: ["submitted"],
560
- setup(n, { emit: r }) {
561
- const e = n, f = Oe(), i = ke(), g = pt(e, "show"), x = O(!1), D = O(!1), u = O(!1), C = O(new Array()), T = Ne(), M = Be(), d = lt(), m = Ge({}), R = H(() => new Set(
562
- d.skus.filter((a) => {
563
- var t;
564
- return m[(t = a.customAttributes) == null ? void 0 : t.tag];
565
- }).map((a) => a._id)
566
- )), b = r, v = H(() => {
567
- var t, s;
568
- const a = [...((t = e.draft) == null ? void 0 : t.items) ?? [], ...((s = e.draft) == null ? void 0 : s.negativeStockItems) ?? []];
569
- return R.value.size ? a.filter((l) => R.value.has(l.sku._id)) : a;
570
- }), j = H(() => {
571
- const a = v.value.map((t) => t.sku);
572
- return a.sort((t, s) => t.code.localeCompare(s.code)), a;
573
- }), z = H(() => v.value.groupBy(
574
- (t) => t.sku._id,
575
- (t) => t.measurementsAmounts.filter((s) => !s.measurement.abbrev.toLocaleLowerCase().includes("inactive")).map((s) => s.measurement.id)
576
- ));
577
- We(k), qe(
578
- () => e.show,
579
- (a) => {
580
- a && (te.value = ue[0], k());
581
- }
582
- );
583
- const S = ge(0), I = ge(100);
584
- async function k() {
585
- var t, s, l;
586
- x.value = !0;
587
- const a = ((t = e.draft) == null ? void 0 : t.status) === oe.enum.COMPLETED;
588
- try {
589
- if (await d.init(), a) {
590
- const c = e.draft.closingAdjustmentId;
591
- if (!c) {
592
- M.open({
593
- title: "Something went wrong",
594
- message: "Closing draft is completed but closing document cannot be found.",
595
- type: "error"
596
- }), console.error("Closing draft is completed but closing document cannot be found.", {
597
- draftId: (s = e.draft) == null ? void 0 : s._id
598
- });
599
- return;
600
- }
601
- const p = await T.readAdjustmentById(c), B = (p == null ? void 0 : p.skus) ?? [];
602
- C.value = B.map((U) => ({
603
- id: U.sku._id,
604
- balance: U.fromBalance,
605
- costs: U.fromCostBalances
606
- }));
607
- } else
608
- C.value = ((l = e.draft) == null ? void 0 : l.stockSnapshot) ?? [];
609
- } catch (c) {
610
- M.open({
611
- title: "Something went wrong",
612
- message: "Something went wrong when fetching info. Please try again.",
613
- type: "error"
614
- }), console.error("error on fetch stock balances", c);
615
- } finally {
616
- x.value = !1;
617
- }
618
- }
619
- async function Z() {
620
- var t, s;
621
- const a = ((t = e.draft) == null ? void 0 : t.effectiveAt) ?? ((s = e.draft) == null ? void 0 : s.updatedAt);
622
- if (!a) {
623
- M.open({
624
- title: "Cannot refresh",
625
- message: "Effective date is not available for this draft.",
626
- type: "error"
627
- });
628
- return;
629
- }
630
- D.value = !0;
631
- try {
632
- const l = await T.recalculation.calculateStockSnapshotAtDate(
633
- a,
634
- e.draft._id
635
- );
636
- C.value = l, M.open({
637
- title: "Balance refreshed",
638
- message: "Stock balance has been recalculated.",
639
- type: "success"
640
- });
641
- } catch (l) {
642
- M.open({
643
- title: "Refresh failed",
644
- message: "Failed to refresh stock balance. Please try again.",
645
- type: "error"
646
- }), console.error("error refreshing stock balances", l);
647
- } finally {
648
- D.value = !1;
649
- }
650
- }
651
- const ce = H(
652
- () => C.value.groupBy(
653
- (a) => a.id,
654
- (a) => a.balance
655
- )
656
- ), J = H(() => v.value.groupBy((a) => a.sku._id));
657
- function Q(a) {
658
- return w(
659
- fe.FmTooltip,
660
- { zIndex: 51, placement: "left", class: "w-full flex justify-end" },
661
- {
662
- default() {
663
- return a;
664
- },
665
- content() {
666
- return "Differences are calculated using this formula: (Adjusted / System) × 100%";
667
- }
668
- }
669
- );
670
- }
671
- const ve = H(() => {
672
- const a = j.value.reduce((s, l) => {
673
- var c, p;
674
- return Math.max(s, ((p = (c = z.value) == null ? void 0 : c.get(l._id)) == null ? void 0 : p[0].length) ?? 0);
675
- }, 0);
676
- return [
677
- {
678
- id: "sku",
679
- accessorFn: (s) => `${s.code} ${s.name}`,
680
- header: () => "Name",
681
- size: 350,
682
- cell(s) {
683
- const l = s.row.original, c = l.adjustedDiffPercentage, p = typeof c == "number" && Math.abs(c) > 10, B = w("div", { class: "flex flex-col gap-4" }, [
684
- w(
685
- "div",
686
- {
687
- class: [
688
- "line-clamp-1 fm-typo-en-body-lg-400",
689
- p ? " text-fm-color-system-error-300" : "text-fm-color-typo-primary"
690
- ]
691
- },
692
- l.name
693
- ),
694
- w(
695
- "div",
696
- {
697
- class: [
698
- "line-clamp-1 fm-typo-en-body-md-400",
699
- p ? " text-fm-color-system-error-300" : "text-fm-color-typo-secondary"
700
- ]
701
- },
702
- l.code
703
- )
704
- ]);
705
- return w(
706
- fe.FmTooltip,
707
- {
708
- zIndex: 51
709
- },
710
- {
711
- content() {
712
- return p ? "Adjustment difference is more than 10%." : `${l.code} - ${l.name}`;
713
- },
714
- default() {
715
- return w("div", { class: "flex items-center gap-4 justify-start w-full" }, [
716
- B
717
- ]);
718
- }
719
- }
720
- );
721
- }
722
- },
723
- {
724
- id: "baseUnit",
725
- header: () => "Base unit",
726
- accessorKey: "baseUnit"
727
- },
728
- {
729
- id: "physicalBalance",
730
- accessorKey: "physicalBalance",
731
- header: () => Q("Actual balance"),
732
- size: 200,
733
- meta: {
734
- textAlign: "right"
735
- }
736
- },
737
- {
738
- id: "systemBalance",
739
- accessorKey: "systemBalance",
740
- header: () => Q("Balance"),
741
- size: 200,
742
- meta: {
743
- textAlign: "right"
744
- }
745
- },
746
- {
747
- id: "adjustedAmount",
748
- accessorKey: "adjustedAmount",
749
- header: () => Q("Adjusted balance"),
750
- size: 200,
751
- meta: {
752
- textAlign: "right"
753
- }
754
- },
755
- {
756
- id: "adjustedDiffPercentage",
757
- accessorKey: "adjustedDiffPercentage",
758
- header: () => w(
759
- fe.FmTooltip,
760
- { zIndex: 51, placement: "left", class: "w-full flex justify-end" },
761
- {
762
- default() {
763
- return w("div", { class: "flex items-center gap-4" }, [
764
- "Diff (%)",
765
- w(fe.FmIcon, { name: "info", color: "neutral-gray-400", size: "sm" })
766
- ]);
767
- },
768
- content() {
769
- return "Differences are calculated using this formula: (Adjusted / System) × 100%";
770
- }
771
- }
772
- ),
773
- size: 200,
774
- cell(s) {
775
- const l = s.row.original.adjustedDiffPercentage;
776
- if (!l) return "N/A";
777
- const c = l.toFixed(2);
778
- if (c === "0.00")
779
- return w("div", { class: "flex items-center gap-4 justify-end" }, ["0.00"]);
780
- const p = l > 0;
781
- return w("div", { class: "flex items-center gap-4 justify-end" }, [
782
- w(fe.FmIcon, {
783
- name: p ? "arrow_drop_up" : "arrow_drop_down",
784
- color: p ? "system-success-300" : "system-error-300",
785
- size: "md"
786
- }),
787
- c
788
- ]);
789
- },
790
- meta: {
791
- textAlign: "right"
792
- }
793
- },
794
- {
795
- id: "physicalBalances",
796
- header: () => "Amounts",
797
- enableSorting: !1,
798
- cell(s) {
799
- const l = s.row.original, c = (B, U) => w(
800
- fe.FmTooltip,
801
- { zIndex: 50 },
802
- {
803
- default() {
804
- return w(
805
- "div",
806
- {
807
- class: "fm-typo-en-body-md-400 py-4 px-8 border-1 border-fm-color-typo-secondary fm-corner-radius-md line-clamp-1"
808
- },
809
- [
810
- w("span", { class: "text-fm-color-typo-primary" }, `${B} `),
811
- w(
812
- "span",
813
- {
814
- class: "text-fm-color-typo-secondary",
815
- style: { maxWidth: "80px" }
816
- },
817
- U
818
- )
819
- ]
820
- );
821
- },
822
- content() {
823
- return `${B} ${U}`;
824
- }
825
- }
826
- );
827
- let p = Array.from({ length: a }).map((B, U) => {
828
- if (!l[`measurementAmount${U}`])
829
- return null;
830
- const F = l[`measurementAmount${U}`], de = l[`measurementAbbrev${U}`];
831
- return c(F, de);
832
- }).filter((B) => B);
833
- return (l.baseUnitAmount || !p.length) && (p = [c(l.baseUnitAmount, l.baseUnit), ...p]), w(
834
- "div",
835
- {
836
- class: "flex gap-8 flex-nowrap",
837
- style: {
838
- minWidth: `${120 * p.length}px`
839
- }
840
- },
841
- p
842
- );
843
- }
844
- }
845
- ];
846
- }), be = H(() => ve.value.map((a) => a.size ?? 0).reduce((a, t) => a + t)), ie = O(""), se = H(() => j.value.map((a) => {
847
- var F, de;
848
- const t = (F = J.value.get(a._id)) == null ? void 0 : F[0], s = ((de = ce.value.get(a._id)) == null ? void 0 : de[0]) ?? S;
849
- if (!t)
850
- return {
851
- code: a.code,
852
- name: a.name,
853
- baseUnit: a.unit.abbrev,
854
- baseUnitAmount: 0,
855
- systemBalance: +P(s),
856
- physicalBalance: 0,
857
- adjustedAmount: -+P(s),
858
- adjustedDiffPercentage: -100
859
- };
860
- const l = Ve(t), c = Ie(l, s), p = s.amount === 0 ? null : Ue(c, {
861
- ...s,
862
- amount: Math.abs(s.amount)
863
- }), B = p ? Se(p, I) : null;
864
- return {
865
- code: a.code,
866
- name: a.name,
867
- baseUnit: a.unit.abbrev,
868
- baseUnitAmount: +P(t.baseAmount),
869
- ...t.measurementsAmounts.filter((ae) => {
870
- var K, le, xe;
871
- return (xe = (le = (K = z.value) == null ? void 0 : K.get(a._id)) == null ? void 0 : le[0]) == null ? void 0 : xe.includes(ae.measurement.id);
872
- }).reduce((ae, K, le) => (ae[`measurementAbbrev${le}`] = `(${K.measurement.abbrev}) × ${P(K.measurement.conversion)}`, ae[`measurementAmount${le}`] = +P(K.amount), ae), {}),
873
- systemBalance: +P(s),
874
- physicalBalance: +P(l),
875
- adjustedAmount: +P(c),
876
- adjustedDiffPercentage: B ? +P(Ee(B, 2)) : null
877
- };
878
- })), he = H(() => {
879
- var t, s, l;
880
- if (!e.draft) return [];
881
- const a = e.draft.approvedAt ? {
882
- action: `Approve at ${ne(e.draft.approvedAt)}`,
883
- // actionAt: props.draft.approvedAt,
884
- actionBy: e.draft.approvedBy,
885
- remark: e.draft.approveRemark
886
- } : (t = e.draft.rejectionHistory) == null ? void 0 : t.computeFirst((c) => ({
887
- action: `Reject at ${ne(c.rejectedAt)}`,
888
- // actionAt: e.rejectedAt,
889
- actionBy: c.rejectedBy,
890
- remark: c.rejectRemark
891
- }));
892
- return [
893
- {
894
- label: "Created at",
895
- value: ne(e.draft.createdAt)
896
- },
897
- {
898
- label: "Created by",
899
- value: e.draft.createdBy.name
900
- },
901
- {
902
- label: "Updated at",
903
- value: ne(e.draft.updatedAt)
904
- },
905
- {
906
- label: "Updated by",
907
- value: e.draft.updatedBy.name
908
- },
909
- {
910
- label: "Effective at",
911
- value: ne(e.draft.effectiveAt ?? e.draft.updatedAt)
912
- },
913
- {
914
- label: "Using template",
915
- value: ((s = e.draft.usingTemplates.find((c) => c)) == null ? void 0 : s.name) ?? "None"
916
- },
917
- e.draft.remark ? {
918
- label: "Remark",
919
- value: e.draft.remark
920
- } : null,
921
- a ? {
922
- label: "Last action",
923
- value: a.action
924
- } : null,
925
- a && a.actionBy ? {
926
- label: "Last action by",
927
- value: (l = a.actionBy) == null ? void 0 : l.name
928
- } : null,
929
- a && a.remark ? {
930
- label: "Action remark",
931
- value: a.remark
932
- } : null
933
- ].filter((c) => c).map((c) => c);
934
- }), ue = [
935
- {
936
- label: "Overview",
937
- value: "overview"
938
- },
939
- {
940
- label: "Action history",
941
- value: "history"
942
- }
943
- ], te = O(ue[0]), X = H(() => {
944
- var t, s, l, c;
945
- return [
946
- ...(((t = e.draft) == null ? void 0 : t.rejectionHistory) ?? []).map(
947
- (p) => ({
948
- header: "Reject",
949
- date: ne(p.rejectedAt),
950
- info: [
951
- {
952
- label: "Rejected by",
953
- values: [p.rejectedBy.name]
954
- },
955
- {
956
- label: "Rejection remark",
957
- values: [p.rejectRemark]
958
- }
959
- ]
960
- })
961
- ),
962
- ...(s = e.draft) != null && s.approvedBy ? [
963
- {
964
- header: "Approve",
965
- date: e.draft.approvedAt ? ne(e.draft.approvedAt) : "",
966
- info: [
967
- {
968
- label: "Approved by",
969
- values: [(l = e.draft) == null ? void 0 : l.approvedBy.name]
970
- },
971
- {
972
- label: "Approval remark",
973
- values: [((c = e.draft) == null ? void 0 : c.approveRemark) ?? ""]
974
- }
975
- ]
976
- }
977
- ] : []
978
- ];
979
- }), re = H(() => {
980
- var c, p, B, U;
981
- if ((c = e == null ? void 0 : e.draft) != null && c.approvedAt) return "Draft is already approved.";
982
- if (((p = e.draft) == null ? void 0 : p.status) !== oe.enum.DRAFT) return "Status is not draft.";
983
- const a = se.value.some((F) => F.physicalBalance < 0), t = ((U = (B = f.stockBalance.skus) == null ? void 0 : B.filter((F) => F.balance.amount < 0)) == null ? void 0 : U.map((F) => F.id)) ?? [], s = new Set(j.value.map((F) => F._id)), l = t.filter((F) => !s.has(F)).length;
984
- return [
985
- a ? "Negative total exist." : null,
986
- l ? "Negative stock is not included in this draft. Reopen draft in POS and apply changes." : null
987
- ].filter((F) => F).join(" ");
988
- });
989
- return (a, t) => {
990
- const s = E("FmButtonGroup"), l = E("FmMenuDivider"), c = E("FmCard"), p = E("FmButton"), B = E("FmCircularProgress"), U = E("FmTextField"), F = E("FmIcon"), de = E("FmChip"), ae = E("FmTable"), K = E("FmSpacer"), le = E("FmTooltip"), xe = E("FmSideSheet");
991
- return h(), W(xe, {
992
- "dismiss-away": "",
993
- "max-width": 9999,
994
- "model-value": y(g),
995
- "onUpdate:modelValue": t[8] || (t[8] = (A) => Pe(g) ? g.value = A : null),
996
- header: "Closing details"
997
- }, {
998
- "side-sheet-footer": Y(() => {
999
- var A, L, V, me;
1000
- return [
1001
- o("div", ca, [
1002
- ((A = e.draft) == null ? void 0 : A.status) === y(oe).enum.DRAFT ? (h(), $(G, { key: 0 }, [
1003
- re.value ? (h(), W(le, {
1004
- key: 0,
1005
- "z-index": 51
1006
- }, {
1007
- content: Y(() => [
1008
- we(N(re.value), 1)
1009
- ]),
1010
- default: Y(() => [
1011
- _(p, {
1012
- disabled: "",
1013
- key: "approve key",
1014
- label: "Approve",
1015
- onClick: t[3] || (t[3] = () => e.draft && y(i).approveDraft(e.draft, () => b("submitted")))
1016
- })
1017
- ]),
1018
- _: 1
1019
- })) : (h(), W(p, {
1020
- key: "approve key",
1021
- label: "Approve",
1022
- onClick: t[4] || (t[4] = () => e.draft && y(i).approveDraft(e.draft, () => b("submitted")))
1023
- }))
1024
- ], 64)) : ee("", !0),
1025
- ((L = e.draft) == null ? void 0 : L.status) === y(oe).enum.DRAFT ? (h(), W(p, {
1026
- key: 1,
1027
- label: "Reject",
1028
- variant: "destructive",
1029
- onClick: t[5] || (t[5] = () => e.draft && y(i).rejectDraft(e.draft, () => b("submitted")))
1030
- })) : ee("", !0),
1031
- (V = e.draft) != null && V.approvedAt && ((me = e.draft) == null ? void 0 : me.status) !== y(oe).enum.COMPLETED ? (h(), W(p, {
1032
- key: 2,
1033
- label: "Sync",
1034
- loading: u.value,
1035
- onClick: t[6] || (t[6] = () => {
1036
- e.draft && (u.value = !0, y(i).syncDraft(e.draft, () => {
1037
- u.value = !1, b("submitted");
1038
- }));
1039
- })
1040
- }, null, 8, ["loading"])) : ee("", !0),
1041
- _(p, {
1042
- label: "Close",
1043
- variant: "tertiary",
1044
- onClick: t[7] || (t[7] = ($e) => g.value = !1)
1045
- })
1046
- ])
1047
- ];
1048
- }),
1049
- default: Y(() => [
1050
- o("div", Ft, [
1051
- o("div", null, [
1052
- _(s, {
1053
- items: ue,
1054
- modelValue: te.value,
1055
- "onUpdate:modelValue": t[0] || (t[0] = (A) => te.value = A)
1056
- }, null, 8, ["modelValue"])
1057
- ]),
1058
- te.value.value === "overview" ? (h(), $(G, { key: 0 }, [
1059
- _(c, {
1060
- variant: "outlined",
1061
- class: "flex flex-col gap-8 px-12 py-16"
1062
- }, {
1063
- default: Y(() => {
1064
- var A, L;
1065
- return [
1066
- o("div", $t, [
1067
- t[9] || (t[9] = o("div", { class: "fm-typo-en-body-lg-600" }, "Closing summary", -1)),
1068
- o("div", Tt, [
1069
- o("div", {
1070
- class: pe(["fm-status-badge", y(De)(((A = a.draft) == null ? void 0 : A.status) ?? "DRAFT")])
1071
- }, N(y(He)(((L = a.draft) == null ? void 0 : L.status) ?? "")), 3)
1072
- ])
1073
- ]),
1074
- _(l),
1075
- o("div", Rt, [
1076
- (h(!0), $(G, null, ye(he.value, (V, me) => (h(), $("div", {
1077
- class: "flex flex-col gap-4",
1078
- key: me
1079
- }, [
1080
- o("div", Pt, [
1081
- o("div", Mt, N(V.label), 1)
1082
- ]),
1083
- o("div", It, N(V.value), 1)
1084
- ]))), 128))
1085
- ])
1086
- ];
1087
- }),
1088
- _: 1
1089
- }),
1090
- o("div", Ut, [
1091
- o("div", Et, [
1092
- t[10] || (t[10] = o("div", { class: "flex-1 fm-typo-en-title-sm-600 text-fm-color-typo-primary" }, " Closing items ", -1)),
1093
- x.value ? ee("", !0) : (h(), $("div", Ht, [
1094
- a.draft && a.draft.status !== y(oe).enum.COMPLETED ? (h(), W(p, {
1095
- key: 0,
1096
- label: "Refresh balance",
1097
- "prepend-icon": "refresh",
1098
- variant: "secondary",
1099
- "text-color": "primary",
1100
- "bg-color": "transparent",
1101
- "border-color": "primary",
1102
- loading: D.value,
1103
- onClick: Z
1104
- }, null, 8, ["loading"])) : ee("", !0),
1105
- _(p, {
1106
- label: "Export data",
1107
- "prepend-icon": "download",
1108
- variant: "secondary",
1109
- "text-color": "primary",
1110
- "bg-color": "transparent",
1111
- "border-color": "primary",
1112
- onClick: t[1] || (t[1] = (A) => a.draft ? y(i).exportDraft(a.draft, C.value) : null)
1113
- })
1114
- ]))
1115
- ]),
1116
- x.value ? (h(), $("div", Lt, [
1117
- t[12] || (t[12] = o("div", { class: "h-80" }, null, -1)),
1118
- o("div", zt, [
1119
- o("div", null, [
1120
- _(B, { size: "md" })
1121
- ]),
1122
- t[11] || (t[11] = o("div", { class: "fm-typo-en-body-lg-400 text-fm-color-typo-secondary" }, " Fetching info... ", -1))
1123
- ]),
1124
- t[13] || (t[13] = o("div", { class: "h-80" }, null, -1))
1125
- ])) : (h(), $(G, { key: 1 }, [
1126
- o("div", null, [
1127
- _(U, {
1128
- modelValue: ie.value,
1129
- "onUpdate:modelValue": t[2] || (t[2] = (A) => ie.value = A),
1130
- placeholder: "Filter items"
1131
- }, null, 8, ["modelValue"])
1132
- ]),
1133
- y(d).skuTags.size ? (h(), $("div", Nt, [
1134
- (h(!0), $(G, null, ye(y(d).skuTags.keys(), (A) => (h(), W(de, {
1135
- key: `${A}`,
1136
- label: `${A}`,
1137
- selectable: "",
1138
- selected: m[`${A}`],
1139
- onClick: (L) => m[`${A}`] = !m[`${A}`]
1140
- }, {
1141
- default: Y(() => [
1142
- m[`${A}`] ? (h(), W(F, {
1143
- key: 0,
1144
- name: "check",
1145
- class: "text-white",
1146
- size: "sm"
1147
- })) : ee("", !0),
1148
- o("span", {
1149
- class: pe([
1150
- "",
1151
- {
1152
- "text-white fm-typo-en-body-md-600": m[`${A}`],
1153
- "text-fm-color-typo-primary fm-typo-en-body-md-400": !m[`${A}`]
1154
- }
1155
- ])
1156
- }, N(A), 3)
1157
- ]),
1158
- _: 2
1159
- }, 1032, ["label", "selected", "onClick"]))), 128))
1160
- ])) : ee("", !0),
1161
- o("div", Ot, [
1162
- o("div", {
1163
- style: Me({ minWidth: `${be.value}px` })
1164
- }, [
1165
- _(ae, {
1166
- "column-defs": ve.value,
1167
- "row-data": se.value,
1168
- "search-value": ie.value
1169
- }, null, 8, ["column-defs", "row-data", "search-value"])
1170
- ], 4)
1171
- ])
1172
- ], 64))
1173
- ])
1174
- ], 64)) : ee("", !0),
1175
- te.value.value === "history" ? (h(), $("div", Vt, [
1176
- X.value.length ? (h(), $("div", Gt, [
1177
- (h(!0), $(G, null, ye(X.value, (A, L) => (h(), $(G, { key: L }, [
1178
- o("div", Wt, [
1179
- o("div", qt, [
1180
- o("div", Zt, [
1181
- o("div", {
1182
- class: pe([
1183
- {
1184
- "bg-fm-color-primary": L !== 0,
1185
- "bg-white": L === 0
1186
- },
1187
- "w-[2px] h-full"
1188
- ])
1189
- }, null, 2)
1190
- ]),
1191
- t[16] || (t[16] = o("div", { class: "h-24 w-24 bg-fm-color-primary rounded-full" }, null, -1)),
1192
- o("div", Jt, [
1193
- o("div", {
1194
- class: pe([
1195
- {
1196
- "bg-fm-color-primary": L < X.value.length - 1,
1197
- "bg-white": L >= X.value.length - 1
1198
- },
1199
- "w-[2px] h-full"
1200
- ])
1201
- }, null, 2)
1202
- ])
1203
- ]),
1204
- o("div", Qt, [
1205
- o("div", Xt, N(A.header), 1),
1206
- o("div", ea, N(A.date), 1)
1207
- ])
1208
- ]),
1209
- o("div", ta, [
1210
- o("div", aa, [
1211
- o("div", na, [
1212
- o("div", {
1213
- class: pe([
1214
- {
1215
- "bg-fm-color-primary": L < X.value.length - 1,
1216
- "bg-white": L >= X.value.length - 1
1217
- },
1218
- "w-[2px] h-full"
1219
- ])
1220
- }, null, 2)
1221
- ])
1222
- ]),
1223
- o("div", oa, [
1224
- _(c, {
1225
- variant: "outlined",
1226
- class: "py-12 px-16"
1227
- }, {
1228
- default: Y(() => [
1229
- o("div", sa, [
1230
- (h(!0), $(G, null, ye(A.info, (V, me) => (h(), $("div", {
1231
- key: me,
1232
- class: "flex flex-col gap-4"
1233
- }, [
1234
- o("div", ra, N(V == null ? void 0 : V.label), 1),
1235
- o("div", la, [
1236
- (h(!0), $(G, null, ye(V == null ? void 0 : V.values, ($e, Ke) => (h(), $("div", {
1237
- key: Ke,
1238
- class: "fm-typo-en-body-lg-600"
1239
- }, N($e), 1))), 128))
1240
- ])
1241
- ]))), 128))
1242
- ])
1243
- ]),
1244
- _: 2
1245
- }, 1024)
1246
- ])
1247
- ])
1248
- ], 64))), 128))
1249
- ])) : (h(), $("div", Yt, [
1250
- _(K),
1251
- o("div", null, [
1252
- o("img", {
1253
- src: y(gt),
1254
- alt: "List is empty"
1255
- }, null, 8, Kt)
1256
- ]),
1257
- t[14] || (t[14] = o("div", { class: "fm-typo-en-body-lg-600" }, N("No records found"), -1)),
1258
- t[15] || (t[15] = o("div", { class: "fm-typo-en-body-md-400 text-fm-color-typo-secondary px-16" }, N("You can track approval and rejection history here"), -1)),
1259
- _(K),
1260
- _(K)
1261
- ]))
1262
- ])) : ee("", !0)
1263
- ])
1264
- ]),
1265
- _: 1
1266
- }, 8, ["model-value"]);
1267
- };
1268
- }
1269
- }), ua = { class: "flex-1 flex flex-col gap-8" }, da = { class: "flex flex-col" }, ma = { class: "fm-typo-en-body-md-400 text-fm-color-typo-secondary" }, fa = { class: "fm-typo-en-body-lg-600 text-fm-color-typo-primary" }, pa = { class: "fm-typo-en-body-lg-400 text-fm-color-typo-secondary line-clamp-2" }, va = { class: "fm-typo-en-body-lg-400 line-clamp-2" }, Da = /* @__PURE__ */ Ce({
1270
- __name: "ClosingDraftView",
1271
- setup(n) {
1272
- const { t: r } = Le(), { viewDraft: e } = ke(), { viewClosingDraftProps: f, viewClosingDraftShow: i } = yt(ke()), g = je(), x = Bt(), D = ct(), { breakpoints: u } = vt();
1273
- g.watchLocation(x.fetchDrafts);
1274
- const C = H(() => x.loading), T = O(""), M = H(() => u.value.xs || u.value.sm), d = H(() => M.value ? 10 : 20);
1275
- function m(v) {
1276
- switch (v) {
1277
- case "refresh":
1278
- return x.fetchDrafts();
1279
- }
1280
- }
1281
- function R(v) {
1282
- return v;
1283
- }
1284
- const b = H(() => M.value ? [
1285
- {
1286
- label: r("inventory.common.refresh"),
1287
- value: "refresh",
1288
- isPrimary: !1
1289
- }
1290
- ] : [
1291
- {
1292
- label: r("inventory.common.refresh"),
1293
- value: "refresh",
1294
- isPrimary: !1
1295
- }
1296
- ]);
1297
- return (v, j) => {
1298
- const z = E("FmTable");
1299
- return h(), $(G, null, [
1300
- _(it, {
1301
- title: y(r)("inventory.closing.draft.title"),
1302
- actions: b.value,
1303
- "onClick:action": m
1304
- }, {
1305
- default: Y(() => [
1306
- o("div", {
1307
- class: pe([
1308
- "flex flex-col gap-8 max-h-full",
1309
- {
1310
- "p-0": M.value,
1311
- "px-24 ": !M.value
1312
- }
1313
- ])
1314
- }, [
1315
- _(ut, {
1316
- "change-location": "",
1317
- searchable: "",
1318
- search: T.value,
1319
- "onUpdate:search": j[0] || (j[0] = (S) => T.value = S)
1320
- }, null, 8, ["search"]),
1321
- _(z, {
1322
- style: Me(y(D).tableHeight),
1323
- "column-defs": y(x).columnDefs,
1324
- "row-data": y(x).drafts,
1325
- "search-value": T.value,
1326
- loading: C.value,
1327
- onRowClick: j[1] || (j[1] = (S) => y(e)(S.original)),
1328
- "page-size": d.value
1329
- }, {
1330
- "list-row": Y((S) => [
1331
- _(dt, {
1332
- row: S,
1333
- onRowClick: (I) => y(e)(I)
1334
- }, {
1335
- default: Y((I) => {
1336
- var k, Z, ce, J, Q, ve, be, ie, se, he, ue, te, X, re, a, t, s, l, c, p;
1337
- return [
1338
- o("div", ua, [
1339
- o("div", da, [
1340
- o("div", ma, [
1341
- _(y(_e), {
1342
- render: (ce = (Z = (k = I._id) == null ? void 0 : k.column) == null ? void 0 : Z.columnDef) == null ? void 0 : ce.cell,
1343
- props: (Q = (J = I._id) == null ? void 0 : J.getContext) == null ? void 0 : Q.call(J)
1344
- }, null, 8, ["render", "props"])
1345
- ]),
1346
- o("div", fa, [
1347
- _(y(_e), {
1348
- render: (ie = (be = (ve = I.name) == null ? void 0 : ve.column) == null ? void 0 : be.columnDef) == null ? void 0 : ie.cell,
1349
- props: (he = (se = I.name) == null ? void 0 : se.getContext) == null ? void 0 : he.call(se)
1350
- }, null, 8, ["render", "props"])
1351
- ]),
1352
- o("div", pa, N([
1353
- ...S.original.items.slice(0, 3).map((B) => B.sku.name),
1354
- ...S.original.items.length >= 3 ? [`and ${S.original.items.length - 3} more items`] : []
1355
- ].join(", ")), 1),
1356
- o("div", va, [
1357
- _(y(_e), {
1358
- render: (X = (te = (ue = I.ref) == null ? void 0 : ue.column) == null ? void 0 : te.columnDef) == null ? void 0 : X.cell,
1359
- props: (a = (re = I.ref) == null ? void 0 : re.getContext) == null ? void 0 : a.call(re)
1360
- }, null, 8, ["render", "props"])
1361
- ])
1362
- ]),
1363
- o("div", null, [
1364
- _(y(_e), {
1365
- render: (l = (s = (t = I.status) == null ? void 0 : t.column) == null ? void 0 : s.columnDef) == null ? void 0 : l.cell,
1366
- props: (p = (c = I.status) == null ? void 0 : c.getContext) == null ? void 0 : p.call(c)
1367
- }, null, 8, ["render", "props"])
1368
- ])
1369
- ])
1370
- ];
1371
- }),
1372
- _: 2
1373
- }, 1032, ["row", "onRowClick"])
1374
- ]),
1375
- _: 1
1376
- }, 8, ["style", "column-defs", "row-data", "search-value", "loading", "page-size"])
1377
- ], 2)
1378
- ]),
1379
- _: 1
1380
- }, 8, ["title", "actions"]),
1381
- (h(), W(Ze, { to: "body" }, [
1382
- _(ia, Je(y(f), {
1383
- show: y(i),
1384
- "onUpdate:show": j[2] || (j[2] = (S) => Pe(i) ? i.value = S : null),
1385
- onSubmitted: j[3] || (j[3] = () => (i.value = !1, y(x).fetchDrafts()))
1386
- }), null, 16, ["show"])
1387
- ]))
1388
- ], 64);
1389
- };
1390
- }
1391
- });
1392
- export {
1393
- Da as default
1394
- };