@agendize/vue-settings
Version:
Vue agendize's settings component
237 lines • 847 kB
JavaScript
import { ref as P, watch as nA, onBeforeMount as BA, onMounted as wA, defineComponent as PA, openBlock as I, createBlock as WA, unref as r, withCtx as F, createElementBlock as XA, createVNode as o, createElementVNode as l, toDisplayString as R, normalizeClass as E, createCommentVNode as cA } from "vue";
import { i as _, S as U } from "./index.d2d0aba2.js";
import { _ as uA } from "./View.vue_vue_type_style_index_0_lang.18cc377c.js";
import { ConfirmDialog as gA, CardList as lA } from "@agendize/design-system";
import { _ as ZA, a as YA } from "./View.vue_vue_type_style_index_0_lang.c0566e15.js";
import "./vendor.26bbd9f1.js";
import "@agendize/az-i18n";
import "@agendize/vue-tools";
import "@agendize/js-calendar-api";
import "vue-router";
import "@agendize/vue-acl";
import "./viewModel.ceed8ca9.js";
import "./index.b1f405e6.js";
function aA(L, Z, a, e, s, T, m, W, d) {
const n = _(a), u = P([]), z = P([]), M = P(!1), y = P(!1), O = P(""), x = P(/* @__PURE__ */ new Map()), H = P(/* @__PURE__ */ new Map()), Q = [
{
id: "chips-all",
label: n.global.t("settings.servicesGroups-cards.filter.all"),
filter: k,
active: !0,
defaultSelection: !0
},
{
id: "chips-1",
label: n.global.t("settings.servicesGroups-cards.filter.lvl-1"),
filter: $,
active: !1
},
{
id: "chips-2",
label: n.global.t("settings.servicesGroups-cards.filter.lvl-2"),
filter: AA,
active: !1
}
];
function V(A, f) {
var t, w;
const v = (w = (t = A.row) == null ? void 0 : t.id) != null ? w : "";
!v || X(v, f).then(() => {
x.value.set(v, !1), f === "Share" ? y.value = !0 : M.value = !0;
});
}
function J(A) {
V(A, "Share");
}
function S(A) {
V(A, "QRCode");
}
async function X(A, f) {
x.value.set(A, !0);
let v = await Z.getCompanyById(s), t = s;
v && v.result && (t = v.result.encryptedId);
let w = A;
f === "QRCode" && (w = A + "_qrcode");
let g = H.value.get(w);
if (!g) {
let Y = `/web/widget/?c=${t}&serviceGroup=${A}&cs=false`;
f === "QRCode" && (Y = Y + "&source=qrcode"), g = (await Z.cipherUrl(s, Y)).shortenerUrl, H.value.set(w, g);
}
O.value = g;
}
const B = P({
label: n.global.t("settings.servicesGroups-cards.add"),
show: z.value.length === 0,
hasAcl: !1,
actionLoading: !1,
class: "az-btn-color-primary",
mobileIcon: "fa fa-plus",
mobileClass: "az-btn-color-transparent",
action: async () => await W.push({
name: U.ServicesGroupDetails,
params: { companyId: s, serviceGroupId: "0" },
query: { new: "true" }
})
}), b = P({
label: n.global.t("settings.servicesGroups-cards.duplicate"),
show: z.value.length === 1,
hasAcl: !1,
actionLoading: !1,
class: "az-btn-color-primary",
mobileIcon: "fas fa-clone",
mobileClass: "az-btn-color-transparent",
action: async () => {
z.value.length > 0 && await W.push({
name: U.ServicesGroupDetails,
params: { companyId: s, serviceGroupId: z.value[0].id },
query: { clone: "true" }
});
}
}), c = P({
label: n.global.t("settings.servicesGroups-cards.delete"),
show: z.value.length > 0,
hasAcl: !1,
actionLoading: !1,
class: "az-btn-color-error ",
mobileIcon: "fas fa-trash",
mobileClass: "az-btn-color-error",
action: p
}), j = P([b, c, B]);
async function p() {
if (c.value.actionLoading && !z.value || z.value.length === 0)
return;
const { reveal: A, onConfirm: f } = T(gA, {
locale: a,
closeOnBlurClick: !0,
confirmation: n.global.t("settings.servicesGroups-cards.confirm"),
description: n.global.t("settings.servicesGroups-cards.confirmDelete", z.value.length),
title: n.global.t("settings.servicesGroups-cards.delete")
});
f(async () => {
var v, t;
c.value.actionLoading = !0;
for (const w of z.value)
await Z.deleteServiceGroup(s, w.id);
await new Promise((w) => setTimeout(w, 200)), (v = L.value) != null && v.reload && ((t = L.value) == null || t.reload()), m.success(n.global.t("settings.action.delete-success")), z.value = [], c.value.actionLoading = !1;
}), await A();
}
async function N() {
try {
const A = await Z.getAllServiceGroups(s, d.email);
A.results && (u.value = A.results);
} catch {
}
return u.value.map((A) => eA(A));
}
function G(A) {
var f, v;
if (A.parent || ((f = A.members) == null ? void 0 : f.length))
return !1;
for (let t of u.value)
if (((v = t.parent) == null ? void 0 : v.id) === A.id)
return !0;
return !1;
}
function D(A, f) {
let v = [];
for (let t of A)
t.objectType === "servicesGroup" && f == G(t.object) && v.push(t);
return v;
}
function k(A, f) {
return A;
}
function $(A, f) {
return D(A, !0);
}
function AA(A, f) {
return D(A, !1);
}
function fA(A, f) {
return f = f.toLowerCase(), A.filter((v) => vA(v, f));
}
function vA(A, f) {
if (A.objectType !== "servicesGroup")
return !1;
const v = A.object;
return v ? v.name.toLowerCase().indexOf(f) > -1 : !1;
}
function rA(A) {
const f = A.map((v) => v.id);
z.value = u.value.filter((v) => f.indexOf(v.id) >= 0);
}
async function i(A) {
await (W == null ? void 0 : W.push({
name: U.ServicesGroupDetails,
params: { companyId: s, serviceGroupId: A }
}));
}
async function tA(A) {
var f, v;
(f = A.row) != null && f.object.id && await i((v = A.row) == null ? void 0 : v.object.id);
}
async function zA(A) {
await i(A.id);
}
function bA(A) {
var v, t, w, g, Y;
let f = 0;
if ((w = (t = (v = A.row) == null ? void 0 : v.object) == null ? void 0 : t.members) != null && w.length)
f = A.row.object.members.length;
else if ((Y = (g = A.row) == null ? void 0 : g.object) != null && Y.id) {
let q = [];
u.value.filter((K) => {
var C, h;
return ((C = K.parent) == null ? void 0 : C.id) === A.row.object.id && ((h = K.members) == null ? void 0 : h.length);
}).forEach((K) => {
q = q.concat(K.members.map((C) => C.id));
}), f = [...new Set(q)].length;
}
return n.global.t("settings.servicesGroups-cards.services", { nb: f }, f === 0 ? 1 : f);
}
function eA(A) {
var v, t;
let f;
return A.parent && A.parent.name && (f = {
icon: "far fa-tag",
label: A.parent.name
}), {
id: A.id,
title: A.name,
description: "",
picture: { url: (t = (v = A.picture) == null ? void 0 : v.url) != null ? t : "", alt: A.name },
object: A,
objectType: "servicesGroup",
tag: f
};
}
async function sA() {
B.value.hasAcl = await e.can("createService", s), b.value.hasAcl = B.value.hasAcl, c.value.hasAcl = await e.can("deleteService", s);
}
return nA(() => z.value, (A) => {
B.value.show = A.length === 0, c.value.show = A.length > 0, b.value.show = A.length === 1;
}), BA(async () => {
await e.can("readService", s) || W == null || W.push({ name: U.CompanyHome, params: { companyId: s } });
}), wA(async () => {
try {
await sA();
} catch {
}
}), {
actionButtons: j,
showQRCodeModal: M,
showIntegrationModal: y,
link: O,
shareLoading: x,
quickFilters: Q,
fetchServicesGroups: N,
filterServicesGroups: fA,
selectServicesGroup: rA,
selectServicesGroupLine: zA,
selectServicesGroupLineByRow: tA,
openShare: J,
openQRCode: S,
countServices: bA
};
}
const xA = "