chop-logic-components 3.7.3 → 4.0.1
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 +5 -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 +60 -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,35 @@
|
|
|
1
|
+
import { jsx as r, jsxs as m } from "react/jsx-runtime";
|
|
2
|
+
import { GridHeaderCell as c } from "../header-cell/HeaderCell.js";
|
|
3
|
+
import { SelectAllGridRowsCell as p } from "../select-all-grid-rows-cell/SelectAllGridRowsCell.js";
|
|
4
|
+
import './GridHead.css';/* empty css */
|
|
5
|
+
const G = ({
|
|
6
|
+
columns: l,
|
|
7
|
+
gridId: t,
|
|
8
|
+
selectAll: i,
|
|
9
|
+
deselectAll: o,
|
|
10
|
+
selectable: a,
|
|
11
|
+
isAllSelected: d,
|
|
12
|
+
isAllCheckboxDisabled: s = !1
|
|
13
|
+
}) => /* @__PURE__ */ r("thead", { className: "cl-grid-head", children: /* @__PURE__ */ m("tr", { className: "cl-grid-head__row", children: [
|
|
14
|
+
a && /* @__PURE__ */ r(
|
|
15
|
+
p,
|
|
16
|
+
{
|
|
17
|
+
isAllSelected: d,
|
|
18
|
+
disabled: s,
|
|
19
|
+
gridId: t,
|
|
20
|
+
selectAll: i,
|
|
21
|
+
deselectAll: o
|
|
22
|
+
}
|
|
23
|
+
),
|
|
24
|
+
l.map((e) => /* @__PURE__ */ r(
|
|
25
|
+
c,
|
|
26
|
+
{
|
|
27
|
+
title: e.title,
|
|
28
|
+
component: e.component
|
|
29
|
+
},
|
|
30
|
+
`${e.title}_${t}`
|
|
31
|
+
))
|
|
32
|
+
] }) });
|
|
33
|
+
export {
|
|
34
|
+
G as GridHead
|
|
35
|
+
};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { jsx as e } from "react/jsx-runtime";
|
|
2
|
+
import { GridCheckbox as h } from "../checkbox/GridCheckbox.js";
|
|
3
|
+
const m = ({
|
|
4
|
+
gridId: l,
|
|
5
|
+
isAllSelected: t,
|
|
6
|
+
selectAll: c,
|
|
7
|
+
deselectAll: o,
|
|
8
|
+
disabled: r
|
|
9
|
+
}) => /* @__PURE__ */ e("th", { children: /* @__PURE__ */ e(
|
|
10
|
+
h,
|
|
11
|
+
{
|
|
12
|
+
label: "Select all rows",
|
|
13
|
+
onChange: (n) => {
|
|
14
|
+
const { checked: d } = n.target;
|
|
15
|
+
d ? c() : o();
|
|
16
|
+
},
|
|
17
|
+
id: `select_all_${l}`,
|
|
18
|
+
checked: t,
|
|
19
|
+
disabled: r
|
|
20
|
+
}
|
|
21
|
+
) });
|
|
22
|
+
export {
|
|
23
|
+
m as SelectAllGridRowsCell
|
|
24
|
+
};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { jsx as t } from "react/jsx-runtime";
|
|
2
|
+
import { GridCheckbox as h } from "../checkbox/GridCheckbox.js";
|
|
3
|
+
const m = ({
|
|
4
|
+
rowId: e,
|
|
5
|
+
isRowSelected: c,
|
|
6
|
+
selectRowById: l,
|
|
7
|
+
deselectRowById: o,
|
|
8
|
+
disabled: r
|
|
9
|
+
}) => /* @__PURE__ */ t("td", { children: /* @__PURE__ */ t(
|
|
10
|
+
h,
|
|
11
|
+
{
|
|
12
|
+
label: "Select row",
|
|
13
|
+
onChange: (d) => {
|
|
14
|
+
const { checked: n } = d.target;
|
|
15
|
+
n ? l(e) : o(e);
|
|
16
|
+
},
|
|
17
|
+
id: `select_row_${e}`,
|
|
18
|
+
checked: c,
|
|
19
|
+
disabled: r
|
|
20
|
+
}
|
|
21
|
+
) });
|
|
22
|
+
export {
|
|
23
|
+
m as SelectGridRowCell
|
|
24
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.cl-menu-bar{list-style:none;margin:0;padding:0;padding-inline-start:0;display:flex;gap:var(--cl-s-gap);flex-direction:row;justify-content:flex-start;width:100%}.cl-menu-bar_vertical{flex-direction:column}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { jsx as t } from "react/jsx-runtime";
|
|
2
|
+
import { getClassName as l } from "../../../utils/get-class-name.js";
|
|
3
|
+
import { MenuListItem as s } from "./list-item/MenuListItem.js";
|
|
4
|
+
import './Menu.css';/* empty css */
|
|
5
|
+
import { OrientationMode as m } from "../../../enums/orientation-mode.js";
|
|
6
|
+
const b = ({
|
|
7
|
+
items: a = [],
|
|
8
|
+
mode: r = m.Vertical,
|
|
9
|
+
openedOn: i = "click",
|
|
10
|
+
className: o,
|
|
11
|
+
...n
|
|
12
|
+
}) => {
|
|
13
|
+
const c = l([
|
|
14
|
+
"cl-menu-bar",
|
|
15
|
+
o,
|
|
16
|
+
{ "cl-menu-bar_vertical": r === m.Vertical }
|
|
17
|
+
]);
|
|
18
|
+
return /* @__PURE__ */ t("menu", { ...n, className: c, children: a.map((e) => /* @__PURE__ */ t(s, { item: e, mode: r, openedOn: i }, e.id)) });
|
|
19
|
+
};
|
|
20
|
+
export {
|
|
21
|
+
b as default
|
|
22
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.cl-menu-leaf{color:var(--cl-base-font-color);display:flex;justify-content:flex-start;align-items:center;gap:var(--cl-m-gap);background-color:var(--cl-base-background-color);padding:var(--cl-m-gap);border-radius:var(--cl-border-radius);cursor:pointer;background-position:center;transition:background .3s;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-menu-leaf{font-size:var(--cl-typography-base-tablet)}}@media(min-width:1024px){.cl-menu-leaf{font-size:var(--cl-typography-base-desktop)}}.cl-menu-leaf:hover{text-shadow:var(--cl-text-shadow)}.cl-menu-leaf:focus-visible{outline:var(--cl-outline-border)}.cl-menu-leaf a{color:var(--cl-base-font-color)}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { jsxs as c, jsx as e } from "react/jsx-runtime";
|
|
2
|
+
import './MenuLeaf.css';/* empty css */
|
|
3
|
+
import f from "../../../atoms/icon/Icon.js";
|
|
4
|
+
import { ElementSize as d } from "../../../../enums/element-size.js";
|
|
5
|
+
const y = ({ item: l }) => {
|
|
6
|
+
const { icon: a, link: n, label: o, onFocus: i, onClick: r, onHover: m } = l, s = n ? /* @__PURE__ */ e("a", { href: n, target: "_blank", rel: "noreferrer", children: o }) : /* @__PURE__ */ e("span", { children: o });
|
|
7
|
+
return /* @__PURE__ */ c(
|
|
8
|
+
"li",
|
|
9
|
+
{
|
|
10
|
+
className: "cl-menu-leaf",
|
|
11
|
+
tabIndex: 0,
|
|
12
|
+
role: "menuitem",
|
|
13
|
+
onFocus: i,
|
|
14
|
+
onClick: r,
|
|
15
|
+
onKeyDown: (t) => {
|
|
16
|
+
t.stopPropagation(), t.key === "Enter" && r?.();
|
|
17
|
+
},
|
|
18
|
+
onMouseOver: m,
|
|
19
|
+
children: [
|
|
20
|
+
/* @__PURE__ */ e(f, { name: a, hidden: !0, size: d.Small }),
|
|
21
|
+
s
|
|
22
|
+
]
|
|
23
|
+
}
|
|
24
|
+
);
|
|
25
|
+
};
|
|
26
|
+
export {
|
|
27
|
+
y as MenuLeaf
|
|
28
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.cl-sub-menu-bar{list-style:none;margin:0;padding:0;padding-inline-start:0;display:flex;gap:var(--cl-s-gap);justify-content:flex-start;width:100%;animation:cl-fade-in ease .4s;flex-direction:column;padding-left:var(--cl-l-gap);margin-left:var(--cl-l-gap);margin-top:var(--cl-s-gap);box-sizing:border-box;border-left:var(--cl-light-border)}.cl-sub-menu-bar_horizontal{position:absolute;top:100%;left:0%;width:max-content;border-radius:var(--cl-border-radius);border:var(--cl-light-border);box-shadow:var(--cl-box-shadow);background-color:var(--cl-base-background-color);padding:var(--cl-m-gap);margin:0;z-index:var(--cl-z-index-menu)}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { jsx as n } from "react/jsx-runtime";
|
|
2
|
+
import { getClassName as m } from "../../../../utils/get-class-name.js";
|
|
3
|
+
import { useState as b } from "react";
|
|
4
|
+
import { MenuLeaf as i } from "../leaf/MenuLeaf.js";
|
|
5
|
+
import { SubMenu as c } from "../sub-menu/SubMenu.js";
|
|
6
|
+
import './MenuListItem.css';/* empty css */
|
|
7
|
+
import { OrientationMode as M } from "../../../../enums/orientation-mode.js";
|
|
8
|
+
const p = ({ item: e, mode: t, openedOn: o }) => {
|
|
9
|
+
const a = !e?.nestedItems?.length, [s, u] = b(!1), l = m([
|
|
10
|
+
"cl-sub-menu-bar",
|
|
11
|
+
{ "cl-sub-menu-bar_horizontal": t === M.Horizontal }
|
|
12
|
+
]);
|
|
13
|
+
return a ? /* @__PURE__ */ n(i, { item: e }) : /* @__PURE__ */ n(
|
|
14
|
+
c,
|
|
15
|
+
{
|
|
16
|
+
item: e,
|
|
17
|
+
isSubMenuOpened: s,
|
|
18
|
+
toggleSubMenu: () => {
|
|
19
|
+
u(!s);
|
|
20
|
+
},
|
|
21
|
+
closeSubMenu: () => {
|
|
22
|
+
u(!1);
|
|
23
|
+
},
|
|
24
|
+
openSubMenu: () => {
|
|
25
|
+
u(!0);
|
|
26
|
+
},
|
|
27
|
+
mode: t,
|
|
28
|
+
openedOn: o,
|
|
29
|
+
children: /* @__PURE__ */ n("ul", { className: l, role: "menu", "aria-label": e.label, children: e?.nestedItems?.map((r) => /* @__PURE__ */ n(p, { item: r, mode: t, openedOn: o }, r.id)) })
|
|
30
|
+
}
|
|
31
|
+
);
|
|
32
|
+
};
|
|
33
|
+
export {
|
|
34
|
+
p as MenuListItem
|
|
35
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.cl-sub-menu{display:flex;justify-content:flex-start;align-items:center;flex-direction:column;gap:0;padding:0;position:relative;border-radius:var(--cl-border-radius)}.cl-sub-menu:focus-visible{outline:var(--cl-outline-border)}.cl-sub-menu a{color:var(--cl-base-font-color);text-decoration:none}.cl-sub-menu__text{color:var(--cl-base-font-color);position:relative;display:flex;box-sizing:border-box;gap:var(--cl-m-gap);align-items:center;width:100%;justify-content:space-between;background:transparent;padding:var(--cl-m-gap);border-radius:var(--cl-border-radius);cursor:pointer;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-sub-menu__text{font-size:var(--cl-typography-base-tablet)}}@media(min-width:1024px){.cl-sub-menu__text{font-size:var(--cl-typography-base-desktop)}}.cl-sub-menu__text:hover{text-shadow:var(--cl-text-shadow)}.cl-sub-menu__text:hover svg{filter:var(--cl-drop-shadow)}.cl-sub-menu__text span{display:flex;gap:var(--cl-m-gap);align-items:center}.cl-sub-menu__icon_opened{transform:rotate(180deg)}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { jsxs as e, jsx as n } from "react/jsx-runtime";
|
|
2
|
+
import { getClassName as b } from "../../../../utils/get-class-name.js";
|
|
3
|
+
import { useRef as h } from "react";
|
|
4
|
+
import './SubMenu.css';/* empty css */
|
|
5
|
+
import r from "../../../atoms/icon/Icon.js";
|
|
6
|
+
import { ElementSize as t } from "../../../../enums/element-size.js";
|
|
7
|
+
import { useClickOutside as w } from "../../../../hooks/use-click-outside/use-click-outside.js";
|
|
8
|
+
import { IconName as y } from "../../../../enums/icon-name.js";
|
|
9
|
+
import { OrientationMode as z } from "../../../../enums/orientation-mode.js";
|
|
10
|
+
const P = ({
|
|
11
|
+
item: C,
|
|
12
|
+
isSubMenuOpened: o,
|
|
13
|
+
toggleSubMenu: i,
|
|
14
|
+
closeSubMenu: a,
|
|
15
|
+
openSubMenu: _,
|
|
16
|
+
openedOn: l,
|
|
17
|
+
mode: k,
|
|
18
|
+
children: v
|
|
19
|
+
}) => {
|
|
20
|
+
const { icon: m, link: s, label: c } = C, p = h(null), d = h(null), x = b([
|
|
21
|
+
"cl-sub-menu__icon",
|
|
22
|
+
{ "cl-sub-menu__icon_opened": o }
|
|
23
|
+
]), N = s ? /* @__PURE__ */ e("a", { href: s, target: "_blank", rel: "noreferrer", children: [
|
|
24
|
+
/* @__PURE__ */ n(r, { name: m, size: t.Small }),
|
|
25
|
+
c
|
|
26
|
+
] }) : /* @__PURE__ */ e("span", { children: [
|
|
27
|
+
/* @__PURE__ */ n(r, { name: m, size: t.Small }),
|
|
28
|
+
c
|
|
29
|
+
] }), f = (u) => {
|
|
30
|
+
u.stopPropagation(), u.key === " " && i();
|
|
31
|
+
};
|
|
32
|
+
return w({ ref: p, dependentRef: d, onClickOutsideHandler: () => {
|
|
33
|
+
k !== z.Vertical && a();
|
|
34
|
+
} }), /* @__PURE__ */ e(
|
|
35
|
+
"li",
|
|
36
|
+
{
|
|
37
|
+
className: "cl-sub-menu",
|
|
38
|
+
tabIndex: 0,
|
|
39
|
+
role: "menuitem",
|
|
40
|
+
"aria-haspopup": "true",
|
|
41
|
+
"aria-expanded": o,
|
|
42
|
+
onKeyDown: f,
|
|
43
|
+
onMouseEnter: l === "hover" ? _ : void 0,
|
|
44
|
+
onMouseLeave: l === "hover" ? a : void 0,
|
|
45
|
+
ref: p,
|
|
46
|
+
children: [
|
|
47
|
+
/* @__PURE__ */ e(
|
|
48
|
+
"span",
|
|
49
|
+
{
|
|
50
|
+
className: "cl-sub-menu__text",
|
|
51
|
+
ref: d,
|
|
52
|
+
onClick: i,
|
|
53
|
+
onKeyDown: f,
|
|
54
|
+
children: [
|
|
55
|
+
N,
|
|
56
|
+
/* @__PURE__ */ n(r, { name: y.ChevronDown, className: x, size: t.Small })
|
|
57
|
+
]
|
|
58
|
+
}
|
|
59
|
+
),
|
|
60
|
+
o && v
|
|
61
|
+
]
|
|
62
|
+
}
|
|
63
|
+
);
|
|
64
|
+
};
|
|
65
|
+
export {
|
|
66
|
+
P as SubMenu
|
|
67
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.cl-tabs{display:flex;flex-direction:column;width:100%}.cl-tabs_vertical{flex-direction:row}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { jsxs as H, jsx as b } from "react/jsx-runtime";
|
|
2
|
+
import { getClassName as L } from "../../../utils/get-class-name.js";
|
|
3
|
+
import { useState as r } from "react";
|
|
4
|
+
import { TabContent as M } from "./content/TabContent.js";
|
|
5
|
+
import { TabList as P } from "./list/TabList.js";
|
|
6
|
+
import './Tabs.css';/* empty css */
|
|
7
|
+
import { OrientationMode as C } from "../../../enums/orientation-mode.js";
|
|
8
|
+
const Q = ({
|
|
9
|
+
tabs: T,
|
|
10
|
+
defaultTabId: o,
|
|
11
|
+
className: g,
|
|
12
|
+
mode: m = C.Horizontal,
|
|
13
|
+
stretched: u = !1,
|
|
14
|
+
editable: S = !1,
|
|
15
|
+
extendable: f = !1,
|
|
16
|
+
extendedTabLabel: v = "New Tab",
|
|
17
|
+
extendedTabContent: h,
|
|
18
|
+
onTabTitleChange: w,
|
|
19
|
+
onTabAdd: x,
|
|
20
|
+
onTabSelect: A,
|
|
21
|
+
onTabDelete: D,
|
|
22
|
+
...N
|
|
23
|
+
}) => {
|
|
24
|
+
const [l, i] = r(T), $ = T.length, [p, j] = r($ + 1), n = l.map((e) => e.id), I = n.map((e) => `tabpanel_${e}`), O = o && n.includes(o) ? o : n[0], [c, _] = r(O), z = L([
|
|
25
|
+
"cl-tabs",
|
|
26
|
+
g,
|
|
27
|
+
{ "cl-tabs_vertical": m === C.Vertical }
|
|
28
|
+
]), d = (e) => {
|
|
29
|
+
_(e), A?.(e);
|
|
30
|
+
};
|
|
31
|
+
return /* @__PURE__ */ H("div", { ...N, className: z, children: [
|
|
32
|
+
/* @__PURE__ */ b(
|
|
33
|
+
P,
|
|
34
|
+
{
|
|
35
|
+
tabs: l,
|
|
36
|
+
selectedTabId: c,
|
|
37
|
+
tabPanelIds: I,
|
|
38
|
+
onTabSelect: d,
|
|
39
|
+
onTabTitleChange: (e, a) => {
|
|
40
|
+
i(
|
|
41
|
+
(t) => t.map((s) => s.id === e ? { ...s, title: a } : s)
|
|
42
|
+
), w?.(e, a);
|
|
43
|
+
},
|
|
44
|
+
mode: m,
|
|
45
|
+
tabIds: n,
|
|
46
|
+
stretched: u,
|
|
47
|
+
editable: S,
|
|
48
|
+
extendable: f,
|
|
49
|
+
onTabAdd: () => {
|
|
50
|
+
const e = `added-tab-${p}`, a = v || `Tab ${p}`, t = {
|
|
51
|
+
id: e,
|
|
52
|
+
title: a,
|
|
53
|
+
content: h || /* @__PURE__ */ b("div", {})
|
|
54
|
+
};
|
|
55
|
+
i((s) => [...s, t]), j((s) => s + 1), x?.(), d(e);
|
|
56
|
+
},
|
|
57
|
+
onTabDelete: (e) => {
|
|
58
|
+
if (i((a) => a.filter((t) => t.id !== e)), c === e) {
|
|
59
|
+
const a = n.indexOf(e);
|
|
60
|
+
let t;
|
|
61
|
+
a > 0 ? t = n[a - 1] : n.length > 1 ? t = n[1] : t = void 0, t && d(t);
|
|
62
|
+
}
|
|
63
|
+
D?.(e);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
),
|
|
67
|
+
/* @__PURE__ */ b(
|
|
68
|
+
M,
|
|
69
|
+
{
|
|
70
|
+
tabs: l,
|
|
71
|
+
selectedTabId: c,
|
|
72
|
+
extendedTabContent: h,
|
|
73
|
+
extendable: f
|
|
74
|
+
}
|
|
75
|
+
)
|
|
76
|
+
] });
|
|
77
|
+
};
|
|
78
|
+
export {
|
|
79
|
+
Q as default
|
|
80
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.cl-tab{color:var(--cl-base-font-color);background:transparent;outline:none;border:none;padding:var(--cl-m-gap);cursor:pointer;flex:1;border-radius:var(--cl-border-radius);white-space:nowrap;text-overflow:ellipsis;overflow:hidden;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-tab{font-size:var(--cl-typography-base-tablet)}}@media(min-width:1024px){.cl-tab{font-size:var(--cl-typography-base-desktop)}}.cl-tab:focus-visible{outline:var(--cl-outline-border);outline-offset:-4px}.cl-tab__wrapper{position:relative;display:flex;align-items:center;justify-content:space-between;gap:var(--cl-l-gap);border-radius:var(--cl-border-radius);border:var(--cl-light-border);background-color:var(--cl-surface-a10)}.cl-tab__buttons{margin-right:var(--cl-s-gap);display:flex;align-items:center;gap:0}.cl-tab__wrapper_selected{top:var(--cl-xs-gap);box-shadow:var(--cl-box-shadow);border:var(--cl-light-border);background-color:var(--cl-base-background-color)}.cl-tab__wrapper_vertical .cl-tab__wrapper_selected{top:0;left:var(--cl-xs-gap)}.cl-tab__wrapper_vertical .cl-tab__buttons{flex-direction:column}.cl-tab__wrapper_stretched{flex:1}.cl-tab__wrapper_disabled{pointer-events:none;opacity:.5}.cl-tab__wrapper_inactive{opacity:.7}.cl-tab__wrapper_inactive:hover{opacity:1}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
import { jsx as l, jsxs as B, Fragment as A } from "react/jsx-runtime";
|
|
2
|
+
import { getClassName as F } from "../../../../utils/get-class-name.js";
|
|
3
|
+
import { useState as E, useRef as O, useId as q, useEffect as g } from "react";
|
|
4
|
+
import { TabEditInput as G } from "../edit-input/TabEditInput.js";
|
|
5
|
+
import './TabButton.css';/* empty css */
|
|
6
|
+
import { OrientationMode as H } from "../../../../enums/orientation-mode.js";
|
|
7
|
+
import w from "../../../atoms/button/Button.js";
|
|
8
|
+
import { ElementSize as C } from "../../../../enums/element-size.js";
|
|
9
|
+
import { IconName as I } from "../../../../enums/icon-name.js";
|
|
10
|
+
import { ButtonView as v } from "../../../../enums/button-view.js";
|
|
11
|
+
const nt = ({
|
|
12
|
+
title: e,
|
|
13
|
+
onTabSelect: T,
|
|
14
|
+
onTabTitleChange: k,
|
|
15
|
+
onTabDelete: d,
|
|
16
|
+
tabId: c,
|
|
17
|
+
isSelected: a,
|
|
18
|
+
isDisabled: o = !1,
|
|
19
|
+
stretched: y = !1,
|
|
20
|
+
editable: f = !1,
|
|
21
|
+
extendable: V = !1,
|
|
22
|
+
tabPanelId: N,
|
|
23
|
+
mode: M
|
|
24
|
+
}) => {
|
|
25
|
+
const [n, i] = E(!1), [r, s] = E(e), p = O(null), m = q(), _ = f && !o && a, b = V && !o && !!d && a, x = _ || b, z = F([
|
|
26
|
+
"cl-tab__wrapper",
|
|
27
|
+
{
|
|
28
|
+
"cl-tab__wrapper_disabled": o,
|
|
29
|
+
"cl-tab__wrapper_vertical": M === H.Vertical,
|
|
30
|
+
"cl-tab__wrapper_selected": a,
|
|
31
|
+
"cl-tab__wrapper_stretched": y,
|
|
32
|
+
"cl-tab__wrapper_editable": f,
|
|
33
|
+
"cl-tab__wrapper_inactive": !a
|
|
34
|
+
}
|
|
35
|
+
]);
|
|
36
|
+
g(() => {
|
|
37
|
+
n && p.current && (p.current.focus(), p.current.select());
|
|
38
|
+
}, [n]), g(() => {
|
|
39
|
+
s(e);
|
|
40
|
+
}, [e]);
|
|
41
|
+
const S = () => {
|
|
42
|
+
o || i(!n);
|
|
43
|
+
}, j = () => {
|
|
44
|
+
n || T(c);
|
|
45
|
+
}, D = (t) => {
|
|
46
|
+
s(t.target.value);
|
|
47
|
+
}, K = (t) => {
|
|
48
|
+
t.relatedTarget?.id === m || u();
|
|
49
|
+
}, R = (t) => {
|
|
50
|
+
t.key === "Enter" ? (t.preventDefault(), u()) : t.key === "Escape" && (t.preventDefault(), h());
|
|
51
|
+
}, u = () => {
|
|
52
|
+
r.trim() && r !== e ? k?.(r.trim()) : s(e), i(!1);
|
|
53
|
+
}, h = () => {
|
|
54
|
+
s(e), i(!1);
|
|
55
|
+
};
|
|
56
|
+
return /* @__PURE__ */ l("span", { className: z, children: n ? /* @__PURE__ */ l(
|
|
57
|
+
G,
|
|
58
|
+
{
|
|
59
|
+
tabId: c,
|
|
60
|
+
editValue: r,
|
|
61
|
+
isEditMode: n,
|
|
62
|
+
onInputChange: D,
|
|
63
|
+
onInputBlur: K,
|
|
64
|
+
onInputKeyDown: R,
|
|
65
|
+
onSave: u,
|
|
66
|
+
onCancel: h,
|
|
67
|
+
cancelButtonId: m
|
|
68
|
+
}
|
|
69
|
+
) : /* @__PURE__ */ B(A, { children: [
|
|
70
|
+
/* @__PURE__ */ l(
|
|
71
|
+
"button",
|
|
72
|
+
{
|
|
73
|
+
role: "tab",
|
|
74
|
+
id: c,
|
|
75
|
+
onClick: j,
|
|
76
|
+
"aria-selected": a,
|
|
77
|
+
"aria-controls": N,
|
|
78
|
+
className: "cl-tab",
|
|
79
|
+
disabled: o,
|
|
80
|
+
children: r
|
|
81
|
+
}
|
|
82
|
+
),
|
|
83
|
+
x && /* @__PURE__ */ B("span", { className: "cl-tab__buttons", children: [
|
|
84
|
+
_ && /* @__PURE__ */ l(
|
|
85
|
+
w,
|
|
86
|
+
{
|
|
87
|
+
view: v.Icon,
|
|
88
|
+
icon: I.Edit3,
|
|
89
|
+
onClick: S,
|
|
90
|
+
label: "Edit tab",
|
|
91
|
+
tooltip: "Edit tab",
|
|
92
|
+
iconSize: C.Small
|
|
93
|
+
}
|
|
94
|
+
),
|
|
95
|
+
b && /* @__PURE__ */ l(
|
|
96
|
+
w,
|
|
97
|
+
{
|
|
98
|
+
view: v.Icon,
|
|
99
|
+
icon: I.Trash2,
|
|
100
|
+
onClick: () => d?.(c),
|
|
101
|
+
label: "Delete tab",
|
|
102
|
+
tooltip: "Delete tab",
|
|
103
|
+
iconSize: C.Small
|
|
104
|
+
}
|
|
105
|
+
)
|
|
106
|
+
] })
|
|
107
|
+
] }) });
|
|
108
|
+
};
|
|
109
|
+
export {
|
|
110
|
+
nt as TabButton
|
|
111
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.cl-tab-content{color:var(--cl-base-font-color);border-top:var(--cl-light-border);background-color:var(--cl-base-background-color);padding:var(--cl-l-gap);flex-grow:1;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-tab-content{font-size:var(--cl-typography-base-tablet)}}@media(min-width:1024px){.cl-tab-content{font-size:var(--cl-typography-base-desktop)}}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { jsx as d } from "react/jsx-runtime";
|
|
2
|
+
import './TabContent.css';/* empty css */
|
|
3
|
+
const l = ({ tabs: o, selectedTabId: t, extendable: a, extendedTabContent: e }) => {
|
|
4
|
+
const n = o.find((c) => c.id === t)?.content, i = `tabpanel_${t}`;
|
|
5
|
+
return /* @__PURE__ */ d(
|
|
6
|
+
"div",
|
|
7
|
+
{
|
|
8
|
+
role: "tabpanel",
|
|
9
|
+
"data-testid": "tab-content",
|
|
10
|
+
"aria-labelledby": t,
|
|
11
|
+
id: i,
|
|
12
|
+
className: "cl-tab-content",
|
|
13
|
+
children: a && !n ? e : n
|
|
14
|
+
}
|
|
15
|
+
);
|
|
16
|
+
};
|
|
17
|
+
export {
|
|
18
|
+
l as TabContent
|
|
19
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.cl-tab-edit-container{display:flex;align-items:center;justify-content:space-between;gap:var(--cl-s-gap);width:100%;padding:0 var(--cl-s-gap)}.cl-tab-edit-container__input{flex:1;padding-block:0;padding-inline:0;padding:var(--cl-s-gap);border:var(--cl-light-border);border-radius:var(--cl-border-radius);color:var(--cl-base-font-color);background:transparent;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-tab-edit-container__input{font-size:var(--cl-typography-base-tablet)}}@media(min-width:1024px){.cl-tab-edit-container__input{font-size:var(--cl-typography-base-desktop)}}.cl-tab-edit-container__input:focus-visible,.cl-tab-edit-container__input:focus{outline:none}.cl-tab-edit-container__buttons{display:flex;align-items:center}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { jsxs as i, jsx as e } from "react/jsx-runtime";
|
|
2
|
+
import { useRef as h, useEffect as S } from "react";
|
|
3
|
+
import './TabEditInput.css';/* empty css */
|
|
4
|
+
import o from "../../../atoms/button/Button.js";
|
|
5
|
+
import { ElementSize as c } from "../../../../enums/element-size.js";
|
|
6
|
+
import { IconName as r } from "../../../../enums/icon-name.js";
|
|
7
|
+
import { ButtonView as a } from "../../../../enums/button-view.js";
|
|
8
|
+
const g = ({
|
|
9
|
+
tabId: l,
|
|
10
|
+
isEditMode: n,
|
|
11
|
+
editValue: m,
|
|
12
|
+
onInputChange: u,
|
|
13
|
+
onInputBlur: s,
|
|
14
|
+
onInputKeyDown: p,
|
|
15
|
+
onSave: f,
|
|
16
|
+
onCancel: b,
|
|
17
|
+
cancelButtonId: d
|
|
18
|
+
}) => {
|
|
19
|
+
const t = h(null);
|
|
20
|
+
return S(() => {
|
|
21
|
+
n && t.current && (t.current.focus(), t.current.select());
|
|
22
|
+
}, [n]), /* @__PURE__ */ i("div", { className: "cl-tab-edit-container", children: [
|
|
23
|
+
/* @__PURE__ */ e(
|
|
24
|
+
"input",
|
|
25
|
+
{
|
|
26
|
+
ref: t,
|
|
27
|
+
id: `${l}-input`,
|
|
28
|
+
type: "text",
|
|
29
|
+
value: m,
|
|
30
|
+
onChange: u,
|
|
31
|
+
onBlur: s,
|
|
32
|
+
onKeyDown: p,
|
|
33
|
+
className: "cl-tab-edit-container__input",
|
|
34
|
+
maxLength: 50
|
|
35
|
+
}
|
|
36
|
+
),
|
|
37
|
+
/* @__PURE__ */ i("span", { className: "cl-tab-edit-container__buttons", children: [
|
|
38
|
+
/* @__PURE__ */ e(
|
|
39
|
+
o,
|
|
40
|
+
{
|
|
41
|
+
view: a.Icon,
|
|
42
|
+
icon: r.Check,
|
|
43
|
+
onClick: f,
|
|
44
|
+
label: "Save tab title",
|
|
45
|
+
iconSize: c.Small
|
|
46
|
+
}
|
|
47
|
+
),
|
|
48
|
+
/* @__PURE__ */ e(
|
|
49
|
+
o,
|
|
50
|
+
{
|
|
51
|
+
view: a.Icon,
|
|
52
|
+
icon: r.X,
|
|
53
|
+
onClick: b,
|
|
54
|
+
label: "Cancel tab title change",
|
|
55
|
+
id: d,
|
|
56
|
+
iconSize: c.Small
|
|
57
|
+
}
|
|
58
|
+
)
|
|
59
|
+
] })
|
|
60
|
+
] });
|
|
61
|
+
};
|
|
62
|
+
export {
|
|
63
|
+
g as TabEditInput
|
|
64
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.cl-tab-list{padding:0 var(--cl-m-gap) var(--cl-m-gap) var(--cl-m-gap);display:flex;gap:var(--cl-m-gap);max-width:100%;overflow-y:hidden;overflow-x:auto}.cl-tab-list:focus{outline:var(--cl-outline-border);outline-offset:4px}.cl-tab-list>span:last-of-type{display:flex;align-items:center;justify-content:center}.cl-tab-list>span:last-of-type button{width:100%}.cl-tab-list_vertical{flex-shrink:0;flex-direction:column;border-bottom:none;border-right:var(--cl-light-border);padding:var(--cl-m-gap) var(--cl-m-gap) var(--cl-m-gap) 0;max-height:100%;overflow-x:hidden;overflow-y:auto}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { jsxs as h, jsx as p } from "react/jsx-runtime";
|
|
2
|
+
import { getClassName as D } from "../../../../utils/get-class-name.js";
|
|
3
|
+
import { moveFocusOnElementById as L } from "../../../../utils/move-focus-on-element-by-id.js";
|
|
4
|
+
import { TabButton as P } from "../button/TabButton.js";
|
|
5
|
+
import './TabList.css';/* empty css */
|
|
6
|
+
import { OrientationMode as s } from "../../../../enums/orientation-mode.js";
|
|
7
|
+
import B from "../../../atoms/button/Button.js";
|
|
8
|
+
import { IconName as C } from "../../../../enums/icon-name.js";
|
|
9
|
+
import { ButtonView as I } from "../../../../enums/button-view.js";
|
|
10
|
+
const E = ({
|
|
11
|
+
tabs: u,
|
|
12
|
+
onTabSelect: l,
|
|
13
|
+
onTabTitleChange: a,
|
|
14
|
+
selectedTabId: c,
|
|
15
|
+
tabPanelIds: w,
|
|
16
|
+
mode: e,
|
|
17
|
+
tabIds: i,
|
|
18
|
+
stretched: d,
|
|
19
|
+
editable: A = !1,
|
|
20
|
+
extendable: m = !1,
|
|
21
|
+
onTabAdd: v,
|
|
22
|
+
onTabDelete: b
|
|
23
|
+
}) => {
|
|
24
|
+
const y = D([
|
|
25
|
+
"cl-tab-list",
|
|
26
|
+
{ "cl-tab-list_vertical": e === s.Vertical }
|
|
27
|
+
]), g = (t) => {
|
|
28
|
+
const o = i.indexOf(c);
|
|
29
|
+
if (!["ArrowLeft", "ArrowUp", "ArrowRight", "ArrowDown"].includes(t.key) || (t.preventDefault(), t.key === "ArrowUp" && e === s.Horizontal || t.key === "ArrowLeft" && e === s.Vertical))
|
|
30
|
+
return;
|
|
31
|
+
const n = t.key === "ArrowLeft" || t.key === "ArrowUp" ? k(o, i.length) : x(o, i.length), r = i[n];
|
|
32
|
+
r && (L(r), l(r));
|
|
33
|
+
}, k = (t, o) => t - 1 >= 0 ? t - 1 : o - 1, x = (t, o) => t === o - 1 ? 0 : t + 1;
|
|
34
|
+
return /* @__PURE__ */ h("div", { role: "tablist", "data-testid": "tab-list", onKeyDown: g, className: y, children: [
|
|
35
|
+
u.map(({ id: t, title: o, disabled: f }, n) => /* @__PURE__ */ p(
|
|
36
|
+
P,
|
|
37
|
+
{
|
|
38
|
+
title: o,
|
|
39
|
+
onTabSelect: l,
|
|
40
|
+
onTabTitleChange: a ? (r) => a(t, r) : void 0,
|
|
41
|
+
tabId: t,
|
|
42
|
+
isSelected: t === c,
|
|
43
|
+
isDisabled: f,
|
|
44
|
+
tabPanelId: w[n],
|
|
45
|
+
mode: e,
|
|
46
|
+
stretched: d,
|
|
47
|
+
editable: A,
|
|
48
|
+
extendable: m,
|
|
49
|
+
onTabDelete: b
|
|
50
|
+
},
|
|
51
|
+
t
|
|
52
|
+
)),
|
|
53
|
+
m && /* @__PURE__ */ p(
|
|
54
|
+
B,
|
|
55
|
+
{
|
|
56
|
+
label: "Add Tab",
|
|
57
|
+
tooltip: "Add Tab",
|
|
58
|
+
view: I.Icon,
|
|
59
|
+
icon: C.PlusCircle,
|
|
60
|
+
onClick: v
|
|
61
|
+
}
|
|
62
|
+
)
|
|
63
|
+
] });
|
|
64
|
+
};
|
|
65
|
+
export {
|
|
66
|
+
E as TabList
|
|
67
|
+
};
|