prometeo-design-system 3.0.9 → 3.1.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.
- package/dist/RecurrentDatePicker.es.js +1 -1
- package/dist/{Select-DYuTa7Cm.js → Select-mdLPyy7g.js} +60 -59
- package/dist/Select.es.js +1 -1
- package/dist/SelectSearch.es.js +168 -161
- package/dist/components/Autocomplete/Autocomplete.d.ts +1 -1
- package/dist/components/Autocomplete/useAutocomplete.d.ts +6 -6
- package/dist/components/SelectSearch/SelectSearch.d.ts +5 -5
- package/dist/prometeo-design-system.es.js +1 -1
- package/package.json +1 -1
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { j as r } from "./jsx-runtime-DKDX3adD.js";
|
|
2
2
|
import O, { useMemo as D, memo as b, useRef as M, useCallback as g, useState as L, useEffect as W } from "react";
|
|
3
3
|
import { D as I } from "./DatePicker-D1EwMGIN.js";
|
|
4
|
-
import { S as f } from "./Select-
|
|
4
|
+
import { S as f } from "./Select-mdLPyy7g.js";
|
|
5
5
|
import { I as R } from "./Input-EkMrxcNX.js";
|
|
6
6
|
import _ from "./CheckBox.es.js";
|
|
7
7
|
import { c as p } from "./cn-B6yFEsav.js";
|
|
@@ -28,13 +28,13 @@ const at = {
|
|
|
28
28
|
}, Fe = {
|
|
29
29
|
icon: " text-neutral-default-disabled",
|
|
30
30
|
container: " border-neutral-strong-default text-neutral-default-disabled"
|
|
31
|
-
}, Ve = ({ id: e, label: n, onRemove: m, className: i, disabled: u, variant:
|
|
31
|
+
}, Ve = ({ id: e, label: n, onRemove: m, className: i, disabled: u, variant: y = "default", tabIndex: p }) => /* @__PURE__ */ s.jsxs(
|
|
32
32
|
"div",
|
|
33
33
|
{
|
|
34
34
|
tabIndex: p,
|
|
35
35
|
className: f(
|
|
36
36
|
"inline-flex max-w-[calc(50%-0.25rem)] items-center gap-1 px-2 py-1 bg-inherit text-xs rounded-lg border h-[30px]",
|
|
37
|
-
at[
|
|
37
|
+
at[y].container,
|
|
38
38
|
u && Fe.container
|
|
39
39
|
),
|
|
40
40
|
children: [
|
|
@@ -76,11 +76,11 @@ const qe = (e, n) => {
|
|
|
76
76
|
if (!n) return !0;
|
|
77
77
|
const m = 0.1, i = String(e).toLowerCase(), u = String(n).toLowerCase().trim();
|
|
78
78
|
if (i.includes(u)) return !0;
|
|
79
|
-
const
|
|
80
|
-
if (
|
|
79
|
+
const y = u.split(/\s+/).filter(Boolean), p = y.filter((b) => /^\d+$/.test(b));
|
|
80
|
+
if (y.length > 1 || p.length > 0) {
|
|
81
81
|
for (const b of p)
|
|
82
82
|
if (!new RegExp(`(^|\\D)${b}(\\D|$)`).test(i)) return !1;
|
|
83
|
-
for (const b of
|
|
83
|
+
for (const b of y)
|
|
84
84
|
if (!/^\d+$/.test(b) && !i.includes(b))
|
|
85
85
|
return !1;
|
|
86
86
|
return !0;
|
|
@@ -93,12 +93,12 @@ const qe = (e, n) => {
|
|
|
93
93
|
if (I === 0) return W;
|
|
94
94
|
if (W === 0) return I;
|
|
95
95
|
const A = new Array(W + 1);
|
|
96
|
-
for (let
|
|
97
|
-
for (let
|
|
98
|
-
let S =
|
|
99
|
-
A[0] =
|
|
96
|
+
for (let v = 0; v <= W; v++) A[v] = v;
|
|
97
|
+
for (let v = 1; v <= I; v++) {
|
|
98
|
+
let S = v - 1;
|
|
99
|
+
A[0] = v;
|
|
100
100
|
for (let z = 1; z <= W; z++) {
|
|
101
|
-
const se = A[z], K = b.charCodeAt(
|
|
101
|
+
const se = A[z], K = b.charCodeAt(v - 1) === k.charCodeAt(z - 1) ? 0 : 1, V = A[z] + 1, M = A[z - 1] + 1, N = S + K;
|
|
102
102
|
A[z] = V < M ? V < N ? V : N : M < N ? M : N, S = se;
|
|
103
103
|
}
|
|
104
104
|
}
|
|
@@ -112,7 +112,7 @@ const qe = (e, n) => {
|
|
|
112
112
|
}, ut = (e) => {
|
|
113
113
|
const n = [], m = (i) => {
|
|
114
114
|
i.forEach((u) => {
|
|
115
|
-
const
|
|
115
|
+
const y = u, p = typeof y == "object" ? y?.options : [];
|
|
116
116
|
Array.isArray(p) && p.length > 0 ? m(p) : n.push(u);
|
|
117
117
|
});
|
|
118
118
|
};
|
|
@@ -170,11 +170,11 @@ const qe = (e, n) => {
|
|
|
170
170
|
)
|
|
171
171
|
};
|
|
172
172
|
function ct(e) {
|
|
173
|
-
const [n, m] = je(!1), [i, u] = je([]), [
|
|
173
|
+
const [n, m] = je(!1), [i, u] = je([]), [y, p] = je(""), D = ce(null), g = ce(null), b = ce(null), k = ce(null), I = ce(
|
|
174
174
|
() => {
|
|
175
175
|
}
|
|
176
176
|
), W = ce(null), A = ce(/* @__PURE__ */ new Set()), {
|
|
177
|
-
id:
|
|
177
|
+
id: v,
|
|
178
178
|
name: S,
|
|
179
179
|
label: z,
|
|
180
180
|
height: se,
|
|
@@ -211,8 +211,8 @@ function ct(e) {
|
|
|
211
211
|
axis: "x",
|
|
212
212
|
cursor: { idle: "default", dragging: "grabbing" }
|
|
213
213
|
}), pe = e.multiple ? Array.isArray(e.value) && e.value.length > 0 && e.value.every((t) => t != null && t !== "") : e.value !== void 0 && e.value !== null && e.value !== "", Le = {}, Te = oe(() => ie === "static" && N ? N : "", [ie, N]), Ge = oe(
|
|
214
|
-
() => O?.controledSearchValue ||
|
|
215
|
-
[O?.controledSearchValue,
|
|
214
|
+
() => O?.controledSearchValue || y,
|
|
215
|
+
[O?.controledSearchValue, y]
|
|
216
216
|
), $e = () => {
|
|
217
217
|
const t = {
|
|
218
218
|
static: {
|
|
@@ -341,7 +341,7 @@ function ct(e) {
|
|
|
341
341
|
e.onChange?.(H, S);
|
|
342
342
|
}
|
|
343
343
|
};
|
|
344
|
-
const
|
|
344
|
+
const x = U(
|
|
345
345
|
(t, a = !1) => {
|
|
346
346
|
X?.(t, S), I.current?.(t), a && (m(!1), Se?.());
|
|
347
347
|
},
|
|
@@ -408,13 +408,13 @@ function ct(e) {
|
|
|
408
408
|
n && m(!1);
|
|
409
409
|
},
|
|
410
410
|
toggle: () => m((t) => !t),
|
|
411
|
-
handleOptionSelect:
|
|
411
|
+
handleOptionSelect: x,
|
|
412
412
|
subscribeOpenChange: (t) => (A.current.add(t), () => {
|
|
413
413
|
A.current.delete(t);
|
|
414
414
|
}),
|
|
415
415
|
searchInputRef: b
|
|
416
416
|
}),
|
|
417
|
-
[n,
|
|
417
|
+
[n, x]
|
|
418
418
|
);
|
|
419
419
|
const be = (t) => {
|
|
420
420
|
t.preventDefault(), t.stopPropagation(), t.target.matches(":focus-visible") && !ze && !n && (m(!0), setTimeout(() => {
|
|
@@ -437,7 +437,7 @@ function ct(e) {
|
|
|
437
437
|
/* @__PURE__ */ s.jsx(
|
|
438
438
|
"label",
|
|
439
439
|
{
|
|
440
|
-
htmlFor:
|
|
440
|
+
htmlFor: v,
|
|
441
441
|
ref: Oe,
|
|
442
442
|
className: f(
|
|
443
443
|
"left-3 pointer-events-none bg-inherit z-10",
|
|
@@ -452,7 +452,7 @@ function ct(e) {
|
|
|
452
452
|
/* @__PURE__ */ s.jsxs(
|
|
453
453
|
"div",
|
|
454
454
|
{
|
|
455
|
-
id:
|
|
455
|
+
id: v,
|
|
456
456
|
tabIndex: 0,
|
|
457
457
|
role: "button",
|
|
458
458
|
ref: k,
|
|
@@ -581,7 +581,7 @@ function ct(e) {
|
|
|
581
581
|
dropdownRef: g,
|
|
582
582
|
selectButtonRef: k,
|
|
583
583
|
helperComponentRef: W,
|
|
584
|
-
onOptionClick:
|
|
584
|
+
onOptionClick: x,
|
|
585
585
|
onCloseDropdown: () => m(!1),
|
|
586
586
|
searchValue: Ge,
|
|
587
587
|
setSearchValue: p,
|
|
@@ -619,7 +619,7 @@ function ft({
|
|
|
619
619
|
label: m,
|
|
620
620
|
options: i,
|
|
621
621
|
multiple: u,
|
|
622
|
-
disabled:
|
|
622
|
+
disabled: y,
|
|
623
623
|
selectRef: p,
|
|
624
624
|
inputProps: D,
|
|
625
625
|
dropdownRef: g,
|
|
@@ -628,7 +628,7 @@ function ft({
|
|
|
628
628
|
searchValue: I,
|
|
629
629
|
labelVariant: W,
|
|
630
630
|
emptyMessage: A,
|
|
631
|
-
renderOption:
|
|
631
|
+
renderOption: v,
|
|
632
632
|
renderOptionContext: S,
|
|
633
633
|
renderOptionGroupHeader: z,
|
|
634
634
|
onOptionClick: se,
|
|
@@ -685,8 +685,8 @@ function ft({
|
|
|
685
685
|
}, Me = () => {
|
|
686
686
|
if (!g.current || !p.current) return he;
|
|
687
687
|
const r = p.current.getBoundingClientRect(), o = window.innerHeight - (window.innerHeight - r.top), c = window.innerHeight - r.bottom, d = c >= F, w = o >= F;
|
|
688
|
-
let L = "down",
|
|
689
|
-
return d ? (L = "down",
|
|
688
|
+
let L = "down", x;
|
|
689
|
+
return d ? (L = "down", x = F) : w ? (L = "up", x = F) : c > o ? (L = "down", x = c - 16) : (L = "up", x = o - 16), { direction: L, height: x };
|
|
690
690
|
}, pe = (r) => {
|
|
691
691
|
if (!(!g.current || !p.current)) {
|
|
692
692
|
if (g.current.style.transition = "max-height 0.2s ease,opacity 0.2s ease", !r) {
|
|
@@ -713,15 +713,15 @@ function ft({
|
|
|
713
713
|
}, [i]);
|
|
714
714
|
const Le = (r, o) => {
|
|
715
715
|
if (!o) return r;
|
|
716
|
-
if (
|
|
717
|
-
const
|
|
716
|
+
if (v) {
|
|
717
|
+
const x = [];
|
|
718
718
|
let R = null, q = [];
|
|
719
719
|
const re = () => {
|
|
720
|
-
R && q.length > 0 &&
|
|
720
|
+
R && q.length > 0 && x.push(R, ...q), R = null, q = [];
|
|
721
721
|
};
|
|
722
722
|
return r.forEach((be) => {
|
|
723
723
|
const ue = be;
|
|
724
|
-
if (!!ue
|
|
724
|
+
if (!!(ue || {})?.isGroupHeader) {
|
|
725
725
|
re(), R = ue;
|
|
726
726
|
return;
|
|
727
727
|
}
|
|
@@ -729,21 +729,22 @@ function ft({
|
|
|
729
729
|
a,
|
|
730
730
|
b
|
|
731
731
|
), h = qe(String(l ?? ""), o);
|
|
732
|
-
R ? h && q.push(a) : h &&
|
|
733
|
-
}), re(),
|
|
732
|
+
R ? h && q.push(a) : h && x.push(a);
|
|
733
|
+
}), re(), x;
|
|
734
734
|
}
|
|
735
735
|
const c = [];
|
|
736
736
|
let d = null, w = [];
|
|
737
737
|
const L = () => {
|
|
738
738
|
d && w.length > 0 && c.push(d, ...w), d = null, w = [];
|
|
739
739
|
};
|
|
740
|
-
return r.forEach((
|
|
741
|
-
if (
|
|
742
|
-
|
|
740
|
+
return r.forEach((x) => {
|
|
741
|
+
if (typeof x != "object" || x === null) return;
|
|
742
|
+
if ((x || {})?.isGroupHeader) {
|
|
743
|
+
L(), d = x;
|
|
743
744
|
return;
|
|
744
745
|
}
|
|
745
|
-
const R = qe(
|
|
746
|
-
d ? R && w.push(
|
|
746
|
+
const R = qe(x.label, o);
|
|
747
|
+
d ? R && w.push(x) : R && c.push(x);
|
|
747
748
|
}), L(), c;
|
|
748
749
|
}, Te = (r) => {
|
|
749
750
|
const o = Le(i, r);
|
|
@@ -760,7 +761,7 @@ function ft({
|
|
|
760
761
|
if (K) {
|
|
761
762
|
K(), Q(
|
|
762
763
|
i.filter((r) => {
|
|
763
|
-
const o =
|
|
764
|
+
const o = v ? G(r, k) : r.id;
|
|
764
765
|
return ae.has(o);
|
|
765
766
|
})
|
|
766
767
|
);
|
|
@@ -774,7 +775,7 @@ function ft({
|
|
|
774
775
|
K,
|
|
775
776
|
Q,
|
|
776
777
|
M,
|
|
777
|
-
|
|
778
|
+
v
|
|
778
779
|
]), $e = (r) => {
|
|
779
780
|
r.key === "ArrowDown" ? (r.preventDefault(), g.current?.querySelector(
|
|
780
781
|
"[role=listitem]"
|
|
@@ -797,7 +798,7 @@ function ft({
|
|
|
797
798
|
c[w]?.focus();
|
|
798
799
|
}
|
|
799
800
|
else if (r.key === "Enter" || r.key === " ") {
|
|
800
|
-
if (r.preventDefault(), o
|
|
801
|
+
if (r.preventDefault(), (o || {})?.isGroupHeader || y) return;
|
|
801
802
|
se(o, !u), u || setTimeout(() => {
|
|
802
803
|
J.current?.focus(), fe();
|
|
803
804
|
}, 10);
|
|
@@ -807,8 +808,8 @@ function ft({
|
|
|
807
808
|
J.current?.focus(), fe();
|
|
808
809
|
}, 10);
|
|
809
810
|
}, Y = Array.from({ length: 5 }).map(
|
|
810
|
-
(r, o) =>
|
|
811
|
-
Z(
|
|
811
|
+
(r, o) => v ? Ne.createElement(
|
|
812
|
+
Z(v, (c, d) => c.isSelected === d.isSelected && c.option === d.option && c.disabled === d.disabled && c.multiple === d.multiple && c.renderContext === d.renderContext),
|
|
812
813
|
{
|
|
813
814
|
key: `skeleton-option-${o}`,
|
|
814
815
|
option: { id: o, label: "", value: "" },
|
|
@@ -866,7 +867,7 @@ function ft({
|
|
|
866
867
|
size: "small",
|
|
867
868
|
tabIndex: 0,
|
|
868
869
|
value: I,
|
|
869
|
-
disabled:
|
|
870
|
+
disabled: y,
|
|
870
871
|
ref: V,
|
|
871
872
|
labelVariant: "static",
|
|
872
873
|
icon: /* @__PURE__ */ s.jsx(st, { size: 22 }),
|
|
@@ -882,13 +883,13 @@ function ft({
|
|
|
882
883
|
/* @__PURE__ */ s.jsx("div", { className: " overflow-y-auto flex-1 max-h-max ", children: de.length === 0 ? ee ? /* @__PURE__ */ s.jsx("div", { className: "flex flex-col gap-1 overflow-hidden w-full", children: De || Y }) : /* @__PURE__ */ s.jsx("div", { className: "px-3 py-2 text-neutral-medium-default", children: I ? `No se encontraron resultados para "${I}"` : A }) : (() => {
|
|
883
884
|
let r = !0;
|
|
884
885
|
return de.map((o) => {
|
|
885
|
-
const c = o, d = !!c.isGroupHeader, w =
|
|
886
|
+
const c = o, d = !!(c || {}).isGroupHeader, w = v && !d ? G(o, k) : c.id, L = ae.has(w), x = (l) => !v || d ? l : {
|
|
886
887
|
id: w,
|
|
887
888
|
label: String(G(l, b)),
|
|
888
889
|
value: G(l, k)
|
|
889
890
|
}, R = (l) => {
|
|
890
891
|
d || se(
|
|
891
|
-
|
|
892
|
+
x(o),
|
|
892
893
|
l === void 0 ? !u : l
|
|
893
894
|
);
|
|
894
895
|
}, q = (l) => {
|
|
@@ -897,7 +898,7 @@ function ft({
|
|
|
897
898
|
M(""), Q(i);
|
|
898
899
|
}
|
|
899
900
|
}, re = (l, h) => {
|
|
900
|
-
const H = !!h.isGroupHeader;
|
|
901
|
+
const H = !!(h || {}).isGroupHeader;
|
|
901
902
|
return (
|
|
902
903
|
// biome-ignore lint/a11y/useSemanticElements: <>
|
|
903
904
|
/* @__PURE__ */ s.jsx(
|
|
@@ -907,9 +908,9 @@ function ft({
|
|
|
907
908
|
role: "listitem",
|
|
908
909
|
onKeyDown: ($) => T($, h),
|
|
909
910
|
className: f(
|
|
910
|
-
!H && !
|
|
911
|
+
!H && !y && "focus-visible:bg-neutral-medium-hover outline-none hover:bg-neutral-medium-hover",
|
|
911
912
|
L && "bg-neutral-medium-selected",
|
|
912
|
-
|
|
913
|
+
y && "cursor-default pointer-events-none"
|
|
913
914
|
),
|
|
914
915
|
children: l
|
|
915
916
|
},
|
|
@@ -936,7 +937,7 @@ function ft({
|
|
|
936
937
|
label: l,
|
|
937
938
|
groupOptions: P,
|
|
938
939
|
multiple: u,
|
|
939
|
-
disabled:
|
|
940
|
+
disabled: y,
|
|
940
941
|
expanded: H,
|
|
941
942
|
toggleGroup: le,
|
|
942
943
|
selectGroup: xe,
|
|
@@ -968,9 +969,9 @@ function ft({
|
|
|
968
969
|
c
|
|
969
970
|
);
|
|
970
971
|
}
|
|
971
|
-
const be =
|
|
972
|
+
const be = v ? Ne.createElement(
|
|
972
973
|
Z(
|
|
973
|
-
|
|
974
|
+
v,
|
|
974
975
|
(l, h) => l.isSelected === h.isSelected && l.option === h.option && l.disabled === h.disabled && l.multiple === h.multiple && l.renderContext === h.renderContext
|
|
975
976
|
),
|
|
976
977
|
{
|
|
@@ -979,14 +980,14 @@ function ft({
|
|
|
979
980
|
isSelected: L,
|
|
980
981
|
multiple: u,
|
|
981
982
|
onSelect: R,
|
|
982
|
-
disabled:
|
|
983
|
+
disabled: y,
|
|
983
984
|
isLoading: ee,
|
|
984
985
|
renderContext: S
|
|
985
986
|
}
|
|
986
987
|
) : /* @__PURE__ */ s.jsx(
|
|
987
988
|
Be,
|
|
988
989
|
{
|
|
989
|
-
disabled:
|
|
990
|
+
disabled: y,
|
|
990
991
|
multiple: u,
|
|
991
992
|
isLoading: ee,
|
|
992
993
|
isSelected: L,
|
|
@@ -996,7 +997,7 @@ function ft({
|
|
|
996
997
|
w
|
|
997
998
|
), ue = re(
|
|
998
999
|
be,
|
|
999
|
-
|
|
1000
|
+
x(o)
|
|
1000
1001
|
);
|
|
1001
1002
|
if (!X)
|
|
1002
1003
|
return ue;
|
|
@@ -1010,7 +1011,7 @@ function ft({
|
|
|
1010
1011
|
});
|
|
1011
1012
|
});
|
|
1012
1013
|
})() }),
|
|
1013
|
-
e &&
|
|
1014
|
+
e && e
|
|
1014
1015
|
]
|
|
1015
1016
|
}
|
|
1016
1017
|
)
|
|
@@ -1028,10 +1029,10 @@ const mt = Z(
|
|
|
1028
1029
|
onSelect: m,
|
|
1029
1030
|
multiple: i,
|
|
1030
1031
|
disabled: u,
|
|
1031
|
-
isLoading:
|
|
1032
|
+
isLoading: y
|
|
1032
1033
|
}) => {
|
|
1033
|
-
const p = e
|
|
1034
|
-
if (
|
|
1034
|
+
const p = (e || {})?.isGroupHeader;
|
|
1035
|
+
if (y)
|
|
1035
1036
|
return /* @__PURE__ */ s.jsxs(
|
|
1036
1037
|
"div",
|
|
1037
1038
|
{
|
|
@@ -1077,9 +1078,9 @@ const Je = Z(
|
|
|
1077
1078
|
onRemoveOption: m,
|
|
1078
1079
|
displayMode: i,
|
|
1079
1080
|
multiple: u,
|
|
1080
|
-
className:
|
|
1081
|
+
className: y,
|
|
1081
1082
|
disabled: p
|
|
1082
|
-
}) => e?.length === 0 ? n ? /* @__PURE__ */ s.jsx("span", { className: "text-neutral-medium-default opacity-50", children: n }) : null : i === "chips" && u ? /* @__PURE__ */ s.jsx("div", { className: f("flex items-center gap-1 ",
|
|
1083
|
+
}) => e?.length === 0 ? n ? /* @__PURE__ */ s.jsx("span", { className: "text-neutral-medium-default opacity-50", children: n }) : null : i === "chips" && u ? /* @__PURE__ */ s.jsx("div", { className: f("flex items-center gap-1 ", y), children: e.map((D) => /* @__PURE__ */ s.jsx(
|
|
1083
1084
|
it,
|
|
1084
1085
|
{
|
|
1085
1086
|
tabIndex: -1,
|
package/dist/Select.es.js
CHANGED
package/dist/SelectSearch.es.js
CHANGED
|
@@ -1,247 +1,254 @@
|
|
|
1
|
-
import { j as
|
|
2
|
-
import { g as
|
|
3
|
-
import { useState as
|
|
4
|
-
function
|
|
1
|
+
import { j as X } from "./jsx-runtime-DKDX3adD.js";
|
|
2
|
+
import { g as i, S as Y } from "./Select-mdLPyy7g.js";
|
|
3
|
+
import { useState as w, useRef as T, useEffect as m, useMemo as Z, useCallback as ee } from "react";
|
|
4
|
+
function re(e) {
|
|
5
5
|
const {
|
|
6
6
|
options: y,
|
|
7
|
-
fetcher:
|
|
8
|
-
asyncMode:
|
|
9
|
-
disabled:
|
|
10
|
-
debounceDelay:
|
|
11
|
-
minCharacters:
|
|
12
|
-
optionLabel:
|
|
13
|
-
optionValue:
|
|
14
|
-
controlledValue:
|
|
15
|
-
isOpen:
|
|
16
|
-
inputRef:
|
|
17
|
-
name:
|
|
18
|
-
} = e || {}, [
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
}, [
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
7
|
+
fetcher: a,
|
|
8
|
+
asyncMode: p = "fetch_in_open",
|
|
9
|
+
disabled: O = !1,
|
|
10
|
+
debounceDelay: I = 500,
|
|
11
|
+
minCharacters: C = 3,
|
|
12
|
+
optionLabel: f,
|
|
13
|
+
optionValue: s,
|
|
14
|
+
controlledValue: b,
|
|
15
|
+
isOpen: F,
|
|
16
|
+
inputRef: k,
|
|
17
|
+
name: v
|
|
18
|
+
} = e || {}, j = y ? y.filter((t) => t != null) : [], [V, R] = w(j || []), [M, x] = w(j || []), [c, A] = w(""), [l, d] = w(!1), [g, P] = w(!1), E = T(null), N = T(null), z = T(!1), J = T(a), U = e?.multiple === !0 || !1, L = T(U ? [] : void 0), [h, D] = w(U ? [] : void 0);
|
|
19
|
+
m(() => {
|
|
20
|
+
J.current = a;
|
|
21
|
+
}, [a]), m(() => {
|
|
22
|
+
if (b !== void 0) {
|
|
23
|
+
const t = $(b, "value");
|
|
24
|
+
D(t);
|
|
25
|
+
}
|
|
26
|
+
}, [b]), m(() => {
|
|
27
|
+
L.current = b !== void 0 ? b : h;
|
|
28
|
+
}, [b, h]), m(() => {
|
|
29
|
+
if (e?.options) {
|
|
30
|
+
const t = e.options.filter((n) => n != null);
|
|
31
|
+
R(t), x(t);
|
|
32
|
+
}
|
|
27
33
|
}, [e?.options]);
|
|
28
|
-
const
|
|
29
|
-
|
|
30
|
-
}), [
|
|
31
|
-
const n =
|
|
34
|
+
const B = Z(() => (t, n) => new Promise((o, r) => {
|
|
35
|
+
E.current && clearTimeout(E.current), E.current = setTimeout(() => t(c).then(o).catch(r), n);
|
|
36
|
+
}), [c]), te = (t) => {
|
|
37
|
+
const n = b !== void 0, o = (r) => s ? i(r, s) : i(r, "id");
|
|
32
38
|
if (e?.multiple === !0) {
|
|
33
|
-
const
|
|
34
|
-
let
|
|
35
|
-
|
|
39
|
+
const r = L.current || [];
|
|
40
|
+
let u;
|
|
41
|
+
r.some((_) => o(_) === o(t)) ? u = r.filter((_) => o(_) !== o(t)) : u = [...r, t], n ? (L.current = u, e?.onChange?.(u, v)) : (L.current = u, D(u), e?.onChange?.(u, v));
|
|
36
42
|
} else
|
|
37
|
-
n ? (
|
|
38
|
-
},
|
|
39
|
-
|
|
43
|
+
n ? (L.current = t, e?.onChange?.(t, v)) : (L.current = t, D(t), e?.onChange?.(t, v));
|
|
44
|
+
}, q = (t) => (e?.onFetchingStart?.(), J.current?.(t) || Promise.resolve([])), $ = (t, n) => Array.isArray(t) ? (t.some((o) => typeof o != "object" || o === null) && console.debug(`El valor del ${n || "resultado del fetcher"} contiene elementos no válidos (null,undefined, no-object)`, t), t?.filter((o) => o != null) || []) : (console.debug(`El valor del ${n || "resultado del fetcher"} no es un Array (tipo de dato obtenido: ${typeof t})`), []), K = ee((t, n) => t.length === 0 ? n : s ? n.filter((o) => !t.some((r) => i(r, s) === i(o, s))) : n.filter((o) => !t.some((r) => i(r, "id") === i(o, "id"))), [s]);
|
|
45
|
+
m(() => {
|
|
40
46
|
const t = e?.subscribeOpenChange;
|
|
41
47
|
if (!t) return;
|
|
42
|
-
const n = t((
|
|
43
|
-
|
|
48
|
+
const n = t((o) => {
|
|
49
|
+
P(o);
|
|
44
50
|
});
|
|
45
51
|
return () => {
|
|
46
52
|
n && n();
|
|
47
53
|
};
|
|
48
54
|
}, [e?.subscribeOpenChange]);
|
|
49
|
-
const
|
|
50
|
-
|
|
51
|
-
if (!
|
|
52
|
-
if (!
|
|
53
|
-
|
|
55
|
+
const G = F !== void 0 ? F : g;
|
|
56
|
+
m(() => {
|
|
57
|
+
if (!O && J.current && p === "fetch_on_type") {
|
|
58
|
+
if (!c || c === "" || c.length < C) {
|
|
59
|
+
E.current && clearTimeout(E.current), d(!1);
|
|
54
60
|
return;
|
|
55
61
|
}
|
|
56
|
-
const t =
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
j(n);
|
|
62
|
+
const t = B(q, I);
|
|
63
|
+
d(!0), t.then((n) => {
|
|
64
|
+
const o = $(n);
|
|
65
|
+
R(o);
|
|
61
66
|
}).finally(() => {
|
|
62
|
-
|
|
67
|
+
d(!1), e?.onFetchingEnd?.();
|
|
63
68
|
});
|
|
64
69
|
}
|
|
65
|
-
}, [
|
|
66
|
-
if (!
|
|
67
|
-
if (
|
|
68
|
-
if (e?.onOpen?.(),
|
|
69
|
-
if (!
|
|
70
|
+
}, [p, c, O, I, B, C]), m(() => {
|
|
71
|
+
if (!O)
|
|
72
|
+
if (G) {
|
|
73
|
+
if (e?.onOpen?.(), p === "fetch_in_open") {
|
|
74
|
+
if (!J.current)
|
|
70
75
|
return;
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
return l(r, c) !== void 0;
|
|
76
|
+
d(!0), q().then((t) => {
|
|
77
|
+
const n = $(t);
|
|
78
|
+
R(() => {
|
|
79
|
+
const o = n.filter((r) => {
|
|
80
|
+
if (s)
|
|
81
|
+
return i(r, s) !== void 0;
|
|
78
82
|
});
|
|
79
|
-
return
|
|
83
|
+
return U && h.length > 0 ? [...K(h, o), ...h] : o;
|
|
80
84
|
});
|
|
81
85
|
}).finally(() => {
|
|
82
|
-
|
|
86
|
+
d(!1), e?.onFetchingEnd?.();
|
|
83
87
|
});
|
|
84
88
|
}
|
|
85
89
|
} else
|
|
86
90
|
e?.onClose?.();
|
|
87
|
-
}, [
|
|
88
|
-
const
|
|
89
|
-
if (
|
|
90
|
-
return
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
91
|
+
}, [G, p, O]);
|
|
92
|
+
const H = (t, n) => t?.filter((o) => {
|
|
93
|
+
if (f)
|
|
94
|
+
return i(o, f)?.toLowerCase().includes(n.toLowerCase());
|
|
95
|
+
{
|
|
96
|
+
const r = o;
|
|
97
|
+
switch (typeof r) {
|
|
98
|
+
case "string":
|
|
99
|
+
return r?.toLowerCase().includes(n.toLowerCase());
|
|
100
|
+
case "number":
|
|
101
|
+
return r.toString().includes(n);
|
|
102
|
+
case "object":
|
|
103
|
+
return Object.values(r).some((S) => S.toString()?.toLowerCase().includes(n.toLowerCase()));
|
|
104
|
+
default:
|
|
105
|
+
return !1;
|
|
106
|
+
}
|
|
100
107
|
}
|
|
101
|
-
}) || [],
|
|
102
|
-
if (
|
|
103
|
-
return
|
|
108
|
+
}) || [], ne = (t) => t?.sort((n, o) => {
|
|
109
|
+
if (f)
|
|
110
|
+
return i(n, f) < i(o, f) ? -1 : 1;
|
|
104
111
|
{
|
|
105
|
-
const
|
|
106
|
-
switch (typeof
|
|
112
|
+
const u = ["label", "name", "value"].find((W) => typeof n == "object" && Object.keys(n).includes(W)), S = n, _ = o;
|
|
113
|
+
switch (typeof S) {
|
|
107
114
|
case "string":
|
|
108
|
-
return
|
|
115
|
+
return S < _ ? -1 : 1;
|
|
109
116
|
case "number":
|
|
110
|
-
return
|
|
117
|
+
return S < _ ? -1 : 1;
|
|
111
118
|
case "object":
|
|
112
|
-
if (
|
|
113
|
-
const
|
|
114
|
-
return
|
|
119
|
+
if (u) {
|
|
120
|
+
const W = i(n, u), oe = i(o, u);
|
|
121
|
+
return W < oe ? -1 : 1;
|
|
115
122
|
} else
|
|
116
123
|
return 1;
|
|
117
124
|
default:
|
|
118
125
|
return 1;
|
|
119
126
|
}
|
|
120
127
|
}
|
|
121
|
-
}) || [],
|
|
122
|
-
const n = typeof
|
|
123
|
-
t.target === n?.current && (
|
|
124
|
-
|
|
125
|
-
},
|
|
128
|
+
}) || [], Q = (t) => {
|
|
129
|
+
const n = typeof k == "function" ? k() : k;
|
|
130
|
+
t.target === n?.current && (N.current && clearTimeout(N.current), z.current || (z.current = !0, e?.onTypeStart?.()), N.current = setTimeout(() => {
|
|
131
|
+
z.current = !1;
|
|
132
|
+
}, I));
|
|
126
133
|
};
|
|
127
|
-
return
|
|
128
|
-
if (
|
|
129
|
-
|
|
130
|
-
else if (
|
|
131
|
-
const t = K(
|
|
132
|
-
|
|
134
|
+
return m(() => {
|
|
135
|
+
if (c === "")
|
|
136
|
+
x(ne(V));
|
|
137
|
+
else if (U) {
|
|
138
|
+
const t = K(h, V);
|
|
139
|
+
x([...H(t, c), ...h]);
|
|
133
140
|
} else {
|
|
134
|
-
const t = K([
|
|
135
|
-
|
|
141
|
+
const t = K([h], V);
|
|
142
|
+
x([...H(t, c), h]);
|
|
136
143
|
}
|
|
137
|
-
}, [
|
|
138
|
-
document.removeEventListener("keydown",
|
|
144
|
+
}, [V]), m(() => (document.addEventListener("keydown", Q), () => {
|
|
145
|
+
document.removeEventListener("keydown", Q);
|
|
139
146
|
}), []), {
|
|
140
|
-
inputValue:
|
|
141
|
-
setInputValue:
|
|
147
|
+
inputValue: c,
|
|
148
|
+
setInputValue: A,
|
|
142
149
|
cleanInputValue: () => {
|
|
143
|
-
|
|
150
|
+
A("");
|
|
144
151
|
},
|
|
145
|
-
filteredOptions:
|
|
146
|
-
isLoading:
|
|
147
|
-
value:
|
|
148
|
-
setValue:
|
|
149
|
-
onOptionClick:
|
|
152
|
+
filteredOptions: M,
|
|
153
|
+
isLoading: l,
|
|
154
|
+
value: h,
|
|
155
|
+
setValue: D,
|
|
156
|
+
onOptionClick: te
|
|
150
157
|
};
|
|
151
158
|
}
|
|
152
|
-
const
|
|
153
|
-
const y =
|
|
154
|
-
|
|
159
|
+
const ae = (e) => {
|
|
160
|
+
const y = T(null);
|
|
161
|
+
m(() => {
|
|
155
162
|
e.controls && (e.controls.current = y.current);
|
|
156
163
|
}, [e.controls]);
|
|
157
|
-
const { asyncMode:
|
|
158
|
-
const
|
|
159
|
-
options:
|
|
160
|
-
fetcher:
|
|
161
|
-
asyncMode:
|
|
162
|
-
debounceDelay:
|
|
163
|
-
minCharacters:
|
|
164
|
-
disabled:
|
|
165
|
-
optionValue:
|
|
166
|
-
optionLabel:
|
|
164
|
+
const { asyncMode: a = "fetch_in_open" } = e, p = (l, d, g) => {
|
|
165
|
+
const P = {
|
|
166
|
+
options: l.options,
|
|
167
|
+
fetcher: l.fetcher,
|
|
168
|
+
asyncMode: d,
|
|
169
|
+
debounceDelay: l.debounceDelay,
|
|
170
|
+
minCharacters: l.minCharacters,
|
|
171
|
+
disabled: l.disabled,
|
|
172
|
+
optionValue: l.optionValue,
|
|
173
|
+
optionLabel: l.optionLabel,
|
|
167
174
|
onFetchingStart: () => {
|
|
168
|
-
|
|
175
|
+
d === "fetch_on_type" && g.current?.open();
|
|
169
176
|
},
|
|
170
177
|
onTypeStart: () => {
|
|
171
|
-
!
|
|
178
|
+
!l?.fetcher && g.current?.open();
|
|
172
179
|
},
|
|
173
|
-
inputRef: () =>
|
|
174
|
-
subscribeOpenChange:
|
|
175
|
-
name:
|
|
180
|
+
inputRef: () => g.current?.searchInputRef,
|
|
181
|
+
subscribeOpenChange: g.current?.subscribeOpenChange,
|
|
182
|
+
name: l.name
|
|
176
183
|
};
|
|
177
|
-
return
|
|
178
|
-
...
|
|
184
|
+
return l.multiple ? {
|
|
185
|
+
...P,
|
|
179
186
|
multiple: !0,
|
|
180
|
-
controlledValue:
|
|
181
|
-
onChange:
|
|
187
|
+
controlledValue: l.value,
|
|
188
|
+
onChange: l.onChange
|
|
182
189
|
} : {
|
|
183
|
-
...
|
|
190
|
+
...P,
|
|
184
191
|
multiple: !1,
|
|
185
|
-
controlledValue:
|
|
186
|
-
onChange:
|
|
192
|
+
controlledValue: l.value,
|
|
193
|
+
onChange: l.onChange
|
|
187
194
|
};
|
|
188
|
-
}, { inputValue:
|
|
189
|
-
const
|
|
190
|
-
|
|
191
|
-
}, { displayMode:
|
|
192
|
-
controledSearchValue:
|
|
193
|
-
onSearchValueChange:
|
|
194
|
-
onSearchClear:
|
|
195
|
+
}, { inputValue: O, setInputValue: I, filteredOptions: C, isLoading: f, value: s, onOptionClick: b, cleanInputValue: F } = re(p(e, a, y)), k = ee(() => a === "fetch_on_type" ? f : !1, [a, f]), v = Z(() => e.multiple ? s.map((l) => i(l, e.optionValue)) : s ? i(s, e.optionValue) : void 0, [s, e.optionValue, e.multiple]), j = (l) => {
|
|
196
|
+
const d = C.find((g) => i(g, e.optionValue) === l.id);
|
|
197
|
+
d && b(d);
|
|
198
|
+
}, { displayMode: V = e.multiple ? "chips" : "compact", dropdownOptions: R, overflow: M = "scroll", onChange: x, ...c } = e.selectComponentProps || {}, A = {
|
|
199
|
+
controledSearchValue: O,
|
|
200
|
+
onSearchValueChange: a === "fetch_on_type" ? I : void 0,
|
|
201
|
+
onSearchClear: a === "fetch_on_type" ? F : void 0,
|
|
195
202
|
inputSearchPlaceholder: e.inputSearchPlaceholder,
|
|
196
|
-
isLoading:
|
|
197
|
-
...
|
|
203
|
+
isLoading: k(),
|
|
204
|
+
...R || {}
|
|
198
205
|
};
|
|
199
|
-
return e.multiple ? /* @__PURE__ */
|
|
200
|
-
|
|
206
|
+
return e.multiple ? /* @__PURE__ */ X.jsx(
|
|
207
|
+
Y,
|
|
201
208
|
{
|
|
202
209
|
disabled: e.disabled,
|
|
203
210
|
className: e.className,
|
|
204
211
|
name: e.name,
|
|
205
|
-
overflow:
|
|
206
|
-
...
|
|
212
|
+
overflow: M,
|
|
213
|
+
...c,
|
|
207
214
|
multiple: !0,
|
|
208
|
-
value:
|
|
215
|
+
value: v,
|
|
209
216
|
label: e.label || "",
|
|
210
|
-
options:
|
|
217
|
+
options: C,
|
|
211
218
|
optionValue: e.optionValue,
|
|
212
219
|
optionLabel: e.optionLabel,
|
|
213
220
|
renderOption: e.renderOption,
|
|
214
|
-
onOptionClick:
|
|
215
|
-
displayMode:
|
|
221
|
+
onOptionClick: j,
|
|
222
|
+
displayMode: V,
|
|
216
223
|
controls: y,
|
|
217
224
|
emptyMessage: "Use el buscador para obtener las opciones disponibles",
|
|
218
|
-
dropdownOptions:
|
|
219
|
-
isLoading:
|
|
225
|
+
dropdownOptions: A,
|
|
226
|
+
isLoading: a === "fetch_in_open" ? f : !1
|
|
220
227
|
}
|
|
221
|
-
) : /* @__PURE__ */
|
|
222
|
-
|
|
228
|
+
) : /* @__PURE__ */ X.jsx(
|
|
229
|
+
Y,
|
|
223
230
|
{
|
|
224
231
|
disabled: e.disabled,
|
|
225
|
-
...
|
|
232
|
+
...c,
|
|
226
233
|
className: e.className,
|
|
227
|
-
overflow:
|
|
234
|
+
overflow: M,
|
|
228
235
|
name: e.name,
|
|
229
236
|
multiple: !1,
|
|
230
|
-
value:
|
|
237
|
+
value: v,
|
|
231
238
|
label: e.label || "",
|
|
232
|
-
options:
|
|
239
|
+
options: C,
|
|
233
240
|
optionValue: e.optionValue,
|
|
234
241
|
optionLabel: e.optionLabel,
|
|
235
242
|
renderOption: e.renderOption,
|
|
236
|
-
onOptionClick:
|
|
243
|
+
onOptionClick: j,
|
|
237
244
|
displayMode: "compact",
|
|
238
245
|
controls: y,
|
|
239
246
|
emptyMessage: "Use el buscador para obtener las opciones disponibles",
|
|
240
|
-
dropdownOptions:
|
|
241
|
-
isLoading:
|
|
247
|
+
dropdownOptions: A,
|
|
248
|
+
isLoading: a === "fetch_in_open" ? f : !1
|
|
242
249
|
}
|
|
243
250
|
);
|
|
244
251
|
};
|
|
245
252
|
export {
|
|
246
|
-
|
|
253
|
+
ae as default
|
|
247
254
|
};
|
|
@@ -16,5 +16,5 @@ export interface AutocompleteProps<T> {
|
|
|
16
16
|
disabled?: boolean;
|
|
17
17
|
renderOption?: ComponentType<CustomSelectOptionRendererProps<T>>;
|
|
18
18
|
}
|
|
19
|
-
declare const Autocomplete: <T>(props: AutocompleteProps<T>) => import("react/jsx-runtime").JSX.Element;
|
|
19
|
+
declare const Autocomplete: <T extends object>(props: AutocompleteProps<T>) => import("react/jsx-runtime").JSX.Element;
|
|
20
20
|
export default Autocomplete;
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
import { OptionAccessor } from '../Shared/types';
|
|
2
|
-
export interface UseAutocompleteOptionsMultiple<T> extends UseAutocompleteBaseOptions<T> {
|
|
2
|
+
export interface UseAutocompleteOptionsMultiple<T extends object> extends UseAutocompleteBaseOptions<T> {
|
|
3
3
|
multiple: true;
|
|
4
4
|
controlledValue?: T[];
|
|
5
5
|
onChange?: (newValue: T[], name?: string) => void;
|
|
6
6
|
}
|
|
7
|
-
export interface UseAutocompleteOptionsSingle<T> extends UseAutocompleteBaseOptions<T> {
|
|
7
|
+
export interface UseAutocompleteOptionsSingle<T extends object> extends UseAutocompleteBaseOptions<T> {
|
|
8
8
|
multiple?: false;
|
|
9
9
|
controlledValue?: T;
|
|
10
10
|
onChange?: (newValue: T, name?: string) => void;
|
|
11
11
|
}
|
|
12
|
-
export interface UseAutocompleteBaseOptions<T> {
|
|
13
|
-
options?: T[];
|
|
12
|
+
export interface UseAutocompleteBaseOptions<T extends object> {
|
|
13
|
+
options?: (T | undefined | null)[];
|
|
14
14
|
fetcher?: (input?: string) => Promise<T[]>;
|
|
15
15
|
asyncMode?: 'fetch_in_open' | 'fetch_on_type';
|
|
16
16
|
disabled?: boolean;
|
|
@@ -28,8 +28,8 @@ export interface UseAutocompleteBaseOptions<T> {
|
|
|
28
28
|
subscribeOpenChange?: (cb: (open: boolean) => void) => (() => void) | undefined;
|
|
29
29
|
name?: string;
|
|
30
30
|
}
|
|
31
|
-
export type UseAutocompleteOptions<T> = UseAutocompleteOptionsMultiple<T> | UseAutocompleteOptionsSingle<T>;
|
|
32
|
-
export declare function useAutocomplete<T>(options?: UseAutocompleteOptions<T>): {
|
|
31
|
+
export type UseAutocompleteOptions<T extends object> = UseAutocompleteOptionsMultiple<T> | UseAutocompleteOptionsSingle<T>;
|
|
32
|
+
export declare function useAutocomplete<T extends object>(options?: UseAutocompleteOptions<T>): {
|
|
33
33
|
inputValue: string;
|
|
34
34
|
setInputValue: import('react').Dispatch<import('react').SetStateAction<string>>;
|
|
35
35
|
cleanInputValue: () => void;
|
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
import { ComponentType } from 'react';
|
|
2
2
|
import { CustomSelectionDisplayProps, CustomSelectOptionRendererProps, SelectControlsHandler, SelectProps } from '../Select/Select';
|
|
3
3
|
import { OptionAccessor } from '../Shared/types';
|
|
4
|
-
interface SimpleSelectSearchProps<T> extends BaseSelectSearchProps<T> {
|
|
4
|
+
interface SimpleSelectSearchProps<T extends object> extends BaseSelectSearchProps<T> {
|
|
5
5
|
multiple?: false;
|
|
6
6
|
value?: T | undefined;
|
|
7
7
|
onChange?: (newValue: T, name?: string) => void;
|
|
8
8
|
}
|
|
9
|
-
interface MultipleSelectSearchProps<T> extends BaseSelectSearchProps<T> {
|
|
9
|
+
interface MultipleSelectSearchProps<T extends object> extends BaseSelectSearchProps<T> {
|
|
10
10
|
multiple: true;
|
|
11
11
|
value?: T[];
|
|
12
12
|
onChange?: (newValue: T[], name?: string) => void;
|
|
13
13
|
}
|
|
14
|
-
export interface BaseSelectSearchProps<T> {
|
|
14
|
+
export interface BaseSelectSearchProps<T extends object> {
|
|
15
15
|
label?: string;
|
|
16
16
|
placeholder?: string;
|
|
17
17
|
name?: string;
|
|
@@ -31,6 +31,6 @@ export interface BaseSelectSearchProps<T> {
|
|
|
31
31
|
controls?: React.RefObject<SelectControlsHandler | null>;
|
|
32
32
|
selectComponentProps?: Partial<Omit<SelectProps<T>, 'controls'>>;
|
|
33
33
|
}
|
|
34
|
-
export type SelectSearchProps<T> = SimpleSelectSearchProps<T> | MultipleSelectSearchProps<T>;
|
|
35
|
-
declare const SelectSearch: <T>(props: SelectSearchProps<T>) => import("react/jsx-runtime").JSX.Element;
|
|
34
|
+
export type SelectSearchProps<T extends object> = SimpleSelectSearchProps<T> | MultipleSelectSearchProps<T>;
|
|
35
|
+
declare const SelectSearch: <T extends object>(props: SelectSearchProps<T>) => import("react/jsx-runtime").JSX.Element;
|
|
36
36
|
export default SelectSearch;
|
|
@@ -13,7 +13,7 @@ import { default as Ke } from "./Menu.es.js";
|
|
|
13
13
|
import { default as Ye } from "./Pagination.es.js";
|
|
14
14
|
import { default as tt } from "./ProfilePictureUpload.es.js";
|
|
15
15
|
import { default as rt } from "./ProgressBar.es.js";
|
|
16
|
-
import { S as nt } from "./Select-
|
|
16
|
+
import { S as nt } from "./Select-mdLPyy7g.js";
|
|
17
17
|
import { default as it } from "./Spinner.es.js";
|
|
18
18
|
import { default as ct } from "./Steps.es.js";
|
|
19
19
|
import { default as dt } from "./SwipeContainer.es.js";
|