@feedmepos/mf-inventory-portal 1.0.3 → 1.0.5-dev

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 (68) hide show
  1. package/dist/{App-C1VupiZY.js → App-HiQFjdJ-.js} +1 -1
  2. package/dist/{ApprovalView-DplI9cBD.js → ApprovalView-CynLDEVc.js} +2 -2
  3. package/dist/{BindingsDialog-BRODuQYW.js → BindingsDialog-Bnp9wpfo.js} +2 -2
  4. package/dist/{BindingsPicker-BQJeW4T5.js → BindingsPicker-d0mYW8dg.js} +5 -5
  5. package/dist/{BindingsTable-DdPACqSs.js → BindingsTable-DTqY2ksc.js} +5 -5
  6. package/dist/ClosingDraftView-CWioP0pS.js +1394 -0
  7. package/dist/{ClosingTemplateView-BONrPuvT.js → ClosingTemplateView-BQrAl5fV.js} +2 -2
  8. package/dist/{DeliveryOrderPrintPreview-C9ZT6Hlg.js → DeliveryOrderPrintPreview-BDF8lY7Y.js} +1 -1
  9. package/dist/{FmFilterableMenuOptions.vue_vue_type_script_setup_true_lang-YdcIpvT7.js → FmFilterableMenuOptions.vue_vue_type_script_setup_true_lang-BN_xp-N6.js} +3 -3
  10. package/dist/{FmUnitInput.vue_vue_type_script_setup_true_lang-B0cMgy-R.js → FmUnitInput.vue_vue_type_script_setup_true_lang-BWUrzPyM.js} +1 -1
  11. package/dist/{IngredientBindedItem.vue_vue_type_script_setup_true_lang-DbCkYQRx.js → IngredientBindedItem.vue_vue_type_script_setup_true_lang-XhFhN0MD.js} +1 -1
  12. package/dist/{IngredientGroupView-K00nLk1c.js → IngredientGroupView-CyjtkSE4.js} +1 -1
  13. package/dist/{IngredientsView-B6Yu-gfy.js → IngredientsView-DcTIYA5r.js} +3 -3
  14. package/dist/IntegrationView-Jeh9aw2u.js +2148 -0
  15. package/dist/{InventoryBindingForm-Ck3YkMP8.js → InventoryBindingForm-dlNXDnnO.js} +1 -1
  16. package/dist/{InventoryBindingForm.vue_vue_type_script_setup_true_lang-Z0ofZoa5.js → InventoryBindingForm.vue_vue_type_script_setup_true_lang-BeUd7kC6.js} +3 -3
  17. package/dist/{InventoryBindingSummary-mDDEGGrj.js → InventoryBindingSummary-BPvSql2a.js} +1 -1
  18. package/dist/{NumberPrecisionInput.vue_vue_type_script_setup_true_lang-p1otjx3-.js → NumberPrecisionInput.vue_vue_type_script_setup_true_lang-DFofvMkD.js} +1 -1
  19. package/dist/{PremiumBadge.vue_vue_type_script_setup_true_lang-Q7bKAXW1.js → PremiumBadge.vue_vue_type_script_setup_true_lang-CaBtx2ad.js} +1 -1
  20. package/dist/{PublishView-DIGrMK7M.js → PublishView-4Mh9EtfQ.js} +2 -2
  21. package/dist/{PurchaseOrderPrintPreview-CIvH6ak4.js → PurchaseOrderPrintPreview-DFNVxR7Q.js} +1 -1
  22. package/dist/{ReceiveRequestView-Do8YpHUz.js → ReceiveRequestView-DGfyfwbS.js} +8 -8
  23. package/dist/{RecipeView-D87QEyUM.js → RecipeView-D-M9rodW.js} +3 -3
  24. package/dist/{StockView-BlAsmxkM.js → StockView-Dmy2nTn9.js} +6 -6
  25. package/dist/{SupplierView-CJW6pqqq.js → SupplierView-dwayUuSs.js} +3 -3
  26. package/dist/{TransferDetails.vue_vue_type_script_setup_true_lang-QGPSA275.js → TransferDetails.vue_vue_type_script_setup_true_lang-DtrWgdXq.js} +6 -6
  27. package/dist/{TransferTemplateView-Ufv0RRVH.js → TransferTemplateView-zl-E8FWk.js} +6 -6
  28. package/dist/{UnitView-CRJGTNRn.js → UnitView-DlgkMRfA.js} +3 -3
  29. package/dist/{WarehouseView-D_iqmtil.js → WarehouseView-Cwm2w_Li.js} +1 -1
  30. package/dist/api/closing.d.ts +7 -1
  31. package/dist/api/netsuite.d.ts +82 -0
  32. package/dist/api/stock.d.ts +44 -0
  33. package/dist/{app-DUVoMWjT.js → app-7jcARtWe.js} +2150 -2098
  34. package/dist/app.js +1 -1
  35. package/dist/{decimal-C2cu01Ty.js → decimal-Df15BvRp.js} +1 -1
  36. package/dist/{format-unit-display-BhApyqDh.js → format-unit-display-CEjqAYMQ.js} +2 -2
  37. package/dist/index-D1mi5w82.js +125 -0
  38. package/dist/{index-CzrCaC5N.js → index-D76OeHWL.js} +1 -1
  39. package/dist/{stock-BRe9UgbU.js → stock-C2o7RYsv.js} +35 -31
  40. package/dist/stores/feature.d.ts +4 -1
  41. package/dist/stores/integration/index.d.ts +1 -0
  42. package/dist/stores/integration/netsuite.d.ts +11 -0
  43. package/dist/stores/integration/xilnex.d.ts +12 -0
  44. package/dist/stores/inventory.d.ts +12 -12
  45. package/dist/stores/stock.d.ts +12 -12
  46. package/dist/{supplier-CjOLvGsU.js → supplier-DX4BGHJ3.js} +1 -1
  47. package/dist/tsconfig.app.tsbuildinfo +1 -1
  48. package/dist/{use-ingredient-select-dialog-316K96zh.js → use-ingredient-select-dialog-BQq-zLGA.js} +1 -1
  49. package/dist/{use-inventory-binding-dialog-fGBCj6Ba.js → use-inventory-binding-dialog-NM2fZkBw.js} +1 -1
  50. package/dist/views/closing-draft/components/closing-draft-dialog/ClosingDraftDialog.vue.d.ts +40 -40
  51. package/dist/views/closing-draft/composables/use-closing-draft-table.d.ts +240 -240
  52. package/dist/views/integration/XilnexView.vue.d.ts +2 -0
  53. package/dist/views/integration/components/Xilnex/XilnexOpeningImport.vue.d.ts +2 -0
  54. package/dist/views/integration/components/Xilnex/XilnexProps.d.ts +7 -0
  55. package/dist/views/integration/components/Xilnex/XilnexSideSheet.vue.d.ts +24 -0
  56. package/dist/views/integration/components/Xilnex/importFn.d.ts +16 -0
  57. package/dist/views/integration/components/netsuite/AddLocationDialog.vue.d.ts +1334 -0
  58. package/dist/views/integration/components/netsuite/LocationConfigurationDialog.vue.d.ts +174 -0
  59. package/dist/views/integration/components/netsuite/LocationConfigurationDialogProps.d.ts +16 -0
  60. package/dist/views/integration/components/netsuite/NetSuiteLocationField.vue.d.ts +71 -0
  61. package/dist/views/receive-request/components/transfer-form/TransferForm.vue.d.ts +32 -32
  62. package/dist/views/receive-request/composables/use-receive-request-form.d.ts +66 -66
  63. package/dist/views/receive-request/composables/use-receive-request-table.d.ts +66 -66
  64. package/dist/{vue-i18n-DCtJpaCZ.js → vue-i18n-BRmzzMWS.js} +2 -2
  65. package/package.json +3 -2
  66. package/dist/ClosingDraftView-wCIesJUP.js +0 -1348
  67. package/dist/IntegrationView-CX3c7RQq.js +0 -1197
  68. package/dist/index-CrxvXOng.js +0 -84
@@ -0,0 +1,1394 @@
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-7jcARtWe.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-C2o7RYsv.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
+ };