UNPKG

@agendize/vue-settings

Version:
221 lines 964 kB
import { ref as c, watch as AA, onBeforeMount as zA, onMounted as vA, defineComponent as fA, openBlock as K, createBlock as sA, unref as f, withCtx as S, createElementBlock as BA, createVNode as V, createElementVNode as X, toDisplayString as i, normalizeClass as I, createCommentVNode as nA } from "vue"; import { i as E, S as Q } from "./index.d2d0aba2.js"; import { _ as wA } from "./View.vue_vue_type_style_index_0_lang.18cc377c.js"; import { ConfirmDialog as eA, CardList as gA } from "@agendize/design-system"; import { getDurationLabel as cA } from "@agendize/vue-tools"; import { u as tA } from "./vendor.26bbd9f1.js"; import { _ as MA, a as rA } from "./View.vue_vue_type_style_index_0_lang.c0566e15.js"; import "@agendize/az-i18n"; import "@agendize/js-calendar-api"; import "vue-router"; import "@agendize/vue-acl"; import "./viewModel.ceed8ca9.js"; import "./index.b1f405e6.js"; function YA(W, l, L, n, w, N, y, M, x) { const { t: O } = tA(), B = E(L), r = c([]), e = c([]), C = c(!1), m = c(!1), J = c(""), u = c(/* @__PURE__ */ new Map()), G = c(/* @__PURE__ */ new Map()); function a(A, z) { var t, g; const v = (g = (t = A.row) == null ? void 0 : t.id) != null ? g : ""; !v || P(v, z).then(() => { u.value.set(v, !1), z === "Share" ? m.value = !0 : C.value = !0; }); } function F(A) { a(A, "Share"); } function Y(A) { a(A, "QRCode"); } async function P(A, z) { u.value.set(A, !0); let v = await l.getCompanyById(w), t = w; v && v.result && (t = v.result.encryptedId); let g = A; z === "QRCode" && (g = A + "_qrcode"); let Z = G.value.get(g); if (!Z) { let p = `/web/widget/?c=${t}&service=${A}&cs=false`; z === "QRCode" && (p = p + "&source=qrcode"), Z = (await l.cipherUrl(w, p)).shortenerUrl, G.value.set(g, Z); } J.value = Z; } const s = c({ label: B.global.t("settings.services-cards.add"), show: e.value.length === 0, hasAcl: !1, actionLoading: !1, class: "az-btn-color-primary", mobileIcon: "fa fa-plus", mobileClass: "az-btn-color-transparent", action: async () => await M.push({ name: Q.ServiceDetails, params: { companyId: w, serviceId: "0" }, query: { new: "true" } }) }), D = c({ label: B.global.t("settings.services-cards.duplicate"), show: e.value.length === 1, hasAcl: !1, actionLoading: !1, class: "az-btn-color-primary", mobileIcon: "fas fa-clone", mobileClass: "az-btn-color-transparent", action: async () => { e.value.length > 0 && await M.push({ name: Q.ServiceDetails, params: { companyId: w, serviceId: e.value[0].id }, query: { clone: "true" } }); } }), b = c({ label: B.global.t("settings.services-cards.delete"), show: e.value.length > 0, hasAcl: !1, actionLoading: !1, class: "az-btn-color-error ", mobileIcon: "fas fa-trash", mobileClass: "az-btn-color-error", action: H }), d = c([D, b, s]); async function H() { if (b.value.actionLoading && !e.value || e.value.length === 0) return; const { reveal: A, onConfirm: z } = N(eA, { locale: L, closeOnBlurClick: !0, confirmation: B.global.t("settings.services-cards.confirm"), description: B.global.t("settings.services.confirmDelete", e.value.length), title: B.global.t("settings.services-cards.delete") }); z(async () => { var v, t; b.value.actionLoading = !0; for (const g of e.value) await l.deleteService(w, g.id); await new Promise((g) => setTimeout(g, 200)), (v = W.value) != null && v.reload && ((t = W.value) == null || t.reload()), y.success(B.global.t("settings.action.delete-success")), e.value = [], b.value.actionLoading = !1; }), await A(); } function j(A) { var z, v; return cA(O, (v = (z = A.row) == null ? void 0 : z.object) == null ? void 0 : v.duration); } async function k() { try { const A = await l.getAllServices(w, x.email); A.results && (r.value = A.results); } catch { } return r.value.map((A) => _(A)); } function T(A, z) { return z = z.toLowerCase(), A.filter((v) => o(v, z)); } function o(A, z) { if (A.objectType !== "service") return !1; const v = A.object; return v ? v.name.toLowerCase().indexOf(z) > -1 : !1; } function q(A) { const z = A.map((v) => v.id); e.value = r.value.filter((v) => z.indexOf(v.id) >= 0); } async function h(A) { var z, v; (z = A.row) != null && z.object.id && await U((v = A.row) == null ? void 0 : v.object.id); } async function R(A) { await U(A.id); } async function U(A) { await (M == null ? void 0 : M.push({ name: Q.ServiceDetails, params: { companyId: w, serviceId: A } })); } function _(A) { var t, g, Z; let z, v = !1; if (A.availability == "disabled") z = { icon: "far fa-eye-slash", label: B.global.t("settings.services-cards.tag.disabled"), translatable: !0 }, v = !0; else if (A.locations && A.locations.length > 1) z = { icon: "far fa-pen-to-square", label: B.global.t("settings.services-cards.tag.multiple"), translatable: !0 }; else if (A.locations && A.locations.length === 1) switch (z = { icon: "", label: "" }, A.locations[0]) { case "companyAddress": z = { icon: "far fa-location-dot", label: B.global.t("settings.services-cards.tag.address"), translatable: !0 }; break; case "videoconference": z = { icon: "far fa-video", label: B.global.t("settings.services-cards.tag.visio"), translatable: !0 }; break; case "phone": z = { icon: "far fa-phone", label: B.global.t("settings.services-cards.tag.phone"), translatable: !0 }; break; case "custom": z = { icon: "far fa-i-cursor", label: B.global.t("settings.services-cards.tag.custom"), translatable: !0 }; break; } return { id: A.id, title: A.name, description: (t = A.description) != null ? t : "", picture: { url: (Z = (g = A.picture) == null ? void 0 : g.url) != null ? Z : "", alt: A.name }, disabledObject: v, object: A, objectType: "service", tag: z }; } async function $() { s.value.hasAcl = await n.can("createService", w), D.value.hasAcl = s.value.hasAcl, b.value.hasAcl = await n.can("deleteService", w); } return AA(() => e.value, (A) => { s.value.show = A.length === 0, b.value.show = A.length > 0, D.value.show = A.length === 1; }), zA(async () => { await n.can("readService", w) || M == null || M.push({ name: Q.CompanyHome, params: { companyId: w } }); }), vA(async () => { try { await $(); } catch { } }), { actionButtons: d, showQRCodeModal: C, showIntegrationModal: m, link: J, shareLoading: u, getDuration: j, fetchServices: k, filterServices: T, selectService: q, selectServiceLine: R, selectServiceLineByRow: h, openShare: F, openQRCode: Y }; } const PA = "