chop-logic-components 3.7.3 → 4.0.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/README.md +4 -4
- package/dist/components/atoms/button/Button.css +1 -0
- package/dist/components/atoms/button/Button.js +66 -0
- package/dist/components/atoms/button/icon-button/IconButton.css +1 -0
- package/dist/components/atoms/button/icon-button/IconButton.js +15 -0
- package/dist/components/atoms/button/icon-button/index.js +3 -0
- package/dist/components/atoms/button/index.js +3 -0
- package/dist/components/atoms/button/inner-button/InnerButton.css +1 -0
- package/dist/components/atoms/button/inner-button/InnerButton.js +28 -0
- package/dist/components/atoms/button/inner-button/index.js +3 -0
- package/dist/components/atoms/button/primary-button/PrimaryButton.css +1 -0
- package/dist/components/atoms/button/primary-button/PrimaryButton.js +18 -0
- package/dist/components/atoms/button/primary-button/index.js +3 -0
- package/dist/components/atoms/button/secondary-button/SecondaryButton.css +1 -0
- package/dist/components/atoms/button/secondary-button/SecondaryButton.js +18 -0
- package/dist/components/atoms/button/secondary-button/index.js +3 -0
- package/dist/components/atoms/editable-text/EditView.js +37 -0
- package/dist/components/atoms/editable-text/EditableText.css +1 -0
- package/dist/components/atoms/editable-text/EditableText.js +71 -0
- package/dist/components/atoms/editable-text/ReadView.js +25 -0
- package/dist/components/atoms/editable-text/index.js +3 -0
- package/dist/components/atoms/editable-text/useEditModeState.js +17 -0
- package/dist/components/atoms/editable-text/useInputFocus.js +9 -0
- package/dist/components/atoms/editable-text/useValueState.js +21 -0
- package/dist/components/atoms/error-message/ErrorMessage.css +1 -0
- package/dist/components/atoms/error-message/ErrorMessage.js +30 -0
- package/dist/components/atoms/error-message/index.js +3 -0
- package/dist/components/atoms/header/Header.css +1 -0
- package/dist/components/atoms/header/Header.js +22 -0
- package/dist/components/atoms/header/index.js +3 -0
- package/dist/components/atoms/icon/Icon.css +1 -0
- package/dist/components/atoms/icon/Icon.js +31 -0
- package/dist/components/atoms/icon/index.js +3 -0
- package/dist/components/atoms/image/BasicImage.js +27 -0
- package/dist/components/atoms/image/FallBackImage.js +10 -0
- package/dist/components/atoms/image/Image.css +1 -0
- package/dist/components/atoms/image/Image.js +24 -0
- package/dist/components/atoms/image/ResponsivePicture.js +17 -0
- package/dist/components/atoms/image/index.js +3 -0
- package/dist/components/atoms/input/Input.css +1 -0
- package/dist/components/atoms/input/Input.js +10 -0
- package/dist/components/atoms/input/index.js +3 -0
- package/dist/components/atoms/label/Label.css +1 -0
- package/dist/components/atoms/label/Label.js +30 -0
- package/dist/components/atoms/label/index.js +3 -0
- package/dist/components/atoms/link/Link.css +1 -0
- package/dist/components/atoms/link/Link.js +39 -0
- package/dist/components/atoms/link/index.js +3 -0
- package/dist/components/atoms/portal/Portal.js +11 -0
- package/dist/components/atoms/portal/index.js +2 -0
- package/dist/components/atoms/tooltip/Tooltip.controller.js +35 -0
- package/dist/components/atoms/tooltip/Tooltip.css +1 -0
- package/dist/components/atoms/tooltip/Tooltip.js +70 -0
- package/dist/components/atoms/tooltip/index.js +3 -0
- package/dist/components/contexts/form/FormContext.js +5 -0
- package/dist/components/contexts/theme/ThemeContext.js +11 -0
- package/dist/components/contexts/theme/ThemeProvider.js +21 -0
- package/dist/components/hocs/with-figure-caption/Figure.css +1 -0
- package/dist/components/hocs/with-figure-caption/index.js +2 -0
- package/dist/components/hocs/with-figure-caption/with-figure-caption.js +11 -0
- package/dist/components/hocs/with-tooltip/index.js +2 -0
- package/dist/components/hocs/with-tooltip/with-tooltip.js +8 -0
- package/dist/components/molecules/accordion/Accordion.css +1 -0
- package/dist/components/molecules/accordion/Accordion.js +11 -0
- package/dist/components/molecules/accordion/AccordionItem.css +1 -0
- package/dist/components/molecules/accordion/AccordionItem.js +24 -0
- package/dist/components/molecules/accordion/index.js +3 -0
- package/dist/components/molecules/alert/Alert.css +1 -0
- package/dist/components/molecules/alert/Alert.helpers.js +41 -0
- package/dist/components/molecules/alert/Alert.js +59 -0
- package/dist/components/molecules/alert/AlertProgressBar.js +13 -0
- package/dist/components/molecules/alert/index.js +3 -0
- package/dist/components/molecules/breadcrumbs/BreadcrumbItem.js +27 -0
- package/dist/components/molecules/breadcrumbs/BreadcrumbList.js +6 -0
- package/dist/components/molecules/breadcrumbs/Breadcrumbs.css +1 -0
- package/dist/components/molecules/breadcrumbs/Breadcrumbs.js +31 -0
- package/dist/components/molecules/breadcrumbs/index.js +3 -0
- package/dist/components/molecules/checkbox/Checkbox.controller.js +25 -0
- package/dist/components/molecules/checkbox/Checkbox.css +1 -0
- package/dist/components/molecules/checkbox/Checkbox.helpers.js +10 -0
- package/dist/components/molecules/checkbox/Checkbox.js +7 -0
- package/dist/components/molecules/checkbox/CheckboxStateful.js +61 -0
- package/dist/components/molecules/checkbox/CheckboxStateless.js +59 -0
- package/dist/components/molecules/checkbox/index.js +3 -0
- package/dist/components/molecules/multi-select/MultiSelect.Combobox.js +47 -0
- package/dist/components/molecules/multi-select/MultiSelect.Dropdown.js +31 -0
- package/dist/components/molecules/multi-select/MultiSelect.controller.js +37 -0
- package/dist/components/molecules/multi-select/MultiSelect.helpers.js +22 -0
- package/dist/components/molecules/multi-select/MultiSelect.js +61 -0
- package/dist/components/molecules/multi-select/MultiSelectComboboxSelectedValues.js +8 -0
- package/dist/components/molecules/multi-select/Option.js +40 -0
- package/dist/components/molecules/multi-select/index.js +2 -0
- package/dist/components/molecules/numeric-input/NumericInput.controller.js +45 -0
- package/dist/components/molecules/numeric-input/NumericInput.css +1 -0
- package/dist/components/molecules/numeric-input/NumericInput.helpers.js +20 -0
- package/dist/components/molecules/numeric-input/NumericInput.js +7 -0
- package/dist/components/molecules/numeric-input/NumericInputStateful.js +108 -0
- package/dist/components/molecules/numeric-input/NumericInputStateless.js +96 -0
- package/dist/components/molecules/numeric-input/index.js +3 -0
- package/dist/components/molecules/search/Search.controller.js +42 -0
- package/dist/components/molecules/search/Search.css +1 -0
- package/dist/components/molecules/search/Search.js +112 -0
- package/dist/components/molecules/search/index.js +3 -0
- package/dist/components/molecules/select/Select.controller.js +32 -0
- package/dist/components/molecules/select/Select.css +1 -0
- package/dist/components/molecules/select/Select.helpers.js +16 -0
- package/dist/components/molecules/select/Select.js +64 -0
- package/dist/components/molecules/select/combobox/Combobox.css +1 -0
- package/dist/components/molecules/select/combobox/Combobox.js +46 -0
- package/dist/components/molecules/select/combobox/index.js +3 -0
- package/dist/components/molecules/select/dropdown/Dropdown.css +1 -0
- package/dist/components/molecules/select/dropdown/Dropdown.js +46 -0
- package/dist/components/molecules/select/dropdown/index.js +3 -0
- package/dist/components/molecules/select/index.js +3 -0
- package/dist/components/molecules/select/option/Option.css +1 -0
- package/dist/components/molecules/select/option/Option.js +38 -0
- package/dist/components/molecules/select/option/index.js +3 -0
- package/dist/components/molecules/switch/Switch.controller.js +33 -0
- package/dist/components/molecules/switch/Switch.css +1 -0
- package/dist/components/molecules/switch/Switch.helpers.js +10 -0
- package/dist/components/molecules/switch/Switch.js +68 -0
- package/dist/components/molecules/switch/index.js +3 -0
- package/dist/components/molecules/text-input/TextInput.controller.js +36 -0
- package/dist/components/molecules/text-input/TextInput.css +1 -0
- package/dist/components/molecules/text-input/TextInput.helpers.js +18 -0
- package/dist/components/molecules/text-input/TextInput.js +7 -0
- package/dist/components/molecules/text-input/TextInputButtons.js +37 -0
- package/dist/components/molecules/text-input/TextInputStateful.js +92 -0
- package/dist/components/molecules/text-input/TextInputStateless.js +89 -0
- package/dist/components/molecules/text-input/index.js +3 -0
- package/dist/components/organisms/dialog/Dialog.css +1 -0
- package/dist/components/organisms/dialog/Dialog.js +32 -0
- package/dist/components/organisms/dialog/index.js +3 -0
- package/dist/components/organisms/form/Form.controller.js +29 -0
- package/dist/components/organisms/form/Form.css +1 -0
- package/dist/components/organisms/form/Form.helpers.js +14 -0
- package/dist/components/organisms/form/Form.js +48 -0
- package/dist/components/organisms/form/index.js +3 -0
- package/dist/components/organisms/grid/Grid.controller.js +34 -0
- package/dist/components/organisms/grid/Grid.css +1 -0
- package/dist/components/organisms/grid/Grid.helpers.js +15 -0
- package/dist/components/organisms/grid/Grid.js +60 -0
- package/dist/components/organisms/grid/body/GridBody.css +1 -0
- package/dist/components/organisms/grid/body/GridBody.js +31 -0
- package/dist/components/organisms/grid/checkbox/GridCheckbox.css +1 -0
- package/dist/components/organisms/grid/checkbox/GridCheckbox.js +52 -0
- package/dist/components/organisms/grid/column-group/GridColumnGroup.css +1 -0
- package/dist/components/organisms/grid/column-group/GridColumnGroup.js +26 -0
- package/dist/components/organisms/grid/data-cell/GridDataCell.js +5 -0
- package/dist/components/organisms/grid/grid-row/GridRow.css +1 -0
- package/dist/components/organisms/grid/grid-row/GridRow.js +35 -0
- package/dist/components/organisms/grid/grid-row/index.js +3 -0
- package/dist/components/organisms/grid/head/GridHead.css +1 -0
- package/dist/components/organisms/grid/head/GridHead.js +35 -0
- package/dist/components/organisms/grid/header-cell/HeaderCell.js +8 -0
- package/dist/components/organisms/grid/header-cell/index.js +2 -0
- package/dist/components/organisms/grid/index.js +3 -0
- package/dist/components/organisms/grid/select-all-grid-rows-cell/SelectAllGridRowsCell.js +24 -0
- package/dist/components/organisms/grid/select-all-grid-rows-cell/index.js +2 -0
- package/dist/components/organisms/grid/select-grid-row-cell/SelectGridRowCell.js +24 -0
- package/dist/components/organisms/grid/select-grid-row-cell/index.js +2 -0
- package/dist/components/organisms/menu/Menu.css +1 -0
- package/dist/components/organisms/menu/Menu.js +22 -0
- package/dist/components/organisms/menu/index.js +3 -0
- package/dist/components/organisms/menu/leaf/MenuLeaf.css +1 -0
- package/dist/components/organisms/menu/leaf/MenuLeaf.js +28 -0
- package/dist/components/organisms/menu/list-item/MenuListItem.css +1 -0
- package/dist/components/organisms/menu/list-item/MenuListItem.js +35 -0
- package/dist/components/organisms/menu/sub-menu/SubMenu.css +1 -0
- package/dist/components/organisms/menu/sub-menu/SubMenu.js +67 -0
- package/dist/components/organisms/menu/sub-menu/index.js +3 -0
- package/dist/components/organisms/tabs/Tabs.css +1 -0
- package/dist/components/organisms/tabs/Tabs.js +80 -0
- package/dist/components/organisms/tabs/button/TabButton.css +1 -0
- package/dist/components/organisms/tabs/button/TabButton.js +111 -0
- package/dist/components/organisms/tabs/content/TabContent.css +1 -0
- package/dist/components/organisms/tabs/content/TabContent.js +19 -0
- package/dist/components/organisms/tabs/edit-input/TabEditInput.css +1 -0
- package/dist/components/organisms/tabs/edit-input/TabEditInput.js +64 -0
- package/dist/components/organisms/tabs/index.js +3 -0
- package/dist/components/organisms/tabs/list/TabList.css +1 -0
- package/dist/components/organisms/tabs/list/TabList.js +67 -0
- package/dist/enums/alert-mode.js +4 -0
- package/dist/enums/button-view.js +4 -0
- package/dist/enums/element-size.js +4 -0
- package/dist/enums/icon-name.js +4 -0
- package/dist/enums/index.js +8 -0
- package/dist/enums/loader-view.js +4 -0
- package/dist/enums/orientation-mode.js +4 -0
- package/dist/enums/semantic-color.js +4 -0
- package/dist/enums/tooltip-container.js +4 -0
- package/dist/hooks/index.js +15 -0
- package/dist/hooks/use-auto-close/index.js +2 -0
- package/dist/hooks/use-auto-close/use-auto-close.js +18 -0
- package/dist/hooks/use-click-outside/index.js +2 -0
- package/dist/hooks/use-click-outside/use-click-outside.js +19 -0
- package/dist/hooks/use-container-dimensions/index.js +2 -0
- package/dist/hooks/use-container-dimensions/use-container-dimensions.js +16 -0
- package/dist/hooks/use-debounce/index.js +2 -0
- package/dist/hooks/use-debounce/use-debounce.js +15 -0
- package/dist/hooks/use-element-ids/index.js +2 -0
- package/dist/hooks/use-element-ids/use-element-ids.js +12 -0
- package/dist/hooks/use-is-hovered/index.js +2 -0
- package/dist/hooks/use-is-hovered/use-is-hovered.js +15 -0
- package/dist/hooks/use-is-mounted/index.js +2 -0
- package/dist/hooks/use-is-mounted/use-is-mounted.js +15 -0
- package/dist/hooks/use-is-overflow/index.js +2 -0
- package/dist/hooks/use-is-overflow/use-is-overflow.js +27 -0
- package/dist/hooks/use-key-press/index.js +2 -0
- package/dist/hooks/use-key-press/use-key-press.js +14 -0
- package/dist/hooks/use-modal-focus-trap/index.js +2 -0
- package/dist/hooks/use-modal-focus-trap/use-modal-focus-trap.js +20 -0
- package/dist/hooks/use-remaining-timer/index.js +2 -0
- package/dist/hooks/use-remaining-timer/use-remaining-timer.js +38 -0
- package/dist/hooks/use-reset-form-input/index.js +2 -0
- package/dist/hooks/use-reset-form-input/use-reset-form-input.js +11 -0
- package/dist/hooks/use-theme/index.js +2 -0
- package/dist/hooks/use-theme/use-theme.js +6 -0
- package/dist/hooks/use-tooltip-position/index.js +2 -0
- package/dist/hooks/use-tooltip-position/use-tooltip-position.js +31 -0
- package/dist/hooks/use-window-dimensions/index.js +2 -0
- package/dist/hooks/use-window-dimensions/use-window-dimensions.js +17 -0
- package/dist/index.d.ts +327 -70
- package/dist/index.es.js +109 -4591
- package/dist/styles/icons.css +1 -0
- package/dist/styles/main.css +1 -0
- package/dist/utils/get-class-name.js +16 -0
- package/dist/utils/handle-dropdown-list-key-press.js +32 -0
- package/dist/utils/index.js +3 -0
- package/dist/utils/move-focus-on-element-by-id.js +7 -0
- package/package.json +75 -22
- package/dist/favicon.ico +0 -0
- package/dist/index.cjs.js +0 -7
- package/dist/index.cjs.js.map +0 -1
- package/dist/index.css +0 -1
- package/dist/index.es.js.map +0 -1
- package/dist/logo.jpeg +0 -0
- package/dist/logo.png +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.cl-label{display:flex;align-items:baseline;gap:var(--cl-s-gap);color:var(--cl-base-font-color);font-family:var(--cl-core-font);font-size:var(--cl-typography-small-mobile);font-weight:400;line-height:1.5;letter-spacing:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media(min-width:640px){.cl-label{font-size:var(--cl-typography-small-tablet)}}@media(min-width:1024px){.cl-label{font-size:var(--cl-typography-small-desktop)}}.cl-label:hover{text-shadow:var(--cl-text-shadow);cursor:pointer}.cl-label__text{text-wrap:nowrap;overflow:hidden;text-overflow:ellipsis}.cl-label__required{text-decoration:none;cursor:pointer;color:var(--cl-accent-a0);margin-left:var(--cl-s-gap)}.cl-label_disabled{pointer-events:none;opacity:.5}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { jsxs as s, jsx as t } from "react/jsx-runtime";
|
|
2
|
+
import './Label.css';/* empty css */
|
|
3
|
+
import { getClassName as x } from "../../../utils/get-class-name.js";
|
|
4
|
+
import { ElementSize as _ } from "../../../enums/element-size.js";
|
|
5
|
+
import u from "../icon/Icon.js";
|
|
6
|
+
const q = ({
|
|
7
|
+
label: r,
|
|
8
|
+
required: i,
|
|
9
|
+
inputId: m,
|
|
10
|
+
icon: e,
|
|
11
|
+
iconPosition: l,
|
|
12
|
+
isTextHidden: c = !1,
|
|
13
|
+
iconSize: o = _.ExtraSmall,
|
|
14
|
+
disabled: n = !1,
|
|
15
|
+
className: b,
|
|
16
|
+
testId: d
|
|
17
|
+
}) => {
|
|
18
|
+
const f = !!e && l === "left", p = !!e && l === "right", a = /* @__PURE__ */ t(u, { name: e, size: o }), h = x(["cl-label", b, { "cl-label_disabled": n }]);
|
|
19
|
+
return /* @__PURE__ */ s("label", { className: h, htmlFor: m, "data-testid": d, children: [
|
|
20
|
+
f && a,
|
|
21
|
+
!c && /* @__PURE__ */ s("span", { className: "cl-label__text", children: [
|
|
22
|
+
r,
|
|
23
|
+
i && /* @__PURE__ */ t("abbr", { className: "cl-label__required", title: "required", children: "*" })
|
|
24
|
+
] }),
|
|
25
|
+
p && a
|
|
26
|
+
] });
|
|
27
|
+
};
|
|
28
|
+
export {
|
|
29
|
+
q as default
|
|
30
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.cl-link{display:inline-flex;align-items:center;gap:var(--cl-s-gap);text-decoration:none;transition:all .2s ease;color:var(--cl-info-a0)}.cl-link:focus{outline:var(--cl-outline-border);outline-offset:var(--cl-s-gap);border-radius:var(--cl-border-radius)}.cl-link:focus:not(:focus-visible){outline:none}.cl-link:visited{color:var(--cl-warning-a0)}.cl-link:hover{text-shadow:var(--cl-text-shadow)}.cl-link_disabled{pointer-events:none;opacity:.5}.cl-link__text{font-family:var(--cl-core-font);font-size:var(--cl-typography-base-mobile);color:inherit;font-weight:400;line-height:1.5;letter-spacing:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-decoration:underline}.cl-link__icon:before{color:var(--cl-info-a0)}@media(min-width:640px){.cl-link__text{font-size:var(--cl-typography-base-tablet)}}@media(min-width:1024px){.cl-link__text{font-size:var(--cl-typography-base-desktop)}}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { jsx as r, jsxs as _ } from "react/jsx-runtime";
|
|
2
|
+
import { getClassName as g } from "../../../utils/get-class-name.js";
|
|
3
|
+
import './Link.css';/* empty css */
|
|
4
|
+
import x from "../icon/Icon.js";
|
|
5
|
+
import { ElementSize as u } from "../../../enums/element-size.js";
|
|
6
|
+
const j = ({
|
|
7
|
+
href: s,
|
|
8
|
+
children: n,
|
|
9
|
+
icon: t,
|
|
10
|
+
iconPosition: l = "left",
|
|
11
|
+
external: m = !1,
|
|
12
|
+
disabled: e = !1,
|
|
13
|
+
className: c,
|
|
14
|
+
target: a,
|
|
15
|
+
...p
|
|
16
|
+
}) => {
|
|
17
|
+
const f = g(["cl-link", c, { "cl-link_disabled": e }]), i = m || s.startsWith("http") || s.startsWith("//"), k = i ? a || "_blank" : a, o = t ? /* @__PURE__ */ r(x, { name: t, className: "cl-link__icon", hidden: !0, size: u.Small }) : null, d = t && l === "left", w = t && l === "right";
|
|
18
|
+
return /* @__PURE__ */ _(
|
|
19
|
+
"a",
|
|
20
|
+
{
|
|
21
|
+
href: s,
|
|
22
|
+
className: f,
|
|
23
|
+
target: k,
|
|
24
|
+
...i && {
|
|
25
|
+
"aria-label": typeof n == "string" ? `${n} (opens in new window)` : "Opens in new window"
|
|
26
|
+
},
|
|
27
|
+
"aria-disabled": e,
|
|
28
|
+
...p,
|
|
29
|
+
children: [
|
|
30
|
+
d && o,
|
|
31
|
+
/* @__PURE__ */ r("span", { className: "cl-link__text", children: n }),
|
|
32
|
+
w && o
|
|
33
|
+
]
|
|
34
|
+
}
|
|
35
|
+
);
|
|
36
|
+
};
|
|
37
|
+
export {
|
|
38
|
+
j as default
|
|
39
|
+
};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { useState as r, useEffect as o } from "react";
|
|
2
|
+
import a from "react-dom";
|
|
3
|
+
const m = ({ children: t }) => {
|
|
4
|
+
const [e] = r(() => document.createElement("div"));
|
|
5
|
+
return o(() => (document.body.appendChild(e), () => {
|
|
6
|
+
e.remove();
|
|
7
|
+
}), [e]), a.createPortal(t, e);
|
|
8
|
+
};
|
|
9
|
+
export {
|
|
10
|
+
m as default
|
|
11
|
+
};
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { useState as T, useRef as r } from "react";
|
|
2
|
+
import { useTooltipPosition as O } from "../../../hooks/use-tooltip-position/use-tooltip-position.js";
|
|
3
|
+
import { useElementIds as R } from "../../../hooks/use-element-ids/use-element-ids.js";
|
|
4
|
+
import { useKeyPress as k } from "../../../hooks/use-key-press/use-key-press.js";
|
|
5
|
+
import { useClickOutside as y } from "../../../hooks/use-click-outside/use-click-outside.js";
|
|
6
|
+
import { useAutoClose as I } from "../../../hooks/use-auto-close/use-auto-close.js";
|
|
7
|
+
const v = ({ id: p, autoClose: i, autoCloseDelay: u }) => {
|
|
8
|
+
const [e, s] = T(!1), n = r(null), o = r(null), { top: f, left: c } = O({ wrapperRef: n, tooltipRef: o, isOpened: e }), { elementId: m } = R(p), t = () => s(!1), d = () => s(!0), l = () => s(!e), a = (C) => {
|
|
9
|
+
C.preventDefault(), l();
|
|
10
|
+
};
|
|
11
|
+
return k({ keyCode: "Escape", ref: o, onKeyPress: t }), y({
|
|
12
|
+
ref: o,
|
|
13
|
+
onClickOutsideHandler: t,
|
|
14
|
+
dependentRef: n
|
|
15
|
+
}), I({
|
|
16
|
+
isOpened: e,
|
|
17
|
+
onClose: t,
|
|
18
|
+
autoClose: i,
|
|
19
|
+
autoCloseDelay: u
|
|
20
|
+
}), {
|
|
21
|
+
elementId: m,
|
|
22
|
+
openTooltip: d,
|
|
23
|
+
closeTooltip: t,
|
|
24
|
+
toggleTooltip: l,
|
|
25
|
+
handleContextMenu: a,
|
|
26
|
+
top: f,
|
|
27
|
+
left: c,
|
|
28
|
+
isOpened: e,
|
|
29
|
+
wrapperRef: n,
|
|
30
|
+
tooltipRef: o
|
|
31
|
+
};
|
|
32
|
+
};
|
|
33
|
+
export {
|
|
34
|
+
v as useTooltipController
|
|
35
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.cl-tooltip{color:var(--cl-base-font-color);position:absolute;left:0;top:0;z-index:var(--cl-z-index-popup);background-color:var(--cl-surface-a0);border:var(--cl-light-border);padding:var(--cl-m-gap);border-radius:var(--cl-border-radius);box-shadow:var(--cl-box-shadow);pointer-events:none;white-space:nowrap;animation:cl-fade-in ease .4s;font-family:var(--cl-core-font);font-size:var(--cl-typography-small-mobile);font-weight:400;line-height:1.5;letter-spacing:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.cl-tooltip_info{background-color:var(--cl-info-a0);color:#fff;border:none}.cl-tooltip_success{background-color:var(--cl-success-a0);color:#fff;border:none}.cl-tooltip_danger{background-color:var(--cl-danger-a0);color:#fff;border:none}.cl-tooltip_warning{background-color:var(--cl-warning-a0);color:#fff;border:none}@media(min-width:640px){.cl-tooltip{font-size:var(--cl-typography-small-tablet)}}@media(min-width:1024px){.cl-tooltip{font-size:var(--cl-typography-small-desktop)}}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { jsxs as I, jsx as i } from "react/jsx-runtime";
|
|
2
|
+
import { getClassName as N } from "../../../utils/get-class-name.js";
|
|
3
|
+
import './Tooltip.css';/* empty css */
|
|
4
|
+
import { useTooltipController as R } from "./Tooltip.controller.js";
|
|
5
|
+
import { SemanticColor as n } from "../../../enums/semantic-color.js";
|
|
6
|
+
import { TooltipContainer as S } from "../../../enums/tooltip-container.js";
|
|
7
|
+
import w from "../portal/Portal.js";
|
|
8
|
+
const z = ({
|
|
9
|
+
children: p,
|
|
10
|
+
tooltipContent: s,
|
|
11
|
+
id: a,
|
|
12
|
+
style: c,
|
|
13
|
+
className: m,
|
|
14
|
+
containerTag: d = S.Span,
|
|
15
|
+
visibleOn: o = "hover",
|
|
16
|
+
autoClose: f = !1,
|
|
17
|
+
autoCloseDelay: u = 3e3,
|
|
18
|
+
color: t = n.Default,
|
|
19
|
+
...C
|
|
20
|
+
}) => {
|
|
21
|
+
const v = d, {
|
|
22
|
+
openTooltip: e,
|
|
23
|
+
closeTooltip: r,
|
|
24
|
+
toggleTooltip: h,
|
|
25
|
+
handleContextMenu: x,
|
|
26
|
+
elementId: l,
|
|
27
|
+
top: T,
|
|
28
|
+
left: M,
|
|
29
|
+
isOpened: g,
|
|
30
|
+
wrapperRef: y,
|
|
31
|
+
tooltipRef: j
|
|
32
|
+
} = R({ id: a, autoClose: f, autoCloseDelay: u }), k = N([
|
|
33
|
+
"cl-tooltip",
|
|
34
|
+
m,
|
|
35
|
+
{ [`cl-tooltip_${t}`]: t !== n.Default }
|
|
36
|
+
]);
|
|
37
|
+
return /* @__PURE__ */ I(
|
|
38
|
+
v,
|
|
39
|
+
{
|
|
40
|
+
style: { position: "relative", cursor: "pointer" },
|
|
41
|
+
onClick: o === "click" ? h : void 0,
|
|
42
|
+
onMouseOver: o === "hover" ? e : void 0,
|
|
43
|
+
onMouseLeave: o === "hover" ? r : void 0,
|
|
44
|
+
onFocus: o === "focus" ? e : void 0,
|
|
45
|
+
onBlur: o === "focus" ? r : void 0,
|
|
46
|
+
onContextMenu: o === "contextmenu" ? (D) => x(D) : void 0,
|
|
47
|
+
tabIndex: -1,
|
|
48
|
+
ref: y,
|
|
49
|
+
"aria-describedby": l,
|
|
50
|
+
children: [
|
|
51
|
+
p,
|
|
52
|
+
g && /* @__PURE__ */ i(w, { children: /* @__PURE__ */ i(
|
|
53
|
+
"div",
|
|
54
|
+
{
|
|
55
|
+
style: { ...c, top: T, left: M },
|
|
56
|
+
ref: j,
|
|
57
|
+
role: "tooltip",
|
|
58
|
+
id: l,
|
|
59
|
+
...C,
|
|
60
|
+
className: k,
|
|
61
|
+
children: s
|
|
62
|
+
}
|
|
63
|
+
) })
|
|
64
|
+
]
|
|
65
|
+
}
|
|
66
|
+
);
|
|
67
|
+
};
|
|
68
|
+
export {
|
|
69
|
+
z as default
|
|
70
|
+
};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { createContext as e } from "react";
|
|
2
|
+
const t = "cl-components-light-theme", n = "cl-components-dark-theme", c = e({
|
|
3
|
+
mode: t,
|
|
4
|
+
setMode: () => {
|
|
5
|
+
}
|
|
6
|
+
});
|
|
7
|
+
export {
|
|
8
|
+
n as CL_DARK_THEME_CLASS,
|
|
9
|
+
t as CL_LIGHT_THEME_CLASS,
|
|
10
|
+
c as ThemeContext
|
|
11
|
+
};
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { jsx as u } from "react/jsx-runtime";
|
|
2
|
+
import '../../../styles/icons.css';import '../../../styles/main.css';/* empty css */
|
|
3
|
+
/* empty css */
|
|
4
|
+
import { useState as a, useEffect as s, useMemo as c } from "react";
|
|
5
|
+
import { CL_LIGHT_THEME_CLASS as e, CL_DARK_THEME_CLASS as r, ThemeContext as f } from "./ThemeContext.js";
|
|
6
|
+
const y = ({
|
|
7
|
+
children: m,
|
|
8
|
+
injectedMode: t
|
|
9
|
+
}) => {
|
|
10
|
+
const [o, i] = a(e);
|
|
11
|
+
s(() => {
|
|
12
|
+
o && typeof o == "string" && (document.body.classList.remove(e, r), document.body.classList.add(o));
|
|
13
|
+
}, [o]), s(() => {
|
|
14
|
+
t && typeof t == "string" && (document.body.classList.remove(e, r), document.body.classList.add(t));
|
|
15
|
+
}, [t]);
|
|
16
|
+
const d = c(() => ({ mode: o, setMode: i }), [o]);
|
|
17
|
+
return /* @__PURE__ */ u(f.Provider, { value: d, children: m });
|
|
18
|
+
};
|
|
19
|
+
export {
|
|
20
|
+
y as ThemeProvider
|
|
21
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.cl-figure{margin:0;display:block}.cl-figure__caption{text-align:center;padding-top:var(--cl-s-gap);color:var(--cl-base-font-color);font-size:var(--cl-typography-small-mobile)}@media(min-width:640px){.cl-figure__caption{font-size:var(--cl-typography-small-tablet)}}@media(min-width:1024px){.cl-figure__caption{font-size:var(--cl-typography-small-desktop)}}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { jsxs as c, jsx as i } from "react/jsx-runtime";
|
|
2
|
+
import './Figure.css';/* empty css */
|
|
3
|
+
function f(r) {
|
|
4
|
+
return ({ caption: e, ...t }) => e?.trim()?.length ? /* @__PURE__ */ c("figure", { className: "cl-figure", children: [
|
|
5
|
+
/* @__PURE__ */ i(r, { ...t }),
|
|
6
|
+
/* @__PURE__ */ i("figcaption", { className: "cl-figure__caption", children: e })
|
|
7
|
+
] }) : /* @__PURE__ */ i(r, { ...t });
|
|
8
|
+
}
|
|
9
|
+
export {
|
|
10
|
+
f as withFigureCaption
|
|
11
|
+
};
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { jsx as t } from "react/jsx-runtime";
|
|
2
|
+
import e from "../../atoms/tooltip/Tooltip.js";
|
|
3
|
+
function h(o) {
|
|
4
|
+
return ({ tooltip: i, visibleOn: n, ...r }) => i?.length ? /* @__PURE__ */ t(e, { tooltipContent: i, visibleOn: n, children: /* @__PURE__ */ t(o, { ...r }) }) : /* @__PURE__ */ t(o, { ...r });
|
|
5
|
+
}
|
|
6
|
+
export {
|
|
7
|
+
h as withTooltip
|
|
8
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.cl-accordion{display:flex;flex-direction:column;width:100%}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { jsx as r } from "react/jsx-runtime";
|
|
2
|
+
import { getClassName as s } from "../../../utils/get-class-name.js";
|
|
3
|
+
import './Accordion.css';/* empty css */
|
|
4
|
+
import { AccordionItem as t } from "./AccordionItem.js";
|
|
5
|
+
const l = ({ items: c, className: m }) => {
|
|
6
|
+
const a = s(["cl-accordion", m]);
|
|
7
|
+
return /* @__PURE__ */ r("div", { className: a, children: c.map((o) => /* @__PURE__ */ r(t, { ...o }, o.summary)) });
|
|
8
|
+
};
|
|
9
|
+
export {
|
|
10
|
+
l as default
|
|
11
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.cl-accordion{display:flex;flex-direction:column;width:100%}.cl-accordion-item{display:flex;flex-direction:column}.cl-accordion-item__summary{font-family:var(--cl-core-font);font-size:var(--cl-typography-base-mobile);font-weight:700;color:var(--cl-base-font-color);cursor:pointer;display:flex;justify-content:space-between;align-items:center;padding:var(--cl-l-gap);border-bottom:var(--cl-light-border);line-height:1.5;letter-spacing:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media(min-width:640px){.cl-accordion-item__summary{font-size:var(--cl-typography-base-tablet)}}@media(min-width:1024px){.cl-accordion-item__summary{font-size:var(--cl-typography-base-desktop)}}.cl-accordion-item__summary:hover{text-shadow:var(--cl-text-shadow)}.cl-accordion-item__summary::-webkit-details-marker{display:none}.cl-accordion-item__summary:focus-visible{outline:var(--cl-outline-border);outline-offset:-4px}.cl-accordion-item__content{color:var(--cl-base-font-color);padding:var(--cl-l-gap);font-family:var(--cl-core-font);font-size:var(--cl-typography-base-mobile);font-weight:400;line-height:1.5;letter-spacing:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media(min-width:640px){.cl-accordion-item__content{font-size:var(--cl-typography-base-tablet)}}@media(min-width:1024px){.cl-accordion-item__content{font-size:var(--cl-typography-base-desktop)}}.cl-accordion-item__icon{transition:transform .3s ease}.cl-accordion-item[open] .cl-accordion-item__summary{border-bottom:none}.cl-accordion-item[open] .cl-accordion-item__content{border-bottom:var(--cl-light-border)}.cl-accordion-item[open] .cl-accordion-item__icon{transform:rotate(180deg)}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { jsxs as o, jsx as c } from "react/jsx-runtime";
|
|
2
|
+
import './AccordionItem.css';/* empty css */
|
|
3
|
+
import i from "../../atoms/icon/Icon.js";
|
|
4
|
+
import { ElementSize as r } from "../../../enums/element-size.js";
|
|
5
|
+
import { IconName as a } from "../../../enums/icon-name.js";
|
|
6
|
+
const p = ({ summary: e, children: m }) => /* @__PURE__ */ o("details", { className: "cl-accordion-item", children: [
|
|
7
|
+
/* @__PURE__ */ o("summary", { className: "cl-accordion-item__summary", children: [
|
|
8
|
+
e,
|
|
9
|
+
/* @__PURE__ */ c(
|
|
10
|
+
i,
|
|
11
|
+
{
|
|
12
|
+
name: a.ChevronDown,
|
|
13
|
+
className: "cl-accordion-item__icon",
|
|
14
|
+
"aria-label": "Toggle Details",
|
|
15
|
+
testId: "accordion-icon",
|
|
16
|
+
size: r.Small
|
|
17
|
+
}
|
|
18
|
+
)
|
|
19
|
+
] }),
|
|
20
|
+
/* @__PURE__ */ c("div", { className: "cl-accordion-item__content", children: m })
|
|
21
|
+
] });
|
|
22
|
+
export {
|
|
23
|
+
p as AccordionItem
|
|
24
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.cl-alert{animation:cl-fade-in ease .4s;position:fixed;bottom:var(--cl-l-gap);left:50%;transform:translate(-50%);z-index:var(--cl-z-index-popup);width:90vw}@media screen and (min-width:1024px){.cl-alert{width:50vw;transform:none;right:var(--cl-l-gap);left:auto}}.cl-alert__content{color:var(--cl-base-font-color);display:flex;flex-direction:column;gap:var(--cl-m-gap);background:var(--cl-base-background-color);padding:var(--cl-m-gap) var(--cl-l-gap);box-shadow:var(--cl-box-shadow);border:var(--cl-accent-border);border-radius:var(--cl-border-radius);position:relative;font-family:var(--cl-core-font);font-size:var(--cl-typography-small-mobile);font-weight:400;line-height:1.5;letter-spacing:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.cl-alert__header{padding-right:var(--cl-thumb-size)}@media(min-width:640px){.cl-alert__content{font-size:var(--cl-typography-small-tablet)}}@media(min-width:1024px){.cl-alert__content{font-size:var(--cl-typography-small-desktop)}}.cl-alert__message{margin:var(--cl-m-gap) 0}.cl-alert__button{position:absolute;right:var(--cl-m-gap);top:var(--cl-m-gap)}.cl-alert__progress-bar{-webkit-appearance:none;appearance:none;width:100%;height:var(--cl-s-gap);border:none;background-color:var(--cl-base-background-color)}.cl-alert__progress-bar::-webkit-progress-bar{background-color:var(--cl-base-background-color)}.cl-alert__progress-bar::-webkit-progress-value{background-color:var(--cl-surface-tonal-a30)}.cl-alert__progress-bar::-moz-progress-bar{background-color:var(--cl-surface-tonal-a30)}.cl-alert_closing{animation:cl-fade-out ease .4s}.cl-alert_success .cl-alert__content{border:var(--cl-success-border);color:var(--cl-success-a0)}.cl-alert_success .cl-alert__header{border-bottom:var(--cl-success-border);color:var(--cl-success-a0)}.cl-alert_success .cl-alert__button span:before{color:var(--cl-success-a0)}.cl-alert_success .cl-alert__progress-bar::-webkit-progress-value{background-color:var(--cl-success-a0)}.cl-alert_success .cl-alert__progress-bar::-moz-progress-bar{background-color:var(--cl-success-a0)}.cl-alert_error .cl-alert__content{border:var(--cl-danger-border);color:var(--cl-danger-a0)}.cl-alert_error .cl-alert__button span:before{color:var(--cl-danger-a0)}.cl-alert_error .cl-alert__header{border-bottom:var(--cl-danger-border);color:var(--cl-danger-a0)}.cl-alert_error .cl-alert__progress-bar::-webkit-progress-value{background-color:var(--cl-danger-a0)}.cl-alert_error .cl-alert__progress-bar::-moz-progress-bar{background-color:var(--cl-danger-a0)}.cl-alert_warning .cl-alert__content{border:var(--cl-warning-border);color:var(--cl-warning-a0)}.cl-alert_warning .cl-alert__header{border-bottom:var(--cl-warning-border);color:var(--cl-warning-a0)}.cl-alert_warning .cl-alert__button span:before{color:var(--cl-warning-a0)}.cl-alert_warning .cl-alert__progress-bar::-webkit-progress-value{background-color:var(--cl-warning-a0)}.cl-alert_warning .cl-alert__progress-bar::-moz-progress-bar{background-color:var(--cl-warning-a0)}.cl-alert_info .cl-alert__content{border:var(--cl-info-border);color:var(--cl-info-a0)}.cl-alert_info .cl-alert__header{border-bottom:var(--cl-info-border);color:var(--cl-info-a0)}.cl-alert_info .cl-alert__button span:before{color:var(--cl-info-a0)}.cl-alert_info .cl-alert__progress-bar::-webkit-progress-value{background-color:var(--cl-info-a0)}.cl-alert_info .cl-alert__progress-bar::-moz-progress-bar{background-color:var(--cl-info-a0)}.cl-alert_help .cl-alert__content{border:var(--cl-light-border)}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { AlertMode as r } from "../../../enums/alert-mode.js";
|
|
2
|
+
import { IconName as t } from "../../../enums/icon-name.js";
|
|
3
|
+
function a(n, e) {
|
|
4
|
+
if (e) return e;
|
|
5
|
+
switch (n) {
|
|
6
|
+
case r.Info:
|
|
7
|
+
return "For your information";
|
|
8
|
+
case r.Warning:
|
|
9
|
+
return "Please pay attention";
|
|
10
|
+
case r.Error:
|
|
11
|
+
return "Something went wrong";
|
|
12
|
+
case r.Success:
|
|
13
|
+
return "Everything is okay";
|
|
14
|
+
case r.Help:
|
|
15
|
+
return "Useful tip";
|
|
16
|
+
default:
|
|
17
|
+
return "Alert";
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
function c(n, e) {
|
|
21
|
+
if (e)
|
|
22
|
+
return e;
|
|
23
|
+
switch (n) {
|
|
24
|
+
case r.Info:
|
|
25
|
+
return t.Info;
|
|
26
|
+
case r.Warning:
|
|
27
|
+
return t.AlertTriangle;
|
|
28
|
+
case r.Error:
|
|
29
|
+
return t.XOctagon;
|
|
30
|
+
case r.Success:
|
|
31
|
+
return t.CheckCircle;
|
|
32
|
+
case r.Help:
|
|
33
|
+
return t.LifeBuoy;
|
|
34
|
+
default:
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
export {
|
|
39
|
+
c as getAlertIcon,
|
|
40
|
+
a as getAlertTitle
|
|
41
|
+
};
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { jsx as e, jsxs as I } from "react/jsx-runtime";
|
|
2
|
+
import { getClassName as v } from "../../../utils/get-class-name.js";
|
|
3
|
+
import { useRef as A } from "react";
|
|
4
|
+
import './Alert.css';/* empty css */
|
|
5
|
+
import { getAlertTitle as C, getAlertIcon as B } from "./Alert.helpers.js";
|
|
6
|
+
import { AlertProgressBar as M } from "./AlertProgressBar.js";
|
|
7
|
+
import { useIsMounted as T } from "../../../hooks/use-is-mounted/use-is-mounted.js";
|
|
8
|
+
import { useIsHovered as b } from "../../../hooks/use-is-hovered/use-is-hovered.js";
|
|
9
|
+
import { useRemainingTimer as w } from "../../../hooks/use-remaining-timer/use-remaining-timer.js";
|
|
10
|
+
import { AlertMode as x } from "../../../enums/alert-mode.js";
|
|
11
|
+
import H from "../../atoms/portal/Portal.js";
|
|
12
|
+
import P from "../../atoms/button/Button.js";
|
|
13
|
+
import { ElementSize as R } from "../../../enums/element-size.js";
|
|
14
|
+
import { ButtonView as j } from "../../../enums/button-view.js";
|
|
15
|
+
import { IconName as z } from "../../../enums/icon-name.js";
|
|
16
|
+
import S from "../../atoms/header/Header.js";
|
|
17
|
+
const W = ({
|
|
18
|
+
isOpened: o,
|
|
19
|
+
onClose: l,
|
|
20
|
+
title: n,
|
|
21
|
+
message: m,
|
|
22
|
+
mode: t = x.Info,
|
|
23
|
+
icon: a,
|
|
24
|
+
autoClose: i = !1,
|
|
25
|
+
autoCloseDelay: c = 3e3,
|
|
26
|
+
...f
|
|
27
|
+
}) => {
|
|
28
|
+
const r = T(o), p = r && !o, s = A(null), d = b(s, r), u = !i, g = w({
|
|
29
|
+
isOpened: r,
|
|
30
|
+
isHovered: d,
|
|
31
|
+
onClose: l,
|
|
32
|
+
autoCloseDelay: c
|
|
33
|
+
});
|
|
34
|
+
if (!r) return null;
|
|
35
|
+
const _ = C(t, n), h = B(t, a), N = v([
|
|
36
|
+
"cl-alert",
|
|
37
|
+
`cl-alert_${t.toLowerCase()}`,
|
|
38
|
+
{ "cl-alert_closing": p }
|
|
39
|
+
]);
|
|
40
|
+
return /* @__PURE__ */ e(H, { children: /* @__PURE__ */ e("div", { ref: s, className: N, children: /* @__PURE__ */ I("div", { ...f, className: "cl-alert__content", children: [
|
|
41
|
+
u && /* @__PURE__ */ e(
|
|
42
|
+
P,
|
|
43
|
+
{
|
|
44
|
+
icon: z.X,
|
|
45
|
+
view: j.Icon,
|
|
46
|
+
iconSize: R.Medium,
|
|
47
|
+
label: "Close alert",
|
|
48
|
+
onClick: l,
|
|
49
|
+
className: "cl-alert__button"
|
|
50
|
+
}
|
|
51
|
+
),
|
|
52
|
+
/* @__PURE__ */ e("header", { children: /* @__PURE__ */ e(S, { icon: h, as: "h3", className: "cl-alert__header", children: _ }) }),
|
|
53
|
+
/* @__PURE__ */ e("p", { className: "cl-alert__message", children: m }),
|
|
54
|
+
i && /* @__PURE__ */ e(M, { remainingPercentage: g })
|
|
55
|
+
] }) }) });
|
|
56
|
+
};
|
|
57
|
+
export {
|
|
58
|
+
W as default
|
|
59
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { jsx as s } from "react/jsx-runtime";
|
|
2
|
+
const t = ({ remainingPercentage: r }) => /* @__PURE__ */ s(
|
|
3
|
+
"progress",
|
|
4
|
+
{
|
|
5
|
+
className: "cl-alert__progress-bar",
|
|
6
|
+
value: r,
|
|
7
|
+
max: 100,
|
|
8
|
+
style: { width: "100%" }
|
|
9
|
+
}
|
|
10
|
+
);
|
|
11
|
+
export {
|
|
12
|
+
t as AlertProgressBar
|
|
13
|
+
};
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { jsxs as c, Fragment as l, jsx as e } from "react/jsx-runtime";
|
|
2
|
+
import i from "../../atoms/link/Link.js";
|
|
3
|
+
import o from "../../atoms/icon/Icon.js";
|
|
4
|
+
import { ElementSize as m } from "../../../enums/element-size.js";
|
|
5
|
+
import { IconName as s } from "../../../enums/icon-name.js";
|
|
6
|
+
const f = ({ item: r, isLastItem: n }) => {
|
|
7
|
+
const a = !!r.link && !n;
|
|
8
|
+
return /* @__PURE__ */ c(l, { children: [
|
|
9
|
+
/* @__PURE__ */ e("li", { className: "cl-breadcrumbs__item", children: a ? /* @__PURE__ */ e(
|
|
10
|
+
i,
|
|
11
|
+
{
|
|
12
|
+
href: r?.link ?? "",
|
|
13
|
+
icon: r.icon,
|
|
14
|
+
iconPosition: "left",
|
|
15
|
+
className: "cl-breadcrumbs__link",
|
|
16
|
+
children: r.label
|
|
17
|
+
}
|
|
18
|
+
) : /* @__PURE__ */ c("span", { "aria-current": n ? "page" : void 0, className: "cl-breadcrumbs__text", children: [
|
|
19
|
+
r.icon && /* @__PURE__ */ e(o, { name: r.icon, hidden: !0 }),
|
|
20
|
+
r.label
|
|
21
|
+
] }) }),
|
|
22
|
+
!n && /* @__PURE__ */ e(o, { name: s.ChevronRight, size: m.Small, testId: "breadcrumb-separator" })
|
|
23
|
+
] });
|
|
24
|
+
};
|
|
25
|
+
export {
|
|
26
|
+
f as default
|
|
27
|
+
};
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { jsx as e } from "react/jsx-runtime";
|
|
2
|
+
import l from "./BreadcrumbItem.js";
|
|
3
|
+
const c = ({ items: r }) => /* @__PURE__ */ e("ol", { className: "cl-breadcrumbs__list", children: r.map((a, t) => /* @__PURE__ */ e(l, { item: a, isLastItem: t === r.length - 1 }, a.label)) });
|
|
4
|
+
export {
|
|
5
|
+
c as default
|
|
6
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.cl-breadcrumbs{display:inline-block;background-color:transparent}.cl-breadcrumbs__list{display:flex;align-items:center;flex-wrap:wrap;list-style:none;margin:0;padding:0;gap:var(--cl-s-gap)}.cl-breadcrumbs__item{display:flex;align-items:center}.cl-breadcrumbs__text{display:inline-flex;align-items:center;gap:var(--cl-s-gap);color:var(--cl-base-font-color);font-family:var(--cl-core-font);font-size:var(--cl-typography-base-mobile);font-weight:400;line-height:1.5;letter-spacing:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.cl-breadcrumbs__link{color:var(--cl-base-font-color)!important}.cl-breadcrumbs__link span:before{color:var(--cl-base-font-color)}@media(min-width:640px){.cl-breadcrumbs__text{font-size:var(--cl-typography-base-tablet)}}@media(min-width:1024px){.cl-breadcrumbs__text{font-size:var(--cl-typography-base-desktop)}}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { jsx as a } from "react/jsx-runtime";
|
|
2
|
+
import { getClassName as u } from "../../../utils/get-class-name.js";
|
|
3
|
+
import './Breadcrumbs.css';/* empty css */
|
|
4
|
+
import b from "./BreadcrumbList.js";
|
|
5
|
+
const p = ({
|
|
6
|
+
items: r,
|
|
7
|
+
className: e,
|
|
8
|
+
id: m,
|
|
9
|
+
style: s,
|
|
10
|
+
tabIndex: l,
|
|
11
|
+
title: t,
|
|
12
|
+
...c
|
|
13
|
+
}) => {
|
|
14
|
+
const o = u(["cl-breadcrumbs", e]);
|
|
15
|
+
return !r || r.length === 0 ? null : /* @__PURE__ */ a(
|
|
16
|
+
"nav",
|
|
17
|
+
{
|
|
18
|
+
"aria-label": "Breadcrumb",
|
|
19
|
+
className: o,
|
|
20
|
+
id: m,
|
|
21
|
+
style: s,
|
|
22
|
+
tabIndex: l,
|
|
23
|
+
title: t,
|
|
24
|
+
...c,
|
|
25
|
+
children: /* @__PURE__ */ a(b, { items: r })
|
|
26
|
+
}
|
|
27
|
+
);
|
|
28
|
+
};
|
|
29
|
+
export {
|
|
30
|
+
p as default
|
|
31
|
+
};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { useContext as k, useState as p, useRef as i, useCallback as d } from "react";
|
|
2
|
+
import { getCheckboxInitialValue as g } from "./Checkbox.helpers.js";
|
|
3
|
+
import { FormContext as x } from "../../contexts/form/FormContext.js";
|
|
4
|
+
import { useResetFormInput as I } from "../../../hooks/use-reset-form-input/use-reset-form-input.js";
|
|
5
|
+
function v({
|
|
6
|
+
name: e,
|
|
7
|
+
defaultChecked: a,
|
|
8
|
+
onChange: l
|
|
9
|
+
}) {
|
|
10
|
+
const { onChangeFormInput: t, initialValues: h } = k(x), n = g({ initialValues: h, name: e, defaultChecked: a }), [C, r] = p(n), c = i(t), o = i(n);
|
|
11
|
+
c.current = t, o.current = n;
|
|
12
|
+
const m = (u) => {
|
|
13
|
+
const s = u.target.checked;
|
|
14
|
+
r(s), l?.(u), t?.({ name: e, value: s });
|
|
15
|
+
}, f = d(() => {
|
|
16
|
+
r(o.current), c.current?.({ name: e, value: o.current });
|
|
17
|
+
}, [e]);
|
|
18
|
+
return I(f), {
|
|
19
|
+
handleChange: m,
|
|
20
|
+
checked: C
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
export {
|
|
24
|
+
v as useCheckboxController
|
|
25
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.cl-checkbox{overflow:hidden;padding:var(--cl-m-gap);display:inline-flex;justify-content:flex-start;align-items:center}.cl-checkbox label{font-size:var(--cl-typography-base-mobile);align-items:center;gap:var(--cl-m-gap)}@media(min-width:640px){.cl-checkbox .cl-label__text{font-size:var(--cl-typography-base-tablet)}}@media(min-width:1024px){.cl-checkbox .cl-label__text{font-size:var(--cl-typography-base-desktop)}}.cl-checkbox input{position:absolute;z-index:-1;opacity:0;top:4px;left:0;margin:0}.cl-checkbox input:focus-visible+label{outline:var(--cl-outline-border);outline-offset:var(--cl-s-gap)}.cl-checkbox_checked svg{color:var(--cl-accent-a0)}.cl-checkbox_disabled{pointer-events:none;opacity:.5}
|