chop-logic-components 4.0.0 → 4.0.3
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 +6 -0
- package/dist/components/atoms/button/Button.css +1 -1
- package/dist/components/atoms/button/Button2.js +51 -0
- package/dist/components/atoms/button/icon-button/IconButton.css +1 -1
- package/dist/components/atoms/button/icon-button/IconButton2.js +18 -0
- package/dist/components/atoms/button/inner-button/InnerButton.css +1 -1
- package/dist/components/atoms/button/inner-button/InnerButton2.js +21 -0
- package/dist/components/atoms/button/primary-button/PrimaryButton.css +1 -1
- package/dist/components/atoms/button/primary-button/PrimaryButton2.js +20 -0
- package/dist/components/atoms/button/secondary-button/SecondaryButton.css +1 -1
- package/dist/components/atoms/button/secondary-button/SecondaryButton2.js +20 -0
- package/dist/components/atoms/editable-text/EditView.js +18 -37
- package/dist/components/atoms/editable-text/EditableText.css +1 -1
- package/dist/components/atoms/editable-text/EditableText2.js +53 -0
- package/dist/components/atoms/editable-text/ReadView.js +16 -25
- package/dist/components/atoms/editable-text/useEditModeState.js +16 -16
- package/dist/components/atoms/editable-text/useInputFocus.js +13 -8
- package/dist/components/atoms/editable-text/useValueState.js +20 -20
- package/dist/components/atoms/error-message/ErrorMessage.css +1 -1
- package/dist/components/atoms/error-message/ErrorMessage2.js +18 -0
- package/dist/components/atoms/header/Header.css +1 -1
- package/dist/components/atoms/header/Header2.js +23 -0
- package/dist/components/atoms/icon/Icon.css +1 -1
- package/dist/components/atoms/icon/Icon2.js +29 -0
- package/dist/components/atoms/image/BasicImage.js +15 -27
- package/dist/components/atoms/image/FallBackImage.js +16 -10
- package/dist/components/atoms/image/Image.css +1 -1
- package/dist/components/atoms/image/Image2.js +28 -0
- package/dist/components/atoms/image/ResponsivePicture.js +13 -17
- package/dist/components/atoms/input/Input.css +1 -1
- package/dist/components/atoms/input/Input2.js +13 -0
- package/dist/components/atoms/label/Label.css +1 -1
- package/dist/components/atoms/label/Label2.js +35 -0
- package/dist/components/atoms/link/Link.css +1 -1
- package/dist/components/atoms/link/Link2.js +36 -0
- package/dist/components/atoms/portal/Portal.js +10 -10
- package/dist/components/atoms/tooltip/Tooltip.controller.js +42 -34
- package/dist/components/atoms/tooltip/Tooltip.css +1 -1
- package/dist/components/atoms/tooltip/Tooltip2.js +49 -0
- package/dist/components/contexts/form/FormContext.js +5 -5
- package/dist/components/contexts/theme/ThemeContext.js +6 -9
- package/dist/components/contexts/theme/ThemeProvider.js +23 -20
- package/dist/components/hocs/with-figure-caption/Figure.css +1 -1
- package/dist/components/hocs/with-figure-caption/with-figure-caption.js +13 -10
- package/dist/components/hocs/with-tooltip/with-tooltip.js +10 -6
- package/dist/components/molecules/accordion/Accordion.css +1 -1
- package/dist/components/molecules/accordion/Accordion2.js +11 -0
- package/dist/components/molecules/accordion/AccordionItem.css +1 -1
- package/dist/components/molecules/accordion/AccordionItem2.js +24 -0
- package/dist/components/molecules/alert/Alert.css +1 -1
- package/dist/components/molecules/alert/Alert.helpers.js +24 -38
- package/dist/components/molecules/alert/Alert2.js +63 -0
- package/dist/components/molecules/alert/AlertProgressBar.js +10 -13
- package/dist/components/molecules/breadcrumbs/BreadcrumbItem.js +29 -27
- package/dist/components/molecules/breadcrumbs/BreadcrumbList.js +12 -6
- package/dist/components/molecules/breadcrumbs/Breadcrumbs.css +1 -1
- package/dist/components/molecules/breadcrumbs/Breadcrumbs2.js +20 -0
- package/dist/components/molecules/checkbox/Checkbox.controller.js +28 -24
- package/dist/components/molecules/checkbox/Checkbox.css +1 -1
- package/dist/components/molecules/checkbox/Checkbox.helpers.js +5 -9
- package/dist/components/molecules/checkbox/Checkbox2.js +7 -0
- package/dist/components/molecules/checkbox/CheckboxStateful.js +46 -59
- package/dist/components/molecules/checkbox/CheckboxStateless.js +41 -58
- package/dist/components/molecules/multi-select/MultiSelect.Combobox.js +34 -46
- package/dist/components/molecules/multi-select/MultiSelect.Dropdown.js +22 -30
- package/dist/components/molecules/multi-select/MultiSelect.controller.js +32 -36
- package/dist/components/molecules/multi-select/MultiSelect.helpers.js +17 -20
- package/dist/components/molecules/multi-select/MultiSelect.js +59 -60
- package/dist/components/molecules/multi-select/MultiSelectComboboxSelectedValues.js +7 -7
- package/dist/components/molecules/multi-select/Option.js +40 -39
- package/dist/components/molecules/numeric-input/NumericInput.controller.js +50 -44
- package/dist/components/molecules/numeric-input/NumericInput.css +1 -1
- package/dist/components/molecules/numeric-input/NumericInput.helpers.js +7 -18
- package/dist/components/molecules/numeric-input/NumericInput2.js +7 -0
- package/dist/components/molecules/numeric-input/NumericInputStateful.js +72 -107
- package/dist/components/molecules/numeric-input/NumericInputStateless.js +60 -95
- package/dist/components/molecules/search/Search.controller.js +31 -41
- package/dist/components/molecules/search/Search.css +1 -1
- package/dist/components/molecules/search/Search2.js +67 -0
- package/dist/components/molecules/select/Select.controller.js +35 -31
- package/dist/components/molecules/select/Select.css +1 -1
- package/dist/components/molecules/select/Select.helpers.js +10 -15
- package/dist/components/molecules/select/Select2.js +62 -0
- package/dist/components/molecules/select/combobox/Combobox.css +1 -1
- package/dist/components/molecules/select/combobox/Combobox2.js +31 -0
- package/dist/components/molecules/select/dropdown/Dropdown.css +1 -1
- package/dist/components/molecules/select/dropdown/Dropdown2.js +31 -0
- package/dist/components/molecules/select/option/Option.css +1 -1
- package/dist/components/molecules/select/option/Option2.js +36 -0
- package/dist/components/molecules/switch/Switch.controller.js +32 -32
- package/dist/components/molecules/switch/Switch.css +1 -1
- package/dist/components/molecules/switch/Switch.helpers.js +5 -9
- package/dist/components/molecules/switch/Switch2.js +58 -0
- package/dist/components/molecules/text-input/TextInput.controller.js +46 -35
- package/dist/components/molecules/text-input/TextInput.css +1 -1
- package/dist/components/molecules/text-input/TextInput.helpers.js +7 -16
- package/dist/components/molecules/text-input/TextInput2.js +7 -0
- package/dist/components/molecules/text-input/TextInputButtons.js +20 -37
- package/dist/components/molecules/text-input/TextInputStateful.js +62 -91
- package/dist/components/molecules/text-input/TextInputStateless.js +59 -88
- package/dist/components/organisms/dialog/Dialog.css +1 -1
- package/dist/components/organisms/dialog/Dialog2.js +50 -0
- package/dist/components/organisms/form/Form.controller.js +28 -28
- package/dist/components/organisms/form/Form.css +1 -1
- package/dist/components/organisms/form/Form.helpers.js +9 -11
- package/dist/components/organisms/form/Form2.js +52 -0
- package/dist/components/organisms/grid/Grid.controller.js +27 -33
- package/dist/components/organisms/grid/Grid.css +1 -1
- package/dist/components/organisms/grid/Grid.helpers.js +13 -14
- package/dist/components/organisms/grid/Grid2.js +52 -0
- package/dist/components/organisms/grid/body/GridBody.css +1 -1
- package/dist/components/organisms/grid/body/GridBody2.js +26 -0
- package/dist/components/organisms/grid/checkbox/GridCheckbox.css +1 -1
- package/dist/components/organisms/grid/checkbox/GridCheckbox2.js +35 -0
- package/dist/components/organisms/grid/column-group/GridColumnGroup2.js +14 -0
- package/dist/components/organisms/grid/data-cell/GridDataCell.js +5 -5
- package/dist/components/organisms/grid/grid-row/GridRow2.js +24 -0
- package/dist/components/organisms/grid/head/GridHead.css +1 -1
- package/dist/components/organisms/grid/head/GridHead2.js +23 -0
- package/dist/components/organisms/grid/header-cell/HeaderCell.js +5 -8
- package/dist/components/organisms/grid/select-all-grid-rows-cell/SelectAllGridRowsCell.js +15 -24
- package/dist/components/organisms/grid/select-grid-row-cell/SelectGridRowCell.js +14 -23
- package/dist/components/organisms/menu/Menu.css +1 -1
- package/dist/components/organisms/menu/Menu2.js +24 -0
- package/dist/components/organisms/menu/leaf/MenuLeaf.css +1 -1
- package/dist/components/organisms/menu/leaf/MenuLeaf2.js +31 -0
- package/dist/components/organisms/menu/list-item/MenuListItem.css +1 -1
- package/dist/components/organisms/menu/list-item/MenuListItem2.js +38 -0
- package/dist/components/organisms/menu/sub-menu/SubMenu.css +1 -1
- package/dist/components/organisms/menu/sub-menu/SubMenu2.js +56 -0
- package/dist/components/organisms/tabs/Tabs.css +1 -1
- package/dist/components/organisms/tabs/Tabs2.js +60 -0
- package/dist/components/organisms/tabs/button/TabButton.css +1 -1
- package/dist/components/organisms/tabs/button/TabButton2.js +83 -0
- package/dist/components/organisms/tabs/content/TabContent.css +1 -1
- package/dist/components/organisms/tabs/content/TabContent2.js +16 -0
- package/dist/components/organisms/tabs/edit-input/TabEditInput.css +1 -1
- package/dist/components/organisms/tabs/edit-input/TabEditInput2.js +45 -0
- package/dist/components/organisms/tabs/list/TabList.css +1 -1
- package/dist/components/organisms/tabs/list/TabList2.js +51 -0
- package/dist/enums/alert-mode.js +6 -4
- package/dist/enums/button-view.js +6 -4
- package/dist/enums/element-size.js +6 -4
- package/dist/enums/icon-name.js +6 -4
- package/dist/enums/loader-view.js +6 -4
- package/dist/enums/orientation-mode.js +6 -4
- package/dist/enums/semantic-color.js +6 -4
- package/dist/enums/tooltip-container.js +6 -4
- package/dist/hooks/use-auto-close/use-auto-close.js +17 -17
- package/dist/hooks/use-click-outside/use-click-outside.js +18 -18
- package/dist/hooks/use-container-dimensions/use-container-dimensions.js +15 -15
- package/dist/hooks/use-debounce/use-debounce.js +14 -14
- package/dist/hooks/use-element-ids/use-element-ids.js +11 -11
- package/dist/hooks/use-is-hovered/use-is-hovered.js +14 -14
- package/dist/hooks/use-is-mounted/use-is-mounted.js +14 -14
- package/dist/hooks/use-is-overflow/use-is-overflow.js +26 -26
- package/dist/hooks/use-key-press/use-key-press.js +17 -13
- package/dist/hooks/use-modal-focus-trap/use-modal-focus-trap.js +15 -19
- package/dist/hooks/use-remaining-timer/use-remaining-timer.js +35 -37
- package/dist/hooks/use-reset-form-input/use-reset-form-input.js +10 -10
- package/dist/hooks/use-theme/use-theme.js +6 -6
- package/dist/hooks/use-tooltip-position/use-tooltip-position.js +36 -30
- package/dist/hooks/use-window-dimensions/use-window-dimensions.js +18 -15
- package/dist/index.es.js +55 -112
- package/dist/styles/icons.css +1 -1
- package/dist/styles/main.css +1 -1
- package/dist/utils/get-class-name.js +13 -15
- package/dist/utils/handle-dropdown-list-key-press.js +26 -31
- package/dist/utils/move-focus-on-element-by-id.js +6 -6
- package/package.json +15 -17
- package/dist/components/atoms/button/Button.js +0 -66
- package/dist/components/atoms/button/icon-button/IconButton.js +0 -15
- package/dist/components/atoms/button/icon-button/index.js +0 -3
- package/dist/components/atoms/button/index.js +0 -3
- package/dist/components/atoms/button/inner-button/InnerButton.js +0 -28
- package/dist/components/atoms/button/inner-button/index.js +0 -3
- package/dist/components/atoms/button/primary-button/PrimaryButton.js +0 -18
- package/dist/components/atoms/button/primary-button/index.js +0 -3
- package/dist/components/atoms/button/secondary-button/SecondaryButton.js +0 -18
- package/dist/components/atoms/button/secondary-button/index.js +0 -3
- package/dist/components/atoms/editable-text/EditableText.js +0 -71
- package/dist/components/atoms/editable-text/index.js +0 -3
- package/dist/components/atoms/error-message/ErrorMessage.js +0 -30
- package/dist/components/atoms/error-message/index.js +0 -3
- package/dist/components/atoms/header/Header.js +0 -22
- package/dist/components/atoms/header/index.js +0 -3
- package/dist/components/atoms/icon/Icon.js +0 -31
- package/dist/components/atoms/icon/index.js +0 -3
- package/dist/components/atoms/image/Image.js +0 -24
- package/dist/components/atoms/image/index.js +0 -3
- package/dist/components/atoms/input/Input.js +0 -10
- package/dist/components/atoms/input/index.js +0 -3
- package/dist/components/atoms/label/Label.js +0 -30
- package/dist/components/atoms/label/index.js +0 -3
- package/dist/components/atoms/link/Link.js +0 -39
- package/dist/components/atoms/link/index.js +0 -3
- package/dist/components/atoms/tooltip/Tooltip.js +0 -70
- package/dist/components/atoms/tooltip/index.js +0 -3
- package/dist/components/molecules/accordion/Accordion.js +0 -11
- package/dist/components/molecules/accordion/AccordionItem.js +0 -24
- package/dist/components/molecules/accordion/index.js +0 -3
- package/dist/components/molecules/alert/Alert.js +0 -59
- package/dist/components/molecules/alert/index.js +0 -3
- package/dist/components/molecules/breadcrumbs/Breadcrumbs.js +0 -31
- package/dist/components/molecules/breadcrumbs/index.js +0 -3
- package/dist/components/molecules/checkbox/Checkbox.js +0 -7
- package/dist/components/molecules/checkbox/index.js +0 -3
- package/dist/components/molecules/numeric-input/NumericInput.js +0 -7
- package/dist/components/molecules/numeric-input/index.js +0 -3
- package/dist/components/molecules/search/Search.js +0 -112
- package/dist/components/molecules/search/index.js +0 -3
- package/dist/components/molecules/select/Select.js +0 -64
- package/dist/components/molecules/select/combobox/Combobox.js +0 -46
- package/dist/components/molecules/select/combobox/index.js +0 -3
- package/dist/components/molecules/select/dropdown/Dropdown.js +0 -46
- package/dist/components/molecules/select/dropdown/index.js +0 -3
- package/dist/components/molecules/select/index.js +0 -3
- package/dist/components/molecules/select/option/Option.js +0 -38
- package/dist/components/molecules/select/option/index.js +0 -3
- package/dist/components/molecules/switch/Switch.js +0 -68
- package/dist/components/molecules/switch/index.js +0 -3
- package/dist/components/molecules/text-input/TextInput.js +0 -7
- package/dist/components/molecules/text-input/index.js +0 -3
- package/dist/components/organisms/dialog/Dialog.js +0 -32
- package/dist/components/organisms/dialog/index.js +0 -3
- package/dist/components/organisms/form/Form.js +0 -48
- package/dist/components/organisms/form/index.js +0 -3
- package/dist/components/organisms/grid/Grid.js +0 -60
- package/dist/components/organisms/grid/body/GridBody.js +0 -31
- package/dist/components/organisms/grid/checkbox/GridCheckbox.js +0 -52
- package/dist/components/organisms/grid/column-group/GridColumnGroup.js +0 -26
- package/dist/components/organisms/grid/grid-row/GridRow.js +0 -35
- package/dist/components/organisms/grid/grid-row/index.js +0 -3
- package/dist/components/organisms/grid/head/GridHead.js +0 -35
- package/dist/components/organisms/grid/index.js +0 -3
- package/dist/components/organisms/menu/Menu.js +0 -22
- package/dist/components/organisms/menu/index.js +0 -3
- package/dist/components/organisms/menu/leaf/MenuLeaf.js +0 -28
- package/dist/components/organisms/menu/list-item/MenuListItem.js +0 -35
- package/dist/components/organisms/menu/sub-menu/SubMenu.js +0 -67
- package/dist/components/organisms/menu/sub-menu/index.js +0 -3
- package/dist/components/organisms/tabs/Tabs.js +0 -80
- package/dist/components/organisms/tabs/button/TabButton.js +0 -111
- package/dist/components/organisms/tabs/content/TabContent.js +0 -19
- package/dist/components/organisms/tabs/edit-input/TabEditInput.js +0 -64
- package/dist/components/organisms/tabs/index.js +0 -3
- package/dist/components/organisms/tabs/list/TabList.js +0 -67
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { GridHeaderCell as e } from "../header-cell/HeaderCell.js";
|
|
2
|
+
import { SelectAllGridRowsCell as t } from "../select-all-grid-rows-cell/SelectAllGridRowsCell.js";
|
|
3
|
+
import './GridHead.css';/* empty css */
|
|
4
|
+
import { jsx as n, jsxs as r } from "react/jsx-runtime";
|
|
5
|
+
//#region src/components/organisms/grid/head/GridHead.tsx
|
|
6
|
+
var i = ({ columns: i, gridId: a, selectAll: o, deselectAll: s, selectable: c, isAllSelected: l, isAllCheckboxDisabled: u = !1 }) => /* @__PURE__ */ n("thead", {
|
|
7
|
+
className: "cl-grid-head",
|
|
8
|
+
children: /* @__PURE__ */ r("tr", {
|
|
9
|
+
className: "cl-grid-head__row",
|
|
10
|
+
children: [c && /* @__PURE__ */ n(t, {
|
|
11
|
+
isAllSelected: l,
|
|
12
|
+
disabled: u,
|
|
13
|
+
gridId: a,
|
|
14
|
+
selectAll: o,
|
|
15
|
+
deselectAll: s
|
|
16
|
+
}), i.map((t) => /* @__PURE__ */ n(e, {
|
|
17
|
+
title: t.title,
|
|
18
|
+
component: t.component
|
|
19
|
+
}, `${t.title}_${a}`))]
|
|
20
|
+
})
|
|
21
|
+
});
|
|
22
|
+
//#endregion
|
|
23
|
+
export { i as GridHead };
|
|
@@ -1,8 +1,5 @@
|
|
|
1
|
-
import { jsx as
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
export {
|
|
7
|
-
d as GridHeaderCell
|
|
8
|
-
};
|
|
1
|
+
import { jsx as e } from "react/jsx-runtime";
|
|
2
|
+
//#region src/components/organisms/grid/header-cell/HeaderCell.tsx
|
|
3
|
+
var t = ({ title: t, component: n }) => /* @__PURE__ */ e("th", { children: n ?? t ?? "" });
|
|
4
|
+
//#endregion
|
|
5
|
+
export { t as GridHeaderCell };
|
|
@@ -1,24 +1,15 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
},
|
|
17
|
-
id: `select_all_${l}`,
|
|
18
|
-
checked: t,
|
|
19
|
-
disabled: r
|
|
20
|
-
}
|
|
21
|
-
) });
|
|
22
|
-
export {
|
|
23
|
-
m as SelectAllGridRowsCell
|
|
24
|
-
};
|
|
1
|
+
import { GridCheckbox as e } from "../checkbox/GridCheckbox2.js";
|
|
2
|
+
import { jsx as t } from "react/jsx-runtime";
|
|
3
|
+
//#region src/components/organisms/grid/select-all-grid-rows-cell/SelectAllGridRowsCell.tsx
|
|
4
|
+
var n = ({ gridId: n, isAllSelected: r, selectAll: i, deselectAll: a, disabled: o }) => /* @__PURE__ */ t("th", { children: /* @__PURE__ */ t(e, {
|
|
5
|
+
label: "Select all rows",
|
|
6
|
+
onChange: (e) => {
|
|
7
|
+
let { checked: t } = e.target;
|
|
8
|
+
t ? i() : a();
|
|
9
|
+
},
|
|
10
|
+
id: `select_all_${n}`,
|
|
11
|
+
checked: r,
|
|
12
|
+
disabled: o
|
|
13
|
+
}) });
|
|
14
|
+
//#endregion
|
|
15
|
+
export { n as SelectAllGridRowsCell };
|
|
@@ -1,24 +1,15 @@
|
|
|
1
|
+
import { GridCheckbox as e } from "../checkbox/GridCheckbox2.js";
|
|
1
2
|
import { jsx as t } from "react/jsx-runtime";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
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
|
-
};
|
|
3
|
+
//#region src/components/organisms/grid/select-grid-row-cell/SelectGridRowCell.tsx
|
|
4
|
+
var n = ({ rowId: n, isRowSelected: r, selectRowById: i, deselectRowById: a, disabled: o }) => /* @__PURE__ */ t("td", { children: /* @__PURE__ */ t(e, {
|
|
5
|
+
label: "Select row",
|
|
6
|
+
onChange: (e) => {
|
|
7
|
+
let { checked: t } = e.target;
|
|
8
|
+
t ? i(n) : a(n);
|
|
9
|
+
},
|
|
10
|
+
id: `select_row_${n}`,
|
|
11
|
+
checked: r,
|
|
12
|
+
disabled: o
|
|
13
|
+
}) });
|
|
14
|
+
//#endregion
|
|
15
|
+
export { n as SelectGridRowCell };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
.cl-menu-bar{
|
|
1
|
+
.cl-menu-bar{padding:0;gap:var(--cl-s-gap);flex-direction:row;justify-content:flex-start;width:100%;margin:0;padding-inline-start:0;list-style:none;display:flex}.cl-menu-bar_vertical{flex-direction:column}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { getClassName as e } from "../../../utils/get-class-name.js";
|
|
2
|
+
import { OrientationMode as t } from "../../../enums/orientation-mode.js";
|
|
3
|
+
import { MenuListItem as n } from "./list-item/MenuListItem2.js";
|
|
4
|
+
import './Menu.css';/* empty css */
|
|
5
|
+
import { jsx as r } from "react/jsx-runtime";
|
|
6
|
+
//#region src/components/organisms/menu/Menu.tsx
|
|
7
|
+
var i = ({ items: i = [], mode: a = t.Vertical, openedOn: o = "click", className: s, ...c }) => {
|
|
8
|
+
let l = e([
|
|
9
|
+
"cl-menu-bar",
|
|
10
|
+
s,
|
|
11
|
+
{ "cl-menu-bar_vertical": a === t.Vertical }
|
|
12
|
+
]);
|
|
13
|
+
return /* @__PURE__ */ r("menu", {
|
|
14
|
+
...c,
|
|
15
|
+
className: l,
|
|
16
|
+
children: i.map((e) => /* @__PURE__ */ r(n, {
|
|
17
|
+
item: e,
|
|
18
|
+
mode: a,
|
|
19
|
+
openedOn: o
|
|
20
|
+
}, e.id))
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
//#endregion
|
|
24
|
+
export { i as default };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
.cl-menu-leaf{color:var(--cl-base-font-color);
|
|
1
|
+
.cl-menu-leaf{color:var(--cl-base-font-color);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;font-family:var(--cl-core-font);font-size:var(--cl-typography-base-mobile);letter-spacing:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-position:50%;font-weight:400;line-height:1.5;transition:background .3s;display:flex}@media (width>=640px){.cl-menu-leaf{font-size:var(--cl-typography-base-tablet)}}@media (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,31 @@
|
|
|
1
|
+
import { ElementSize as e } from "../../../../enums/element-size.js";
|
|
2
|
+
import t from "../../../atoms/icon/Icon2.js";
|
|
3
|
+
import './MenuLeaf.css';/* empty css */
|
|
4
|
+
import { jsx as n, jsxs as r } from "react/jsx-runtime";
|
|
5
|
+
//#region src/components/organisms/menu/leaf/MenuLeaf.tsx
|
|
6
|
+
var i = ({ item: i }) => {
|
|
7
|
+
let { icon: a, link: o, label: s, onFocus: c, onClick: l, onHover: u } = i, d = o ? /* @__PURE__ */ n("a", {
|
|
8
|
+
href: o,
|
|
9
|
+
target: "_blank",
|
|
10
|
+
rel: "noreferrer",
|
|
11
|
+
children: s
|
|
12
|
+
}) : /* @__PURE__ */ n("span", { children: s });
|
|
13
|
+
return /* @__PURE__ */ r("li", {
|
|
14
|
+
className: "cl-menu-leaf",
|
|
15
|
+
tabIndex: 0,
|
|
16
|
+
role: "menuitem",
|
|
17
|
+
onFocus: c,
|
|
18
|
+
onClick: l,
|
|
19
|
+
onKeyDown: (e) => {
|
|
20
|
+
e.stopPropagation(), e.key === "Enter" && l?.();
|
|
21
|
+
},
|
|
22
|
+
onMouseOver: u,
|
|
23
|
+
children: [/* @__PURE__ */ n(t, {
|
|
24
|
+
name: a,
|
|
25
|
+
hidden: !0,
|
|
26
|
+
size: e.Small
|
|
27
|
+
}), d]
|
|
28
|
+
});
|
|
29
|
+
};
|
|
30
|
+
//#endregion
|
|
31
|
+
export { i as MenuLeaf };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
.cl-sub-menu-bar{
|
|
1
|
+
.cl-sub-menu-bar{padding:0;gap:var(--cl-s-gap);width:100%;padding-inline-start:0;padding-left:var(--cl-l-gap);margin:0;margin-left:var(--cl-l-gap);margin-top:var(--cl-s-gap);box-sizing:border-box;border-left:var(--cl-light-border);flex-direction:column;justify-content:flex-start;list-style:none;animation:.4s cl-fade-in;display:flex}.cl-sub-menu-bar_horizontal{border-radius:var(--cl-border-radius);border:var(--cl-light-border);width:max-content;box-shadow:var(--cl-box-shadow);background-color:var(--cl-base-background-color);padding:var(--cl-m-gap);z-index:var(--cl-z-index-menu);margin:0;position:absolute;top:100%;left:0%}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { getClassName as e } from "../../../../utils/get-class-name.js";
|
|
2
|
+
import { OrientationMode as t } from "../../../../enums/orientation-mode.js";
|
|
3
|
+
import { MenuLeaf as n } from "../leaf/MenuLeaf2.js";
|
|
4
|
+
import { SubMenu as r } from "../sub-menu/SubMenu2.js";
|
|
5
|
+
import './MenuListItem.css';/* empty css */
|
|
6
|
+
import { jsx as i } from "react/jsx-runtime";
|
|
7
|
+
import { useState as a } from "react";
|
|
8
|
+
//#region src/components/organisms/menu/list-item/MenuListItem.tsx
|
|
9
|
+
var o = ({ item: s, mode: c, openedOn: l }) => {
|
|
10
|
+
let u = !s?.nestedItems?.length, [d, f] = a(!1), p = e(["cl-sub-menu-bar", { "cl-sub-menu-bar_horizontal": c === t.Horizontal }]);
|
|
11
|
+
return u ? /* @__PURE__ */ i(n, { item: s }) : /* @__PURE__ */ i(r, {
|
|
12
|
+
item: s,
|
|
13
|
+
isSubMenuOpened: d,
|
|
14
|
+
toggleSubMenu: () => {
|
|
15
|
+
f(!d);
|
|
16
|
+
},
|
|
17
|
+
closeSubMenu: () => {
|
|
18
|
+
f(!1);
|
|
19
|
+
},
|
|
20
|
+
openSubMenu: () => {
|
|
21
|
+
f(!0);
|
|
22
|
+
},
|
|
23
|
+
mode: c,
|
|
24
|
+
openedOn: l,
|
|
25
|
+
children: /* @__PURE__ */ i("ul", {
|
|
26
|
+
className: p,
|
|
27
|
+
role: "menu",
|
|
28
|
+
"aria-label": s.label,
|
|
29
|
+
children: s?.nestedItems?.map((e) => /* @__PURE__ */ i(o, {
|
|
30
|
+
item: e,
|
|
31
|
+
mode: c,
|
|
32
|
+
openedOn: l
|
|
33
|
+
}, e.id))
|
|
34
|
+
})
|
|
35
|
+
});
|
|
36
|
+
};
|
|
37
|
+
//#endregion
|
|
38
|
+
export { o as MenuListItem };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
.cl-sub-menu{
|
|
1
|
+
.cl-sub-menu{border-radius:var(--cl-border-radius);flex-direction:column;justify-content:flex-start;align-items:center;gap:0;padding:0;display:flex;position:relative}.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);box-sizing:border-box;gap:var(--cl-m-gap);width:100%;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);letter-spacing:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:0 0;justify-content:space-between;align-items:center;font-weight:400;line-height:1.5;display:flex;position:relative}@media (width>=640px){.cl-sub-menu__text{font-size:var(--cl-typography-base-tablet)}}@media (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{gap:var(--cl-m-gap);align-items:center;display:flex}.cl-sub-menu__icon_opened{transform:rotate(180deg)}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { getClassName as e } from "../../../../utils/get-class-name.js";
|
|
2
|
+
import { ElementSize as t } from "../../../../enums/element-size.js";
|
|
3
|
+
import { IconName as n } from "../../../../enums/icon-name.js";
|
|
4
|
+
import { OrientationMode as r } from "../../../../enums/orientation-mode.js";
|
|
5
|
+
import i from "../../../atoms/icon/Icon2.js";
|
|
6
|
+
import { useClickOutside as a } from "../../../../hooks/use-click-outside/use-click-outside.js";
|
|
7
|
+
import './SubMenu.css';/* empty css */
|
|
8
|
+
import { jsx as o, jsxs as s } from "react/jsx-runtime";
|
|
9
|
+
import { useRef as c } from "react";
|
|
10
|
+
//#region src/components/organisms/menu/sub-menu/SubMenu.tsx
|
|
11
|
+
var l = ({ item: l, isSubMenuOpened: u, toggleSubMenu: d, closeSubMenu: f, openSubMenu: p, openedOn: m, mode: h, children: g }) => {
|
|
12
|
+
let { icon: _, link: v, label: y } = l, b = c(null), x = c(null), S = e(["cl-sub-menu__icon", { "cl-sub-menu__icon_opened": u }]), C = v ? /* @__PURE__ */ s("a", {
|
|
13
|
+
href: v,
|
|
14
|
+
target: "_blank",
|
|
15
|
+
rel: "noreferrer",
|
|
16
|
+
children: [/* @__PURE__ */ o(i, {
|
|
17
|
+
name: _,
|
|
18
|
+
size: t.Small
|
|
19
|
+
}), y]
|
|
20
|
+
}) : /* @__PURE__ */ s("span", { children: [/* @__PURE__ */ o(i, {
|
|
21
|
+
name: _,
|
|
22
|
+
size: t.Small
|
|
23
|
+
}), y] }), w = (e) => {
|
|
24
|
+
e.stopPropagation(), e.key === " " && d();
|
|
25
|
+
};
|
|
26
|
+
return a({
|
|
27
|
+
ref: b,
|
|
28
|
+
dependentRef: x,
|
|
29
|
+
onClickOutsideHandler: () => {
|
|
30
|
+
h !== r.Vertical && f();
|
|
31
|
+
}
|
|
32
|
+
}), /* @__PURE__ */ s("li", {
|
|
33
|
+
className: "cl-sub-menu",
|
|
34
|
+
tabIndex: 0,
|
|
35
|
+
role: "menuitem",
|
|
36
|
+
"aria-haspopup": "true",
|
|
37
|
+
"aria-expanded": u,
|
|
38
|
+
onKeyDown: w,
|
|
39
|
+
onMouseEnter: m === "hover" ? p : void 0,
|
|
40
|
+
onMouseLeave: m === "hover" ? f : void 0,
|
|
41
|
+
ref: b,
|
|
42
|
+
children: [/* @__PURE__ */ s("span", {
|
|
43
|
+
className: "cl-sub-menu__text",
|
|
44
|
+
ref: x,
|
|
45
|
+
onClick: d,
|
|
46
|
+
onKeyDown: w,
|
|
47
|
+
children: [C, /* @__PURE__ */ o(i, {
|
|
48
|
+
name: n.ChevronDown,
|
|
49
|
+
className: S,
|
|
50
|
+
size: t.Small
|
|
51
|
+
})]
|
|
52
|
+
}), u && g]
|
|
53
|
+
});
|
|
54
|
+
};
|
|
55
|
+
//#endregion
|
|
56
|
+
export { l as SubMenu };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
.cl-tabs{
|
|
1
|
+
.cl-tabs{flex-direction:column;width:100%;display:flex}.cl-tabs_vertical{flex-direction:row}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { getClassName as e } from "../../../utils/get-class-name.js";
|
|
2
|
+
import { OrientationMode as t } from "../../../enums/orientation-mode.js";
|
|
3
|
+
import { TabContent as n } from "./content/TabContent2.js";
|
|
4
|
+
import { TabList as r } from "./list/TabList2.js";
|
|
5
|
+
import './Tabs.css';/* empty css */
|
|
6
|
+
import { jsx as i, jsxs as a } from "react/jsx-runtime";
|
|
7
|
+
import { useState as o } from "react";
|
|
8
|
+
//#region src/components/organisms/tabs/Tabs.tsx
|
|
9
|
+
var s = ({ tabs: s, defaultTabId: c, className: l, mode: u = t.Horizontal, stretched: d = !1, editable: f = !1, extendable: p = !1, extendedTabLabel: m = "New Tab", extendedTabContent: h, onTabTitleChange: g, onTabAdd: _, onTabSelect: v, onTabDelete: y, ...b }) => {
|
|
10
|
+
let [x, S] = o(s), C = s.length, [w, T] = o(C + 1), E = x.map((e) => e.id), D = E.map((e) => `tabpanel_${e}`), [O, k] = o(c && E.includes(c) ? c : E[0]), A = e([
|
|
11
|
+
"cl-tabs",
|
|
12
|
+
l,
|
|
13
|
+
{ "cl-tabs_vertical": u === t.Vertical }
|
|
14
|
+
]), j = (e) => {
|
|
15
|
+
k(e), v?.(e);
|
|
16
|
+
}, M = (e, t) => {
|
|
17
|
+
S((n) => n.map((n) => n.id === e ? {
|
|
18
|
+
...n,
|
|
19
|
+
title: t
|
|
20
|
+
} : n)), g?.(e, t);
|
|
21
|
+
}, N = () => {
|
|
22
|
+
let e = `added-tab-${w}`, t = {
|
|
23
|
+
id: e,
|
|
24
|
+
title: m || `Tab ${w}`,
|
|
25
|
+
content: h || /* @__PURE__ */ i("div", {})
|
|
26
|
+
};
|
|
27
|
+
S((e) => [...e, t]), T((e) => e + 1), _?.(), j(e);
|
|
28
|
+
}, P = (e) => {
|
|
29
|
+
if (S((t) => t.filter((t) => t.id !== e)), O === e) {
|
|
30
|
+
let t = E.indexOf(e), n;
|
|
31
|
+
n = t > 0 ? E[t - 1] : E.length > 1 ? E[1] : void 0, n && j(n);
|
|
32
|
+
}
|
|
33
|
+
y?.(e);
|
|
34
|
+
};
|
|
35
|
+
return /* @__PURE__ */ a("div", {
|
|
36
|
+
...b,
|
|
37
|
+
className: A,
|
|
38
|
+
children: [/* @__PURE__ */ i(r, {
|
|
39
|
+
tabs: x,
|
|
40
|
+
selectedTabId: O,
|
|
41
|
+
tabPanelIds: D,
|
|
42
|
+
onTabSelect: j,
|
|
43
|
+
onTabTitleChange: M,
|
|
44
|
+
mode: u,
|
|
45
|
+
tabIds: E,
|
|
46
|
+
stretched: d,
|
|
47
|
+
editable: f,
|
|
48
|
+
extendable: p,
|
|
49
|
+
onTabAdd: N,
|
|
50
|
+
onTabDelete: P
|
|
51
|
+
}), /* @__PURE__ */ i(n, {
|
|
52
|
+
tabs: x,
|
|
53
|
+
selectedTabId: O,
|
|
54
|
+
extendedTabContent: h,
|
|
55
|
+
extendable: p
|
|
56
|
+
})]
|
|
57
|
+
});
|
|
58
|
+
};
|
|
59
|
+
//#endregion
|
|
60
|
+
export { s as default };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
.cl-tab{color:var(--cl-base-font-color);
|
|
1
|
+
.cl-tab{color:var(--cl-base-font-color);padding:var(--cl-m-gap);cursor:pointer;border-radius:var(--cl-border-radius);white-space:nowrap;text-overflow:ellipsis;font-family:var(--cl-core-font);font-size:var(--cl-typography-base-mobile);letter-spacing:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:0 0;border:none;outline:none;flex:1;font-weight:400;line-height:1.5;overflow:hidden}@media (width>=640px){.cl-tab{font-size:var(--cl-typography-base-tablet)}}@media (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{justify-content:space-between;align-items:center;gap:var(--cl-l-gap);border-radius:var(--cl-border-radius);border:var(--cl-light-border);background-color:var(--cl-surface-a10);display:flex;position:relative}.cl-tab__buttons{margin-right:var(--cl-s-gap);align-items:center;gap:0;display:flex}.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,83 @@
|
|
|
1
|
+
import { getClassName as e } from "../../../../utils/get-class-name.js";
|
|
2
|
+
import { ButtonView as t } from "../../../../enums/button-view.js";
|
|
3
|
+
import { ElementSize as n } from "../../../../enums/element-size.js";
|
|
4
|
+
import { IconName as r } from "../../../../enums/icon-name.js";
|
|
5
|
+
import { OrientationMode as i } from "../../../../enums/orientation-mode.js";
|
|
6
|
+
import a from "../../../atoms/button/Button2.js";
|
|
7
|
+
import { TabEditInput as o } from "../edit-input/TabEditInput2.js";
|
|
8
|
+
import './TabButton.css';/* empty css */
|
|
9
|
+
import { Fragment as s, jsx as c, jsxs as l } from "react/jsx-runtime";
|
|
10
|
+
import { useEffect as u, useId as d, useRef as f, useState as p } from "react";
|
|
11
|
+
//#region src/components/organisms/tabs/button/TabButton.tsx
|
|
12
|
+
var m = ({ title: m, onTabSelect: h, onTabTitleChange: g, onTabDelete: _, tabId: v, isSelected: y, isDisabled: b = !1, stretched: x = !1, editable: S = !1, extendable: C = !1, tabPanelId: w, mode: T }) => {
|
|
13
|
+
let [E, D] = p(!1), [O, k] = p(m), A = f(null), j = d(), M = S && !b && y, N = C && !b && !!_ && y, P = M || N, F = e(["cl-tab__wrapper", {
|
|
14
|
+
"cl-tab__wrapper_disabled": b,
|
|
15
|
+
"cl-tab__wrapper_vertical": T === i.Vertical,
|
|
16
|
+
"cl-tab__wrapper_selected": y,
|
|
17
|
+
"cl-tab__wrapper_stretched": x,
|
|
18
|
+
"cl-tab__wrapper_editable": S,
|
|
19
|
+
"cl-tab__wrapper_inactive": !y
|
|
20
|
+
}]);
|
|
21
|
+
u(() => {
|
|
22
|
+
E && A.current && (A.current.focus(), A.current.select());
|
|
23
|
+
}, [E]), u(() => {
|
|
24
|
+
k(m);
|
|
25
|
+
}, [m]);
|
|
26
|
+
let I = () => {
|
|
27
|
+
b || D(!E);
|
|
28
|
+
}, L = () => {
|
|
29
|
+
E || h(v);
|
|
30
|
+
}, R = (e) => {
|
|
31
|
+
k(e.target.value);
|
|
32
|
+
}, z = (e) => {
|
|
33
|
+
e.relatedTarget?.id !== j && V();
|
|
34
|
+
}, B = (e) => {
|
|
35
|
+
e.key === "Enter" ? (e.preventDefault(), V()) : e.key === "Escape" && (e.preventDefault(), H());
|
|
36
|
+
}, V = () => {
|
|
37
|
+
O.trim() && O !== m ? g?.(O.trim()) : k(m), D(!1);
|
|
38
|
+
}, H = () => {
|
|
39
|
+
k(m), D(!1);
|
|
40
|
+
};
|
|
41
|
+
return /* @__PURE__ */ c("span", {
|
|
42
|
+
className: F,
|
|
43
|
+
children: E ? /* @__PURE__ */ c(o, {
|
|
44
|
+
tabId: v,
|
|
45
|
+
editValue: O,
|
|
46
|
+
isEditMode: E,
|
|
47
|
+
onInputChange: R,
|
|
48
|
+
onInputBlur: z,
|
|
49
|
+
onInputKeyDown: B,
|
|
50
|
+
onSave: V,
|
|
51
|
+
onCancel: H,
|
|
52
|
+
cancelButtonId: j
|
|
53
|
+
}) : /* @__PURE__ */ l(s, { children: [/* @__PURE__ */ c("button", {
|
|
54
|
+
role: "tab",
|
|
55
|
+
id: v,
|
|
56
|
+
onClick: L,
|
|
57
|
+
"aria-selected": y,
|
|
58
|
+
"aria-controls": w,
|
|
59
|
+
className: "cl-tab",
|
|
60
|
+
disabled: b,
|
|
61
|
+
children: O
|
|
62
|
+
}), P && /* @__PURE__ */ l("span", {
|
|
63
|
+
className: "cl-tab__buttons",
|
|
64
|
+
children: [M && /* @__PURE__ */ c(a, {
|
|
65
|
+
view: t.Icon,
|
|
66
|
+
icon: r.Edit3,
|
|
67
|
+
onClick: I,
|
|
68
|
+
label: "Edit tab",
|
|
69
|
+
tooltip: "Edit tab",
|
|
70
|
+
iconSize: n.Small
|
|
71
|
+
}), N && /* @__PURE__ */ c(a, {
|
|
72
|
+
view: t.Icon,
|
|
73
|
+
icon: r.Trash2,
|
|
74
|
+
onClick: () => _?.(v),
|
|
75
|
+
label: "Delete tab",
|
|
76
|
+
tooltip: "Delete tab",
|
|
77
|
+
iconSize: n.Small
|
|
78
|
+
})]
|
|
79
|
+
})] })
|
|
80
|
+
});
|
|
81
|
+
};
|
|
82
|
+
//#endregion
|
|
83
|
+
export { m as TabButton };
|
|
@@ -1 +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);
|
|
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);font-family:var(--cl-core-font);font-size:var(--cl-typography-base-mobile);letter-spacing:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;flex-grow:1;font-weight:400;line-height:1.5}@media (width>=640px){.cl-tab-content{font-size:var(--cl-typography-base-tablet)}}@media (width>=1024px){.cl-tab-content{font-size:var(--cl-typography-base-desktop)}}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import './TabContent.css';/* empty css */
|
|
2
|
+
import { jsx as e } from "react/jsx-runtime";
|
|
3
|
+
//#region src/components/organisms/tabs/content/TabContent.tsx
|
|
4
|
+
var t = ({ tabs: t, selectedTabId: n, extendable: r, extendedTabContent: i }) => {
|
|
5
|
+
let a = t.find((e) => e.id === n)?.content, o = `tabpanel_${n}`, s = r && !a;
|
|
6
|
+
return /* @__PURE__ */ e("div", {
|
|
7
|
+
role: "tabpanel",
|
|
8
|
+
"data-testid": "tab-content",
|
|
9
|
+
"aria-labelledby": n,
|
|
10
|
+
id: o,
|
|
11
|
+
className: "cl-tab-content",
|
|
12
|
+
children: s ? i : a
|
|
13
|
+
});
|
|
14
|
+
};
|
|
15
|
+
//#endregion
|
|
16
|
+
export { t as TabContent };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
.cl-tab-edit-container{
|
|
1
|
+
.cl-tab-edit-container{justify-content:space-between;align-items:center;gap:var(--cl-s-gap);width:100%;padding:0 var(--cl-s-gap);display:flex}.cl-tab-edit-container__input{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);font-family:var(--cl-core-font);font-size:var(--cl-typography-base-mobile);letter-spacing:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:0 0;flex:1;font-weight:400;line-height:1.5}@media (width>=640px){.cl-tab-edit-container__input{font-size:var(--cl-typography-base-tablet)}}@media (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{align-items:center;display:flex}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { ButtonView as e } from "../../../../enums/button-view.js";
|
|
2
|
+
import { ElementSize as t } from "../../../../enums/element-size.js";
|
|
3
|
+
import { IconName as n } from "../../../../enums/icon-name.js";
|
|
4
|
+
import r from "../../../atoms/button/Button2.js";
|
|
5
|
+
import './TabEditInput.css';/* empty css */
|
|
6
|
+
import { jsx as i, jsxs as a } from "react/jsx-runtime";
|
|
7
|
+
import { useEffect as o, useRef as s } from "react";
|
|
8
|
+
//#region src/components/organisms/tabs/edit-input/TabEditInput.tsx
|
|
9
|
+
var c = ({ tabId: c, isEditMode: l, editValue: u, onInputChange: d, onInputBlur: f, onInputKeyDown: p, onSave: m, onCancel: h, cancelButtonId: g }) => {
|
|
10
|
+
let _ = s(null);
|
|
11
|
+
return o(() => {
|
|
12
|
+
l && _.current && (_.current.focus(), _.current.select());
|
|
13
|
+
}, [l]), /* @__PURE__ */ a("div", {
|
|
14
|
+
className: "cl-tab-edit-container",
|
|
15
|
+
children: [/* @__PURE__ */ i("input", {
|
|
16
|
+
ref: _,
|
|
17
|
+
id: `${c}-input`,
|
|
18
|
+
type: "text",
|
|
19
|
+
value: u,
|
|
20
|
+
onChange: d,
|
|
21
|
+
onBlur: f,
|
|
22
|
+
onKeyDown: p,
|
|
23
|
+
className: "cl-tab-edit-container__input",
|
|
24
|
+
maxLength: 50
|
|
25
|
+
}), /* @__PURE__ */ a("span", {
|
|
26
|
+
className: "cl-tab-edit-container__buttons",
|
|
27
|
+
children: [/* @__PURE__ */ i(r, {
|
|
28
|
+
view: e.Icon,
|
|
29
|
+
icon: n.Check,
|
|
30
|
+
onClick: m,
|
|
31
|
+
label: "Save tab title",
|
|
32
|
+
iconSize: t.Small
|
|
33
|
+
}), /* @__PURE__ */ i(r, {
|
|
34
|
+
view: e.Icon,
|
|
35
|
+
icon: n.X,
|
|
36
|
+
onClick: h,
|
|
37
|
+
label: "Cancel tab title change",
|
|
38
|
+
id: g,
|
|
39
|
+
iconSize: t.Small
|
|
40
|
+
})]
|
|
41
|
+
})]
|
|
42
|
+
});
|
|
43
|
+
};
|
|
44
|
+
//#endregion
|
|
45
|
+
export { c as TabEditInput };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
.cl-tab-list{padding:0 var(--cl-m-gap) var(--cl-m-gap) var(--cl-m-gap);
|
|
1
|
+
.cl-tab-list{padding:0 var(--cl-m-gap) var(--cl-m-gap) var(--cl-m-gap);gap:var(--cl-m-gap);max-width:100%;display:flex;overflow:auto hidden}.cl-tab-list:focus{outline:var(--cl-outline-border);outline-offset:4px}.cl-tab-list>span:last-of-type{justify-content:center;align-items:center;display:flex}.cl-tab-list>span:last-of-type button{width:100%}.cl-tab-list_vertical{border-bottom:none;border-right:var(--cl-light-border);padding:var(--cl-m-gap) var(--cl-m-gap) var(--cl-m-gap) 0;flex-direction:column;flex-shrink:0;max-height:100%;overflow:hidden auto}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { getClassName as e } from "../../../../utils/get-class-name.js";
|
|
2
|
+
import { moveFocusOnElementById as t } from "../../../../utils/move-focus-on-element-by-id.js";
|
|
3
|
+
import { ButtonView as n } from "../../../../enums/button-view.js";
|
|
4
|
+
import { IconName as r } from "../../../../enums/icon-name.js";
|
|
5
|
+
import { OrientationMode as i } from "../../../../enums/orientation-mode.js";
|
|
6
|
+
import a from "../../../atoms/button/Button2.js";
|
|
7
|
+
import { TabButton as o } from "../button/TabButton2.js";
|
|
8
|
+
import './TabList.css';/* empty css */
|
|
9
|
+
import { jsx as s, jsxs as c } from "react/jsx-runtime";
|
|
10
|
+
//#region src/components/organisms/tabs/list/TabList.tsx
|
|
11
|
+
var l = ({ tabs: l, onTabSelect: u, onTabTitleChange: d, selectedTabId: f, tabPanelIds: p, mode: m, tabIds: h, stretched: g, editable: _ = !1, extendable: v = !1, onTabAdd: y, onTabDelete: b }) => {
|
|
12
|
+
let x = e(["cl-tab-list", { "cl-tab-list_vertical": m === i.Vertical }]), S = (e) => {
|
|
13
|
+
let n = h.indexOf(f);
|
|
14
|
+
if (![
|
|
15
|
+
"ArrowLeft",
|
|
16
|
+
"ArrowUp",
|
|
17
|
+
"ArrowRight",
|
|
18
|
+
"ArrowDown"
|
|
19
|
+
].includes(e.key) || (e.preventDefault(), e.key === "ArrowUp" && m === i.Horizontal || e.key === "ArrowLeft" && m === i.Vertical)) return;
|
|
20
|
+
let r = h[e.key === "ArrowLeft" || e.key === "ArrowUp" ? C(n, h.length) : w(n, h.length)];
|
|
21
|
+
r && (t(r), u(r));
|
|
22
|
+
}, C = (e, t) => e - 1 >= 0 ? e - 1 : t - 1, w = (e, t) => e === t - 1 ? 0 : e + 1;
|
|
23
|
+
return /* @__PURE__ */ c("div", {
|
|
24
|
+
role: "tablist",
|
|
25
|
+
"data-testid": "tab-list",
|
|
26
|
+
onKeyDown: S,
|
|
27
|
+
className: x,
|
|
28
|
+
children: [l.map(({ id: e, title: t, disabled: n }, r) => /* @__PURE__ */ s(o, {
|
|
29
|
+
title: t,
|
|
30
|
+
onTabSelect: u,
|
|
31
|
+
onTabTitleChange: d ? (t) => d(e, t) : void 0,
|
|
32
|
+
tabId: e,
|
|
33
|
+
isSelected: e === f,
|
|
34
|
+
isDisabled: n,
|
|
35
|
+
tabPanelId: p[r],
|
|
36
|
+
mode: m,
|
|
37
|
+
stretched: g,
|
|
38
|
+
editable: _,
|
|
39
|
+
extendable: v,
|
|
40
|
+
onTabDelete: b
|
|
41
|
+
}, e)), v && /* @__PURE__ */ s(a, {
|
|
42
|
+
label: "Add Tab",
|
|
43
|
+
tooltip: "Add Tab",
|
|
44
|
+
view: n.Icon,
|
|
45
|
+
icon: r.PlusCircle,
|
|
46
|
+
onClick: y
|
|
47
|
+
})]
|
|
48
|
+
});
|
|
49
|
+
};
|
|
50
|
+
//#endregion
|
|
51
|
+
export { l as TabList };
|
package/dist/enums/alert-mode.js
CHANGED
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
};
|
|
1
|
+
//#region src/enums/alert-mode.ts
|
|
2
|
+
var e = /* @__PURE__ */ function(e) {
|
|
3
|
+
return e.Success = "success", e.Error = "error", e.Warning = "warning", e.Info = "info", e.Help = "help", e;
|
|
4
|
+
}({});
|
|
5
|
+
//#endregion
|
|
6
|
+
export { e as AlertMode };
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
};
|
|
1
|
+
//#region src/enums/button-view.ts
|
|
2
|
+
var e = /* @__PURE__ */ function(e) {
|
|
3
|
+
return e.Primary = "primary", e.Secondary = "secondary", e.Icon = "icon", e.Inner = "inner", e;
|
|
4
|
+
}({});
|
|
5
|
+
//#endregion
|
|
6
|
+
export { e as ButtonView };
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
};
|
|
1
|
+
//#region src/enums/element-size.ts
|
|
2
|
+
var e = /* @__PURE__ */ function(e) {
|
|
3
|
+
return e.ExtraSmall = "xs", e.Small = "s", e.Medium = "m", e.Large = "l", e.ExtraLarge = "xl", e.ExtraExtraLarge = "2xl", e;
|
|
4
|
+
}({});
|
|
5
|
+
//#endregion
|
|
6
|
+
export { e as ElementSize };
|