@unoff/ui 1.21.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/LICENSE +21 -0
- package/README.md +880 -0
- package/dist/assets/Accordion.css +1 -0
- package/dist/assets/ActionsItem.css +1 -0
- package/dist/assets/ActionsList.css +1 -0
- package/dist/assets/Avatar.css +1 -0
- package/dist/assets/Bar.css +1 -0
- package/dist/assets/Button.css +1 -0
- package/dist/assets/Card.css +1 -0
- package/dist/assets/Chip.css +1 -0
- package/dist/assets/ColorChip.css +1 -0
- package/dist/assets/ColorItem.css +1 -0
- package/dist/assets/Consent.css +1 -0
- package/dist/assets/Dialog.css +1 -0
- package/dist/assets/DraggableItem.css +1 -0
- package/dist/assets/DraggableWindow.css +1 -0
- package/dist/assets/Drawer.css +1 -0
- package/dist/assets/Dropdown.css +1 -0
- package/dist/assets/Dropzone.css +1 -0
- package/dist/assets/FormItem.css +1 -0
- package/dist/assets/Icon.css +1 -0
- package/dist/assets/IconChip.css +1 -0
- package/dist/assets/Input.css +1 -0
- package/dist/assets/InputsBar.css +1 -0
- package/dist/assets/KeyboardShortcutItem.css +1 -0
- package/dist/assets/Knob.css +1 -0
- package/dist/assets/Layout.css +1 -0
- package/dist/assets/List.css +1 -0
- package/dist/assets/MembersList.css +1 -0
- package/dist/assets/Menu.css +1 -0
- package/dist/assets/Message.css +1 -0
- package/dist/assets/MultipleSlider.css +1 -0
- package/dist/assets/Notification.css +1 -0
- package/dist/assets/Popin.css +1 -0
- package/dist/assets/Section.css +1 -0
- package/dist/assets/SectionTitle.css +1 -0
- package/dist/assets/Select.css +1 -0
- package/dist/assets/SemanticMessage.css +1 -0
- package/dist/assets/SimpleItem.css +1 -0
- package/dist/assets/SimpleSlider.css +1 -0
- package/dist/assets/SortableList.css +1 -0
- package/dist/assets/Tabs.css +1 -0
- package/dist/assets/Text.css +1 -0
- package/dist/assets/Thumbnail.css +1 -0
- package/dist/assets/Tooltip.css +1 -0
- package/dist/assets/styles/icons/icons.css +1 -0
- package/dist/assets/styles/icons/styles/figma.css +1 -0
- package/dist/assets/styles/icons/styles/framer.css +1 -0
- package/dist/assets/styles/icons/styles/penpot.css +1 -0
- package/dist/assets/styles/icons/styles/sketch.css +1 -0
- package/dist/assets/styles/layouts.css +1 -0
- package/dist/assets/styles/texts/styles/figma.css +1 -0
- package/dist/assets/styles/texts/styles/framer.css +1 -0
- package/dist/assets/styles/texts/styles/penpot.css +1 -0
- package/dist/assets/styles/texts/styles/sketch.css +1 -0
- package/dist/assets/styles/texts/texts.css +1 -0
- package/dist/assets/styles/tokens/figma-types.css +1 -0
- package/dist/assets/styles/tokens/framer-types.css +1 -0
- package/dist/assets/styles/tokens/modules/figma-colors.css +1 -0
- package/dist/assets/styles/tokens/modules/figma-types.css +1 -0
- package/dist/assets/styles/tokens/modules/framer-colors.css +1 -0
- package/dist/assets/styles/tokens/modules/framer-types.css +1 -0
- package/dist/assets/styles/tokens/modules/globals.css +1 -0
- package/dist/assets/styles/tokens/modules/penpot-colors.css +1 -0
- package/dist/assets/styles/tokens/modules/penpot-types.css +1 -0
- package/dist/assets/styles/tokens/modules/sketch-colors.css +1 -0
- package/dist/assets/styles/tokens/modules/sketch-types.css +1 -0
- package/dist/assets/styles/tokens/penpot-types.css +1 -0
- package/dist/assets/styles/tokens/sketch-types.css +1 -0
- package/dist/components/actions/accordion/Accordion.d.ts +59 -0
- package/dist/components/actions/accordion/Accordion.d.ts.map +1 -0
- package/dist/components/actions/accordion/Accordion.js +104 -0
- package/dist/components/actions/accordion/Accordion.js.map +1 -0
- package/dist/components/actions/button/Button.d.ts +148 -0
- package/dist/components/actions/button/Button.d.ts.map +1 -0
- package/dist/components/actions/button/Button.figma.d.ts +2 -0
- package/dist/components/actions/button/Button.figma.d.ts.map +1 -0
- package/dist/components/actions/button/Button.figma.js +43 -0
- package/dist/components/actions/button/Button.figma.js.map +1 -0
- package/dist/components/actions/button/Button.js +306 -0
- package/dist/components/actions/button/Button.js.map +1 -0
- package/dist/components/actions/card/Card.d.ts +39 -0
- package/dist/components/actions/card/Card.d.ts.map +1 -0
- package/dist/components/actions/card/Card.js +99 -0
- package/dist/components/actions/card/Card.js.map +1 -0
- package/dist/components/actions/knob/Knob.d.ts +93 -0
- package/dist/components/actions/knob/Knob.d.ts.map +1 -0
- package/dist/components/actions/knob/Knob.js +179 -0
- package/dist/components/actions/knob/Knob.js.map +1 -0
- package/dist/components/actions/menu/Menu.d.ts +104 -0
- package/dist/components/actions/menu/Menu.d.ts.map +1 -0
- package/dist/components/actions/menu/Menu.js +200 -0
- package/dist/components/actions/menu/Menu.js.map +1 -0
- package/dist/components/assets/avatar/Avatar.d.ts +30 -0
- package/dist/components/assets/avatar/Avatar.d.ts.map +1 -0
- package/dist/components/assets/avatar/Avatar.js +54 -0
- package/dist/components/assets/avatar/Avatar.js.map +1 -0
- package/dist/components/assets/icon/Icon.d.ts +28 -0
- package/dist/components/assets/icon/Icon.d.ts.map +1 -0
- package/dist/components/assets/icon/Icon.figma.d.ts +2 -0
- package/dist/components/assets/icon/Icon.figma.d.ts.map +1 -0
- package/dist/components/assets/icon/Icon.figma.js +27 -0
- package/dist/components/assets/icon/Icon.figma.js.map +1 -0
- package/dist/components/assets/icon/Icon.js +35 -0
- package/dist/components/assets/icon/Icon.js.map +1 -0
- package/dist/components/assets/section-title/SectionTitle.d.ts +22 -0
- package/dist/components/assets/section-title/SectionTitle.d.ts.map +1 -0
- package/dist/components/assets/section-title/SectionTitle.js +42 -0
- package/dist/components/assets/section-title/SectionTitle.js.map +1 -0
- package/dist/components/assets/text/Text.d.ts +34 -0
- package/dist/components/assets/text/Text.d.ts.map +1 -0
- package/dist/components/assets/text/Text.js +35 -0
- package/dist/components/assets/text/Text.js.map +1 -0
- package/dist/components/assets/thumbnail/Thumbnail.d.ts +25 -0
- package/dist/components/assets/thumbnail/Thumbnail.d.ts.map +1 -0
- package/dist/components/assets/thumbnail/Thumbnail.js +67 -0
- package/dist/components/assets/thumbnail/Thumbnail.js.map +1 -0
- package/dist/components/dialogs/consent/Consent.d.ts +85 -0
- package/dist/components/dialogs/consent/Consent.d.ts.map +1 -0
- package/dist/components/dialogs/consent/Consent.js +402 -0
- package/dist/components/dialogs/consent/Consent.js.map +1 -0
- package/dist/components/dialogs/dialog/Dialog.d.ts +81 -0
- package/dist/components/dialogs/dialog/Dialog.d.ts.map +1 -0
- package/dist/components/dialogs/dialog/Dialog.js +58 -0
- package/dist/components/dialogs/dialog/Dialog.js.map +1 -0
- package/dist/components/dialogs/message/Message.d.ts +25 -0
- package/dist/components/dialogs/message/Message.d.ts.map +1 -0
- package/dist/components/dialogs/message/Message.js +141 -0
- package/dist/components/dialogs/message/Message.js.map +1 -0
- package/dist/components/dialogs/notification/Notification.d.ts +22 -0
- package/dist/components/dialogs/notification/Notification.d.ts.map +1 -0
- package/dist/components/dialogs/notification/Notification.js +38 -0
- package/dist/components/dialogs/notification/Notification.js.map +1 -0
- package/dist/components/dialogs/semantic-message/SemanticMessage.d.ts +40 -0
- package/dist/components/dialogs/semantic-message/SemanticMessage.d.ts.map +1 -0
- package/dist/components/dialogs/semantic-message/SemanticMessage.js +71 -0
- package/dist/components/dialogs/semantic-message/SemanticMessage.js.map +1 -0
- package/dist/components/inputs/dropdown/Dropdown.d.ts +123 -0
- package/dist/components/inputs/dropdown/Dropdown.d.ts.map +1 -0
- package/dist/components/inputs/dropdown/Dropdown.figma.d.ts +2 -0
- package/dist/components/inputs/dropdown/Dropdown.figma.d.ts.map +1 -0
- package/dist/components/inputs/dropdown/Dropdown.figma.js +28 -0
- package/dist/components/inputs/dropdown/Dropdown.figma.js.map +1 -0
- package/dist/components/inputs/dropdown/Dropdown.js +307 -0
- package/dist/components/inputs/dropdown/Dropdown.js.map +1 -0
- package/dist/components/inputs/dropzone/Dropzone.d.ts +78 -0
- package/dist/components/inputs/dropzone/Dropzone.d.ts.map +1 -0
- package/dist/components/inputs/dropzone/Dropzone.js +222 -0
- package/dist/components/inputs/dropzone/Dropzone.js.map +1 -0
- package/dist/components/inputs/input/Input.d.ts +203 -0
- package/dist/components/inputs/input/Input.d.ts.map +1 -0
- package/dist/components/inputs/input/Input.figma.d.ts +2 -0
- package/dist/components/inputs/input/Input.figma.d.ts.map +1 -0
- package/dist/components/inputs/input/Input.figma.js +35 -0
- package/dist/components/inputs/input/Input.figma.js.map +1 -0
- package/dist/components/inputs/input/Input.js +713 -0
- package/dist/components/inputs/input/Input.js.map +1 -0
- package/dist/components/inputs/inputs-bar/InputsBar.d.ts +18 -0
- package/dist/components/inputs/inputs-bar/InputsBar.d.ts.map +1 -0
- package/dist/components/inputs/inputs-bar/InputsBar.js +15 -0
- package/dist/components/inputs/inputs-bar/InputsBar.js.map +1 -0
- package/dist/components/inputs/multiple-slider/MultipleSlider.d.ts +125 -0
- package/dist/components/inputs/multiple-slider/MultipleSlider.d.ts.map +1 -0
- package/dist/components/inputs/multiple-slider/MultipleSlider.js +417 -0
- package/dist/components/inputs/multiple-slider/MultipleSlider.js.map +1 -0
- package/dist/components/inputs/multiple-slider/actions/addStop.d.ts +8 -0
- package/dist/components/inputs/multiple-slider/actions/addStop.d.ts.map +1 -0
- package/dist/components/inputs/multiple-slider/actions/deleteStop.d.ts +8 -0
- package/dist/components/inputs/multiple-slider/actions/deleteStop.d.ts.map +1 -0
- package/dist/components/inputs/multiple-slider/actions/shiftLeftStop.d.ts +5 -0
- package/dist/components/inputs/multiple-slider/actions/shiftLeftStop.d.ts.map +1 -0
- package/dist/components/inputs/multiple-slider/actions/shiftRightStop.d.ts +5 -0
- package/dist/components/inputs/multiple-slider/actions/shiftRightStop.d.ts.map +1 -0
- package/dist/components/inputs/select/Select.d.ts +112 -0
- package/dist/components/inputs/select/Select.d.ts.map +1 -0
- package/dist/components/inputs/select/Select.js +313 -0
- package/dist/components/inputs/select/Select.js.map +1 -0
- package/dist/components/inputs/simple-slider/SimpleSlider.d.ts +93 -0
- package/dist/components/inputs/simple-slider/SimpleSlider.d.ts.map +1 -0
- package/dist/components/inputs/simple-slider/SimpleSlider.js +166 -0
- package/dist/components/inputs/simple-slider/SimpleSlider.js.map +1 -0
- package/dist/components/lists/actions-item/ActionsItem.d.ts +64 -0
- package/dist/components/lists/actions-item/ActionsItem.d.ts.map +1 -0
- package/dist/components/lists/actions-item/ActionsItem.js +115 -0
- package/dist/components/lists/actions-item/ActionsItem.js.map +1 -0
- package/dist/components/lists/actions-list/ActionsList.d.ts +79 -0
- package/dist/components/lists/actions-list/ActionsList.d.ts.map +1 -0
- package/dist/components/lists/actions-list/ActionsList.js +384 -0
- package/dist/components/lists/actions-list/ActionsList.js.map +1 -0
- package/dist/components/lists/color-item/ColorItem.d.ts +27 -0
- package/dist/components/lists/color-item/ColorItem.d.ts.map +1 -0
- package/dist/components/lists/color-item/ColorItem.js +70 -0
- package/dist/components/lists/color-item/ColorItem.js.map +1 -0
- package/dist/components/lists/draggable-item/DraggableItem.d.ts +110 -0
- package/dist/components/lists/draggable-item/DraggableItem.d.ts.map +1 -0
- package/dist/components/lists/draggable-item/DraggableItem.js +176 -0
- package/dist/components/lists/draggable-item/DraggableItem.js.map +1 -0
- package/dist/components/lists/keyboard-shortcut-item/KeyboardShortcutItem.d.ts +19 -0
- package/dist/components/lists/keyboard-shortcut-item/KeyboardShortcutItem.d.ts.map +1 -0
- package/dist/components/lists/keyboard-shortcut-item/KeyboardShortcutItem.js +75 -0
- package/dist/components/lists/keyboard-shortcut-item/KeyboardShortcutItem.js.map +1 -0
- package/dist/components/lists/members-list/MembersList.d.ts +32 -0
- package/dist/components/lists/members-list/MembersList.d.ts.map +1 -0
- package/dist/components/lists/members-list/MembersList.js +117 -0
- package/dist/components/lists/members-list/MembersList.js.map +1 -0
- package/dist/components/lists/sortable-list/SortableList.d.ts +103 -0
- package/dist/components/lists/sortable-list/SortableList.d.ts.map +1 -0
- package/dist/components/lists/sortable-list/SortableList.js +148 -0
- package/dist/components/lists/sortable-list/SortableList.js.map +1 -0
- package/dist/components/lists/tabs/Tabs.d.ts +48 -0
- package/dist/components/lists/tabs/Tabs.d.ts.map +1 -0
- package/dist/components/lists/tabs/Tabs.figma.d.ts +2 -0
- package/dist/components/lists/tabs/Tabs.figma.d.ts.map +1 -0
- package/dist/components/lists/tabs/Tabs.figma.js +31 -0
- package/dist/components/lists/tabs/Tabs.figma.js.map +1 -0
- package/dist/components/lists/tabs/Tabs.js +165 -0
- package/dist/components/lists/tabs/Tabs.js.map +1 -0
- package/dist/components/slots/bar/Bar.d.ts +65 -0
- package/dist/components/slots/bar/Bar.d.ts.map +1 -0
- package/dist/components/slots/bar/Bar.js +100 -0
- package/dist/components/slots/bar/Bar.js.map +1 -0
- package/dist/components/slots/draggable-window/DraggableWindow.d.ts +25 -0
- package/dist/components/slots/draggable-window/DraggableWindow.d.ts.map +1 -0
- package/dist/components/slots/draggable-window/DraggableWindow.js +100 -0
- package/dist/components/slots/draggable-window/DraggableWindow.js.map +1 -0
- package/dist/components/slots/drawer/Drawer.d.ts +78 -0
- package/dist/components/slots/drawer/Drawer.d.ts.map +1 -0
- package/dist/components/slots/drawer/Drawer.js +148 -0
- package/dist/components/slots/drawer/Drawer.js.map +1 -0
- package/dist/components/slots/form-item/FormItem.d.ts +52 -0
- package/dist/components/slots/form-item/FormItem.d.ts.map +1 -0
- package/dist/components/slots/form-item/FormItem.js +89 -0
- package/dist/components/slots/form-item/FormItem.js.map +1 -0
- package/dist/components/slots/layout/Layout.d.ts +34 -0
- package/dist/components/slots/layout/Layout.d.ts.map +1 -0
- package/dist/components/slots/layout/Layout.js +45 -0
- package/dist/components/slots/layout/Layout.js.map +1 -0
- package/dist/components/slots/list/List.d.ts +49 -0
- package/dist/components/slots/list/List.d.ts.map +1 -0
- package/dist/components/slots/list/List.js +55 -0
- package/dist/components/slots/list/List.js.map +1 -0
- package/dist/components/slots/popin/Popin.d.ts +85 -0
- package/dist/components/slots/popin/Popin.d.ts.map +1 -0
- package/dist/components/slots/popin/Popin.js +182 -0
- package/dist/components/slots/popin/Popin.js.map +1 -0
- package/dist/components/slots/section/Section.d.ts +32 -0
- package/dist/components/slots/section/Section.d.ts.map +1 -0
- package/dist/components/slots/section/Section.js +49 -0
- package/dist/components/slots/section/Section.js.map +1 -0
- package/dist/components/slots/simple-item/SimpleItem.d.ts +45 -0
- package/dist/components/slots/simple-item/SimpleItem.d.ts.map +1 -0
- package/dist/components/slots/simple-item/SimpleItem.js +100 -0
- package/dist/components/slots/simple-item/SimpleItem.js.map +1 -0
- package/dist/components/tags/chip/Chip.d.ts +43 -0
- package/dist/components/tags/chip/Chip.d.ts.map +1 -0
- package/dist/components/tags/chip/Chip.figma.d.ts +2 -0
- package/dist/components/tags/chip/Chip.figma.d.ts.map +1 -0
- package/dist/components/tags/chip/Chip.figma.js +18 -0
- package/dist/components/tags/chip/Chip.figma.js.map +1 -0
- package/dist/components/tags/chip/Chip.js +88 -0
- package/dist/components/tags/chip/Chip.js.map +1 -0
- package/dist/components/tags/color-chip/ColorChip.d.ts +36 -0
- package/dist/components/tags/color-chip/ColorChip.d.ts.map +1 -0
- package/dist/components/tags/color-chip/ColorChip.js +39 -0
- package/dist/components/tags/color-chip/ColorChip.js.map +1 -0
- package/dist/components/tags/icon-chip/IconChip.d.ts +42 -0
- package/dist/components/tags/icon-chip/IconChip.d.ts.map +1 -0
- package/dist/components/tags/icon-chip/IconChip.js +54 -0
- package/dist/components/tags/icon-chip/IconChip.js.map +1 -0
- package/dist/components/tags/tooltip/Tooltip.d.ts +25 -0
- package/dist/components/tags/tooltip/Tooltip.d.ts.map +1 -0
- package/dist/components/tags/tooltip/Tooltip.js +72 -0
- package/dist/components/tags/tooltip/Tooltip.js.map +1 -0
- package/dist/do-classnames-DSDFCvzy.js +5 -0
- package/dist/do-classnames-DSDFCvzy.js.map +1 -0
- package/dist/do-map-2nhWP1KI.js +8 -0
- package/dist/do-map-2nhWP1KI.js.map +1 -0
- package/dist/index.d.ts +61 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +113 -0
- package/dist/index.js.map +1 -0
- package/dist/index_react-CmuCVQet.js +13799 -0
- package/dist/index_react-CmuCVQet.js.map +1 -0
- package/dist/styles/icons/icons.module.js +115 -0
- package/dist/styles/icons/icons.module.js.map +1 -0
- package/dist/styles/layouts.module.js +37 -0
- package/dist/styles/layouts.module.js.map +1 -0
- package/dist/styles/texts/texts.module.js +23 -0
- package/dist/styles/texts/texts.module.js.map +1 -0
- package/dist/styles/tokens/modules/figma-colors.module.js +9 -0
- package/dist/styles/tokens/modules/figma-colors.module.js.map +1 -0
- package/dist/styles/tokens/modules/figma-types.module.js +9 -0
- package/dist/styles/tokens/modules/figma-types.module.js.map +1 -0
- package/dist/styles/tokens/modules/framer-colors.module.js +9 -0
- package/dist/styles/tokens/modules/framer-colors.module.js.map +1 -0
- package/dist/styles/tokens/modules/framer-types.module.js +9 -0
- package/dist/styles/tokens/modules/framer-types.module.js.map +1 -0
- package/dist/styles/tokens/modules/globals.module.js +9 -0
- package/dist/styles/tokens/modules/globals.module.js.map +1 -0
- package/dist/styles/tokens/modules/penpot-colors.module.js +9 -0
- package/dist/styles/tokens/modules/penpot-colors.module.js.map +1 -0
- package/dist/styles/tokens/modules/penpot-types.module.js +9 -0
- package/dist/styles/tokens/modules/penpot-types.module.js.map +1 -0
- package/dist/styles/tokens/modules/sketch-colors.module.js +9 -0
- package/dist/styles/tokens/modules/sketch-colors.module.js.map +1 -0
- package/dist/styles/tokens/modules/sketch-types.module.js +9 -0
- package/dist/styles/tokens/modules/sketch-types.module.js.map +1 -0
- package/dist/tests/setup.d.ts +2 -0
- package/dist/tests/setup.d.ts.map +1 -0
- package/dist/types/consent.types.d.ts +10 -0
- package/dist/types/consent.types.d.ts.map +1 -0
- package/dist/types/consent.types.js +2 -0
- package/dist/types/consent.types.js.map +1 -0
- package/dist/types/icon.types.d.ts +2 -0
- package/dist/types/icon.types.d.ts.map +1 -0
- package/dist/types/icon.types.js +2 -0
- package/dist/types/icon.types.js.map +1 -0
- package/dist/types/list.types.d.ts +14 -0
- package/dist/types/list.types.d.ts.map +1 -0
- package/dist/types/list.types.js +2 -0
- package/dist/types/list.types.js.map +1 -0
- package/package.json +108 -0
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
import '../../../assets/Tabs.css';
|
|
2
|
+
import { jsx as n, jsxs as l } from "react/jsx-runtime";
|
|
3
|
+
import { useState as I, useRef as L, useEffect as C } from "react";
|
|
4
|
+
import c from "../../../styles/texts/texts.module.js";
|
|
5
|
+
import f from "../../tags/chip/Chip.js";
|
|
6
|
+
import { Icon as T } from "../../assets/icon/Icon.js";
|
|
7
|
+
import O from "../../actions/menu/Menu.js";
|
|
8
|
+
import { t as a } from "../../../do-classnames-DSDFCvzy.js";
|
|
9
|
+
const D = (h) => {
|
|
10
|
+
const {
|
|
11
|
+
tabs: r,
|
|
12
|
+
active: o,
|
|
13
|
+
direction: y = "HORIZONTAL",
|
|
14
|
+
isFlex: m = !1,
|
|
15
|
+
maxVisibleTabs: p = 3,
|
|
16
|
+
action: s
|
|
17
|
+
} = h, [v, _] = I(window.innerWidth), b = L(
|
|
18
|
+
`tabs-menu-${Math.random().toString(36).substr(2, 9)}`
|
|
19
|
+
);
|
|
20
|
+
if (C(() => {
|
|
21
|
+
const t = () => _(window.innerWidth);
|
|
22
|
+
return window.addEventListener("resize", t), () => window.removeEventListener("resize", t);
|
|
23
|
+
}, []), r.length > 1) {
|
|
24
|
+
const t = v <= 460 ? "HORIZONTAL" : y;
|
|
25
|
+
if (v > 460)
|
|
26
|
+
return /* @__PURE__ */ n(
|
|
27
|
+
"div",
|
|
28
|
+
{
|
|
29
|
+
className: a([
|
|
30
|
+
"tabs",
|
|
31
|
+
t === "VERTICAL" && "tabs--vertical"
|
|
32
|
+
]),
|
|
33
|
+
role: "tablist",
|
|
34
|
+
"aria-orientation": t === "VERTICAL" ? "vertical" : "horizontal",
|
|
35
|
+
children: r.map((e) => /* @__PURE__ */ l(
|
|
36
|
+
"div",
|
|
37
|
+
{
|
|
38
|
+
role: "tab",
|
|
39
|
+
className: a([
|
|
40
|
+
"tabs__tab",
|
|
41
|
+
o === e.id && "tabs__tab--active",
|
|
42
|
+
e.isUpdated && "tabs__tab--updated",
|
|
43
|
+
e.icon !== void 0 && "tabs__tab--with-icon",
|
|
44
|
+
m && t !== "VERTICAL" && "tabs__tab--flex"
|
|
45
|
+
]),
|
|
46
|
+
"data-feature": e.id,
|
|
47
|
+
tabIndex: o === e.id ? -1 : 0,
|
|
48
|
+
onMouseDown: s,
|
|
49
|
+
onKeyDown: (i) => {
|
|
50
|
+
(i.key === "Enter" || i.key === " ") && s(i), i.key === "Escape" && i.target.blur();
|
|
51
|
+
},
|
|
52
|
+
children: [
|
|
53
|
+
e.icon !== void 0 && /* @__PURE__ */ n(
|
|
54
|
+
T,
|
|
55
|
+
{
|
|
56
|
+
type: e.icon.type,
|
|
57
|
+
iconName: e.icon.type === "PICTO" ? e.icon.name : void 0,
|
|
58
|
+
iconLetter: e.icon.type === "LETTER" ? e.icon.name : void 0,
|
|
59
|
+
"aria-hidden": "true"
|
|
60
|
+
}
|
|
61
|
+
),
|
|
62
|
+
/* @__PURE__ */ n(
|
|
63
|
+
"span",
|
|
64
|
+
{
|
|
65
|
+
className: a([c.type, c["type--truncated"]]),
|
|
66
|
+
children: e.label
|
|
67
|
+
}
|
|
68
|
+
),
|
|
69
|
+
e.isNew && /* @__PURE__ */ n(f, { children: "New" })
|
|
70
|
+
]
|
|
71
|
+
},
|
|
72
|
+
e.label.toLowerCase()
|
|
73
|
+
))
|
|
74
|
+
}
|
|
75
|
+
);
|
|
76
|
+
const E = r.slice(0, p - 1), d = r.slice(p - 1), u = d.some(
|
|
77
|
+
(e) => e.id === o
|
|
78
|
+
);
|
|
79
|
+
return /* @__PURE__ */ l(
|
|
80
|
+
"div",
|
|
81
|
+
{
|
|
82
|
+
id: b.current,
|
|
83
|
+
className: a([
|
|
84
|
+
"tabs",
|
|
85
|
+
t === "VERTICAL" && "tabs--vertical"
|
|
86
|
+
]),
|
|
87
|
+
role: "tablist",
|
|
88
|
+
"aria-orientation": t === "VERTICAL" ? "vertical" : "horizontal",
|
|
89
|
+
children: [
|
|
90
|
+
E.map((e) => /* @__PURE__ */ l(
|
|
91
|
+
"div",
|
|
92
|
+
{
|
|
93
|
+
role: "tab",
|
|
94
|
+
className: a([
|
|
95
|
+
"tabs__tab",
|
|
96
|
+
o === e.id && "tabs__tab--active",
|
|
97
|
+
e.isUpdated && "tabs__tab--updated",
|
|
98
|
+
e.icon !== void 0 && "tabs__tab--with-icon",
|
|
99
|
+
m && t !== "VERTICAL" && "tabs__tab--flex"
|
|
100
|
+
]),
|
|
101
|
+
"data-feature": e.id,
|
|
102
|
+
tabIndex: o === e.id ? -1 : 0,
|
|
103
|
+
onMouseDown: s,
|
|
104
|
+
onKeyDown: (i) => {
|
|
105
|
+
(i.key === "Enter" || i.key === " ") && s(i), i.key === "Escape" && i.target.blur();
|
|
106
|
+
},
|
|
107
|
+
children: [
|
|
108
|
+
e.icon !== void 0 && /* @__PURE__ */ n(
|
|
109
|
+
T,
|
|
110
|
+
{
|
|
111
|
+
type: e.icon.type,
|
|
112
|
+
iconName: e.icon.type === "PICTO" ? e.icon.name : void 0,
|
|
113
|
+
iconLetter: e.icon.type === "LETTER" ? e.icon.name : void 0,
|
|
114
|
+
"aria-hidden": "true"
|
|
115
|
+
}
|
|
116
|
+
),
|
|
117
|
+
/* @__PURE__ */ n(
|
|
118
|
+
"span",
|
|
119
|
+
{
|
|
120
|
+
className: a([c.type, c["type--truncated"]]),
|
|
121
|
+
children: e.label
|
|
122
|
+
}
|
|
123
|
+
),
|
|
124
|
+
e.isNew && /* @__PURE__ */ n(f, { children: "New" })
|
|
125
|
+
]
|
|
126
|
+
},
|
|
127
|
+
e.label.toLowerCase()
|
|
128
|
+
)),
|
|
129
|
+
d.length > 0 && /* @__PURE__ */ n(
|
|
130
|
+
O,
|
|
131
|
+
{
|
|
132
|
+
id: "tabs-overflow-menu",
|
|
133
|
+
type: "ICON",
|
|
134
|
+
icon: "ellipses",
|
|
135
|
+
options: d.map((e) => ({
|
|
136
|
+
label: e.label,
|
|
137
|
+
value: e.id,
|
|
138
|
+
type: "OPTION",
|
|
139
|
+
isNew: e.isNew,
|
|
140
|
+
action: (i) => {
|
|
141
|
+
const w = {
|
|
142
|
+
dataset: { feature: e.id }
|
|
143
|
+
}, N = {
|
|
144
|
+
...i,
|
|
145
|
+
target: w,
|
|
146
|
+
currentTarget: w
|
|
147
|
+
};
|
|
148
|
+
s(N);
|
|
149
|
+
}
|
|
150
|
+
})),
|
|
151
|
+
selected: u ? o : void 0,
|
|
152
|
+
alignment: "BOTTOM_LEFT",
|
|
153
|
+
isNew: u
|
|
154
|
+
}
|
|
155
|
+
)
|
|
156
|
+
]
|
|
157
|
+
}
|
|
158
|
+
);
|
|
159
|
+
}
|
|
160
|
+
return null;
|
|
161
|
+
};
|
|
162
|
+
export {
|
|
163
|
+
D as default
|
|
164
|
+
};
|
|
165
|
+
//# sourceMappingURL=Tabs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Tabs.js","sources":["../../../../src/components/lists/tabs/Tabs.tsx"],"sourcesContent":["import './tabs.scss'\nimport { useState, useRef, useEffect } from 'react'\nimport { IconList } from '@tps/icon.types'\nimport texts from '@styles/texts/texts.module.scss'\nimport Chip from '@components/tags/chip/Chip'\nimport Icon from '@components/assets/icon/Icon'\nimport Menu from '@components/actions/menu/Menu'\nimport { doClassnames } from '@a_ng_d/figmug-utils'\n\nexport interface TabsProps {\n /**\n * Array of tab configurations\n */\n tabs: Array<{\n /** Tab label */\n label: string\n /** Unique tab ID */\n id: string\n /** Optional icon */\n icon?: {\n type: 'PICTO' | 'LETTER'\n name: IconList\n }\n /** Whether tab has been updated */\n isUpdated: boolean\n /** Whether to show a \"New\" badge */\n isNew?: boolean\n }>\n /**\n * ID of the active tab\n */\n active: string\n /**\n * Layout direction\n * @default 'HORIZONTAL'\n */\n direction?: 'HORIZONTAL' | 'VERTICAL'\n /**\n * Whether tabs should use flex layout\n * @default false\n */\n isFlex?: boolean\n /**\n * Maximum number of tabs to display before collapsing into menu\n * @default 3\n */\n maxVisibleTabs?: number\n /**\n * Click handler\n */\n action: React.MouseEventHandler & React.KeyboardEventHandler\n}\n\nconst Tabs = (props: TabsProps) => {\n const {\n tabs,\n active,\n direction = 'HORIZONTAL',\n isFlex = false,\n maxVisibleTabs = 3,\n action,\n } = props\n\n const [windowWidth, setWindowWidth] = useState(window.innerWidth)\n const menuContainerId = useRef(\n `tabs-menu-${Math.random().toString(36).substr(2, 9)}`\n )\n\n useEffect(() => {\n const handleResize = () => setWindowWidth(window.innerWidth)\n window.addEventListener('resize', handleResize)\n return () => window.removeEventListener('resize', handleResize)\n }, [])\n\n if (tabs.length > 1) {\n const effectiveDirection = windowWidth <= 460 ? 'HORIZONTAL' : direction\n\n if (windowWidth > 460)\n return (\n <div\n className={doClassnames([\n 'tabs',\n effectiveDirection === 'VERTICAL' && 'tabs--vertical',\n ])}\n role=\"tablist\"\n aria-orientation={\n effectiveDirection === 'VERTICAL' ? 'vertical' : 'horizontal'\n }\n >\n {tabs.map((tab) => (\n <div\n role=\"tab\"\n key={tab.label.toLowerCase()}\n className={doClassnames([\n 'tabs__tab',\n active === tab.id && 'tabs__tab--active',\n tab.isUpdated && 'tabs__tab--updated',\n tab.icon !== undefined && 'tabs__tab--with-icon',\n isFlex &&\n effectiveDirection !== 'VERTICAL' &&\n 'tabs__tab--flex',\n ])}\n data-feature={tab.id}\n tabIndex={active === tab.id ? -1 : 0}\n onMouseDown={action}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === ' ') action(e)\n if (e.key === 'Escape') (e.target as HTMLElement).blur()\n }}\n >\n {tab.icon !== undefined && (\n <Icon\n type={tab.icon.type}\n iconName={\n tab.icon.type === 'PICTO' ? tab.icon.name : undefined\n }\n iconLetter={\n tab.icon.type === 'LETTER' ? tab.icon.name : undefined\n }\n aria-hidden=\"true\"\n />\n )}\n <span\n className={doClassnames([texts.type, texts['type--truncated']])}\n >\n {tab.label}\n </span>\n {tab.isNew && <Chip>New</Chip>}\n </div>\n ))}\n </div>\n )\n\n const responsiveVisibleTabs = tabs.slice(0, maxVisibleTabs - 1)\n const responsiveOverflowTabs = tabs.slice(maxVisibleTabs - 1)\n\n const activeInOverflow = responsiveOverflowTabs.some(\n (tab) => tab.id === active\n )\n\n return (\n <div\n id={menuContainerId.current}\n className={doClassnames([\n 'tabs',\n effectiveDirection === 'VERTICAL' && 'tabs--vertical',\n ])}\n role=\"tablist\"\n aria-orientation={\n effectiveDirection === 'VERTICAL' ? 'vertical' : 'horizontal'\n }\n >\n {responsiveVisibleTabs.map((tab) => (\n <div\n role=\"tab\"\n key={tab.label.toLowerCase()}\n className={doClassnames([\n 'tabs__tab',\n active === tab.id && 'tabs__tab--active',\n tab.isUpdated && 'tabs__tab--updated',\n tab.icon !== undefined && 'tabs__tab--with-icon',\n isFlex && effectiveDirection !== 'VERTICAL' && 'tabs__tab--flex',\n ])}\n data-feature={tab.id}\n tabIndex={active === tab.id ? -1 : 0}\n onMouseDown={action}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === ' ') action(e)\n if (e.key === 'Escape') (e.target as HTMLElement).blur()\n }}\n >\n {tab.icon !== undefined && (\n <Icon\n type={tab.icon.type}\n iconName={tab.icon.type === 'PICTO' ? tab.icon.name : undefined}\n iconLetter={\n tab.icon.type === 'LETTER' ? tab.icon.name : undefined\n }\n aria-hidden=\"true\"\n />\n )}\n <span\n className={doClassnames([texts.type, texts['type--truncated']])}\n >\n {tab.label}\n </span>\n {tab.isNew && <Chip>New</Chip>}\n </div>\n ))}\n\n {responsiveOverflowTabs.length > 0 && (\n <Menu\n id=\"tabs-overflow-menu\"\n type=\"ICON\"\n icon=\"ellipses\"\n options={responsiveOverflowTabs.map((tab) => ({\n label: tab.label,\n value: tab.id,\n type: 'OPTION',\n isNew: tab.isNew,\n action: (e: React.MouseEvent | React.KeyboardEvent) => {\n const mockTarget = {\n dataset: { feature: tab.id },\n }\n\n const mockEvent = {\n ...e,\n target: mockTarget,\n currentTarget: mockTarget,\n } as unknown as React.MouseEvent & React.KeyboardEvent\n\n action(mockEvent)\n },\n }))}\n selected={activeInOverflow ? active : undefined}\n alignment=\"BOTTOM_LEFT\"\n isNew={activeInOverflow}\n />\n )}\n </div>\n )\n }\n\n return null\n}\n\nexport default Tabs\n"],"names":["Tabs","props","tabs","active","direction","isFlex","maxVisibleTabs","action","windowWidth","setWindowWidth","useState","menuContainerId","useRef","useEffect","handleResize","effectiveDirection","jsx","doClassnames","tab","jsxs","e","Icon","texts","Chip","responsiveVisibleTabs","responsiveOverflowTabs","activeInOverflow","Menu","mockTarget","mockEvent"],"mappings":";;;;;;;AAqDA,MAAMA,IAAO,CAACC,MAAqB;AACjC,QAAM;AAAA,IACJ,MAAAC;AAAA,IACA,QAAAC;AAAA,IACA,WAAAC,IAAY;AAAA,IACZ,QAAAC,IAAS;AAAA,IACT,gBAAAC,IAAiB;AAAA,IACjB,QAAAC;AAAA,EAAA,IACEN,GAEE,CAACO,GAAaC,CAAc,IAAIC,EAAS,OAAO,UAAU,GAC1DC,IAAkBC;AAAA,IACtB,aAAa,KAAK,SAAS,SAAS,EAAE,EAAE,OAAO,GAAG,CAAC,CAAC;AAAA,EAAA;AAStD,MANAC,EAAU,MAAM;AACd,UAAMC,IAAe,MAAML,EAAe,OAAO,UAAU;AAC3D,kBAAO,iBAAiB,UAAUK,CAAY,GACvC,MAAM,OAAO,oBAAoB,UAAUA,CAAY;AAAA,EAChE,GAAG,CAAA,CAAE,GAEDZ,EAAK,SAAS,GAAG;AACnB,UAAMa,IAAqBP,KAAe,MAAM,eAAeJ;AAE/D,QAAII,IAAc;AAChB,aACE,gBAAAQ;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,WAAWC,EAAa;AAAA,YACtB;AAAA,YACAF,MAAuB,cAAc;AAAA,UAAA,CACtC;AAAA,UACD,MAAK;AAAA,UACL,oBACEA,MAAuB,aAAa,aAAa;AAAA,UAGlD,UAAAb,EAAK,IAAI,CAACgB,MACT,gBAAAC;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,MAAK;AAAA,cAEL,WAAWF,EAAa;AAAA,gBACtB;AAAA,gBACAd,MAAWe,EAAI,MAAM;AAAA,gBACrBA,EAAI,aAAa;AAAA,gBACjBA,EAAI,SAAS,UAAa;AAAA,gBAC1Bb,KACEU,MAAuB,cACvB;AAAA,cAAA,CACH;AAAA,cACD,gBAAcG,EAAI;AAAA,cAClB,UAAUf,MAAWe,EAAI,KAAK,KAAK;AAAA,cACnC,aAAaX;AAAA,cACb,WAAW,CAACa,MAAM;AAChB,iBAAIA,EAAE,QAAQ,WAAWA,EAAE,QAAQ,UAAYA,CAAC,GAC5CA,EAAE,QAAQ,YAAWA,EAAE,OAAuB,KAAA;AAAA,cACpD;AAAA,cAEC,UAAA;AAAA,gBAAAF,EAAI,SAAS,UACZ,gBAAAF;AAAA,kBAACK;AAAA,kBAAA;AAAA,oBACC,MAAMH,EAAI,KAAK;AAAA,oBACf,UACEA,EAAI,KAAK,SAAS,UAAUA,EAAI,KAAK,OAAO;AAAA,oBAE9C,YACEA,EAAI,KAAK,SAAS,WAAWA,EAAI,KAAK,OAAO;AAAA,oBAE/C,eAAY;AAAA,kBAAA;AAAA,gBAAA;AAAA,gBAGhB,gBAAAF;AAAA,kBAAC;AAAA,kBAAA;AAAA,oBACC,WAAWC,EAAa,CAACK,EAAM,MAAMA,EAAM,iBAAiB,CAAC,CAAC;AAAA,oBAE7D,UAAAJ,EAAI;AAAA,kBAAA;AAAA,gBAAA;AAAA,gBAENA,EAAI,SAAS,gBAAAF,EAACO,GAAA,EAAK,UAAA,MAAA,CAAG;AAAA,cAAA;AAAA,YAAA;AAAA,YAnClBL,EAAI,MAAM,YAAA;AAAA,UAAY,CAqC9B;AAAA,QAAA;AAAA,MAAA;AAIP,UAAMM,IAAwBtB,EAAK,MAAM,GAAGI,IAAiB,CAAC,GACxDmB,IAAyBvB,EAAK,MAAMI,IAAiB,CAAC,GAEtDoB,IAAmBD,EAAuB;AAAA,MAC9C,CAACP,MAAQA,EAAI,OAAOf;AAAA,IAAA;AAGtB,WACE,gBAAAgB;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,IAAIR,EAAgB;AAAA,QACpB,WAAWM,EAAa;AAAA,UACtB;AAAA,UACAF,MAAuB,cAAc;AAAA,QAAA,CACtC;AAAA,QACD,MAAK;AAAA,QACL,oBACEA,MAAuB,aAAa,aAAa;AAAA,QAGlD,UAAA;AAAA,UAAAS,EAAsB,IAAI,CAACN,MAC1B,gBAAAC;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,MAAK;AAAA,cAEL,WAAWF,EAAa;AAAA,gBACtB;AAAA,gBACAd,MAAWe,EAAI,MAAM;AAAA,gBACrBA,EAAI,aAAa;AAAA,gBACjBA,EAAI,SAAS,UAAa;AAAA,gBAC1Bb,KAAUU,MAAuB,cAAc;AAAA,cAAA,CAChD;AAAA,cACD,gBAAcG,EAAI;AAAA,cAClB,UAAUf,MAAWe,EAAI,KAAK,KAAK;AAAA,cACnC,aAAaX;AAAA,cACb,WAAW,CAACa,MAAM;AAChB,iBAAIA,EAAE,QAAQ,WAAWA,EAAE,QAAQ,UAAYA,CAAC,GAC5CA,EAAE,QAAQ,YAAWA,EAAE,OAAuB,KAAA;AAAA,cACpD;AAAA,cAEC,UAAA;AAAA,gBAAAF,EAAI,SAAS,UACZ,gBAAAF;AAAA,kBAACK;AAAA,kBAAA;AAAA,oBACC,MAAMH,EAAI,KAAK;AAAA,oBACf,UAAUA,EAAI,KAAK,SAAS,UAAUA,EAAI,KAAK,OAAO;AAAA,oBACtD,YACEA,EAAI,KAAK,SAAS,WAAWA,EAAI,KAAK,OAAO;AAAA,oBAE/C,eAAY;AAAA,kBAAA;AAAA,gBAAA;AAAA,gBAGhB,gBAAAF;AAAA,kBAAC;AAAA,kBAAA;AAAA,oBACC,WAAWC,EAAa,CAACK,EAAM,MAAMA,EAAM,iBAAiB,CAAC,CAAC;AAAA,oBAE7D,UAAAJ,EAAI;AAAA,kBAAA;AAAA,gBAAA;AAAA,gBAENA,EAAI,SAAS,gBAAAF,EAACO,GAAA,EAAK,UAAA,MAAA,CAAG;AAAA,cAAA;AAAA,YAAA;AAAA,YA/BlBL,EAAI,MAAM,YAAA;AAAA,UAAY,CAiC9B;AAAA,UAEAO,EAAuB,SAAS,KAC/B,gBAAAT;AAAA,YAACW;AAAA,YAAA;AAAA,cACC,IAAG;AAAA,cACH,MAAK;AAAA,cACL,MAAK;AAAA,cACL,SAASF,EAAuB,IAAI,CAACP,OAAS;AAAA,gBAC5C,OAAOA,EAAI;AAAA,gBACX,OAAOA,EAAI;AAAA,gBACX,MAAM;AAAA,gBACN,OAAOA,EAAI;AAAA,gBACX,QAAQ,CAACE,MAA8C;AACrD,wBAAMQ,IAAa;AAAA,oBACjB,SAAS,EAAE,SAASV,EAAI,GAAA;AAAA,kBAAG,GAGvBW,IAAY;AAAA,oBAChB,GAAGT;AAAA,oBACH,QAAQQ;AAAA,oBACR,eAAeA;AAAA,kBAAA;AAGjB,kBAAArB,EAAOsB,CAAS;AAAA,gBAClB;AAAA,cAAA,EACA;AAAA,cACF,UAAUH,IAAmBvB,IAAS;AAAA,cACtC,WAAU;AAAA,cACV,OAAOuB;AAAA,YAAA;AAAA,UAAA;AAAA,QACT;AAAA,MAAA;AAAA,IAAA;AAAA,EAIR;AAEA,SAAO;AACT;"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
|
|
3
|
+
export interface BarProps {
|
|
4
|
+
/**
|
|
5
|
+
* HTML id attribute
|
|
6
|
+
*/
|
|
7
|
+
id?: string;
|
|
8
|
+
/**
|
|
9
|
+
* Content for the left section
|
|
10
|
+
*/
|
|
11
|
+
leftPartSlot?: React.ReactElement | null;
|
|
12
|
+
/**
|
|
13
|
+
* Content for the center section (when used alone)
|
|
14
|
+
*/
|
|
15
|
+
soloPartSlot?: React.ReactElement | null;
|
|
16
|
+
/**
|
|
17
|
+
* Content for the right section
|
|
18
|
+
*/
|
|
19
|
+
rightPartSlot?: React.ReactElement | null;
|
|
20
|
+
/**
|
|
21
|
+
* Array of border positions
|
|
22
|
+
*/
|
|
23
|
+
border?: Array<'TOP' | 'LEFT' | 'BOTTOM' | 'RIGHT'>;
|
|
24
|
+
/**
|
|
25
|
+
* Array of clip positions (for visual effects)
|
|
26
|
+
*/
|
|
27
|
+
clip?: Array<'LEFT' | 'RIGHT' | 'SOLO'>;
|
|
28
|
+
/**
|
|
29
|
+
* Custom padding value
|
|
30
|
+
*/
|
|
31
|
+
padding?: string;
|
|
32
|
+
/**
|
|
33
|
+
* Whether to use compact spacing
|
|
34
|
+
* @default false
|
|
35
|
+
*/
|
|
36
|
+
isCompact?: boolean;
|
|
37
|
+
/**
|
|
38
|
+
* Whether the bar contains only text
|
|
39
|
+
* @default false
|
|
40
|
+
*/
|
|
41
|
+
isOnlyText?: boolean;
|
|
42
|
+
/**
|
|
43
|
+
* Whether to use inverted color scheme
|
|
44
|
+
* @default false
|
|
45
|
+
*/
|
|
46
|
+
isInverted?: boolean;
|
|
47
|
+
/**
|
|
48
|
+
* Whether to center the content
|
|
49
|
+
* @default false
|
|
50
|
+
*/
|
|
51
|
+
isCentered?: boolean;
|
|
52
|
+
/**
|
|
53
|
+
* Whether to reflow on small screens
|
|
54
|
+
* @default false
|
|
55
|
+
*/
|
|
56
|
+
shouldReflow?: boolean;
|
|
57
|
+
}
|
|
58
|
+
export default class Bar extends React.Component<BarProps> {
|
|
59
|
+
static defaultProps: Partial<BarProps>;
|
|
60
|
+
setBorder: (orientation: Array<'TOP' | 'LEFT' | 'BOTTOM' | 'RIGHT'> | undefined) => {
|
|
61
|
+
[key: string]: React.CSSProperties;
|
|
62
|
+
};
|
|
63
|
+
render(): import("react/jsx-runtime").JSX.Element | null;
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=Bar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Bar.d.ts","sourceRoot":"","sources":["../../../../src/components/slots/bar/Bar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,YAAY,CAAA;AAEnB,MAAM,WAAW,QAAQ;IACvB;;OAEG;IACH,EAAE,CAAC,EAAE,MAAM,CAAA;IACX;;OAEG;IACH,YAAY,CAAC,EAAE,KAAK,CAAC,YAAY,GAAG,IAAI,CAAA;IACxC;;OAEG;IACH,YAAY,CAAC,EAAE,KAAK,CAAC,YAAY,GAAG,IAAI,CAAA;IACxC;;OAEG;IACH,aAAa,CAAC,EAAE,KAAK,CAAC,YAAY,GAAG,IAAI,CAAA;IACzC;;OAEG;IACH,MAAM,CAAC,EAAE,KAAK,CAAC,KAAK,GAAG,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC,CAAA;IACnD;;OAEG;IACH,IAAI,CAAC,EAAE,KAAK,CAAC,MAAM,GAAG,OAAO,GAAG,MAAM,CAAC,CAAA;IACvC;;OAEG;IACH,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB;;;OAGG;IACH,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB;;;OAGG;IACH,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB;;;OAGG;IACH,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB;;;OAGG;IACH,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB;;;OAGG;IACH,YAAY,CAAC,EAAE,OAAO,CAAA;CACvB;AAED,MAAM,CAAC,OAAO,OAAO,GAAI,SAAQ,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC;IACxD,MAAM,CAAC,YAAY,EAAE,OAAO,CAAC,QAAQ,CAAC,CAMrC;IAED,SAAS,gBACM,MAAM,KAAK,GAAG,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC,GAAG,SAAS;;MAcpE;IAED,MAAM;CA+EP"}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
import '../../../assets/Bar.css';
|
|
2
|
+
import { jsx as t, jsxs as v } from "react/jsx-runtime";
|
|
3
|
+
import T from "react";
|
|
4
|
+
import { t as g } from "../../../do-classnames-DSDFCvzy.js";
|
|
5
|
+
class C extends T.Component {
|
|
6
|
+
static defaultProps = {
|
|
7
|
+
isCompact: !1,
|
|
8
|
+
isOnlyText: !1,
|
|
9
|
+
isInverted: !1,
|
|
10
|
+
isCentered: !1,
|
|
11
|
+
shouldReflow: !1
|
|
12
|
+
};
|
|
13
|
+
setBorder = (s) => {
|
|
14
|
+
const e = "var(--bar-border-width) solid var(--bar-border-color)", r = {};
|
|
15
|
+
return s && s.forEach((o) => {
|
|
16
|
+
o === "TOP" && (r.borderTop = e), o === "LEFT" && (r.borderLeft = e), o === "BOTTOM" && (r.borderBottom = e), o === "RIGHT" && (r.borderRight = e);
|
|
17
|
+
}), r;
|
|
18
|
+
};
|
|
19
|
+
render() {
|
|
20
|
+
const {
|
|
21
|
+
id: s,
|
|
22
|
+
isCompact: e,
|
|
23
|
+
isOnlyText: r,
|
|
24
|
+
isInverted: o,
|
|
25
|
+
isCentered: p,
|
|
26
|
+
shouldReflow: h,
|
|
27
|
+
border: c,
|
|
28
|
+
padding: n,
|
|
29
|
+
clip: l,
|
|
30
|
+
leftPartSlot: a,
|
|
31
|
+
soloPartSlot: i,
|
|
32
|
+
rightPartSlot: d
|
|
33
|
+
} = this.props, f = i != null, u = a != null, m = d != null;
|
|
34
|
+
if (!f && !u && !m) return null;
|
|
35
|
+
const b = g([
|
|
36
|
+
"bar",
|
|
37
|
+
e && "bar--compact",
|
|
38
|
+
r && "bar--text-only",
|
|
39
|
+
o && "bar--inverted",
|
|
40
|
+
p && "bar--centered",
|
|
41
|
+
h && "bar--reflow",
|
|
42
|
+
l && l.includes("LEFT") && "bar--clip-left",
|
|
43
|
+
l && l.includes("RIGHT") && "bar--clip-right",
|
|
44
|
+
l && l.includes("SOLO") && "bar--clip-solo"
|
|
45
|
+
]);
|
|
46
|
+
return f ? /* @__PURE__ */ t(
|
|
47
|
+
"div",
|
|
48
|
+
{
|
|
49
|
+
id: s,
|
|
50
|
+
className: b,
|
|
51
|
+
style: {
|
|
52
|
+
...this.setBorder(c),
|
|
53
|
+
padding: n
|
|
54
|
+
},
|
|
55
|
+
role: "toolbar",
|
|
56
|
+
children: /* @__PURE__ */ t(
|
|
57
|
+
"div",
|
|
58
|
+
{
|
|
59
|
+
className: "bar__solo",
|
|
60
|
+
role: "group",
|
|
61
|
+
children: i
|
|
62
|
+
}
|
|
63
|
+
)
|
|
64
|
+
}
|
|
65
|
+
) : /* @__PURE__ */ v(
|
|
66
|
+
"div",
|
|
67
|
+
{
|
|
68
|
+
id: s,
|
|
69
|
+
className: b,
|
|
70
|
+
style: {
|
|
71
|
+
...this.setBorder(c),
|
|
72
|
+
padding: n
|
|
73
|
+
},
|
|
74
|
+
role: "toolbar",
|
|
75
|
+
children: [
|
|
76
|
+
/* @__PURE__ */ t(
|
|
77
|
+
"div",
|
|
78
|
+
{
|
|
79
|
+
className: "bar__left",
|
|
80
|
+
role: "group",
|
|
81
|
+
children: a
|
|
82
|
+
}
|
|
83
|
+
),
|
|
84
|
+
/* @__PURE__ */ t(
|
|
85
|
+
"div",
|
|
86
|
+
{
|
|
87
|
+
className: "bar__right",
|
|
88
|
+
role: "group",
|
|
89
|
+
children: d
|
|
90
|
+
}
|
|
91
|
+
)
|
|
92
|
+
]
|
|
93
|
+
}
|
|
94
|
+
);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
export {
|
|
98
|
+
C as default
|
|
99
|
+
};
|
|
100
|
+
//# sourceMappingURL=Bar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Bar.js","sources":["../../../../src/components/slots/bar/Bar.tsx"],"sourcesContent":["import React from 'react'\nimport { doClassnames } from '@a_ng_d/figmug-utils'\nimport './bar.scss'\n\nexport interface BarProps {\n /**\n * HTML id attribute\n */\n id?: string\n /**\n * Content for the left section\n */\n leftPartSlot?: React.ReactElement | null\n /**\n * Content for the center section (when used alone)\n */\n soloPartSlot?: React.ReactElement | null\n /**\n * Content for the right section\n */\n rightPartSlot?: React.ReactElement | null\n /**\n * Array of border positions\n */\n border?: Array<'TOP' | 'LEFT' | 'BOTTOM' | 'RIGHT'>\n /**\n * Array of clip positions (for visual effects)\n */\n clip?: Array<'LEFT' | 'RIGHT' | 'SOLO'>\n /**\n * Custom padding value\n */\n padding?: string\n /**\n * Whether to use compact spacing\n * @default false\n */\n isCompact?: boolean\n /**\n * Whether the bar contains only text\n * @default false\n */\n isOnlyText?: boolean\n /**\n * Whether to use inverted color scheme\n * @default false\n */\n isInverted?: boolean\n /**\n * Whether to center the content\n * @default false\n */\n isCentered?: boolean\n /**\n * Whether to reflow on small screens\n * @default false\n */\n shouldReflow?: boolean\n}\n\nexport default class Bar extends React.Component<BarProps> {\n static defaultProps: Partial<BarProps> = {\n isCompact: false,\n isOnlyText: false,\n isInverted: false,\n isCentered: false,\n shouldReflow: false,\n }\n\n setBorder = (\n orientation: Array<'TOP' | 'LEFT' | 'BOTTOM' | 'RIGHT'> | undefined\n ) => {\n const property =\n 'var(--bar-border-width) solid var(--bar-border-color)' as React.CSSProperties\n const styles: { [key: string]: React.CSSProperties } = {}\n\n if (!orientation) return styles\n orientation.forEach((entry) => {\n if (entry === 'TOP') styles.borderTop = property\n if (entry === 'LEFT') styles.borderLeft = property\n if (entry === 'BOTTOM') styles.borderBottom = property\n if (entry === 'RIGHT') styles.borderRight = property\n })\n return styles\n }\n\n render() {\n const {\n id,\n isCompact,\n isOnlyText,\n isInverted,\n isCentered,\n shouldReflow,\n border,\n padding,\n clip,\n leftPartSlot,\n soloPartSlot,\n rightPartSlot,\n } = this.props\n\n const hasValidSolo = soloPartSlot !== undefined && soloPartSlot !== null\n const hasValidLeft = leftPartSlot !== undefined && leftPartSlot !== null\n const hasValidRight = rightPartSlot !== undefined && rightPartSlot !== null\n\n if (!hasValidSolo && !hasValidLeft && !hasValidRight) return null\n\n const barClassName = doClassnames([\n 'bar',\n isCompact && 'bar--compact',\n isOnlyText && 'bar--text-only',\n isInverted && 'bar--inverted',\n isCentered && 'bar--centered',\n shouldReflow && 'bar--reflow',\n clip && clip.includes('LEFT') && 'bar--clip-left',\n clip && clip.includes('RIGHT') && 'bar--clip-right',\n clip && clip.includes('SOLO') && 'bar--clip-solo',\n ])\n\n if (hasValidSolo)\n return (\n <div\n id={id}\n className={barClassName}\n style={{\n ...this.setBorder(border),\n padding: padding,\n }}\n role=\"toolbar\"\n >\n <div\n className=\"bar__solo\"\n role=\"group\"\n >\n {soloPartSlot}\n </div>\n </div>\n )\n\n return (\n <div\n id={id}\n className={barClassName}\n style={{\n ...this.setBorder(border),\n padding: padding,\n }}\n role=\"toolbar\"\n >\n <div\n className=\"bar__left\"\n role=\"group\"\n >\n {leftPartSlot}\n </div>\n <div\n className=\"bar__right\"\n role=\"group\"\n >\n {rightPartSlot}\n </div>\n </div>\n )\n }\n}\n"],"names":["Bar","React","orientation","property","styles","entry","id","isCompact","isOnlyText","isInverted","isCentered","shouldReflow","border","padding","clip","leftPartSlot","soloPartSlot","rightPartSlot","hasValidSolo","hasValidLeft","hasValidRight","barClassName","doClassnames","jsx","jsxs"],"mappings":";;;AA4DA,MAAqBA,UAAYC,EAAM,UAAoB;AAAA,EACzD,OAAO,eAAkC;AAAA,IACvC,WAAW;AAAA,IACX,YAAY;AAAA,IACZ,YAAY;AAAA,IACZ,YAAY;AAAA,IACZ,cAAc;AAAA,EAAA;AAAA,EAGhB,YAAY,CACVC,MACG;AACH,UAAMC,IACJ,yDACIC,IAAiD,CAAA;AAEvD,WAAKF,KACLA,EAAY,QAAQ,CAACG,MAAU;AAC7B,MAAIA,MAAU,UAAOD,EAAO,YAAYD,IACpCE,MAAU,WAAQD,EAAO,aAAaD,IACtCE,MAAU,aAAUD,EAAO,eAAeD,IAC1CE,MAAU,YAASD,EAAO,cAAcD;AAAA,IAC9C,CAAC,GACMC;AAAA,EACT;AAAA,EAEA,SAAS;AACP,UAAM;AAAA,MACJ,IAAAE;AAAA,MACA,WAAAC;AAAA,MACA,YAAAC;AAAA,MACA,YAAAC;AAAA,MACA,YAAAC;AAAA,MACA,cAAAC;AAAA,MACA,QAAAC;AAAA,MACA,SAAAC;AAAA,MACA,MAAAC;AAAA,MACA,cAAAC;AAAA,MACA,cAAAC;AAAA,MACA,eAAAC;AAAA,IAAA,IACE,KAAK,OAEHC,IAA6CF,KAAiB,MAC9DG,IAA6CJ,KAAiB,MAC9DK,IAA+CH,KAAkB;AAEvE,QAAI,CAACC,KAAgB,CAACC,KAAgB,CAACC,EAAe,QAAO;AAE7D,UAAMC,IAAeC,EAAa;AAAA,MAChC;AAAA,MACAf,KAAa;AAAA,MACbC,KAAc;AAAA,MACdC,KAAc;AAAA,MACdC,KAAc;AAAA,MACdC,KAAgB;AAAA,MAChBG,KAAQA,EAAK,SAAS,MAAM,KAAK;AAAA,MACjCA,KAAQA,EAAK,SAAS,OAAO,KAAK;AAAA,MAClCA,KAAQA,EAAK,SAAS,MAAM,KAAK;AAAA,IAAA,CAClC;AAED,WAAII,IAEA,gBAAAK;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,IAAAjB;AAAA,QACA,WAAWe;AAAA,QACX,OAAO;AAAA,UACL,GAAG,KAAK,UAAUT,CAAM;AAAA,UACxB,SAAAC;AAAA,QAAA;AAAA,QAEF,MAAK;AAAA,QAEL,UAAA,gBAAAU;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,WAAU;AAAA,YACV,MAAK;AAAA,YAEJ,UAAAP;AAAA,UAAA;AAAA,QAAA;AAAA,MACH;AAAA,IAAA,IAKJ,gBAAAQ;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,IAAAlB;AAAA,QACA,WAAWe;AAAA,QACX,OAAO;AAAA,UACL,GAAG,KAAK,UAAUT,CAAM;AAAA,UACxB,SAAAC;AAAA,QAAA;AAAA,QAEF,MAAK;AAAA,QAEL,UAAA;AAAA,UAAA,gBAAAU;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,WAAU;AAAA,cACV,MAAK;AAAA,cAEJ,UAAAR;AAAA,YAAA;AAAA,UAAA;AAAA,UAEH,gBAAAQ;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,WAAU;AAAA,cACV,MAAK;AAAA,cAEJ,UAAAN;AAAA,YAAA;AAAA,UAAA;AAAA,QACH;AAAA,MAAA;AAAA,IAAA;AAAA,EAGN;AACF;"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
import { default as Button } from '../../actions/button/Button';
|
|
3
|
+
|
|
4
|
+
export interface DraggableWindowProps {
|
|
5
|
+
/**
|
|
6
|
+
* Title of the window
|
|
7
|
+
* @default 'Options'
|
|
8
|
+
*/
|
|
9
|
+
title?: string;
|
|
10
|
+
/**
|
|
11
|
+
* Content of the window
|
|
12
|
+
*/
|
|
13
|
+
children: React.ReactNode;
|
|
14
|
+
/**
|
|
15
|
+
* Reference to the trigger button
|
|
16
|
+
*/
|
|
17
|
+
triggerRef: React.RefObject<Button>;
|
|
18
|
+
/**
|
|
19
|
+
* Close handler
|
|
20
|
+
*/
|
|
21
|
+
onClose: () => void;
|
|
22
|
+
}
|
|
23
|
+
declare const DraggableWindow: (props: DraggableWindowProps) => import("react/jsx-runtime").JSX.Element;
|
|
24
|
+
export default DraggableWindow;
|
|
25
|
+
//# sourceMappingURL=DraggableWindow.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DraggableWindow.d.ts","sourceRoot":"","sources":["../../../../src/components/slots/draggable-window/DraggableWindow.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAsC,MAAM,OAAO,CAAA;AAE1D,OAAO,MAAM,MAAM,mCAAmC,CAAA;AAItD,OAAO,yBAAyB,CAAA;AAEhC,MAAM,WAAW,oBAAoB;IACnC;;;OAGG;IACH,KAAK,CAAC,EAAE,MAAM,CAAA;IACd;;OAEG;IACH,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;IACzB;;OAEG;IACH,UAAU,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,CAAA;IACnC;;OAEG;IACH,OAAO,EAAE,MAAM,IAAI,CAAA;CACpB;AAED,QAAA,MAAM,eAAe,UAAW,oBAAoB,4CA2GnD,CAAA;AAED,eAAe,eAAe,CAAA"}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
import '../../../assets/DraggableWindow.css';
|
|
2
|
+
import { jsxs as y, jsx as t } from "react/jsx-runtime";
|
|
3
|
+
import { useState as r, useRef as R, useEffect as m } from "react";
|
|
4
|
+
import M from "../../assets/section-title/SectionTitle.js";
|
|
5
|
+
import E from "../../actions/button/Button.js";
|
|
6
|
+
import { t as O } from "../../../do-classnames-DSDFCvzy.js";
|
|
7
|
+
import _ from "../bar/Bar.js";
|
|
8
|
+
const N = (w) => {
|
|
9
|
+
const { title: d = "Options", children: p, triggerRef: s, onClose: v } = w, [n, c] = r(!1), [g, x] = r(!1), [o, u] = r({ x: 0, y: 0 }), [a, b] = r({ x: 0, y: 0 }), l = R(null);
|
|
10
|
+
m(() => {
|
|
11
|
+
if (s.current?.buttonRef?.current && l.current) {
|
|
12
|
+
const e = l.current.getBoundingClientRect(), i = s.current.buttonRef.current.getBoundingClientRect();
|
|
13
|
+
u({
|
|
14
|
+
x: i.left - e.width - 8,
|
|
15
|
+
y: 0
|
|
16
|
+
}), x(!0);
|
|
17
|
+
}
|
|
18
|
+
}, [s]);
|
|
19
|
+
const h = (e) => {
|
|
20
|
+
e.target instanceof HTMLElement && e.target.closest(".draggable-window__header") && (c(!0), b({
|
|
21
|
+
x: e.clientX - o.x,
|
|
22
|
+
y: e.clientY - o.y
|
|
23
|
+
}));
|
|
24
|
+
}, f = () => {
|
|
25
|
+
c(!1);
|
|
26
|
+
};
|
|
27
|
+
return m(() => {
|
|
28
|
+
const e = (i) => {
|
|
29
|
+
n && u({
|
|
30
|
+
x: i.clientX - a.x,
|
|
31
|
+
y: i.clientY - a.y
|
|
32
|
+
});
|
|
33
|
+
};
|
|
34
|
+
return n && (window.addEventListener("mousemove", e), window.addEventListener("mouseup", f)), () => {
|
|
35
|
+
window.removeEventListener("mousemove", e), window.removeEventListener("mouseup", f);
|
|
36
|
+
};
|
|
37
|
+
}, [n, a]), /* @__PURE__ */ y(
|
|
38
|
+
"div",
|
|
39
|
+
{
|
|
40
|
+
className: O([
|
|
41
|
+
"draggable-window",
|
|
42
|
+
n && "draggable-window--dragging"
|
|
43
|
+
]),
|
|
44
|
+
style: {
|
|
45
|
+
transform: `translate(${o.x}px, ${o.y}px)`,
|
|
46
|
+
visibility: g ? "visible" : "hidden"
|
|
47
|
+
},
|
|
48
|
+
onMouseDown: h,
|
|
49
|
+
ref: l,
|
|
50
|
+
role: "dialog",
|
|
51
|
+
"aria-modal": "true",
|
|
52
|
+
"aria-hidden": !g,
|
|
53
|
+
children: [
|
|
54
|
+
/* @__PURE__ */ t(
|
|
55
|
+
"div",
|
|
56
|
+
{
|
|
57
|
+
className: "draggable-window__header",
|
|
58
|
+
role: "presentation",
|
|
59
|
+
children: /* @__PURE__ */ t(
|
|
60
|
+
_,
|
|
61
|
+
{
|
|
62
|
+
leftPartSlot: /* @__PURE__ */ t(
|
|
63
|
+
M,
|
|
64
|
+
{
|
|
65
|
+
label: d,
|
|
66
|
+
id: `draggable-window-title-${d}`
|
|
67
|
+
}
|
|
68
|
+
),
|
|
69
|
+
rightPartSlot: /* @__PURE__ */ t(
|
|
70
|
+
E,
|
|
71
|
+
{
|
|
72
|
+
type: "icon",
|
|
73
|
+
icon: "close",
|
|
74
|
+
action: v
|
|
75
|
+
}
|
|
76
|
+
),
|
|
77
|
+
padding: "0 var(--size-pos-xxsmall)",
|
|
78
|
+
isCompact: !0,
|
|
79
|
+
shouldReflow: !1,
|
|
80
|
+
border: ["BOTTOM"]
|
|
81
|
+
}
|
|
82
|
+
)
|
|
83
|
+
}
|
|
84
|
+
),
|
|
85
|
+
/* @__PURE__ */ t(
|
|
86
|
+
"div",
|
|
87
|
+
{
|
|
88
|
+
className: "draggable-window__content",
|
|
89
|
+
role: "document",
|
|
90
|
+
children: p
|
|
91
|
+
}
|
|
92
|
+
)
|
|
93
|
+
]
|
|
94
|
+
}
|
|
95
|
+
);
|
|
96
|
+
};
|
|
97
|
+
export {
|
|
98
|
+
N as default
|
|
99
|
+
};
|
|
100
|
+
//# sourceMappingURL=DraggableWindow.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DraggableWindow.js","sources":["../../../../src/components/slots/draggable-window/DraggableWindow.tsx"],"sourcesContent":["import React, { useState, useRef, useEffect } from 'react'\nimport SectionTitle from '@components/assets/section-title/SectionTitle'\nimport Button from '@components/actions/button/Button'\nimport { doClassnames } from '@a_ng_d/figmug-utils'\nimport Bar from '../bar/Bar'\n\nimport './draggable-window.scss'\n\nexport interface DraggableWindowProps {\n /**\n * Title of the window\n * @default 'Options'\n */\n title?: string\n /**\n * Content of the window\n */\n children: React.ReactNode\n /**\n * Reference to the trigger button\n */\n triggerRef: React.RefObject<Button>\n /**\n * Close handler\n */\n onClose: () => void\n}\n\nconst DraggableWindow = (props: DraggableWindowProps) => {\n const { title = 'Options', children, triggerRef, onClose } = props\n const [isDragging, setIsDragging] = useState(false)\n const [isOpen, setIsOpen] = useState(false)\n const [position, setPosition] = useState({ x: 0, y: 0 })\n const [offset, setOffset] = useState({ x: 0, y: 0 })\n const windowRef = useRef<HTMLDivElement>(null)\n\n useEffect(() => {\n if (triggerRef.current?.buttonRef?.current && windowRef.current) {\n const windowRect = windowRef.current.getBoundingClientRect()\n const triggerRect =\n triggerRef.current.buttonRef.current.getBoundingClientRect()\n\n setPosition({\n x: triggerRect.left - windowRect.width - 8,\n y: 0,\n })\n setIsOpen(true)\n }\n }, [triggerRef])\n\n const handleMouseDown = (e: React.MouseEvent<HTMLDivElement>) => {\n if (\n e.target instanceof HTMLElement &&\n e.target.closest('.draggable-window__header')\n ) {\n setIsDragging(true)\n setOffset({\n x: e.clientX - position.x,\n y: e.clientY - position.y,\n })\n }\n }\n\n const handleMouseUp = () => {\n setIsDragging(false)\n }\n\n useEffect(() => {\n const handleMouseMove = (e: MouseEvent) => {\n if (isDragging)\n setPosition({\n x: e.clientX - offset.x,\n y: e.clientY - offset.y,\n })\n }\n\n if (isDragging) {\n window.addEventListener('mousemove', handleMouseMove)\n window.addEventListener('mouseup', handleMouseUp)\n }\n\n return () => {\n window.removeEventListener('mousemove', handleMouseMove)\n window.removeEventListener('mouseup', handleMouseUp)\n }\n }, [isDragging, offset])\n\n return (\n <div\n className={doClassnames([\n 'draggable-window',\n isDragging && 'draggable-window--dragging',\n ])}\n style={{\n transform: `translate(${position.x}px, ${position.y}px)`,\n visibility: isOpen ? 'visible' : 'hidden',\n }}\n onMouseDown={handleMouseDown}\n ref={windowRef}\n role=\"dialog\"\n aria-modal=\"true\"\n aria-hidden={!isOpen}\n >\n <div\n className=\"draggable-window__header\"\n role=\"presentation\"\n >\n <Bar\n leftPartSlot={\n <SectionTitle\n label={title}\n id={`draggable-window-title-${title}`}\n />\n }\n rightPartSlot={\n <Button\n type=\"icon\"\n icon=\"close\"\n action={onClose}\n />\n }\n padding=\"0 var(--size-pos-xxsmall)\"\n isCompact\n shouldReflow={false}\n border={['BOTTOM']}\n />\n </div>\n <div\n className=\"draggable-window__content\"\n role=\"document\"\n >\n {children}\n </div>\n </div>\n )\n}\n\nexport default DraggableWindow\n"],"names":["DraggableWindow","props","title","children","triggerRef","onClose","isDragging","setIsDragging","useState","isOpen","setIsOpen","position","setPosition","offset","setOffset","windowRef","useRef","useEffect","windowRect","triggerRect","handleMouseDown","handleMouseUp","handleMouseMove","e","jsxs","doClassnames","jsx","Bar","SectionTitle","Button"],"mappings":"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"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
|
|
3
|
+
interface Unit {
|
|
4
|
+
value?: number;
|
|
5
|
+
unit: 'PIXEL' | 'PERCENT' | 'AUTO';
|
|
6
|
+
}
|
|
7
|
+
export type DrawerProps = {
|
|
8
|
+
/**
|
|
9
|
+
* HTML id attribute
|
|
10
|
+
*/
|
|
11
|
+
id?: string;
|
|
12
|
+
/**
|
|
13
|
+
* Direction of the drawer layout
|
|
14
|
+
*/
|
|
15
|
+
direction: 'VERTICAL' | 'HORIZONTAL';
|
|
16
|
+
/**
|
|
17
|
+
* Position of the drawer
|
|
18
|
+
*/
|
|
19
|
+
pin: 'TOP' | 'BOTTOM' | 'LEFT' | 'RIGHT';
|
|
20
|
+
/**
|
|
21
|
+
* Default size of the drawer
|
|
22
|
+
*/
|
|
23
|
+
defaultSize: Unit;
|
|
24
|
+
/**
|
|
25
|
+
* Maximum allowed size
|
|
26
|
+
*/
|
|
27
|
+
maxSize: Unit;
|
|
28
|
+
/**
|
|
29
|
+
* Minimum allowed size
|
|
30
|
+
*/
|
|
31
|
+
minSize: Unit;
|
|
32
|
+
/**
|
|
33
|
+
* Array of border positions
|
|
34
|
+
*/
|
|
35
|
+
border?: Array<'TOP' | 'LEFT' | 'BOTTOM' | 'RIGHT'>;
|
|
36
|
+
/**
|
|
37
|
+
* Whether the content is scrollable
|
|
38
|
+
* @default false
|
|
39
|
+
*/
|
|
40
|
+
isScrolling?: boolean;
|
|
41
|
+
/**
|
|
42
|
+
* Drawer content
|
|
43
|
+
*/
|
|
44
|
+
children?: React.ReactNode;
|
|
45
|
+
/**
|
|
46
|
+
* Callback when drawer collapses
|
|
47
|
+
*/
|
|
48
|
+
onCollapse?: () => void;
|
|
49
|
+
/**
|
|
50
|
+
* Callback when drawer expands
|
|
51
|
+
*/
|
|
52
|
+
onExpand?: () => void;
|
|
53
|
+
};
|
|
54
|
+
export type DrawerState = {
|
|
55
|
+
isDrawerCollapsed: boolean;
|
|
56
|
+
drawerSize: {
|
|
57
|
+
value?: number;
|
|
58
|
+
unit: 'PIXEL' | 'PERCENT' | 'AUTO';
|
|
59
|
+
};
|
|
60
|
+
};
|
|
61
|
+
export default class Drawer extends React.Component<DrawerProps, DrawerState> {
|
|
62
|
+
drawerRef: React.RefObject<HTMLDivElement>;
|
|
63
|
+
static defaultProps: Partial<DrawerProps>;
|
|
64
|
+
constructor(props: DrawerProps);
|
|
65
|
+
componentDidUpdate: (_: Readonly<DrawerProps>, prevState: Readonly<DrawerState>) => void;
|
|
66
|
+
clickHandler: (e: React.MouseEvent<HTMLDivElement>) => void;
|
|
67
|
+
setBorder: (orientation: Array<'TOP' | 'LEFT' | 'BOTTOM' | 'RIGHT'> | undefined) => {
|
|
68
|
+
[key: string]: React.CSSProperties;
|
|
69
|
+
};
|
|
70
|
+
setUnit: (size: Unit) => string;
|
|
71
|
+
expandDrawer: () => void;
|
|
72
|
+
collapseDrawer: () => void;
|
|
73
|
+
onGrab: () => void;
|
|
74
|
+
onDrag: (e: MouseEvent) => void;
|
|
75
|
+
render(): import("react/jsx-runtime").JSX.Element;
|
|
76
|
+
}
|
|
77
|
+
export {};
|
|
78
|
+
//# sourceMappingURL=Drawer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Drawer.d.ts","sourceRoot":"","sources":["../../../../src/components/slots/drawer/Drawer.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,eAAe,CAAA;AAEtB,UAAU,IAAI;IACZ,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,IAAI,EAAE,OAAO,GAAG,SAAS,GAAG,MAAM,CAAA;CACnC;AAED,MAAM,MAAM,WAAW,GAAG;IACxB;;OAEG;IACH,EAAE,CAAC,EAAE,MAAM,CAAA;IACX;;OAEG;IACH,SAAS,EAAE,UAAU,GAAG,YAAY,CAAA;IACpC;;OAEG;IACH,GAAG,EAAE,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,OAAO,CAAA;IACxC;;OAEG;IACH,WAAW,EAAE,IAAI,CAAA;IACjB;;OAEG;IACH,OAAO,EAAE,IAAI,CAAA;IACb;;OAEG;IACH,OAAO,EAAE,IAAI,CAAA;IACb;;OAEG;IACH,MAAM,CAAC,EAAE,KAAK,CAAC,KAAK,GAAG,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC,CAAA;IACnD;;;OAGG;IACH,WAAW,CAAC,EAAE,OAAO,CAAA;IACrB;;OAEG;IACH,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IAC1B;;OAEG;IACH,UAAU,CAAC,EAAE,MAAM,IAAI,CAAA;IACvB;;OAEG;IACH,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAA;CACtB,CAAA;AAED,MAAM,MAAM,WAAW,GAAG;IACxB,iBAAiB,EAAE,OAAO,CAAA;IAC1B,UAAU,EAAE;QACV,KAAK,CAAC,EAAE,MAAM,CAAA;QACd,IAAI,EAAE,OAAO,GAAG,SAAS,GAAG,MAAM,CAAA;KACnC,CAAA;CACF,CAAA;AAED,MAAM,CAAC,OAAO,OAAO,MAAO,SAAQ,KAAK,CAAC,SAAS,CAAC,WAAW,EAAE,WAAW,CAAC;IAC3E,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC,cAAc,CAAC,CAAA;IAE1C,MAAM,CAAC,YAAY,EAAE,OAAO,CAAC,WAAW,CAAC,CAExC;gBAEW,KAAK,EAAE,WAAW;IAa9B,kBAAkB,MACb,SAAS,WAAW,CAAC,aACb,SAAS,WAAW,CAAC,UASjC;IAGD,YAAY,MAAO,gBAAgB,CAAC,cAAc,CAAC,UAYlD;IAGD,SAAS,gBACM,MAAM,KAAK,GAAG,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC,GAAG,SAAS;;MAapE;IAED,OAAO,SAAU,IAAI,YAGpB;IAED,YAAY,aAOX;IAED,cAAc,aAOb;IAED,MAAM,aAGL;IAED,MAAM,MAAO,UAAU,UAyDtB;IAGD,MAAM;CAuDP"}
|