v-sistec-features 1.2.5 → 1.3.0

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.
@@ -0,0 +1,9 @@
1
+ const s = (t, r) => {
2
+ const o = t.__vccOpts || t;
3
+ for (const [c, e] of r)
4
+ o[c] = e;
5
+ return o;
6
+ };
7
+ export {
8
+ s as _
9
+ };
@@ -8,4 +8,4 @@
8
8
  * Copyright 2018-2025 The Tabler Authors
9
9
  * Copyright 2018-2025 codecalm.net Paweł Kuna
10
10
  * Licensed under MIT (https://github.com/tabler/tabler/blob/master/LICENSE)
11
- */[data-bs-theme-base=slate]{--tblr-gray-50:#f8fafc;--tblr-gray-100:#f1f5f9;--tblr-gray-200:#e2e8f0;--tblr-gray-300:#cbd5e1;--tblr-gray-400:#94a3b8;--tblr-gray-500:#64748b;--tblr-gray-600:#475569;--tblr-gray-700:#334155;--tblr-gray-800:#1e293b;--tblr-gray-900:#0f172a;--tblr-gray-950:#020617}[data-bs-theme-base=gray]{--tblr-gray-50:#f9fafb;--tblr-gray-100:#f3f4f6;--tblr-gray-200:#e5e7eb;--tblr-gray-300:#d1d5db;--tblr-gray-400:#9ca3af;--tblr-gray-500:#6b7280;--tblr-gray-600:#4b5563;--tblr-gray-700:#374151;--tblr-gray-800:#1f2937;--tblr-gray-900:#111827;--tblr-gray-950:#030712}[data-bs-theme-base=zinc]{--tblr-gray-50:#fafafa;--tblr-gray-100:#f4f4f5;--tblr-gray-200:#e4e4e7;--tblr-gray-300:#d4d4d8;--tblr-gray-400:#a1a1aa;--tblr-gray-500:#71717a;--tblr-gray-600:#52525b;--tblr-gray-700:#3f3f46;--tblr-gray-800:#27272a;--tblr-gray-900:#18181b;--tblr-gray-950:#09090b}[data-bs-theme-base=neutral]{--tblr-gray-50:#fafafa;--tblr-gray-100:#f5f5f5;--tblr-gray-200:#e5e5e5;--tblr-gray-300:#d4d4d4;--tblr-gray-400:#a3a3a3;--tblr-gray-500:#737373;--tblr-gray-600:#525252;--tblr-gray-700:#404040;--tblr-gray-800:#262626;--tblr-gray-900:#171717;--tblr-gray-950:#0a0a0a}[data-bs-theme-base=stone]{--tblr-gray-50:#fafaf9;--tblr-gray-100:#f5f5f4;--tblr-gray-200:#e7e5e4;--tblr-gray-300:#d6d3d1;--tblr-gray-400:#a8a29e;--tblr-gray-500:#78716c;--tblr-gray-600:#57534e;--tblr-gray-700:#44403c;--tblr-gray-800:#292524;--tblr-gray-900:#1c1917;--tblr-gray-950:#0c0a09}[data-bs-theme-base=pink]{--tblr-gray-50:#fdf2f8;--tblr-gray-100:#fce7f3;--tblr-gray-200:#fbcfe8;--tblr-gray-300:#f9a8d4;--tblr-gray-400:#f472b6;--tblr-gray-500:#ec4899;--tblr-gray-600:#db2777;--tblr-gray-700:#be185d;--tblr-gray-800:#9d174d;--tblr-gray-900:#831843;--tblr-gray-950:#500724}[data-bs-theme-primary=blue]{--tblr-primary:#066fd1;--tblr-primary-rgb:6,111,209}[data-bs-theme-primary=azure]{--tblr-primary:#4299e1;--tblr-primary-rgb:66,153,225}[data-bs-theme-primary=indigo]{--tblr-primary:#4263eb;--tblr-primary-rgb:66,99,235}[data-bs-theme-primary=purple]{--tblr-primary:#ae3ec9;--tblr-primary-rgb:174,62,201}[data-bs-theme-primary=pink]{--tblr-primary:#d6336c;--tblr-primary-rgb:214,51,108}[data-bs-theme-primary=red]{--tblr-primary:#d63939;--tblr-primary-rgb:214,57,57}[data-bs-theme-primary=orange]{--tblr-primary:#f76707;--tblr-primary-rgb:247,103,7}[data-bs-theme-primary=yellow]{--tblr-primary:#f59f00;--tblr-primary-rgb:245,159,0}[data-bs-theme-primary=lime]{--tblr-primary:#74b816;--tblr-primary-rgb:116,184,22}[data-bs-theme-primary=green]{--tblr-primary:#2fb344;--tblr-primary-rgb:47,179,68}[data-bs-theme-primary=teal]{--tblr-primary:#0ca678;--tblr-primary-rgb:12,166,120}[data-bs-theme-primary=cyan]{--tblr-primary:#17a2b8;--tblr-primary-rgb:23,162,184}[data-bs-theme-radius="0"]{--tblr-border-radius-scale:0}[data-bs-theme-radius="0.5"]{--tblr-border-radius-scale:.5}[data-bs-theme-radius="1"]{--tblr-border-radius-scale:1}[data-bs-theme-radius="1.5"]{--tblr-border-radius-scale:1.5}[data-bs-theme-radius="2"]{--tblr-border-radius-scale:2}[data-bs-theme-primary=inverted]{--tblr-primary:var(--tblr-gray-800);--tblr-primary-fg:var(--tblr-light);--tblr-primary-rgb:31,41,55}[data-bs-theme-primary=inverted] [data-bs-theme=dark],[data-bs-theme-primary=inverted][data-bs-theme=dark]{--tblr-primary:#f9fafb;--tblr-primary-fg:var(--tblr-dark);--tblr-primary-rgb:249,250,251}[data-bs-theme-font=monospace]{--tblr-body-font-family:var(--tblr-font-monospace);--tblr-body-font-size:80%}[data-bs-theme-font=sans-serif]{--tblr-body-font-family:var(--tblr-font-sans-serif)}[data-bs-theme-font=serif]{--tblr-body-font-family:var(--tblr-font-serif)}[data-bs-theme-font=comic]{--tblr-body-font-family:var(--tblr-font-comic)}.rotate-180[data-v-b9735591] svg{transform:rotate(180deg)}.page-select[data-v-b9735591]{background-color:var(--tblr-primary)!important;color:#fff!important;border:none!important}.page-estilo[data-v-b9735591]{border:none;--cor-escurecida: color-mix(in srgb, var(--tblr-primary), #000 25%);background:transparent;padding:1px 10px;border-radius:7px;margin:0!important;transition:color .15s ease-in-out,background-color .15s ease-in-out}.page-estilo[data-v-b9735591]:hover{background:var(--cor-escurecida);color:#fff}.btn[data-v-b9735591]{padding:0!important;margin:0!important;background:transparent!important;border:none!important;box-shadow:none!important}[data-v-b9735591] .btn-estilo svg{padding:0!important;margin:0!important}[data-v-b9735591] .btn-estilo:hover svg{stroke:var(--tblr-primary)}.icon-tabler[data-v-b9735591]{margin:0!important;padding:0!important}.inputClose[data-v-1b6ff54b]{color:var(--tblr-icon-color);z-index:10;position:absolute;top:50%;right:0;transform:translateY(-50%);font-size:1.2em;min-width:2.5rem;display:flex;justify-content:center}.inputClose[data-v-1b6ff54b]:hover{cursor:pointer}.selected[data-v-1b6ff54b]:hover{background-color:#b02a2a!important;color:#fff!important}.table-responsive[data-v-8ae12dec]{overflow-x:auto}.state-feedback[data-v-8ae12dec]{padding:1rem;text-align:center}.state-feedback.error[data-v-8ae12dec]{color:red}.pagination-controls[data-v-8ae12dec]{margin-top:1rem;display:flex;justify-content:space-between}.placeholder-img[data-v-8ae12dec]{width:40px;height:40px;border-radius:4px}.container-img[data-v-8ae12dec]{aspect-ratio:1;display:flex;justify-content:center;overflow:hidden;position:relative;max-width:40px;min-width:40px}.container-img .img-tamanho-cover[data-v-8ae12dec]{position:absolute;top:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.5;filter:blur(4px)}.container-img .img-tamanho[data-v-8ae12dec]{object-fit:contain;width:100%;height:100%;z-index:2}.container-img.container-img-preview[data-v-8ae12dec]{cursor:pointer}.container-img.container-img-preview[data-v-8ae12dec]:hover{border-style:dashed;border-color:var(--tblr-primary);border-width:2px;transition:border-width .15s ease-in-out}.container-img.container-img-preview:hover .img-tamanho[data-v-8ae12dec]{opacity:.3}.erro-custom-container[data-v-8ae12dec]{display:inline-block;padding:.2em .6em;border-radius:4px;background-color:#fff;font-weight:700;text-transform:uppercase}.erro-custom-text[data-v-8ae12dec]{font-size:.8em;text-transform:uppercase;font-weight:700}.bg-img[data-v-8ae12dec]{background-color:#0000004d;position:absolute;top:0;width:100%;height:100%;z-index:1}.image-preview-container[data-v-8ae12dec]{position:fixed;z-index:9999;background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #0003;padding:5px;pointer-events:none;transition:opacity .2s ease-in-out}.image-preview-container .image-preview-large[data-v-8ae12dec]{display:block;max-width:250px;max-height:250px;border-radius:4px}.form-check-input[data-v-8ae12dec]{border-width:1px!important;border-color:#00000064!important;width:17px;height:17px}[data-bs-theme=dark] .form-check-input[data-v-8ae12dec]{border-color:#ffffff5f!important}
11
+ */[data-bs-theme-base=slate]{--tblr-gray-50:#f8fafc;--tblr-gray-100:#f1f5f9;--tblr-gray-200:#e2e8f0;--tblr-gray-300:#cbd5e1;--tblr-gray-400:#94a3b8;--tblr-gray-500:#64748b;--tblr-gray-600:#475569;--tblr-gray-700:#334155;--tblr-gray-800:#1e293b;--tblr-gray-900:#0f172a;--tblr-gray-950:#020617}[data-bs-theme-base=gray]{--tblr-gray-50:#f9fafb;--tblr-gray-100:#f3f4f6;--tblr-gray-200:#e5e7eb;--tblr-gray-300:#d1d5db;--tblr-gray-400:#9ca3af;--tblr-gray-500:#6b7280;--tblr-gray-600:#4b5563;--tblr-gray-700:#374151;--tblr-gray-800:#1f2937;--tblr-gray-900:#111827;--tblr-gray-950:#030712}[data-bs-theme-base=zinc]{--tblr-gray-50:#fafafa;--tblr-gray-100:#f4f4f5;--tblr-gray-200:#e4e4e7;--tblr-gray-300:#d4d4d8;--tblr-gray-400:#a1a1aa;--tblr-gray-500:#71717a;--tblr-gray-600:#52525b;--tblr-gray-700:#3f3f46;--tblr-gray-800:#27272a;--tblr-gray-900:#18181b;--tblr-gray-950:#09090b}[data-bs-theme-base=neutral]{--tblr-gray-50:#fafafa;--tblr-gray-100:#f5f5f5;--tblr-gray-200:#e5e5e5;--tblr-gray-300:#d4d4d4;--tblr-gray-400:#a3a3a3;--tblr-gray-500:#737373;--tblr-gray-600:#525252;--tblr-gray-700:#404040;--tblr-gray-800:#262626;--tblr-gray-900:#171717;--tblr-gray-950:#0a0a0a}[data-bs-theme-base=stone]{--tblr-gray-50:#fafaf9;--tblr-gray-100:#f5f5f4;--tblr-gray-200:#e7e5e4;--tblr-gray-300:#d6d3d1;--tblr-gray-400:#a8a29e;--tblr-gray-500:#78716c;--tblr-gray-600:#57534e;--tblr-gray-700:#44403c;--tblr-gray-800:#292524;--tblr-gray-900:#1c1917;--tblr-gray-950:#0c0a09}[data-bs-theme-base=pink]{--tblr-gray-50:#fdf2f8;--tblr-gray-100:#fce7f3;--tblr-gray-200:#fbcfe8;--tblr-gray-300:#f9a8d4;--tblr-gray-400:#f472b6;--tblr-gray-500:#ec4899;--tblr-gray-600:#db2777;--tblr-gray-700:#be185d;--tblr-gray-800:#9d174d;--tblr-gray-900:#831843;--tblr-gray-950:#500724}[data-bs-theme-primary=blue]{--tblr-primary:#066fd1;--tblr-primary-rgb:6,111,209}[data-bs-theme-primary=azure]{--tblr-primary:#4299e1;--tblr-primary-rgb:66,153,225}[data-bs-theme-primary=indigo]{--tblr-primary:#4263eb;--tblr-primary-rgb:66,99,235}[data-bs-theme-primary=purple]{--tblr-primary:#ae3ec9;--tblr-primary-rgb:174,62,201}[data-bs-theme-primary=pink]{--tblr-primary:#d6336c;--tblr-primary-rgb:214,51,108}[data-bs-theme-primary=red]{--tblr-primary:#d63939;--tblr-primary-rgb:214,57,57}[data-bs-theme-primary=orange]{--tblr-primary:#f76707;--tblr-primary-rgb:247,103,7}[data-bs-theme-primary=yellow]{--tblr-primary:#f59f00;--tblr-primary-rgb:245,159,0}[data-bs-theme-primary=lime]{--tblr-primary:#74b816;--tblr-primary-rgb:116,184,22}[data-bs-theme-primary=green]{--tblr-primary:#2fb344;--tblr-primary-rgb:47,179,68}[data-bs-theme-primary=teal]{--tblr-primary:#0ca678;--tblr-primary-rgb:12,166,120}[data-bs-theme-primary=cyan]{--tblr-primary:#17a2b8;--tblr-primary-rgb:23,162,184}[data-bs-theme-radius="0"]{--tblr-border-radius-scale:0}[data-bs-theme-radius="0.5"]{--tblr-border-radius-scale:.5}[data-bs-theme-radius="1"]{--tblr-border-radius-scale:1}[data-bs-theme-radius="1.5"]{--tblr-border-radius-scale:1.5}[data-bs-theme-radius="2"]{--tblr-border-radius-scale:2}[data-bs-theme-primary=inverted]{--tblr-primary:var(--tblr-gray-800);--tblr-primary-fg:var(--tblr-light);--tblr-primary-rgb:31,41,55}[data-bs-theme-primary=inverted] [data-bs-theme=dark],[data-bs-theme-primary=inverted][data-bs-theme=dark]{--tblr-primary:#f9fafb;--tblr-primary-fg:var(--tblr-dark);--tblr-primary-rgb:249,250,251}[data-bs-theme-font=monospace]{--tblr-body-font-family:var(--tblr-font-monospace);--tblr-body-font-size:80%}[data-bs-theme-font=sans-serif]{--tblr-body-font-family:var(--tblr-font-sans-serif)}[data-bs-theme-font=serif]{--tblr-body-font-family:var(--tblr-font-serif)}[data-bs-theme-font=comic]{--tblr-body-font-family:var(--tblr-font-comic)}.rotate-180[data-v-df81be49] svg{transform:rotate(180deg)}.page-select[data-v-df81be49]{background-color:var(--tblr-primary)!important;color:#fff!important;border:none!important}.page-estilo[data-v-df81be49]{border:none;--cor-escurecida: color-mix(in srgb, var(--tblr-primary), #000 25%);background:transparent;padding:1px 10px;border-radius:7px;margin:0!important;transition:color .15s ease-in-out,background-color .15s ease-in-out}.page-estilo[data-v-df81be49]:hover{background:var(--cor-escurecida);color:#fff}.btn[data-v-df81be49]{padding:0!important;margin:0!important;background:transparent!important;border:none!important;box-shadow:none!important}[data-v-df81be49] .btn-estilo svg{padding:0!important;margin:0!important}[data-v-df81be49] .btn-estilo:hover svg{stroke:var(--tblr-primary)}.icon-tabler[data-v-df81be49]{margin:0!important;padding:0!important}.scroll-finish-style[data-v-e6e86eba]{color:#6c757d;display:block;text-align:center;margin-top:1rem;margin-bottom:1rem}.rotate-180[data-v-b9735591] svg{transform:rotate(180deg)}.page-select[data-v-b9735591]{background-color:var(--tblr-primary)!important;color:#fff!important;border:none!important}.page-estilo[data-v-b9735591]{border:none;--cor-escurecida: color-mix(in srgb, var(--tblr-primary), #000 25%);background:transparent;padding:1px 10px;border-radius:7px;margin:0!important;transition:color .15s ease-in-out,background-color .15s ease-in-out}.page-estilo[data-v-b9735591]:hover{background:var(--cor-escurecida);color:#fff}.btn[data-v-b9735591]{padding:0!important;margin:0!important;background:transparent!important;border:none!important;box-shadow:none!important}[data-v-b9735591] .btn-estilo svg{padding:0!important;margin:0!important}[data-v-b9735591] .btn-estilo:hover svg{stroke:var(--tblr-primary)}.icon-tabler[data-v-b9735591]{margin:0!important;padding:0!important}.inputClose[data-v-1b6ff54b]{color:var(--tblr-icon-color);z-index:10;position:absolute;top:50%;right:0;transform:translateY(-50%);font-size:1.2em;min-width:2.5rem;display:flex;justify-content:center}.inputClose[data-v-1b6ff54b]:hover{cursor:pointer}.selected[data-v-1b6ff54b]:hover{background-color:#b02a2a!important;color:#fff!important}.table-responsive[data-v-5a415ab2]{overflow-x:auto}.state-feedback[data-v-5a415ab2]{padding:1rem;text-align:center}.state-feedback.error[data-v-5a415ab2]{color:red}.pagination-controls[data-v-5a415ab2]{margin-top:1rem;display:flex;justify-content:space-between}.placeholder-img[data-v-5a415ab2]{width:40px;height:40px;border-radius:4px}.container-img[data-v-5a415ab2]{aspect-ratio:1;display:flex;justify-content:center;overflow:hidden;position:relative;max-width:40px;min-width:40px}.container-img .img-tamanho-cover[data-v-5a415ab2]{position:absolute;top:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.5;filter:blur(4px)}.container-img .img-tamanho[data-v-5a415ab2]{object-fit:contain;width:100%;height:100%;z-index:2}.container-img.container-img-preview[data-v-5a415ab2]{cursor:pointer}.container-img.container-img-preview[data-v-5a415ab2]:hover{border-style:dashed;border-color:var(--tblr-primary);border-width:2px;transition:border-width .15s ease-in-out}.container-img.container-img-preview:hover .img-tamanho[data-v-5a415ab2]{opacity:.3}.erro-custom-container[data-v-5a415ab2]{display:inline-block;padding:.2em .6em;border-radius:4px;background-color:#fff;font-weight:700;text-transform:uppercase}.erro-custom-text[data-v-5a415ab2]{font-size:.8em;text-transform:uppercase;font-weight:700}.bg-img[data-v-5a415ab2]{background-color:#0000004d;position:absolute;top:0;width:100%;height:100%;z-index:1}.image-preview-container[data-v-5a415ab2]{position:fixed;z-index:9999;background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #0003;padding:5px;pointer-events:none;transition:opacity .2s ease-in-out}.image-preview-container .image-preview-large[data-v-5a415ab2]{display:block;max-width:250px;max-height:250px;border-radius:4px}.form-check-input[data-v-5a415ab2]{border-width:1px!important;border-color:#00000064!important;width:17px;height:17px}[data-bs-theme=dark] .form-check-input[data-v-5a415ab2]{border-color:#ffffff5f!important}
@@ -0,0 +1,460 @@
1
+ import { defineComponent as R, ref as g, toRefs as re, createElementBlock as d, watch as N, onMounted as Y, onUnmounted as oe, openBlock as _, withDirectives as se, renderSlot as E, createCommentVNode as M, createElementVNode as o, createVNode as V, vShow as ue, toDisplayString as B, nextTick as D, pushScopeId as ce, popScopeId as pe, computed as T, withModifiers as L, Fragment as O, renderList as F, normalizeClass as j, readonly as de, isRef as _e, unref as A, withCtx as q } from "vue";
2
+ import { _ as $ } from "./_plugin-vue_export-helper-CHgC5LLL.js";
3
+ function fe(a, s = null) {
4
+ if (!a)
5
+ return !1;
6
+ const e = a.getBoundingClientRect(), i = s ? s.getBoundingClientRect() : { top: 0, left: 0, bottom: window.innerHeight, right: window.innerWidth };
7
+ return e.bottom >= i.top && e.top <= i.bottom && e.right >= i.left && e.left <= i.right;
8
+ }
9
+ async function ge(a) {
10
+ return a ? (await D(), a.value instanceof HTMLElement ? a.value : a.value ? document.querySelector(a.value) : null) : null;
11
+ }
12
+ function ve(a) {
13
+ let s = `0px 0px ${a.distance}px 0px`;
14
+ a.top && (s = `${a.distance}px 0px 0px 0px`);
15
+ const e = new IntersectionObserver(
16
+ (i) => {
17
+ i[0].isIntersecting && (a.firstload && a.emit(), a.firstload = !0);
18
+ },
19
+ { root: a.parentEl, rootMargin: s }
20
+ );
21
+ return a.infiniteLoading.value && e.observe(a.infiniteLoading.value), e;
22
+ }
23
+ async function G(a, s) {
24
+ if (await D(), !a.top)
25
+ return;
26
+ const e = a.parentEl || document.documentElement;
27
+ e.scrollTop = e.scrollHeight - s;
28
+ }
29
+ const X = (a, s) => {
30
+ const e = a.__vccOpts || a;
31
+ for (const [i, u] of s)
32
+ e[i] = u;
33
+ return e;
34
+ }, me = {}, he = (a) => (ce("data-v-d3e37633"), a = a(), pe(), a), ye = { class: "container" }, be = /* @__PURE__ */ he(() => /* @__PURE__ */ o("div", { class: "spinner" }, null, -1)), ke = [
35
+ be
36
+ ];
37
+ function we(a, s) {
38
+ return _(), d("div", ye, ke);
39
+ }
40
+ const xe = /* @__PURE__ */ X(me, [["render", we], ["__scopeId", "data-v-d3e37633"]]), Ie = { class: "state-error" }, Pe = /* @__PURE__ */ R({
41
+ __name: "InfiniteLoading",
42
+ props: {
43
+ top: { type: Boolean, default: !1 },
44
+ target: {},
45
+ distance: { default: 0 },
46
+ identifier: {},
47
+ firstload: { type: Boolean, default: !0 },
48
+ slots: {}
49
+ },
50
+ emits: ["infinite"],
51
+ setup(a, { emit: s }) {
52
+ const e = a;
53
+ let i = null, u = 0;
54
+ const m = g(null), l = g(""), { top: r, firstload: I, distance: C } = e, { identifier: P, target: x } = re(e), t = {
55
+ infiniteLoading: m,
56
+ top: r,
57
+ firstload: I,
58
+ distance: C,
59
+ parentEl: null,
60
+ emit() {
61
+ u = (t.parentEl || document.documentElement).scrollHeight, h.loading(), s("infinite", h);
62
+ }
63
+ }, h = {
64
+ loading() {
65
+ l.value = "loading";
66
+ },
67
+ async loaded() {
68
+ l.value = "loaded", await G(t, u), fe(m.value, t.parentEl) && t.emit();
69
+ },
70
+ async complete() {
71
+ l.value = "complete", await G(t, u), i?.disconnect();
72
+ },
73
+ error() {
74
+ l.value = "error";
75
+ }
76
+ };
77
+ function v() {
78
+ i?.disconnect(), i = ve(t);
79
+ }
80
+ return N(P, v), Y(async () => {
81
+ t.parentEl = await ge(x), v();
82
+ }), oe(() => i?.disconnect()), (c, y) => (_(), d("div", {
83
+ ref_key: "infiniteLoading",
84
+ ref: m,
85
+ class: "v3-infinite-loading"
86
+ }, [
87
+ se(o("div", null, [
88
+ E(c.$slots, "spinner", {}, () => [
89
+ V(xe)
90
+ ], !0)
91
+ ], 512), [
92
+ [ue, l.value == "loading"]
93
+ ]),
94
+ l.value == "complete" ? E(c.$slots, "complete", { key: 0 }, () => {
95
+ var p;
96
+ return [
97
+ o("span", null, B(((p = c.slots) == null ? void 0 : p.complete) || "No more results!"), 1)
98
+ ];
99
+ }, !0) : M("", !0),
100
+ l.value == "error" ? E(c.$slots, "error", {
101
+ key: 1,
102
+ retry: t.emit
103
+ }, () => {
104
+ var p;
105
+ return [
106
+ o("span", Ie, [
107
+ o("span", null, B(((p = c.slots) == null ? void 0 : p.error) || "Oops something went wrong!"), 1),
108
+ o("button", {
109
+ class: "retry",
110
+ onClick: y[0] || (y[0] = //@ts-ignore
111
+ (...w) => t.emit && t.emit(...w))
112
+ }, "retry")
113
+ ])
114
+ ];
115
+ }, !0) : M("", !0)
116
+ ], 512));
117
+ }
118
+ }), J = /* @__PURE__ */ X(Pe, [["__scopeId", "data-v-4bdee133"]]), Ee = {
119
+ key: 0,
120
+ class: "d-flex align-items-center justify-content-between w-100"
121
+ }, Me = {
122
+ key: 0,
123
+ class: "d-flex align-items-center gap-2"
124
+ }, Ce = { class: "d-flex" }, Be = ["disabled"], De = ["disabled"], Le = { class: "d-flex gap-2" }, Te = ["onClick", "disabled"], ze = {
125
+ key: 1,
126
+ class: "m-0 p-0"
127
+ }, He = { class: "d-flex" }, Se = ["disabled"], Ae = ["disabled"], K = `
128
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none"
129
+ stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"
130
+ class="icon icon-tabler icons-tabler-outline icon-tabler-chevrons-left">
131
+ <path stroke="none" d="M0 0h24v24H0z" fill="none" />
132
+ <path d="M11 7l-5 5l5 5" />
133
+ <path d="M17 7l-5 5l5 5" />
134
+ </svg>
135
+ `, Q = `
136
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none"
137
+ stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"
138
+ class="icon icon-tabler icons-tabler-outline icon-tabler-chevron-left">
139
+ <path stroke="none" d="M0 0h24v24H0z" fill="none" />
140
+ <path d="M15 6l-6 6l6 6" />
141
+ </svg>
142
+ `, Ne = /* @__PURE__ */ R({
143
+ __name: "PaginationDatatable",
144
+ props: {
145
+ pagination: {},
146
+ filtering: { type: Boolean, default: !1 }
147
+ },
148
+ emits: ["tradePage"],
149
+ setup(a, { emit: s }) {
150
+ const e = a, i = s, u = T(() => e.pagination.limit_per_page ? Math.ceil(e.pagination.count / e.pagination.limit_per_page) : 0), m = T(() => e.pagination.current_page + 1 < u.value ? e.pagination.current_page + 1 : null), l = () => {
151
+ e.pagination.current_page++, i("tradePage");
152
+ }, r = (t) => {
153
+ e.pagination.current_page = t - 1, i("tradePage");
154
+ }, I = () => {
155
+ e.pagination.current_page = u.value - 1, i("tradePage");
156
+ }, C = () => {
157
+ e.pagination.current_page = 0, i("tradePage");
158
+ }, P = () => {
159
+ e.pagination.current_page > 0 && (e.pagination.current_page--, i("tradePage"));
160
+ }, x = T(() => {
161
+ if (u.value <= 7)
162
+ return Array.from({ length: u.value }, (p, w) => w + 1);
163
+ const t = e.pagination.current_page + 1, h = u.value, v = /* @__PURE__ */ new Set([
164
+ 1,
165
+ 2,
166
+ // Sempre mostra as 2 primeiras
167
+ t - 1,
168
+ t,
169
+ t + 1,
170
+ // Mostra a atual e vizinhas
171
+ h - 1,
172
+ h
173
+ // Sempre mostra as 2 últimas
174
+ ]), c = [];
175
+ let y = 0;
176
+ return Array.from(v).sort((p, w) => p - w).forEach((p) => {
177
+ p < 1 || p > h || (p > y + 1 && c.push("..."), c.push(p), y = p);
178
+ }), c;
179
+ });
180
+ return (t, h) => e.pagination.count > 0 ? (_(), d("div", Ee, [
181
+ o("span", null, " Mostrando de " + B(e.pagination.count !== 0 ? e.pagination.limit_per_page * e.pagination.current_page + 1 : 0) + " até " + B(e.pagination.limit_per_page * (e.pagination.current_page + 1) < e.pagination.count ? e.pagination.limit_per_page * (e.pagination.current_page + 1) : e.pagination.count) + " de " + B(e.pagination.count) + " registros ", 1),
182
+ u.value > 0 ? (_(), d("div", Me, [
183
+ o("div", Ce, [
184
+ o("button", {
185
+ class: "btn btn-estilo",
186
+ onClick: L(C, ["prevent"]),
187
+ disabled: e.pagination.current_page === 0,
188
+ innerHTML: K
189
+ }, null, 8, Be),
190
+ o("button", {
191
+ class: "btn btn-estilo",
192
+ onClick: L(P, ["prevent"]),
193
+ disabled: e.pagination.current_page === 0,
194
+ innerHTML: Q
195
+ }, null, 8, De)
196
+ ]),
197
+ o("div", Le, [
198
+ (_(!0), d(O, null, F(x.value, (v, c) => (_(), d(O, { key: c }, [
199
+ typeof v == "number" ? (_(), d("button", {
200
+ key: 0,
201
+ class: j([e.pagination.current_page + 1 == v ? "page-select" : "", "page-estilo"]),
202
+ onClick: L((y) => r(v), ["prevent"]),
203
+ disabled: e.pagination.current_page + 1 == v
204
+ }, B(v), 11, Te)) : (_(), d("span", ze, "..."))
205
+ ], 64))), 128))
206
+ ]),
207
+ o("div", He, [
208
+ o("button", {
209
+ onClick: L(l, ["prevent"]),
210
+ class: "btn btn-estilo rotate-180",
211
+ disabled: !m.value,
212
+ innerHTML: Q
213
+ }, null, 8, Se),
214
+ o("button", {
215
+ onClick: L(I, ["prevent"]),
216
+ class: "btn btn-estilo rotate-180",
217
+ disabled: !m.value,
218
+ innerHTML: K
219
+ }, null, 8, Ae)
220
+ ])
221
+ ])) : M("", !0)
222
+ ])) : M("", !0);
223
+ }
224
+ }), Ve = /* @__PURE__ */ $(Ne, [["__scopeId", "data-v-df81be49"]]), je = /* @__PURE__ */ R({
225
+ __name: "VDataPage",
226
+ props: {
227
+ fetch: {},
228
+ fetch_name: { default: "" },
229
+ endpoint: {},
230
+ type_loading: { default: "placeholder" },
231
+ type_fetch: { default: "pagination" },
232
+ custom_loading: { default: null },
233
+ deactivate_default_params: { type: Boolean, default: !1 },
234
+ filter_param_name: { default: "filter" },
235
+ search_param_name: { default: "search" },
236
+ page_param_name: { default: "page" },
237
+ page_size_param_name: { default: "page_size" },
238
+ add_params: { type: [Object, Function], default: () => ({}) },
239
+ data_key: { default: "results" },
240
+ total_key: { default: "count" },
241
+ list_filter: { default: () => [] },
242
+ first_text_page_size: { default: "Mostrar" },
243
+ second_text_page_size: { default: "registros" },
244
+ class_container: { default: "" },
245
+ class_pagination: { default: "" },
246
+ class_filters: { default: "" },
247
+ min_loading_delay: { default: 600 },
248
+ retry_attempts: { default: 3 },
249
+ retry_delay: { default: 2e3 },
250
+ use_checkbox: { type: Boolean, default: !1 },
251
+ item_key: { default: "id" },
252
+ limit_per_page: { default: 5 },
253
+ next_page_response_name: { default: "next_page" },
254
+ page_starts_at: { default: 0 },
255
+ element_id: { default: "" },
256
+ watch: { default: () => [] }
257
+ },
258
+ setup(a, { expose: s }) {
259
+ const e = a, i = g(!0), u = g(Date.now()), m = g(Date.now()), l = g([]), r = g([]), I = g(0), C = g(!1), P = g(null), x = g(!1), t = g({
260
+ current_page: e.page_starts_at,
261
+ // pagina atual
262
+ count: 0,
263
+ // total de itens
264
+ limit_per_page: e.limit_per_page,
265
+ // limite de itens por página
266
+ search: "",
267
+ // termo de busca
268
+ filter: ""
269
+ // filtro selecionado
270
+ }), { data: h, pending: v, error: c, execute: y, attempt: p } = e.fetch(e.endpoint, {
271
+ params: () => e.deactivate_default_params ? e.add_params && typeof e.add_params == "function" ? e.add_params() : {
272
+ ...e.add_params
273
+ } : e.add_params && typeof e.add_params == "function" ? {
274
+ ...w.value,
275
+ ...e.add_params()
276
+ } : {
277
+ ...w.value,
278
+ ...e.add_params
279
+ },
280
+ retry: e.retry_attempts,
281
+ retryDelay: e.retry_delay,
282
+ paramsReactives: !1,
283
+ immediate: !1
284
+ }, e.fetch_name), w = T(() => ({
285
+ [e.page_param_name]: t.value.current_page + 1,
286
+ [e.page_size_param_name]: t.value.limit_per_page,
287
+ [e.search_param_name]: t.value.search || "",
288
+ [e.filter_param_name]: t.value.filter || ""
289
+ }));
290
+ N(h, (n) => {
291
+ n ? (l.value = n[e.data_key] || [], I.value = n[e.total_key] || 0, t.value.count = I.value) : (l.value = [], I.value = 0);
292
+ }, { immediate: !0 });
293
+ async function b() {
294
+ return P.value && clearTimeout(P.value), C.value = !0, P.value = setTimeout(() => {
295
+ C.value = !1;
296
+ }, e.min_loading_delay), y();
297
+ }
298
+ async function W() {
299
+ l.value = [], r.value = [], t.value.current_page = e.page_starts_at, await b(), D(() => {
300
+ r.value.push(...l.value), x.value = !0, u.value++, m.value++;
301
+ });
302
+ }
303
+ function Z(n) {
304
+ n > 0 ? (t.value.limit_per_page = n, t.value.current_page = 0, b()) : console.warn("O limite deve ser um número maior que zero.");
305
+ }
306
+ function ee(n) {
307
+ t.value.search = n, t.value.current_page = 0, b();
308
+ }
309
+ function te(n) {
310
+ t.value.filter = n, t.value.current_page = 0, b();
311
+ }
312
+ function ae(n) {
313
+ n >= 1 && n <= Math.ceil(t.value.count / t.value.limit_per_page) ? (t.value.current_page = n - 1, b()) : console.warn("Número de página inválido.");
314
+ }
315
+ s({
316
+ execute: b,
317
+ pagination: de(t),
318
+ set_limit_per_page: Z,
319
+ set_search: ee,
320
+ set_filter: te,
321
+ set_page: ae,
322
+ default_params: w
323
+ }), Y(() => {
324
+ D(() => {
325
+ i.value && e.type_fetch === "infinite-scroll" ? (W(), i.value = !1) : i.value && e.type_fetch === "pagination" && (b(), i.value = !1);
326
+ });
327
+ });
328
+ const U = T(() => h.value?.[e.next_page_response_name] || null);
329
+ async function ne(n) {
330
+ if (!x.value) return;
331
+ if (!U.value) {
332
+ n.complete();
333
+ return;
334
+ }
335
+ if (t.value.current_page += 1, await y(), c.value) {
336
+ n.error();
337
+ return;
338
+ }
339
+ if (!l.value || l.value.length === 0) {
340
+ n.complete();
341
+ return;
342
+ }
343
+ const f = l.value.filter(
344
+ (k) => !r.value.some((H) => H[e.item_key] === k[e.item_key])
345
+ );
346
+ if (f.length === 0 && l.value.length > 0) {
347
+ n.loaded();
348
+ return;
349
+ }
350
+ r.value.push(...f), D(() => {
351
+ r.value && r.value.length > t.value.limit_per_page * 2 && r.value.splice(0, t.value.limit_per_page), U.value ? n.loaded() : n.complete(), m.value++;
352
+ });
353
+ }
354
+ async function ie(n) {
355
+ if (!x.value) return;
356
+ if (t.value.current_page <= e.page_starts_at) {
357
+ n.complete();
358
+ return;
359
+ }
360
+ const f = r.value[0];
361
+ if (!f) return;
362
+ const k = f[e.item_key];
363
+ if (!k) {
364
+ n.error();
365
+ return;
366
+ }
367
+ if (t.value.current_page -= 1, await y(), c.value) {
368
+ n.error();
369
+ return;
370
+ }
371
+ if (!l.value || l.value.length === 0) {
372
+ n.loaded();
373
+ return;
374
+ }
375
+ const H = l.value.filter(
376
+ (S) => !r.value.some((le) => le[e.item_key] === S[e.item_key])
377
+ );
378
+ if (H.length === 0 && l.value.length > 0) {
379
+ n.loaded();
380
+ return;
381
+ }
382
+ r.value.unshift(...H), r.value && r.value.length > t.value.limit_per_page * 2 && r.value.splice(-t.value.limit_per_page, t.value.limit_per_page), D(() => {
383
+ const S = document.getElementById(e.element_id + k);
384
+ S ? S.scrollIntoView({ behavior: "auto", block: "start" }) : console.warn(`
385
+ Elemento não encontrado para scroll verifique se a propriedade 'element_id' está correta ou não foi definida.
386
+ `), u.value++, n.loaded();
387
+ });
388
+ }
389
+ const z = [];
390
+ return e.watch && Array.isArray(e.watch) && e.watch.forEach((n) => {
391
+ (_e(n) || typeof n == "function") && z.push(n);
392
+ }), z.length > 0 && (e.type_fetch === "pagination" ? N(z, () => {
393
+ t.value.current_page = e.page_starts_at, b();
394
+ }, { deep: !0 }) : e.type_fetch === "infinite-scroll" && N(z, () => {
395
+ x.value = !1, W();
396
+ }, { deep: !0 })), (n, f) => (_(), d("div", null, [
397
+ a.type_fetch === "pagination" ? (_(), d("div", {
398
+ key: 0,
399
+ class: j(["", e.class_container])
400
+ }, [
401
+ (_(!0), d(O, null, F(l.value, (k) => E(n.$slots, "body", {
402
+ key: k[e.item_key],
403
+ item: k
404
+ }, void 0, !0)), 128))
405
+ ], 2)) : a.type_fetch === "infinite-scroll" ? (_(), d("div", {
406
+ key: 1,
407
+ class: j(e.class_container)
408
+ }, [
409
+ V(A(J), {
410
+ identifier: m.value,
411
+ direction: "top",
412
+ onInfinite: ie
413
+ }, {
414
+ complete: q(() => [...f[0] || (f[0] = [
415
+ o("span", null, null, -1)
416
+ ])]),
417
+ spinner: q(() => [...f[1] || (f[1] = [
418
+ o("span", null, null, -1)
419
+ ])]),
420
+ _: 1
421
+ }, 8, ["identifier"]),
422
+ (_(!0), d(O, null, F(r.value, (k) => E(n.$slots, "body", {
423
+ key: k[e.item_key],
424
+ item: k
425
+ }, void 0, !0)), 128)),
426
+ V(A(J), {
427
+ identifier: u.value,
428
+ onInfinite: ne
429
+ }, {
430
+ complete: q(() => [
431
+ E(n.$slots, "scroll-finish", {}, () => [
432
+ f[2] || (f[2] = o("span", { class: "scroll-finish-style" }, " Fim dos registros", -1))
433
+ ], !0)
434
+ ]),
435
+ _: 3
436
+ }, 8, ["identifier"])
437
+ ], 2)) : M("", !0),
438
+ a.type_fetch === "pagination" ? E(n.$slots, "pagination", {
439
+ key: 2,
440
+ pagination: t.value,
441
+ tradePage: b,
442
+ error: A(c)
443
+ }, () => [
444
+ !A(c) && t.value.count > 0 ? (_(), d("div", {
445
+ key: 0,
446
+ class: j(["px-3", e.class_pagination])
447
+ }, [
448
+ V(Ve, {
449
+ filtering: !0,
450
+ pagination: t.value,
451
+ onTradePage: b
452
+ }, null, 8, ["pagination"])
453
+ ], 2)) : M("", !0)
454
+ ], !0) : M("", !0)
455
+ ]));
456
+ }
457
+ }), Fe = /* @__PURE__ */ $(je, [["__scopeId", "data-v-e6e86eba"]]);
458
+ export {
459
+ Fe as VDataPage
460
+ };