@feedmepos/mf-payment 0.0.0-beta.34 → 0.0.0-beta.36

Sign up to get free protection for your applications and to get access to all the features.
Files changed (26) hide show
  1. package/dist/{PayoutAccount-D-9hzZyp.js → PayoutAccount-DlS2OPwj.js} +2 -2
  2. package/dist/{PayoutAccount-BF4TdtVz.js → PayoutAccount-IhMg0cdL.js} +1 -1
  3. package/dist/{SettlementTransactions-w0jXLftr.js → SettlementTransactions-Co4ziq3a.js} +1 -1
  4. package/dist/{SettlementTransactions-CdZswF1S.js → SettlementTransactions-yJhT6FR4.js} +1 -1
  5. package/dist/{Terminal-BbIs7aYi.js → Terminal-BDDP5VT8.js} +1 -1
  6. package/dist/TerminalTransaction-BC-QZh_F.js +416 -0
  7. package/dist/{TerminalTransaction-BEyzFREU.js → TerminalTransaction-DCqbXI2q.js} +4 -4
  8. package/dist/{Transaction-Atm-A5eN.js → Transaction-D6mKrbLJ.js} +1 -1
  9. package/dist/Transaction-DvgeNetP.js +405 -0
  10. package/dist/api/terminal-transaction/index.d.ts +3 -1
  11. package/dist/api/transaction/index.d.ts +1 -0
  12. package/dist/app.js +9 -9
  13. package/dist/components/CursorTable/index.vue.d.ts +4 -0
  14. package/dist/{index-RhSxYSBk.js → index-Dlszue3Y.js} +20 -10
  15. package/dist/{index.vue_vue_type_script_setup_true_lang-B7ePQpGr.js → index.vue_vue_type_script_setup_true_lang-B8eGz19R.js} +62 -58
  16. package/dist/model/transaction.d.ts +2 -1
  17. package/dist/package.json +1 -1
  18. package/dist/{payout-account-C1kHqPZb.js → payout-account-B8jXnkVN.js} +227 -227
  19. package/dist/{transaction-BH1Pm92q.js → transaction-DdbmOKZ7.js} +18 -11
  20. package/dist/tsconfig.app.tsbuildinfo +1 -1
  21. package/dist/views/admin/terminal-transaction/cell/Actions.vue.d.ts +7 -0
  22. package/dist/views/admin/transaction/TransactionTable.vue.d.ts +6 -2
  23. package/dist/views/admin/transaction/cell/Actions.vue.d.ts +7 -0
  24. package/package.json +1 -1
  25. package/dist/TerminalTransaction-CVcDmLvg.js +0 -274
  26. package/dist/Transaction-DpmCjczz.js +0 -243
@@ -0,0 +1,405 @@
1
+ import { defineComponent as h, resolveComponent as _, openBlock as g, createBlock as E, normalizeClass as $, withCtx as x, createElementVNode as b, toDisplayString as L, createElementBlock as F, unref as m, createVNode as y, Fragment as B, renderList as U, ref as N, h as T, onMounted as G, watch as k, isRef as D } from "vue";
2
+ import { t as w, a as J, b as R } from "./transaction-DdbmOKZ7.js";
3
+ import { c as S, u as Q } from "./index-Cnxt2xmc.js";
4
+ import { useSnackbar as Y, useDialog as j } from "@feedmepos/ui-library";
5
+ import "./dinero-CIVmXLL-.js";
6
+ import { h as O } from "./moment-h96o7c8I.js";
7
+ import { g as z, a as H } from "./assets-sX1_K-nt.js";
8
+ import { _ as W } from "./AutoCopyCell.vue_vue_type_script_setup_true_lang-GXPXBEf5.js";
9
+ import { u as X } from "./index-BgnU5ezY.js";
10
+ import { _ as Z } from "./AdminLayout.vue_vue_type_script_setup_true_lang-1DSAdvX7.js";
11
+ import { _ as ee } from "./AsyncButton.vue_vue_type_script_setup_true_lang-DcjzvYwT.js";
12
+ import { w as P } from "./Modal-DB8M9o1T.js";
13
+ import { u as I } from "./error-K1CakhA9.js";
14
+ const te = /* @__PURE__ */ h({
15
+ __name: "Status",
16
+ props: {
17
+ row: {},
18
+ data: {}
19
+ },
20
+ setup(p) {
21
+ const n = p;
22
+ function o() {
23
+ return n.data === S.F_PAYMENT_TRANSACTION_STATUS.Enum.PENDING ? "!w-[16px] !h-[16px] bg-yellow-400" : n.data === S.F_PAYMENT_TRANSACTION_STATUS.Enum.FAILED ? "!w-[16px] !h-[16px] bg-red-400" : n.data === S.F_PAYMENT_TRANSACTION_STATUS.Enum.REFUNDED ? "!w-[16px] !h-[16px] bg-blue-400" : "!w-[16px] !h-[16px] bg-green-400";
24
+ }
25
+ return (l, f) => {
26
+ const s = _("FmBadge");
27
+ return g(), E(s, {
28
+ inline: "",
29
+ class: $(o())
30
+ }, {
31
+ default: x(() => [
32
+ b("div", null, L(l.data), 1)
33
+ ]),
34
+ _: 1
35
+ }, 8, ["class"]);
36
+ };
37
+ }
38
+ }), ae = ["src"], ne = /* @__PURE__ */ h({
39
+ __name: "Gateway",
40
+ props: {
41
+ row: {},
42
+ data: {}
43
+ },
44
+ setup(p) {
45
+ return (n, o) => (g(), F("img", {
46
+ class: "rounded-md m-auto border-transparent w-[32px] h-[32px]",
47
+ src: m(z)(n.row.original.gateway)
48
+ }, null, 8, ae));
49
+ }
50
+ }), oe = ["src"], re = /* @__PURE__ */ h({
51
+ __name: "Method",
52
+ props: {
53
+ row: {},
54
+ data: {}
55
+ },
56
+ setup(p) {
57
+ return (n, o) => (g(), F("img", {
58
+ class: "rounded-md m-auto border-transparent w-[32px] h-[32px]",
59
+ src: m(H)(n.row.original.method.issuer)
60
+ }, null, 8, oe));
61
+ }
62
+ }), se = /* @__PURE__ */ h({
63
+ __name: "Actions",
64
+ props: {
65
+ onAction: { type: Function }
66
+ },
67
+ setup(p) {
68
+ const n = [
69
+ {
70
+ label: "Query",
71
+ sublabel: "Perform transaction status inquriy",
72
+ icon: "question_answer",
73
+ action: "query"
74
+ },
75
+ {
76
+ label: "Refund",
77
+ sublabel: "Perform transaction refund request",
78
+ icon: "request_page",
79
+ action: "refund"
80
+ },
81
+ {
82
+ label: "Notify",
83
+ sublabel: "Perform webhook notification for transaction",
84
+ icon: "webhook",
85
+ action: "notify"
86
+ }
87
+ ];
88
+ return (o, l) => {
89
+ const f = _("FmIcon"), s = _("FmMenuItem"), r = _("FmMenu");
90
+ return g(), F("div", {
91
+ onClick: l[0] || (l[0] = (e) => {
92
+ e.stopPropagation();
93
+ })
94
+ }, [
95
+ y(r, null, {
96
+ "menu-button": x(() => [
97
+ y(f, { name: "settings" })
98
+ ]),
99
+ default: x(() => [
100
+ (g(), F(B, null, U(n, (e) => y(s, {
101
+ selectable: !0,
102
+ key: e.label,
103
+ sublabel: e.sublabel,
104
+ label: e.label,
105
+ icon: e.icon,
106
+ onclick: () => o.onAction(e.action)
107
+ }, null, 8, ["sublabel", "label", "icon", "onclick"])), 64))
108
+ ]),
109
+ _: 1
110
+ })
111
+ ]);
112
+ };
113
+ }
114
+ }), ie = /* @__PURE__ */ h({
115
+ __name: "TransactionTable",
116
+ props: {
117
+ data: {
118
+ type: Array,
119
+ required: !0
120
+ },
121
+ loading: {
122
+ type: Boolean,
123
+ required: !0
124
+ }
125
+ },
126
+ emits: ["query", "refund", "notify"],
127
+ setup(p, { emit: n }) {
128
+ const o = p, l = n, f = N(""), s = [
129
+ {
130
+ header: () => "Transaction ID",
131
+ accessorKey: "id",
132
+ cell: ({ cell: r }) => T(W, { data: r.getValue() })
133
+ },
134
+ {
135
+ header: () => "Pay ID",
136
+ accessorKey: "payId"
137
+ },
138
+ {
139
+ header: () => "Gateway",
140
+ accessorKey: "gateway",
141
+ meta: {
142
+ textAlign: "center"
143
+ },
144
+ cell: ({ cell: r, row: e }) => e.original.method ? T(ne, { row: e, data: r.getValue() }) : ""
145
+ },
146
+ {
147
+ header: () => "Method",
148
+ accessorKey: "method",
149
+ meta: {
150
+ textAlign: "center"
151
+ },
152
+ cell: ({ cell: r, row: e }) => e.original.method ? T(re, { row: e, data: r.getValue() }) : ""
153
+ },
154
+ {
155
+ header: () => "Type",
156
+ accessorKey: "type",
157
+ meta: {
158
+ textAlign: "center"
159
+ },
160
+ cell: ({ row: r }) => {
161
+ if (!r.original.method)
162
+ return "";
163
+ const e = r.original.method.variant;
164
+ return e.includes("_ONLINE") ? "ONLINE" : e.includes("_OFFLINE") ? "OFFLINE" : e;
165
+ }
166
+ },
167
+ {
168
+ header: () => "Status",
169
+ accessorKey: "status",
170
+ cell: ({ cell: r, row: e }) => T(te, { row: e, data: r.getValue() })
171
+ },
172
+ {
173
+ header: () => "Transaction At",
174
+ accessorKey: "transactionAt",
175
+ meta: {
176
+ width: "180px"
177
+ }
178
+ },
179
+ {
180
+ header: () => "Sales Amount",
181
+ accessorKey: "amount"
182
+ },
183
+ {
184
+ header: () => "Fee",
185
+ accessorKey: "fee"
186
+ },
187
+ {
188
+ header: () => "Settlement Amount",
189
+ accessorKey: "payout"
190
+ },
191
+ {
192
+ header: () => "Actions",
193
+ accessorKey: "actions",
194
+ cell: ({ row: r }) => T(se, {
195
+ onAction: (e) => l(e, r.index)
196
+ })
197
+ }
198
+ ];
199
+ return (r, e) => {
200
+ const c = _("FmTable");
201
+ return g(), E(c, {
202
+ modelValue: f.value,
203
+ "onUpdate:modelValue": e[0] || (e[0] = (v) => f.value = v),
204
+ "column-defs": s,
205
+ "row-data": o.data,
206
+ loading: o.loading
207
+ }, null, 8, ["modelValue", "row-data", "loading"]);
208
+ };
209
+ }
210
+ }), ce = { class: "flex justify-between mb-6 items-center" }, le = { class: "flex space-x-4" }, ue = { class: "flex space-x-4" }, Fe = /* @__PURE__ */ h({
211
+ __name: "Transaction",
212
+ setup(p) {
213
+ const { dateRange: n, searchKey: o } = X({
214
+ searchKey: "",
215
+ dateRange: {
216
+ startDate: O().startOf("day").toISOString(),
217
+ endDate: O().endOf("day").toISOString()
218
+ }
219
+ }), { isLoading: l, startAsyncCall: f } = Q(!0), s = Y(), r = j(), e = N([]), c = N([]);
220
+ async function v() {
221
+ await f(async () => {
222
+ const { startDate: i, endDate: t } = n.value, a = await w.readTransactions({
223
+ start: i,
224
+ end: t
225
+ });
226
+ if (e.value = J(a), c.value = e.value, o.value > "") {
227
+ var u = new RegExp(o.value, "i");
228
+ c.value = e.value.filter((d) => {
229
+ const C = JSON.stringify(d);
230
+ return u.test(C);
231
+ });
232
+ }
233
+ });
234
+ }
235
+ function q() {
236
+ v();
237
+ }
238
+ G(q);
239
+ let A;
240
+ k(o, async () => {
241
+ A && clearTimeout(A), A = setTimeout(() => {
242
+ var i = new RegExp(o.value, "i");
243
+ c.value = e.value.filter((t) => {
244
+ const a = JSON.stringify(t);
245
+ return i.test(a);
246
+ });
247
+ }, 700);
248
+ }), k(e, async () => {
249
+ let i = e.value;
250
+ if (o.value) {
251
+ var t = new RegExp(o.value, "i");
252
+ i = e.value.filter((a) => {
253
+ const u = JSON.stringify(a);
254
+ return t.test(u);
255
+ });
256
+ }
257
+ c.value = i;
258
+ }, { deep: !0 });
259
+ async function K(i) {
260
+ const t = c.value.at(i);
261
+ if (!t) {
262
+ s.open({
263
+ type: "error",
264
+ title: "Something went wrong",
265
+ message: "Fail to find transactions from the displayed transactions."
266
+ });
267
+ return;
268
+ }
269
+ try {
270
+ const a = await w.refetchTransaction({ transactionId: t.id }), u = e.value.findIndex((d) => d.id === a._id);
271
+ e.value[u] = R(a), s.open({
272
+ type: "success",
273
+ title: "Transaction queried and updated successfully."
274
+ });
275
+ } catch (a) {
276
+ s.open({
277
+ type: "error",
278
+ title: "Fail to query transaction.",
279
+ message: I(a)
280
+ });
281
+ }
282
+ }
283
+ async function V(i) {
284
+ const t = c.value.at(i);
285
+ if (!t) {
286
+ s.open({
287
+ type: "error",
288
+ title: "Something went wrong",
289
+ message: "Fail to find transactions from the displayed transactions."
290
+ });
291
+ return;
292
+ }
293
+ P(
294
+ r,
295
+ "Refund Transaction",
296
+ "Are you sure to refund transaction? This action cannot be revert!",
297
+ async () => {
298
+ try {
299
+ const a = await w.refundTransaction({
300
+ transactionId: t.id,
301
+ reason: "portal transaction refund",
302
+ amount: t.fdoAmount
303
+ }), u = e.value.findIndex((d) => d.id === a._id);
304
+ e.value[u] = R(a), s.open({
305
+ type: "success",
306
+ title: "Transaction refund request initiated."
307
+ });
308
+ } catch (a) {
309
+ s.open({
310
+ type: "error",
311
+ title: "Fail to request refund transaction.",
312
+ message: I(a)
313
+ });
314
+ }
315
+ }
316
+ );
317
+ }
318
+ async function M(i) {
319
+ const t = c.value.at(i);
320
+ if (!t) {
321
+ s.open({
322
+ type: "error",
323
+ title: "Something went wrong",
324
+ message: "Fail to find transactions from the displayed transactions."
325
+ });
326
+ return;
327
+ }
328
+ P(
329
+ r,
330
+ "Notify Transaction",
331
+ "Are you sure to perform notify transaction?",
332
+ async () => {
333
+ try {
334
+ await w.renotifyTransaction(t.id), s.open({
335
+ type: "success",
336
+ title: "Transaction notify successfully."
337
+ });
338
+ } catch (a) {
339
+ s.open({
340
+ type: "error",
341
+ title: "Fail to notify transaction.",
342
+ message: I(a)
343
+ });
344
+ }
345
+ }
346
+ );
347
+ }
348
+ return (i, t) => {
349
+ const a = _("FmSearch"), u = _("FmDateRangePicker");
350
+ return g(), E(Z, {
351
+ title: "Online Transactions",
352
+ loading: m(l)
353
+ }, {
354
+ default: x(() => [
355
+ b("div", ce, [
356
+ b("div", le, [
357
+ y(a, {
358
+ "model-value": m(o),
359
+ "onUpdate:modelValue": t[0] || (t[0] = (d) => D(o) ? o.value = d : null),
360
+ class: "mr-8",
361
+ label: "Search",
362
+ placeholder: "Search Transactions ..."
363
+ }, null, 8, ["model-value"]),
364
+ y(u, {
365
+ modelValue: m(n),
366
+ "onUpdate:modelValue": [
367
+ t[1] || (t[1] = (d) => D(n) ? n.value = d : null),
368
+ v
369
+ ],
370
+ compare: "",
371
+ "show-predefined-range": ""
372
+ }, null, 8, ["modelValue"])
373
+ ]),
374
+ b("div", ue, [
375
+ y(ee, {
376
+ button: {
377
+ appendIcon: "file_download",
378
+ variant: "primary",
379
+ label: "Export"
380
+ },
381
+ handler: async () => {
382
+ await m(w).downloadTransactionReport({
383
+ start: m(n).startDate,
384
+ end: m(n).endDate
385
+ });
386
+ }
387
+ }, null, 8, ["handler"])
388
+ ])
389
+ ]),
390
+ y(ie, {
391
+ loading: m(l),
392
+ data: c.value,
393
+ onQuery: K,
394
+ onRefund: V,
395
+ onNotify: M
396
+ }, null, 8, ["loading", "data"])
397
+ ]),
398
+ _: 1
399
+ }, 8, ["loading"]);
400
+ };
401
+ }
402
+ });
403
+ export {
404
+ Fe as default
405
+ };
@@ -1,5 +1,7 @@
1
- import { F_TERMINAL_TRANSACTION_ACTION, FdoTerminalTransaction, type PaginatedResult } from "@feedmepos/payment-entity";
1
+ import { F_TERMINAL_TRANSACTION_ACTION, FdoTerminalTransaction, PaymentRefundRequestV2Dto, type PaginatedResult } from "@feedmepos/payment-entity";
2
2
  export declare const terminalTransactionApi: {
3
+ queryTransaction(transactionId: string): Promise<FdoTerminalTransaction>;
4
+ refundTransaction(payload: PaymentRefundRequestV2Dto): Promise<FdoTerminalTransaction>;
3
5
  readTransactions(payload: {
4
6
  status: F_TERMINAL_TRANSACTION_ACTION[];
5
7
  searchKey: string;
@@ -11,6 +11,7 @@ export declare const transactionApi: {
11
11
  transactionId: string;
12
12
  }): Promise<PaymentTransactionDtoOutput>;
13
13
  refundTransaction(req: PaymentRefundByTransactionIdDto): Promise<PaymentTransactionDtoOutput>;
14
+ renotifyTransaction(transactionId: string): Promise<PaymentTransactionDtoOutput>;
14
15
  readRestaurantTransactions(dateRange: {
15
16
  start: string;
16
17
  end: string;
package/dist/app.js CHANGED
@@ -9,7 +9,7 @@ const f = [
9
9
  meta: {
10
10
  sidebarDisplay: "Payout Accounts"
11
11
  },
12
- component: () => import("./PayoutAccount-D-9hzZyp.js")
12
+ component: () => import("./PayoutAccount-DlS2OPwj.js")
13
13
  },
14
14
  {
15
15
  path: "/admin/payout-accounts/:accountId",
@@ -23,7 +23,7 @@ const f = [
23
23
  meta: {
24
24
  sidebarDisplay: "Terminals"
25
25
  },
26
- component: () => import("./Terminal-BbIs7aYi.js")
26
+ component: () => import("./Terminal-BDDP5VT8.js")
27
27
  },
28
28
  {
29
29
  path: "/admin/terminal/:terminalId",
@@ -37,7 +37,7 @@ const f = [
37
37
  meta: {
38
38
  sidebarDisplay: "Offline Transactions"
39
39
  },
40
- component: () => import("./TerminalTransaction-CVcDmLvg.js")
40
+ component: () => import("./TerminalTransaction-BC-QZh_F.js")
41
41
  },
42
42
  {
43
43
  path: "/admin/transaction",
@@ -45,7 +45,7 @@ const f = [
45
45
  meta: {
46
46
  sidebarDisplay: "Online Transactions"
47
47
  },
48
- component: () => import("./Transaction-DpmCjczz.js")
48
+ component: () => import("./Transaction-DvgeNetP.js")
49
49
  },
50
50
  {
51
51
  path: "/admin/settlement",
@@ -59,7 +59,7 @@ const f = [
59
59
  path: "/admin/settlement/:settlementId",
60
60
  name: "mf-payment-admin.settlement-transaction",
61
61
  props: !0,
62
- component: () => import("./SettlementTransactions-CdZswF1S.js")
62
+ component: () => import("./SettlementTransactions-yJhT6FR4.js")
63
63
  }
64
64
  ], y = [
65
65
  {
@@ -69,7 +69,7 @@ const f = [
69
69
  {
70
70
  path: "/payout-account",
71
71
  name: "mf-payment-payout-account",
72
- component: () => import("./PayoutAccount-BF4TdtVz.js"),
72
+ component: () => import("./PayoutAccount-IhMg0cdL.js"),
73
73
  meta: {
74
74
  sidebarDisplay: "Payout Accounts"
75
75
  }
@@ -80,12 +80,12 @@ const f = [
80
80
  meta: {
81
81
  sidebarDisplay: "Offline Transactions"
82
82
  },
83
- component: () => import("./TerminalTransaction-BEyzFREU.js")
83
+ component: () => import("./TerminalTransaction-DCqbXI2q.js")
84
84
  },
85
85
  {
86
86
  path: "/transaction",
87
87
  name: "mf-payment-transaction",
88
- component: () => import("./Transaction-Atm-A5eN.js"),
88
+ component: () => import("./Transaction-D6mKrbLJ.js"),
89
89
  meta: {
90
90
  sidebarDisplay: "Online Transactions"
91
91
  }
@@ -102,7 +102,7 @@ const f = [
102
102
  path: "/settlement/:settlementId",
103
103
  name: "mf-payment-settlement-transaction",
104
104
  props: !0,
105
- component: () => import("./SettlementTransactions-w0jXLftr.js")
105
+ component: () => import("./SettlementTransactions-Co4ziq3a.js")
106
106
  }
107
107
  ], A = P("iframe", () => {
108
108
  const o = {
@@ -13,6 +13,10 @@ export type CursorTableController<T> = {
13
13
  * Current page of the data, before transform
14
14
  */
15
15
  pageData: () => T[];
16
+ /**
17
+ * Replace page data by page index
18
+ */
19
+ replaceData: (index: number, value: T) => void;
16
20
  };
17
21
  declare const _default: <T extends unknown, R extends unknown>(__VLS_props: {
18
22
  readonly "onRow-click"?: ((data: T) => any) | undefined;
@@ -1,21 +1,31 @@
1
- import { a, b as n, r as t, l as i } from "./index-Cnxt2xmc.js";
2
- const r = "", b = {
3
- async readTransactions(s) {
1
+ import { b as s, a, r as t, l as i } from "./index-Cnxt2xmc.js";
2
+ const e = "", b = {
3
+ async queryTransaction(n) {
4
+ return s().get(
5
+ `/payments/terminal-transactions/${n}`
6
+ );
7
+ },
8
+ async refundTransaction(n) {
9
+ return s().post("/payments/terminal-transactions/refund", {
10
+ ...n
11
+ });
12
+ },
13
+ async readTransactions(n) {
4
14
  return a(
5
- await n().get("/payments/terminal-transactions", {
6
- params: s
15
+ await s().get("/payments/terminal-transactions", {
16
+ params: n
7
17
  })
8
18
  );
9
19
  },
10
- async readRestaurantTransactions(s) {
20
+ async readRestaurantTransactions(n) {
11
21
  return a(
12
22
  await t().get("/terminal-transactions", {
13
- params: s
23
+ params: n
14
24
  })
15
25
  );
16
26
  },
17
- async downloadTransactions(s) {
18
- return i(s, {
27
+ async downloadTransactions(n) {
28
+ return i(n, {
19
29
  // @ts-ignore : transform data types won't come together from Zod
20
30
  exclude: ["logs", "owner", "details", "refund", "raw"],
21
31
  rename: {
@@ -30,6 +40,6 @@ const r = "
30
40
  }
31
41
  };
32
42
  export {
33
- r as E,
43
+ e as E,
34
44
  b as t
35
45
  };