@companix/uikit 0.0.79 → 0.0.81

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.
@@ -1,90 +1,26 @@
1
- import { jsxs as o, jsx as n } from "react/jsx-runtime";
2
- import w from "classnames";
3
- import { attr as s } from "@companix/utils-browser";
4
- import { forwardRef as y, useRef as D, useCallback as S } from "react";
5
- import { VisuallyHidden as T } from "@radix-ui/react-visually-hidden";
6
- import { mergeRefs as j } from "react-merge-refs";
7
- import { SelectRightElements as z } from "./bundle.es62.js";
8
- const W = y(
9
- ({
10
- required: a,
11
- size: i,
12
- fill: u,
13
- leftElement: l,
14
- className: d,
15
- value: c,
16
- clearButton: m,
17
- placeholder: p,
18
- clearButtonIcon: f,
19
- disabled: r,
20
- onClear: h,
21
- inputRef: C,
22
- onClick: I,
23
- ...N
24
- }, k) => {
25
- const e = D(null), v = S(
26
- (t) => {
27
- if (!e.current || !document)
28
- return;
29
- t.target !== e.current && (e.current.click(), document.activeElement !== e.current && e.current.focus());
30
- },
31
- [e]
32
- ), F = (t) => {
33
- document && document.activeElement === e.current && t.preventDefault();
34
- }, g = (t) => {
35
- r || v(t);
36
- }, R = (t) => {
37
- F(t);
38
- }, x = (t) => {
39
- e.current && e.current.focus(), h?.(t);
40
- };
41
- return /* @__PURE__ */ o(
42
- "div",
43
- {
44
- ref: k,
45
- className: w("form select", d),
46
- "data-size": i ?? "md",
47
- "data-fill": s(u),
48
- "data-required": s(a),
49
- "data-disabled": s(r),
50
- onMouseDown: R,
51
- onClick: g,
52
- ...N,
53
- children: [
54
- /* @__PURE__ */ o("div", { className: "select-layout form-input", children: [
55
- l && /* @__PURE__ */ n("div", { className: "select-element", children: l }),
56
- /* @__PURE__ */ n("div", { className: "select-content", children: /* @__PURE__ */ o("div", { className: "select-content-text", "aria-disabled": r, children: [
57
- !c && /* @__PURE__ */ n("span", { className: "select-placeholder", children: p }),
58
- c
59
- ] }) }),
60
- /* @__PURE__ */ n("div", { className: "select-element", children: /* @__PURE__ */ n(
61
- z,
62
- {
63
- clearButton: m,
64
- value: !!c,
65
- clearButtonIcon: f,
66
- onClear: x
67
- }
68
- ) })
69
- ] }),
70
- /* @__PURE__ */ n(T, { asChild: !0, children: /* @__PURE__ */ n(
71
- "input",
72
- {
73
- ref: j([C, e]),
74
- autoComplete: "off",
75
- autoCapitalize: "none",
76
- autoCorrect: "off",
77
- spellCheck: "false",
78
- "aria-autocomplete": "none",
79
- onClick: I,
80
- readOnly: !0
81
- }
82
- ) })
83
- ]
84
- }
85
- );
86
- }
87
- );
1
+ import { useRef as s, useCallback as c } from "react";
2
+ const p = () => {
3
+ const t = s(null), r = s({ cb: null }), i = c(() => {
4
+ if (t.current && t.current.parentElement) {
5
+ const e = t.current.parentElement, u = e.style.getPropertyValue("--radix-popper-anchor-width"), n = e.style.getPropertyValue("transform"), o = new MutationObserver(() => {
6
+ e.style.transform !== n && e.style.setProperty("transform", n);
7
+ });
8
+ o.observe(e, {
9
+ attributes: !0,
10
+ attributeFilter: ["style"]
11
+ }), r.current.cb = () => {
12
+ o.disconnect();
13
+ }, t.current.style.setProperty("--radix-popover-trigger-width", u);
14
+ }
15
+ }, []), l = c(() => {
16
+ r.current.cb && (r.current.cb(), r.current.cb = null);
17
+ }, []);
18
+ return {
19
+ popoverRef: t,
20
+ handleAnimationEnd: l,
21
+ froozePopoverPosition: i
22
+ };
23
+ };
88
24
  export {
89
- W as SelectInput
25
+ p as useFroozeClosing
90
26
  };
@@ -1,20 +1,90 @@
1
- import { useRef as u, useCallback as T } from "react";
2
- const g = () => {
3
- const l = u(null), t = u(null);
4
- return { scrollToElement: T(
5
- (r, f) => {
6
- const o = l.current, s = t.current;
7
- if (!o || !s || r < 0 || r > s.children.length)
8
- return;
9
- const c = s.children[r];
10
- if (!c)
11
- return;
12
- const n = o.offsetHeight, i = o.scrollTop, e = c.offsetTop, p = c.offsetHeight;
13
- f === "center" ? o.scrollTop = e - n / 2 + p / 2 : f === "top" ? o.scrollTop = e : e + p > n + i ? o.scrollTop = e - n + p : e < i && (o.scrollTop = e);
14
- },
15
- [t, l]
16
- ), scrollBoxRef: l, optionsWrapperRef: t };
17
- };
1
+ import { jsxs as o, jsx as n } from "react/jsx-runtime";
2
+ import w from "classnames";
3
+ import { attr as s } from "@companix/utils-browser";
4
+ import { forwardRef as y, useRef as D, useCallback as S } from "react";
5
+ import { VisuallyHidden as T } from "@radix-ui/react-visually-hidden";
6
+ import { mergeRefs as j } from "react-merge-refs";
7
+ import { SelectRightElements as z } from "./bundle.es62.js";
8
+ const W = y(
9
+ ({
10
+ required: a,
11
+ size: i,
12
+ fill: u,
13
+ leftElement: l,
14
+ className: d,
15
+ value: c,
16
+ clearButton: m,
17
+ placeholder: p,
18
+ clearButtonIcon: f,
19
+ disabled: r,
20
+ onClear: h,
21
+ inputRef: C,
22
+ onClick: I,
23
+ ...N
24
+ }, k) => {
25
+ const e = D(null), v = S(
26
+ (t) => {
27
+ if (!e.current || !document)
28
+ return;
29
+ t.target !== e.current && (e.current.click(), document.activeElement !== e.current && e.current.focus());
30
+ },
31
+ [e]
32
+ ), F = (t) => {
33
+ document && document.activeElement === e.current && t.preventDefault();
34
+ }, g = (t) => {
35
+ r || v(t);
36
+ }, R = (t) => {
37
+ F(t);
38
+ }, x = (t) => {
39
+ e.current && e.current.focus(), h?.(t);
40
+ };
41
+ return /* @__PURE__ */ o(
42
+ "div",
43
+ {
44
+ ref: k,
45
+ className: w("form select", d),
46
+ "data-size": i ?? "md",
47
+ "data-fill": s(u),
48
+ "data-required": s(a),
49
+ "data-disabled": s(r),
50
+ onMouseDown: R,
51
+ onClick: g,
52
+ ...N,
53
+ children: [
54
+ /* @__PURE__ */ o("div", { className: "select-layout form-input", children: [
55
+ l && /* @__PURE__ */ n("div", { className: "select-element", children: l }),
56
+ /* @__PURE__ */ n("div", { className: "select-content", children: /* @__PURE__ */ o("div", { className: "select-content-text", "aria-disabled": r, children: [
57
+ !c && /* @__PURE__ */ n("span", { className: "select-placeholder", children: p }),
58
+ c
59
+ ] }) }),
60
+ /* @__PURE__ */ n("div", { className: "select-element", children: /* @__PURE__ */ n(
61
+ z,
62
+ {
63
+ clearButton: m,
64
+ value: !!c,
65
+ clearButtonIcon: f,
66
+ onClear: x
67
+ }
68
+ ) })
69
+ ] }),
70
+ /* @__PURE__ */ n(T, { asChild: !0, children: /* @__PURE__ */ n(
71
+ "input",
72
+ {
73
+ ref: j([C, e]),
74
+ autoComplete: "off",
75
+ autoCapitalize: "none",
76
+ autoCorrect: "off",
77
+ spellCheck: "false",
78
+ "aria-autocomplete": "none",
79
+ onClick: I,
80
+ readOnly: !0
81
+ }
82
+ ) })
83
+ ]
84
+ }
85
+ );
86
+ }
87
+ );
18
88
  export {
19
- g as useScrollListController
89
+ W as SelectInput
20
90
  };
@@ -1,95 +1,20 @@
1
- import { jsx as i, jsxs as y } from "react/jsx-runtime";
2
- import { useMemo as k, useEffect as C } from "react";
3
- import { Spinner as P } from "./bundle.es6.js";
4
- import { OptionItem as L } from "./bundle.es15.js";
5
- import { OptionsList as T } from "./bundle.es17.js";
6
- import { Icon as R } from "./bundle.es33.js";
7
- import { faPlus as S } from "@companix/icons-solid";
8
- const b = () => ({ isLoading: !1, options: [] }), I = (n) => {
9
- const { onOptionsLoaded: e, useOptions: s = b, options: o } = n, t = s();
10
- return C(() => {
11
- t.options.length > 0 && e?.(t.options);
12
- }, [t.options]), o ? { options: o, isLoading: !1 } : t;
13
- }, H = (n) => {
14
- const {
15
- isActive: e,
16
- emptyText: s,
17
- isLoading: o,
18
- scrollboxRef: t,
19
- optionsWrapperRef: d,
20
- addOption: p,
21
- onOpened: f,
22
- onSelect: O,
23
- minimalOptions: u,
24
- filterOptions: r,
25
- disableFiltering: l,
26
- close: c,
27
- ...a
28
- } = n, { emptyText: x, options: m, isLoading: g } = I(a), v = k(() => r && !l ? m.filter(r) : m, [m, r, l]);
29
- return g ?? o ? /* @__PURE__ */ i("div", { className: "select-popover-loading", children: /* @__PURE__ */ i(P, { size: 24 }) }) : /* @__PURE__ */ i(
30
- N,
31
- {
32
- options: v,
33
- isActive: e,
34
- emptyText: x ?? s,
35
- scrollboxRef: t,
36
- optionsWrapperRef: d,
37
- minimalOptions: u,
38
- addOption: p,
39
- onOpened: f,
40
- onSelect: O,
41
- close: c
42
- }
43
- );
44
- }, N = (n) => {
45
- const {
46
- isActive: e,
47
- onOpened: s,
48
- addOption: o,
49
- scrollboxRef: t,
50
- optionsWrapperRef: d,
51
- options: p,
52
- onSelect: f,
53
- minimalOptions: O,
54
- emptyText: u = "Ничего не найдено",
55
- close: r
56
- } = n;
57
- C(() => {
58
- s?.(p.findIndex(({ value: c }) => e(c)));
59
- }, []);
60
- const l = o ? /* @__PURE__ */ i(
61
- L,
62
- {
63
- className: "select-add-option",
64
- icon: /* @__PURE__ */ i(R, { icon: S }),
65
- title: o.text,
66
- onClick: o.onClick,
67
- onClickCapture: () => {
68
- o.closeOnClick && r();
69
- }
70
- }
71
- ) : void 0;
72
- return /* @__PURE__ */ y(T, { scrollboxRef: t, optionsWrapperRef: d, maxHeight: 300, children: [
73
- (o?.position === void 0 || o?.position === "first") && l,
74
- p.length === 0 && !o && /* @__PURE__ */ i("div", { className: "select-tags-empty", children: u }),
75
- p.map(({ title: c, value: a, className: x, icon: m, disabled: g, label: v }, h) => /* @__PURE__ */ i(
76
- L,
77
- {
78
- active: e(a),
79
- onClick: () => f?.(a),
80
- minimal: O,
81
- disabled: g,
82
- className: x,
83
- title: c,
84
- label: v,
85
- icon: m
86
- },
87
- `select-option-${h}`
88
- )),
89
- o?.position === "last" && l
90
- ] });
1
+ import { useRef as u, useCallback as T } from "react";
2
+ const g = () => {
3
+ const l = u(null), t = u(null);
4
+ return { scrollToElement: T(
5
+ (r, f) => {
6
+ const o = l.current, s = t.current;
7
+ if (!o || !s || r < 0 || r > s.children.length)
8
+ return;
9
+ const c = s.children[r];
10
+ if (!c)
11
+ return;
12
+ const n = o.offsetHeight, i = o.scrollTop, e = c.offsetTop, p = c.offsetHeight;
13
+ f === "center" ? o.scrollTop = e - n / 2 + p / 2 : f === "top" ? o.scrollTop = e : e + p > n + i ? o.scrollTop = e - n + p : e < i && (o.scrollTop = e);
14
+ },
15
+ [t, l]
16
+ ), scrollBoxRef: l, optionsWrapperRef: t };
91
17
  };
92
18
  export {
93
- H as OptionsPopover,
94
- N as SelectOptionsList
19
+ g as useScrollListController
95
20
  };
@@ -1,76 +1,95 @@
1
- import { clamp as m } from "@companix/utils-browser";
2
- import { formatTime as i } from "@companix/utils-js";
3
- const d = (n, r) => new Date(r, n, 0).getDate(), u = (n, r) => new Date(r, n - 1, 1).getDay(), g = (n) => n === 0 ? 6 : n - 1, D = (n) => new Array(n).fill(0), T = {
4
- add: (n, r) => n.includes(r) ? [...n] : [...n, r],
5
- remove: (n, r) => n.filter((t) => r !== t)
6
- }, p = (n) => ({
7
- day: n.getDate(),
8
- month: n.getMonth() + 1,
9
- year: n.getFullYear()
10
- }), A = ({ min: n, max: r }) => (t) => {
11
- if (n.year === t.year) {
12
- if (t.month !== 0 && t.month < n.month)
13
- return t.month = 0, t.day = 0, t;
14
- if (t.month === n.month && t.day < n.day && t.day !== 0)
15
- return t.day = 0, t;
16
- }
17
- if (r.year === t.year) {
18
- if (t.month !== 0 && t.month > r.month)
19
- return t.month = 0, t.day = 0, t;
20
- if (t.month === r.month && t.day > r.day && t.day !== 0)
21
- return t.day = 0, t;
22
- }
23
- }, M = ["Пн", "Вт", "Ср", "Чт", "Пт", "Сб", "Вс"], w = [
24
- "Январь",
25
- "Февраль",
26
- "Март",
27
- "Апрель",
28
- "Май",
29
- "Июнь",
30
- "Июль",
31
- "Август",
32
- "Сентябрь",
33
- "Октябрь",
34
- "Ноябрь",
35
- "Декабрь"
36
- ], c = 9999, a = 100, F = (n, r) => {
37
- const t = [], o = m(n - r, a, c), e = m(n + r, a, c);
38
- for (let s = o; s <= e; s++)
39
- t.push({ title: String(s).padStart(4, "0"), value: s });
40
- return t;
41
- }, Y = (n) => {
42
- const r = [], t = new Intl.DateTimeFormat(n, {
43
- month: "long"
44
- });
45
- for (let o = 0; o < 12; o++)
46
- r.push({
47
- title: t.format(new Date(2023, o, 15)),
48
- value: o
49
- });
50
- return r;
51
- }, E = (n, r) => r.reduce((t, o) => t.replaceAll(o, ""), n.trim()), _ = ({ hours: n, minutes: r }, t = ":") => [i(n), i(r)].join(t), h = (n, r = ":") => {
52
- const [t, o] = [i(n.hours), i(n.minutes)], e = [t, o].join(r);
53
- return { title: e, value: e, hours: t, minutes: o };
54
- }, I = (n, r = ":") => {
55
- const t = { minutes: -n, hours: 0 };
56
- return Array.from({ length: 1440 / n }).map(() => (t.minutes += n, t.minutes === 60 && (t.minutes = 0, t.hours++), h(t, r)));
1
+ import { jsx as i, jsxs as y } from "react/jsx-runtime";
2
+ import { useMemo as k, useEffect as C } from "react";
3
+ import { Spinner as P } from "./bundle.es6.js";
4
+ import { OptionItem as L } from "./bundle.es15.js";
5
+ import { OptionsList as T } from "./bundle.es17.js";
6
+ import { Icon as R } from "./bundle.es33.js";
7
+ import { faPlus as S } from "@companix/icons-solid";
8
+ const b = () => ({ isLoading: !1, options: [] }), I = (n) => {
9
+ const { onOptionsLoaded: e, useOptions: s = b, options: o } = n, t = s();
10
+ return C(() => {
11
+ t.options.length > 0 && e?.(t.options);
12
+ }, [t.options]), o ? { options: o, isLoading: !1 } : t;
13
+ }, H = (n) => {
14
+ const {
15
+ isActive: e,
16
+ emptyText: s,
17
+ isLoading: o,
18
+ scrollboxRef: t,
19
+ optionsWrapperRef: d,
20
+ addOption: p,
21
+ onOpened: f,
22
+ onSelect: O,
23
+ minimalOptions: u,
24
+ filterOptions: r,
25
+ disableFiltering: l,
26
+ close: c,
27
+ ...a
28
+ } = n, { emptyText: x, options: m, isLoading: g } = I(a), v = k(() => r && !l ? m.filter(r) : m, [m, r, l]);
29
+ return g ?? o ? /* @__PURE__ */ i("div", { className: "select-popover-loading", children: /* @__PURE__ */ i(P, { size: 24 }) }) : /* @__PURE__ */ i(
30
+ N,
31
+ {
32
+ options: v,
33
+ isActive: e,
34
+ emptyText: x ?? s,
35
+ scrollboxRef: t,
36
+ optionsWrapperRef: d,
37
+ minimalOptions: u,
38
+ addOption: p,
39
+ onOpened: f,
40
+ onSelect: O,
41
+ close: c
42
+ }
43
+ );
44
+ }, N = (n) => {
45
+ const {
46
+ isActive: e,
47
+ onOpened: s,
48
+ addOption: o,
49
+ scrollboxRef: t,
50
+ optionsWrapperRef: d,
51
+ options: p,
52
+ onSelect: f,
53
+ minimalOptions: O,
54
+ emptyText: u = "Ничего не найдено",
55
+ close: r
56
+ } = n;
57
+ C(() => {
58
+ s?.(p.findIndex(({ value: c }) => e(c)));
59
+ }, []);
60
+ const l = o ? /* @__PURE__ */ i(
61
+ L,
62
+ {
63
+ className: "select-add-option",
64
+ icon: /* @__PURE__ */ i(R, { icon: S }),
65
+ title: o.text,
66
+ onClick: o.onClick,
67
+ onClickCapture: () => {
68
+ o.closeOnClick && r();
69
+ }
70
+ }
71
+ ) : void 0;
72
+ return /* @__PURE__ */ y(T, { scrollboxRef: t, optionsWrapperRef: d, maxHeight: 300, children: [
73
+ (o?.position === void 0 || o?.position === "first") && l,
74
+ p.length === 0 && !o && /* @__PURE__ */ i("div", { className: "select-tags-empty", children: u }),
75
+ p.map(({ title: c, value: a, className: x, icon: m, disabled: g, label: v }, h) => /* @__PURE__ */ i(
76
+ L,
77
+ {
78
+ active: e(a),
79
+ onClick: () => f?.(a),
80
+ minimal: O,
81
+ disabled: g,
82
+ className: x,
83
+ title: c,
84
+ label: v,
85
+ icon: m
86
+ },
87
+ `select-option-${h}`
88
+ )),
89
+ o?.position === "last" && l
90
+ ] });
57
91
  };
58
92
  export {
59
- c as DEFAULT_MAX_YEAR,
60
- a as DEFAULT_MIN_YEAR,
61
- w as DefaultMonths,
62
- T as arrays,
63
- _ as convertTimeToOption,
64
- A as createDateValidation,
65
- D as createVoids,
66
- p as dateToFormat,
67
- g as getDayIndex,
68
- u as getFirstDay,
69
- d as getMonthMaxDay,
70
- Y as getMonths,
71
- h as getTimeValue,
72
- I as getTimesOptions,
73
- F as getYears,
74
- E as removeDigits,
75
- M as weeks
93
+ H as OptionsPopover,
94
+ N as SelectOptionsList
76
95
  };
@@ -1,26 +1,76 @@
1
- import { jsx as u } from "react/jsx-runtime";
2
- import { forwardRef as m, useCallback as i } from "react";
3
- import c from "react-input-mask";
4
- const I = m(
5
- ({ mask: r, maskChar: f = "_", onChange: n, onValueChange: o, ...a }, e) => {
6
- const p = i(
7
- (t) => {
8
- n?.(t), o?.(t.target.value, t.target);
9
- },
10
- [n, o]
11
- );
12
- return r ? /* @__PURE__ */ u(
13
- c,
14
- {
15
- inputRef: e,
16
- mask: r,
17
- maskChar: f,
18
- onChange: p,
19
- ...a
20
- }
21
- ) : /* @__PURE__ */ u("input", { ref: e, ...a, onChange: p });
1
+ import { clamp as m } from "@companix/utils-browser";
2
+ import { formatTime as i } from "@companix/utils-js";
3
+ const d = (n, r) => new Date(r, n, 0).getDate(), u = (n, r) => new Date(r, n - 1, 1).getDay(), g = (n) => n === 0 ? 6 : n - 1, D = (n) => new Array(n).fill(0), T = {
4
+ add: (n, r) => n.includes(r) ? [...n] : [...n, r],
5
+ remove: (n, r) => n.filter((t) => r !== t)
6
+ }, p = (n) => ({
7
+ day: n.getDate(),
8
+ month: n.getMonth() + 1,
9
+ year: n.getFullYear()
10
+ }), A = ({ min: n, max: r }) => (t) => {
11
+ if (n.year === t.year) {
12
+ if (t.month !== 0 && t.month < n.month)
13
+ return t.month = 0, t.day = 0, t;
14
+ if (t.month === n.month && t.day < n.day && t.day !== 0)
15
+ return t.day = 0, t;
22
16
  }
23
- );
17
+ if (r.year === t.year) {
18
+ if (t.month !== 0 && t.month > r.month)
19
+ return t.month = 0, t.day = 0, t;
20
+ if (t.month === r.month && t.day > r.day && t.day !== 0)
21
+ return t.day = 0, t;
22
+ }
23
+ }, M = ["Пн", "Вт", "Ср", "Чт", "Пт", "Сб", "Вс"], w = [
24
+ "Январь",
25
+ "Февраль",
26
+ "Март",
27
+ "Апрель",
28
+ "Май",
29
+ "Июнь",
30
+ "Июль",
31
+ "Август",
32
+ "Сентябрь",
33
+ "Октябрь",
34
+ "Ноябрь",
35
+ "Декабрь"
36
+ ], c = 9999, a = 100, F = (n, r) => {
37
+ const t = [], o = m(n - r, a, c), e = m(n + r, a, c);
38
+ for (let s = o; s <= e; s++)
39
+ t.push({ title: String(s).padStart(4, "0"), value: s });
40
+ return t;
41
+ }, Y = (n) => {
42
+ const r = [], t = new Intl.DateTimeFormat(n, {
43
+ month: "long"
44
+ });
45
+ for (let o = 0; o < 12; o++)
46
+ r.push({
47
+ title: t.format(new Date(2023, o, 15)),
48
+ value: o
49
+ });
50
+ return r;
51
+ }, E = (n, r) => r.reduce((t, o) => t.replaceAll(o, ""), n.trim()), _ = ({ hours: n, minutes: r }, t = ":") => [i(n), i(r)].join(t), h = (n, r = ":") => {
52
+ const [t, o] = [i(n.hours), i(n.minutes)], e = [t, o].join(r);
53
+ return { title: e, value: e, hours: t, minutes: o };
54
+ }, I = (n, r = ":") => {
55
+ const t = { minutes: -n, hours: 0 };
56
+ return Array.from({ length: 1440 / n }).map(() => (t.minutes += n, t.minutes === 60 && (t.minutes = 0, t.hours++), h(t, r)));
57
+ };
24
58
  export {
25
- I as InputElement
59
+ c as DEFAULT_MAX_YEAR,
60
+ a as DEFAULT_MIN_YEAR,
61
+ w as DefaultMonths,
62
+ T as arrays,
63
+ _ as convertTimeToOption,
64
+ A as createDateValidation,
65
+ D as createVoids,
66
+ p as dateToFormat,
67
+ g as getDayIndex,
68
+ u as getFirstDay,
69
+ d as getMonthMaxDay,
70
+ Y as getMonths,
71
+ h as getTimeValue,
72
+ I as getTimesOptions,
73
+ F as getYears,
74
+ E as removeDigits,
75
+ M as weeks
26
76
  };