@forgedevstack/bear 1.0.1 → 1.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/dist/components/ActiveBar/ActiveBar.cjs +8 -0
- package/dist/components/ActiveBar/ActiveBar.d.ts +2 -0
- package/dist/components/ActiveBar/ActiveBar.js +90 -0
- package/dist/components/ActiveBar/ActiveBar.types.d.ts +16 -0
- package/dist/components/ActiveBar/index.d.ts +2 -0
- package/dist/components/Alert/Alert.cjs +1 -1
- package/dist/components/Alert/Alert.js +38 -38
- package/dist/components/AppBar/AppBar.cjs +1 -1
- package/dist/components/AppBar/AppBar.js +15 -15
- package/dist/components/Badge/Badge.cjs +1 -1
- package/dist/components/Badge/Badge.constants.cjs +1 -0
- package/dist/components/Badge/Badge.constants.d.ts +6 -0
- package/dist/components/Badge/Badge.constants.js +34 -0
- package/dist/components/Badge/Badge.js +27 -52
- package/dist/components/Box/Box.cjs +1 -0
- package/dist/components/Box/Box.d.ts +2 -0
- package/dist/components/Box/Box.js +64 -0
- package/dist/components/Box/Box.types.d.ts +24 -0
- package/dist/components/Box/Box.utils.cjs +1 -0
- package/dist/components/Box/Box.utils.d.ts +3 -0
- package/dist/components/Box/Box.utils.js +21 -0
- package/dist/components/Box/index.d.ts +2 -0
- package/dist/components/Button/Button.cjs +1 -57
- package/dist/components/Button/Button.constants.cjs +57 -0
- package/dist/components/Button/Button.constants.d.ts +3 -0
- package/dist/components/Button/Button.constants.js +77 -0
- package/dist/components/Button/Button.js +55 -119
- package/dist/components/Button/Button.types.d.ts +6 -1
- package/dist/components/ButtonGroup/ButtonGroup.cjs +1 -1
- package/dist/components/ButtonGroup/ButtonGroup.js +17 -17
- package/dist/components/Calendar/Calendar.cjs +1 -0
- package/dist/components/Calendar/Calendar.const.cjs +1 -0
- package/dist/components/Calendar/Calendar.const.d.ts +18 -0
- package/dist/components/Calendar/Calendar.const.js +27 -0
- package/dist/components/Calendar/Calendar.d.ts +3 -0
- package/dist/components/Calendar/Calendar.js +189 -0
- package/dist/components/Calendar/Calendar.types.d.ts +128 -0
- package/dist/components/Calendar/Calendar.utils.cjs +1 -0
- package/dist/components/Calendar/Calendar.utils.d.ts +41 -0
- package/dist/components/Calendar/Calendar.utils.js +33 -0
- package/dist/components/Calendar/index.d.ts +4 -0
- package/dist/components/Card/Card.cjs +1 -1
- package/dist/components/Card/Card.js +65 -65
- package/dist/components/Checkbox/Checkbox.cjs +1 -1
- package/dist/components/Checkbox/Checkbox.js +48 -48
- package/dist/components/CodeBlock/CodeBlock.cjs +2 -0
- package/dist/components/CodeBlock/CodeBlock.d.ts +2 -0
- package/dist/components/CodeBlock/CodeBlock.js +55 -0
- package/dist/components/CodeBlock/CodeBlock.types.d.ts +10 -0
- package/dist/components/CodeBlock/index.d.ts +2 -0
- package/dist/components/Columns/Columns.cjs +1 -0
- package/dist/components/Columns/Columns.d.ts +5 -0
- package/dist/components/Columns/Columns.js +54 -0
- package/dist/components/Columns/Columns.types.d.ts +17 -0
- package/dist/components/Columns/index.d.ts +2 -0
- package/dist/components/Container/Container.cjs +1 -1
- package/dist/components/Container/Container.js +15 -15
- package/dist/components/DatePicker/DatePicker.cjs +1 -1
- package/dist/components/DatePicker/DatePicker.js +77 -85
- package/dist/components/DatePicker/DatePicker.types.d.ts +9 -0
- package/dist/components/DatePicker/DatePicker.utils.cjs +1 -0
- package/dist/components/DatePicker/DatePicker.utils.d.ts +1 -0
- package/dist/components/DatePicker/DatePicker.utils.js +9 -0
- package/dist/components/DateTimePicker/DateTimePicker.cjs +1 -0
- package/dist/components/DateTimePicker/DateTimePicker.d.ts +3 -0
- package/dist/components/DateTimePicker/DateTimePicker.js +178 -0
- package/dist/components/DateTimePicker/DateTimePicker.types.d.ts +26 -0
- package/dist/components/DateTimePicker/DateTimePicker.utils.cjs +1 -0
- package/dist/components/DateTimePicker/DateTimePicker.utils.d.ts +2 -0
- package/dist/components/DateTimePicker/DateTimePicker.utils.js +16 -0
- package/dist/components/DateTimePicker/index.d.ts +2 -0
- package/dist/components/Divider/Divider.cjs +1 -1
- package/dist/components/Divider/Divider.js +29 -29
- package/dist/components/Dropdown/Dropdown.cjs +1 -1
- package/dist/components/Dropdown/Dropdown.js +70 -70
- package/dist/components/Editable/Editable.cjs +1 -0
- package/dist/components/Editable/Editable.d.ts +10 -0
- package/dist/components/Editable/Editable.js +194 -0
- package/dist/components/Editable/Editable.types.d.ts +39 -0
- package/dist/components/Editable/index.d.ts +2 -0
- package/dist/components/Em/Em.cjs +1 -0
- package/dist/components/Em/Em.d.ts +2 -0
- package/dist/components/Em/Em.js +24 -0
- package/dist/components/Em/Em.types.d.ts +5 -0
- package/dist/components/Em/index.d.ts +2 -0
- package/dist/components/Fab/Fab.cjs +1 -1
- package/dist/components/Fab/Fab.js +43 -43
- package/dist/components/FileUpload/FileUpload.cjs +1 -1
- package/dist/components/FileUpload/FileUpload.js +46 -49
- package/dist/components/FileUpload/FileUpload.utils.cjs +1 -0
- package/dist/components/FileUpload/FileUpload.utils.d.ts +1 -0
- package/dist/components/FileUpload/FileUpload.utils.js +9 -0
- package/dist/components/Flex/Flex.cjs +1 -1
- package/dist/components/Flex/Flex.js +58 -58
- package/dist/components/Grid/Grid.cjs +1 -1
- package/dist/components/Grid/Grid.js +60 -60
- package/dist/components/Highlight/Highlight.cjs +1 -0
- package/dist/components/Highlight/Highlight.d.ts +2 -0
- package/dist/components/Highlight/Highlight.js +28 -0
- package/dist/components/Highlight/Highlight.types.d.ts +6 -0
- package/dist/components/Highlight/index.d.ts +2 -0
- package/dist/components/HoverCard/HoverCard.cjs +6 -0
- package/dist/components/HoverCard/HoverCard.d.ts +2 -0
- package/dist/components/HoverCard/HoverCard.js +68 -0
- package/dist/components/HoverCard/HoverCard.types.d.ts +13 -0
- package/dist/components/HoverCard/HoverCard.utils.cjs +1 -0
- package/dist/components/HoverCard/HoverCard.utils.d.ts +2 -0
- package/dist/components/HoverCard/HoverCard.utils.js +23 -0
- package/dist/components/HoverCard/index.d.ts +2 -0
- package/dist/components/Icon/icons/status.js +1 -1
- package/dist/components/Icon/index.cjs +1 -1
- package/dist/components/Icon/index.d.ts +5 -0
- package/dist/components/Icon/index.js +28 -21
- package/dist/components/Link/Link.cjs +1 -1
- package/dist/components/Link/Link.js +47 -47
- package/dist/components/List/List.cjs +1 -1
- package/dist/components/List/List.js +117 -117
- package/dist/components/Mark/Mark.cjs +1 -0
- package/dist/components/Mark/Mark.d.ts +2 -0
- package/dist/components/Mark/Mark.js +26 -0
- package/dist/components/Mark/Mark.types.d.ts +5 -0
- package/dist/components/Mark/index.d.ts +2 -0
- package/dist/components/Menu/Menu.cjs +1 -1
- package/dist/components/Menu/Menu.js +58 -58
- package/dist/components/Paper/Paper.cjs +1 -1
- package/dist/components/Paper/Paper.js +36 -36
- package/dist/components/Radio/Radio.cjs +1 -1
- package/dist/components/Radio/Radio.js +79 -79
- package/dist/components/Rating/Rating.cjs +1 -1
- package/dist/components/Rating/Rating.js +37 -37
- package/dist/components/RichEditor/RichEditor.cjs +10 -0
- package/dist/components/RichEditor/RichEditor.d.ts +4 -0
- package/dist/components/RichEditor/RichEditor.icons.cjs +1 -0
- package/dist/components/RichEditor/RichEditor.icons.d.ts +16 -0
- package/dist/components/RichEditor/RichEditor.icons.js +62 -0
- package/dist/components/RichEditor/RichEditor.js +151 -0
- package/dist/components/RichEditor/RichEditor.types.d.ts +20 -0
- package/dist/components/RichEditor/RichEditor.utils.cjs +1 -0
- package/dist/components/RichEditor/RichEditor.utils.d.ts +3 -0
- package/dist/components/RichEditor/RichEditor.utils.js +22 -0
- package/dist/components/RichEditor/index.d.ts +2 -0
- package/dist/components/Sidebar/Sidebar.cjs +1 -0
- package/dist/components/Sidebar/Sidebar.d.ts +5 -0
- package/dist/components/Sidebar/Sidebar.js +158 -0
- package/dist/components/Sidebar/Sidebar.types.d.ts +40 -0
- package/dist/components/Sidebar/index.d.ts +2 -0
- package/dist/components/Slider/Slider.cjs +1 -1
- package/dist/components/Slider/Slider.js +8 -8
- package/dist/components/SpeedDial/SpeedDial.cjs +1 -1
- package/dist/components/SpeedDial/SpeedDial.js +40 -40
- package/dist/components/Spinner/Spinner.cjs +1 -1
- package/dist/components/Spinner/Spinner.js +24 -24
- package/dist/components/TimePicker/TimePicker.cjs +1 -1
- package/dist/components/TimePicker/TimePicker.constants.cjs +1 -0
- package/dist/components/TimePicker/TimePicker.constants.d.ts +5 -0
- package/dist/components/TimePicker/TimePicker.constants.js +16 -0
- package/dist/components/TimePicker/TimePicker.js +91 -70
- package/dist/components/TimePicker/TimePicker.types.d.ts +5 -2
- package/dist/components/TimePicker/TimePicker.utils.cjs +1 -0
- package/dist/components/TimePicker/TimePicker.utils.d.ts +1 -0
- package/dist/components/TimePicker/TimePicker.utils.js +7 -0
- package/dist/components/TransferList/TransferList.cjs +1 -1
- package/dist/components/TransferList/TransferList.js +74 -74
- package/dist/components/Typography/Typography.cjs +1 -1
- package/dist/components/Typography/Typography.js +52 -52
- package/dist/components/index.cjs +1 -1
- package/dist/components/index.d.ts +26 -0
- package/dist/components/index.js +119 -91
- package/dist/context/BearProvider.cjs +1 -1
- package/dist/context/BearProvider.d.ts +6 -1
- package/dist/context/BearProvider.js +42 -38
- package/dist/context/index.cjs +1 -1
- package/dist/context/index.d.ts +1 -1
- package/dist/context/index.js +6 -5
- package/dist/hooks/bearStyled.cjs +1 -0
- package/dist/hooks/bearStyled.d.ts +17 -0
- package/dist/hooks/bearStyled.js +17 -0
- package/dist/hooks/index.cjs +1 -1
- package/dist/hooks/index.d.ts +2 -0
- package/dist/hooks/index.js +14 -10
- package/dist/hooks/useBearStyles.cjs +1 -0
- package/dist/hooks/useBearStyles.d.ts +11 -0
- package/dist/hooks/useBearStyles.js +14 -0
- package/dist/index.cjs +1 -1
- package/dist/index.js +146 -113
- package/dist/styles.css +1 -1
- package/dist/types/bis.types.d.ts +9 -0
- package/dist/types/component.types.d.ts +3 -0
- package/dist/types/index.d.ts +1 -0
- package/package.json +2 -2
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { jsxs as e, jsx as o } from "react/jsx-runtime";
|
|
2
|
+
const t = ({ size: n = 16 }) => /* @__PURE__ */ e("svg", { width: n, height: n, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2.5", strokeLinecap: "round", strokeLinejoin: "round", children: [
|
|
3
|
+
/* @__PURE__ */ o("path", { d: "M6 4h8a4 4 0 0 1 4 4 4 4 0 0 1-4 4H6z" }),
|
|
4
|
+
/* @__PURE__ */ o("path", { d: "M6 12h9a4 4 0 0 1 4 4 4 4 0 0 1-4 4H6z" })
|
|
5
|
+
] }), i = ({ size: n = 16 }) => /* @__PURE__ */ e("svg", { width: n, height: n, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [
|
|
6
|
+
/* @__PURE__ */ o("line", { x1: "19", y1: "4", x2: "10", y2: "4" }),
|
|
7
|
+
/* @__PURE__ */ o("line", { x1: "14", y1: "20", x2: "5", y2: "20" }),
|
|
8
|
+
/* @__PURE__ */ o("line", { x1: "15", y1: "4", x2: "9", y2: "20" })
|
|
9
|
+
] }), h = ({ size: n = 16 }) => /* @__PURE__ */ e("svg", { width: n, height: n, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [
|
|
10
|
+
/* @__PURE__ */ o("path", { d: "M6 3v7a6 6 0 0 0 6 6 6 6 0 0 0 6-6V3" }),
|
|
11
|
+
/* @__PURE__ */ o("line", { x1: "4", y1: "21", x2: "20", y2: "21" })
|
|
12
|
+
] }), c = ({ size: n = 16 }) => /* @__PURE__ */ e("svg", { width: n, height: n, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [
|
|
13
|
+
/* @__PURE__ */ o("path", { d: "M17.3 4.9c-2.3-.6-4.4-1-6.2-.9-2.7 0-5.3.7-5.3 3.6 0 1.5 1.8 3.3 3.6 3.9h.2" }),
|
|
14
|
+
/* @__PURE__ */ o("path", { d: "M8.7 19.1c2.3.6 4.4 1 6.2.9 2.7 0 5.3-.7 5.3-3.6 0-1.5-1.8-3.3-3.6-3.9h-.2" }),
|
|
15
|
+
/* @__PURE__ */ o("line", { x1: "4", y1: "12", x2: "20", y2: "12" })
|
|
16
|
+
] }), d = ({ size: n = 16 }) => /* @__PURE__ */ e("svg", { width: n, height: n, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [
|
|
17
|
+
/* @__PURE__ */ o("path", { d: "M4 12h8" }),
|
|
18
|
+
/* @__PURE__ */ o("path", { d: "M4 18V6" }),
|
|
19
|
+
/* @__PURE__ */ o("path", { d: "M12 18V6" }),
|
|
20
|
+
/* @__PURE__ */ o("path", { d: "M17 12l3-2v8" })
|
|
21
|
+
] }), l = ({ size: n = 16 }) => /* @__PURE__ */ e("svg", { width: n, height: n, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [
|
|
22
|
+
/* @__PURE__ */ o("path", { d: "M4 12h8" }),
|
|
23
|
+
/* @__PURE__ */ o("path", { d: "M4 18V6" }),
|
|
24
|
+
/* @__PURE__ */ o("path", { d: "M12 18V6" }),
|
|
25
|
+
/* @__PURE__ */ o("path", { d: "M21 18h-4c0-4 4-3 4-6 0-1.5-2-2.5-4-1" })
|
|
26
|
+
] }), s = ({ size: n = 16 }) => /* @__PURE__ */ e("svg", { width: n, height: n, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [
|
|
27
|
+
/* @__PURE__ */ o("line", { x1: "9", y1: "6", x2: "20", y2: "6" }),
|
|
28
|
+
/* @__PURE__ */ o("line", { x1: "9", y1: "12", x2: "20", y2: "12" }),
|
|
29
|
+
/* @__PURE__ */ o("line", { x1: "9", y1: "18", x2: "20", y2: "18" }),
|
|
30
|
+
/* @__PURE__ */ o("circle", { cx: "4", cy: "6", r: "1", fill: "currentColor" }),
|
|
31
|
+
/* @__PURE__ */ o("circle", { cx: "4", cy: "12", r: "1", fill: "currentColor" }),
|
|
32
|
+
/* @__PURE__ */ o("circle", { cx: "4", cy: "18", r: "1", fill: "currentColor" })
|
|
33
|
+
] }), k = ({ size: n = 16 }) => /* @__PURE__ */ e("svg", { width: n, height: n, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [
|
|
34
|
+
/* @__PURE__ */ o("line", { x1: "10", y1: "6", x2: "21", y2: "6" }),
|
|
35
|
+
/* @__PURE__ */ o("line", { x1: "10", y1: "12", x2: "21", y2: "12" }),
|
|
36
|
+
/* @__PURE__ */ o("line", { x1: "10", y1: "18", x2: "21", y2: "18" }),
|
|
37
|
+
/* @__PURE__ */ o("path", { d: "M4 6h1v4" }),
|
|
38
|
+
/* @__PURE__ */ o("path", { d: "M4 10h2" }),
|
|
39
|
+
/* @__PURE__ */ o("path", { d: "M6 18H4c0-1 2-2 2-3s-1-1.5-2-1" })
|
|
40
|
+
] }), a = ({ size: n = 16 }) => /* @__PURE__ */ e("svg", { width: n, height: n, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [
|
|
41
|
+
/* @__PURE__ */ o("path", { d: "M3 21c3 0 7-1 7-8V5c0-1.25-.756-2.017-2-2H4c-1.25 0-2 .75-2 1.972V11c0 1.25.75 2 2 2 1 0 1 0 1 1v1c0 1-1 2-2 2s-1 .008-1 1.031V21z" }),
|
|
42
|
+
/* @__PURE__ */ o("path", { d: "M15 21c3 0 7-1 7-8V5c0-1.25-.757-2.017-2-2h-4c-1.25 0-2 .75-2 1.972V11c0 1.25.75 2 2 2h.75c0 2.25.25 4-2.75 4v3z" })
|
|
43
|
+
] }), u = ({ size: n = 16 }) => /* @__PURE__ */ e("svg", { width: n, height: n, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [
|
|
44
|
+
/* @__PURE__ */ o("polyline", { points: "16 18 22 12 16 6" }),
|
|
45
|
+
/* @__PURE__ */ o("polyline", { points: "8 6 2 12 8 18" })
|
|
46
|
+
] }), x = ({ size: n = 16 }) => /* @__PURE__ */ e("svg", { width: n, height: n, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [
|
|
47
|
+
/* @__PURE__ */ o("path", { d: "M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71" }),
|
|
48
|
+
/* @__PURE__ */ o("path", { d: "M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71" })
|
|
49
|
+
] });
|
|
50
|
+
export {
|
|
51
|
+
a as BlockquoteIcon,
|
|
52
|
+
t as BoldIcon,
|
|
53
|
+
s as BulletListIcon,
|
|
54
|
+
u as CodeIcon,
|
|
55
|
+
d as Heading1Icon,
|
|
56
|
+
l as Heading2Icon,
|
|
57
|
+
i as ItalicIcon,
|
|
58
|
+
x as LinkIcon,
|
|
59
|
+
k as OrderedListIcon,
|
|
60
|
+
c as StrikethroughIcon,
|
|
61
|
+
h as UnderlineIcon
|
|
62
|
+
};
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
import { jsxs as S, jsx as r } from "react/jsx-runtime";
|
|
2
|
+
import { useRef as U, useState as $, useEffect as L, useCallback as m } from "react";
|
|
3
|
+
import { queryCommandState as d, execCommand as t, DEFAULT_TOOLBAR as N } from "./RichEditor.utils.js";
|
|
4
|
+
import { LinkIcon as q, CodeIcon as E, BlockquoteIcon as F, OrderedListIcon as M, BulletListIcon as R, Heading2Icon as A, Heading1Icon as C, StrikethroughIcon as H, UnderlineIcon as j, ItalicIcon as O, BoldIcon as D } from "./RichEditor.icons.js";
|
|
5
|
+
const K = ({ icon: n, title: u, active: s, onClick: k, disabled: i }) => /* @__PURE__ */ r(
|
|
6
|
+
"button",
|
|
7
|
+
{
|
|
8
|
+
type: "button",
|
|
9
|
+
title: u,
|
|
10
|
+
onClick: k,
|
|
11
|
+
disabled: i,
|
|
12
|
+
className: `
|
|
13
|
+
p-1.5 rounded transition-colors
|
|
14
|
+
${s ? "bg-pink-500 text-white" : "text-gray-600 dark:text-gray-400 hover:bg-gray-100 dark:hover:bg-gray-700"}
|
|
15
|
+
${i ? "opacity-50 cursor-not-allowed" : "cursor-pointer"}
|
|
16
|
+
`,
|
|
17
|
+
children: n
|
|
18
|
+
}
|
|
19
|
+
), G = ({
|
|
20
|
+
value: n,
|
|
21
|
+
defaultValue: u = "",
|
|
22
|
+
onChange: s,
|
|
23
|
+
placeholder: k = "Start typing...",
|
|
24
|
+
disabled: i = !1,
|
|
25
|
+
readOnly: b = !1,
|
|
26
|
+
minHeight: f = 150,
|
|
27
|
+
maxHeight: l,
|
|
28
|
+
toolbar: y = N,
|
|
29
|
+
className: I = "",
|
|
30
|
+
...v
|
|
31
|
+
}) => {
|
|
32
|
+
const o = U(null), [x, w] = $(/* @__PURE__ */ new Set());
|
|
33
|
+
L(() => {
|
|
34
|
+
o.current && n !== void 0 && o.current.innerHTML !== n && (o.current.innerHTML = n);
|
|
35
|
+
}, [n]), L(() => {
|
|
36
|
+
o.current && u && !n && (o.current.innerHTML = u);
|
|
37
|
+
}, []);
|
|
38
|
+
const c = m(() => {
|
|
39
|
+
const e = /* @__PURE__ */ new Set();
|
|
40
|
+
d("bold") && e.add("bold"), d("italic") && e.add("italic"), d("underline") && e.add("underline"), d("strikeThrough") && e.add("strikethrough"), d("insertUnorderedList") && e.add("bulletList"), d("insertOrderedList") && e.add("orderedList"), w(e);
|
|
41
|
+
}, []), g = m(() => {
|
|
42
|
+
o.current && s && s(o.current.innerHTML), c();
|
|
43
|
+
}, [s, c]), B = m((e) => {
|
|
44
|
+
var a;
|
|
45
|
+
if (!(i || b)) {
|
|
46
|
+
switch ((a = o.current) == null || a.focus(), e) {
|
|
47
|
+
case "bold":
|
|
48
|
+
t("bold");
|
|
49
|
+
break;
|
|
50
|
+
case "italic":
|
|
51
|
+
t("italic");
|
|
52
|
+
break;
|
|
53
|
+
case "underline":
|
|
54
|
+
t("underline");
|
|
55
|
+
break;
|
|
56
|
+
case "strikethrough":
|
|
57
|
+
t("strikeThrough");
|
|
58
|
+
break;
|
|
59
|
+
case "heading1":
|
|
60
|
+
t("formatBlock", "<h1>");
|
|
61
|
+
break;
|
|
62
|
+
case "heading2":
|
|
63
|
+
t("formatBlock", "<h2>");
|
|
64
|
+
break;
|
|
65
|
+
case "heading3":
|
|
66
|
+
t("formatBlock", "<h3>");
|
|
67
|
+
break;
|
|
68
|
+
case "bulletList":
|
|
69
|
+
t("insertUnorderedList");
|
|
70
|
+
break;
|
|
71
|
+
case "orderedList":
|
|
72
|
+
t("insertOrderedList");
|
|
73
|
+
break;
|
|
74
|
+
case "blockquote":
|
|
75
|
+
t("formatBlock", "<blockquote>");
|
|
76
|
+
break;
|
|
77
|
+
case "code":
|
|
78
|
+
t("formatBlock", "<pre>");
|
|
79
|
+
break;
|
|
80
|
+
case "link":
|
|
81
|
+
const p = prompt("Enter URL:");
|
|
82
|
+
p && t("createLink", p);
|
|
83
|
+
break;
|
|
84
|
+
}
|
|
85
|
+
c(), g();
|
|
86
|
+
}
|
|
87
|
+
}, [i, b, c, g]), T = (e, a) => {
|
|
88
|
+
if (e === "divider")
|
|
89
|
+
return /* @__PURE__ */ r("div", { className: "w-px h-5 bg-gray-300 dark:bg-gray-600 mx-1" }, `divider-${a}`);
|
|
90
|
+
const h = {
|
|
91
|
+
bold: { icon: /* @__PURE__ */ r(D, {}), title: "Bold" },
|
|
92
|
+
italic: { icon: /* @__PURE__ */ r(O, {}), title: "Italic" },
|
|
93
|
+
underline: { icon: /* @__PURE__ */ r(j, {}), title: "Underline" },
|
|
94
|
+
strikethrough: { icon: /* @__PURE__ */ r(H, {}), title: "Strikethrough" },
|
|
95
|
+
heading1: { icon: /* @__PURE__ */ r(C, {}), title: "Heading 1" },
|
|
96
|
+
heading2: { icon: /* @__PURE__ */ r(A, {}), title: "Heading 2" },
|
|
97
|
+
bulletList: { icon: /* @__PURE__ */ r(R, {}), title: "Bullet List" },
|
|
98
|
+
orderedList: { icon: /* @__PURE__ */ r(M, {}), title: "Numbered List" },
|
|
99
|
+
blockquote: { icon: /* @__PURE__ */ r(F, {}), title: "Quote" },
|
|
100
|
+
code: { icon: /* @__PURE__ */ r(E, {}), title: "Code Block" },
|
|
101
|
+
link: { icon: /* @__PURE__ */ r(q, {}), title: "Insert Link" }
|
|
102
|
+
}[e];
|
|
103
|
+
return h ? /* @__PURE__ */ r(
|
|
104
|
+
K,
|
|
105
|
+
{
|
|
106
|
+
icon: h.icon,
|
|
107
|
+
title: h.title,
|
|
108
|
+
active: x.has(e),
|
|
109
|
+
onClick: () => B(e),
|
|
110
|
+
disabled: i || b
|
|
111
|
+
},
|
|
112
|
+
e
|
|
113
|
+
) : null;
|
|
114
|
+
};
|
|
115
|
+
return /* @__PURE__ */ S(
|
|
116
|
+
"div",
|
|
117
|
+
{
|
|
118
|
+
className: `bear-rich-editor rounded-lg border border-gray-300 dark:border-gray-600 overflow-hidden bg-white dark:bg-gray-900 ${I}`,
|
|
119
|
+
...v,
|
|
120
|
+
children: [
|
|
121
|
+
y.length > 0 && /* @__PURE__ */ r("div", { className: "bear-rich-editor-toolbar flex flex-wrap items-center gap-0.5 p-2 border-b border-gray-200 dark:border-gray-700 bg-gray-50 dark:bg-gray-800", children: y.map((e, a) => T(e, a)) }),
|
|
122
|
+
/* @__PURE__ */ r(
|
|
123
|
+
"div",
|
|
124
|
+
{
|
|
125
|
+
ref: o,
|
|
126
|
+
contentEditable: !i && !b,
|
|
127
|
+
onInput: g,
|
|
128
|
+
onSelect: c,
|
|
129
|
+
onKeyUp: c,
|
|
130
|
+
onMouseUp: c,
|
|
131
|
+
"data-placeholder": k,
|
|
132
|
+
className: `
|
|
133
|
+
bear-rich-editor-content p-3 outline-none prose prose-sm dark:prose-invert max-w-none
|
|
134
|
+
text-gray-900 dark:text-white
|
|
135
|
+
[&:empty]:before:content-[attr(data-placeholder)] [&:empty]:before:text-gray-400 [&:empty]:before:pointer-events-none
|
|
136
|
+
${i ? "opacity-50 cursor-not-allowed" : ""}
|
|
137
|
+
`,
|
|
138
|
+
style: {
|
|
139
|
+
minHeight: typeof f == "number" ? `${f}px` : f,
|
|
140
|
+
maxHeight: l ? typeof l == "number" ? `${l}px` : l : void 0,
|
|
141
|
+
overflowY: l ? "auto" : void 0
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
)
|
|
145
|
+
]
|
|
146
|
+
}
|
|
147
|
+
);
|
|
148
|
+
};
|
|
149
|
+
export {
|
|
150
|
+
G as RichEditor
|
|
151
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { HTMLAttributes, ReactNode } from 'react';
|
|
2
|
+
export interface RichEditorProps extends Omit<HTMLAttributes<HTMLDivElement>, 'onChange'> {
|
|
3
|
+
value?: string;
|
|
4
|
+
defaultValue?: string;
|
|
5
|
+
onChange?: (value: string) => void;
|
|
6
|
+
placeholder?: string;
|
|
7
|
+
disabled?: boolean;
|
|
8
|
+
readOnly?: boolean;
|
|
9
|
+
minHeight?: string | number;
|
|
10
|
+
maxHeight?: string | number;
|
|
11
|
+
toolbar?: ToolbarOption[];
|
|
12
|
+
}
|
|
13
|
+
export type ToolbarOption = 'bold' | 'italic' | 'underline' | 'strikethrough' | 'heading1' | 'heading2' | 'heading3' | 'bulletList' | 'orderedList' | 'blockquote' | 'code' | 'link' | 'divider';
|
|
14
|
+
export interface ToolbarButtonProps {
|
|
15
|
+
icon: ReactNode;
|
|
16
|
+
title: string;
|
|
17
|
+
active?: boolean;
|
|
18
|
+
onClick: () => void;
|
|
19
|
+
disabled?: boolean;
|
|
20
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=["bold","italic","underline","divider","heading1","heading2","divider","bulletList","orderedList","divider","blockquote","code","link"],o=(e,d)=>{document.execCommand(e,!1,d)},n=e=>document.queryCommandState(e);exports.DEFAULT_TOOLBAR=t;exports.execCommand=o;exports.queryCommandState=n;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
const t = [
|
|
2
|
+
"bold",
|
|
3
|
+
"italic",
|
|
4
|
+
"underline",
|
|
5
|
+
"divider",
|
|
6
|
+
"heading1",
|
|
7
|
+
"heading2",
|
|
8
|
+
"divider",
|
|
9
|
+
"bulletList",
|
|
10
|
+
"orderedList",
|
|
11
|
+
"divider",
|
|
12
|
+
"blockquote",
|
|
13
|
+
"code",
|
|
14
|
+
"link"
|
|
15
|
+
], n = (e, d) => {
|
|
16
|
+
document.execCommand(e, !1, d);
|
|
17
|
+
}, o = (e) => document.queryCommandState(e);
|
|
18
|
+
export {
|
|
19
|
+
t as DEFAULT_TOOLBAR,
|
|
20
|
+
n as execCommand,
|
|
21
|
+
o as queryCommandState
|
|
22
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),m=require("react"),l=require("../../utils/cn.cjs"),d=require("../Icon/index.cjs"),z=256,N=64,p=({item:r,isActive:b,collapsed:a,depth:t=0,onClick:n})=>{const[s,i]=m.useState(!1),c=r.children&&r.children.length>0,u=a?16:16+t*12,h=m.useCallback(()=>{c&&i(o=>!o),r.onClick&&r.onClick(),n==null||n(r)},[c,r,n]),x=e.jsxs(e.Fragment,{children:[r.icon&&e.jsx("span",{className:"bear-shrink-0 bear-w-5 bear-h-5 bear-flex bear-items-center bear-justify-center",children:r.icon}),!a&&e.jsxs(e.Fragment,{children:[e.jsx("span",{className:"bear-flex-1 bear-truncate",children:r.label}),r.badge&&e.jsx("span",{className:"bear-ml-auto",children:r.badge}),c&&e.jsx(d.ChevronDownIcon,{size:14,className:l.cn("bear-ml-1 bear-transition-transform bear-duration-200",s&&"bear-rotate-180")})]})]}),f=l.cn("bear-flex bear-items-center bear-gap-3 bear-py-2.5 bear-px-3 bear-rounded-lg bear-text-sm bear-transition-all bear-duration-200 bear-cursor-pointer",b?"bear-bg-bear-500 bear-text-white bear-shadow-md":"bear-text-zinc-600 hover:bear-bg-zinc-100 hover:bear-text-zinc-900",r.disabled&&"bear-opacity-50 bear-cursor-not-allowed bear-pointer-events-none",a&&"bear-justify-center"),j=r.href?"a":"button";return e.jsxs("div",{children:[e.jsx(j,{href:r.href,onClick:h,disabled:r.disabled,className:f,style:{paddingLeft:u},title:a?r.label:void 0,children:x}),c&&s&&!a&&e.jsx("div",{className:"bear-mt-1",children:r.children.map(o=>e.jsx(p,{item:o,isActive:!1,collapsed:a,depth:t+1,onClick:n},o.id))})]})},w=({title:r,children:b,collapsible:a=!1,defaultCollapsed:t=!1,className:n})=>{const[s,i]=m.useState(t);return e.jsxs("div",{className:l.cn("bear-mb-4",n),children:[r&&e.jsxs("button",{type:"button",onClick:()=>a&&i(!s),className:l.cn("bear-flex bear-items-center bear-gap-2 bear-px-3 bear-py-2 bear-text-xs bear-font-semibold bear-uppercase bear-tracking-wider bear-text-zinc-400",a&&"bear-cursor-pointer hover:bear-text-zinc-600"),children:[a&&e.jsx(d.ChevronDownIcon,{size:12,className:l.cn("bear-transition-transform",s&&"-bear-rotate-90")}),r]}),!s&&e.jsx("div",{className:"bear-space-y-1",children:b})]})},S=({items:r,collapsed:b=!1,onCollapsedChange:a,width:t=z,collapsedWidth:n=N,header:s,footer:i,activeItemId:c,onItemClick:u,variant:h="default",position:x="left",className:f,style:j})=>{const o=b?n:t,v={default:"bear-bg-white dark:bear-bg-gray-900 bear-border-zinc-200 dark:bear-border-zinc-700",bordered:"bear-bg-white dark:bear-bg-gray-900 bear-border-2 bear-border-zinc-300 dark:bear-border-zinc-600 bear-rounded-xl bear-m-2",floating:"bear-bg-white/95 dark:bear-bg-gray-900/95 bear-backdrop-blur-sm bear-shadow-2xl bear-rounded-xl bear-m-3"},y=x==="left"?"bear-border-r":"bear-border-l";return e.jsxs("aside",{className:l.cn("bear-flex bear-flex-col bear-h-full bear-transition-all bear-duration-300",h==="default"&&y,v[h],f),style:{width:o,...j},children:[s&&e.jsxs("div",{className:"bear-px-3 bear-py-4 bear-border-b bear-border-zinc-100 bear-flex bear-items-center bear-justify-between",children:[!b&&s,a&&e.jsx("button",{type:"button",onClick:()=>a(!b),className:"bear-p-1.5 bear-rounded-lg bear-text-zinc-400 hover:bear-bg-zinc-100 hover:bear-text-zinc-600 bear-transition-colors","aria-label":b?"Expand sidebar":"Collapse sidebar",children:b?x==="left"?e.jsx(d.ChevronRightIcon,{size:18}):e.jsx(d.ChevronLeftIcon,{size:18}):x==="left"?e.jsx(d.ChevronLeftIcon,{size:18}):e.jsx(d.ChevronRightIcon,{size:18})})]}),e.jsx("nav",{className:"bear-flex-1 bear-overflow-y-auto bear-px-2 bear-py-3 bear-space-y-1",children:r.map(g=>e.jsx(p,{item:g,isActive:g.id===c,collapsed:b,onClick:u},g.id))}),i&&e.jsx("div",{className:"bear-px-3 bear-py-3 bear-border-t bear-border-zinc-100 bear-mt-auto",children:b?null:i})]})};exports.Sidebar=S;exports.SidebarGroup=w;
|
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
import { jsxs as s, jsx as r, Fragment as g } from "react/jsx-runtime";
|
|
2
|
+
import { useState as z, useCallback as S } from "react";
|
|
3
|
+
import { cn as l } from "../../utils/cn.js";
|
|
4
|
+
import { ChevronRightIcon as v, ChevronLeftIcon as y, ChevronDownIcon as N } from "../Icon/index.js";
|
|
5
|
+
const k = 256, C = 64, w = ({
|
|
6
|
+
item: e,
|
|
7
|
+
isActive: b,
|
|
8
|
+
collapsed: a,
|
|
9
|
+
depth: i = 0,
|
|
10
|
+
onClick: n
|
|
11
|
+
}) => {
|
|
12
|
+
const [t, o] = z(!1), d = e.children && e.children.length > 0, u = a ? 16 : 16 + i * 12, f = S(() => {
|
|
13
|
+
d && o((c) => !c), e.onClick && e.onClick(), n == null || n(e);
|
|
14
|
+
}, [d, e, n]), h = /* @__PURE__ */ s(g, { children: [
|
|
15
|
+
e.icon && /* @__PURE__ */ r("span", { className: "bear-shrink-0 bear-w-5 bear-h-5 bear-flex bear-items-center bear-justify-center", children: e.icon }),
|
|
16
|
+
!a && /* @__PURE__ */ s(g, { children: [
|
|
17
|
+
/* @__PURE__ */ r("span", { className: "bear-flex-1 bear-truncate", children: e.label }),
|
|
18
|
+
e.badge && /* @__PURE__ */ r("span", { className: "bear-ml-auto", children: e.badge }),
|
|
19
|
+
d && /* @__PURE__ */ r(
|
|
20
|
+
N,
|
|
21
|
+
{
|
|
22
|
+
size: 14,
|
|
23
|
+
className: l(
|
|
24
|
+
"bear-ml-1 bear-transition-transform bear-duration-200",
|
|
25
|
+
t && "bear-rotate-180"
|
|
26
|
+
)
|
|
27
|
+
}
|
|
28
|
+
)
|
|
29
|
+
] })
|
|
30
|
+
] }), m = l(
|
|
31
|
+
"bear-flex bear-items-center bear-gap-3 bear-py-2.5 bear-px-3 bear-rounded-lg bear-text-sm bear-transition-all bear-duration-200 bear-cursor-pointer",
|
|
32
|
+
b ? "bear-bg-bear-500 bear-text-white bear-shadow-md" : "bear-text-zinc-600 hover:bear-bg-zinc-100 hover:bear-text-zinc-900",
|
|
33
|
+
e.disabled && "bear-opacity-50 bear-cursor-not-allowed bear-pointer-events-none",
|
|
34
|
+
a && "bear-justify-center"
|
|
35
|
+
), x = e.href ? "a" : "button";
|
|
36
|
+
return /* @__PURE__ */ s("div", { children: [
|
|
37
|
+
/* @__PURE__ */ r(
|
|
38
|
+
x,
|
|
39
|
+
{
|
|
40
|
+
href: e.href,
|
|
41
|
+
onClick: f,
|
|
42
|
+
disabled: e.disabled,
|
|
43
|
+
className: m,
|
|
44
|
+
style: { paddingLeft: u },
|
|
45
|
+
title: a ? e.label : void 0,
|
|
46
|
+
children: h
|
|
47
|
+
}
|
|
48
|
+
),
|
|
49
|
+
d && t && !a && /* @__PURE__ */ r("div", { className: "bear-mt-1", children: e.children.map((c) => /* @__PURE__ */ r(
|
|
50
|
+
w,
|
|
51
|
+
{
|
|
52
|
+
item: c,
|
|
53
|
+
isActive: !1,
|
|
54
|
+
collapsed: a,
|
|
55
|
+
depth: i + 1,
|
|
56
|
+
onClick: n
|
|
57
|
+
},
|
|
58
|
+
c.id
|
|
59
|
+
)) })
|
|
60
|
+
] });
|
|
61
|
+
}, O = ({
|
|
62
|
+
title: e,
|
|
63
|
+
children: b,
|
|
64
|
+
collapsible: a = !1,
|
|
65
|
+
defaultCollapsed: i = !1,
|
|
66
|
+
className: n
|
|
67
|
+
}) => {
|
|
68
|
+
const [t, o] = z(i);
|
|
69
|
+
return /* @__PURE__ */ s("div", { className: l("bear-mb-4", n), children: [
|
|
70
|
+
e && /* @__PURE__ */ s(
|
|
71
|
+
"button",
|
|
72
|
+
{
|
|
73
|
+
type: "button",
|
|
74
|
+
onClick: () => a && o(!t),
|
|
75
|
+
className: l(
|
|
76
|
+
"bear-flex bear-items-center bear-gap-2 bear-px-3 bear-py-2 bear-text-xs bear-font-semibold bear-uppercase bear-tracking-wider bear-text-zinc-400",
|
|
77
|
+
a && "bear-cursor-pointer hover:bear-text-zinc-600"
|
|
78
|
+
),
|
|
79
|
+
children: [
|
|
80
|
+
a && /* @__PURE__ */ r(
|
|
81
|
+
N,
|
|
82
|
+
{
|
|
83
|
+
size: 12,
|
|
84
|
+
className: l(
|
|
85
|
+
"bear-transition-transform",
|
|
86
|
+
t && "-bear-rotate-90"
|
|
87
|
+
)
|
|
88
|
+
}
|
|
89
|
+
),
|
|
90
|
+
e
|
|
91
|
+
]
|
|
92
|
+
}
|
|
93
|
+
),
|
|
94
|
+
!t && /* @__PURE__ */ r("div", { className: "bear-space-y-1", children: b })
|
|
95
|
+
] });
|
|
96
|
+
}, R = ({
|
|
97
|
+
items: e,
|
|
98
|
+
collapsed: b = !1,
|
|
99
|
+
onCollapsedChange: a,
|
|
100
|
+
width: i = k,
|
|
101
|
+
collapsedWidth: n = C,
|
|
102
|
+
header: t,
|
|
103
|
+
footer: o,
|
|
104
|
+
activeItemId: d,
|
|
105
|
+
onItemClick: u,
|
|
106
|
+
variant: f = "default",
|
|
107
|
+
position: h = "left",
|
|
108
|
+
className: m,
|
|
109
|
+
style: x
|
|
110
|
+
}) => {
|
|
111
|
+
const c = b ? n : i;
|
|
112
|
+
return /* @__PURE__ */ s(
|
|
113
|
+
"aside",
|
|
114
|
+
{
|
|
115
|
+
className: l(
|
|
116
|
+
"bear-flex bear-flex-col bear-h-full bear-transition-all bear-duration-300",
|
|
117
|
+
f === "default" && (h === "left" ? "bear-border-r" : "bear-border-l"),
|
|
118
|
+
{
|
|
119
|
+
default: "bear-bg-white dark:bear-bg-gray-900 bear-border-zinc-200 dark:bear-border-zinc-700",
|
|
120
|
+
bordered: "bear-bg-white dark:bear-bg-gray-900 bear-border-2 bear-border-zinc-300 dark:bear-border-zinc-600 bear-rounded-xl bear-m-2",
|
|
121
|
+
floating: "bear-bg-white/95 dark:bear-bg-gray-900/95 bear-backdrop-blur-sm bear-shadow-2xl bear-rounded-xl bear-m-3"
|
|
122
|
+
}[f],
|
|
123
|
+
m
|
|
124
|
+
),
|
|
125
|
+
style: { width: c, ...x },
|
|
126
|
+
children: [
|
|
127
|
+
t && /* @__PURE__ */ s("div", { className: "bear-px-3 bear-py-4 bear-border-b bear-border-zinc-100 bear-flex bear-items-center bear-justify-between", children: [
|
|
128
|
+
!b && t,
|
|
129
|
+
a && /* @__PURE__ */ r(
|
|
130
|
+
"button",
|
|
131
|
+
{
|
|
132
|
+
type: "button",
|
|
133
|
+
onClick: () => a(!b),
|
|
134
|
+
className: "bear-p-1.5 bear-rounded-lg bear-text-zinc-400 hover:bear-bg-zinc-100 hover:bear-text-zinc-600 bear-transition-colors",
|
|
135
|
+
"aria-label": b ? "Expand sidebar" : "Collapse sidebar",
|
|
136
|
+
children: b ? h === "left" ? /* @__PURE__ */ r(v, { size: 18 }) : /* @__PURE__ */ r(y, { size: 18 }) : h === "left" ? /* @__PURE__ */ r(y, { size: 18 }) : /* @__PURE__ */ r(v, { size: 18 })
|
|
137
|
+
}
|
|
138
|
+
)
|
|
139
|
+
] }),
|
|
140
|
+
/* @__PURE__ */ r("nav", { className: "bear-flex-1 bear-overflow-y-auto bear-px-2 bear-py-3 bear-space-y-1", children: e.map((p) => /* @__PURE__ */ r(
|
|
141
|
+
w,
|
|
142
|
+
{
|
|
143
|
+
item: p,
|
|
144
|
+
isActive: p.id === d,
|
|
145
|
+
collapsed: b,
|
|
146
|
+
onClick: u
|
|
147
|
+
},
|
|
148
|
+
p.id
|
|
149
|
+
)) }),
|
|
150
|
+
o && /* @__PURE__ */ r("div", { className: "bear-px-3 bear-py-3 bear-border-t bear-border-zinc-100 bear-mt-auto", children: b ? null : o })
|
|
151
|
+
]
|
|
152
|
+
}
|
|
153
|
+
);
|
|
154
|
+
};
|
|
155
|
+
export {
|
|
156
|
+
R as Sidebar,
|
|
157
|
+
O as SidebarGroup
|
|
158
|
+
};
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { ReactNode, CSSProperties } from 'react';
|
|
2
|
+
export interface SidebarItem {
|
|
3
|
+
id: string;
|
|
4
|
+
label: string;
|
|
5
|
+
icon?: ReactNode;
|
|
6
|
+
href?: string;
|
|
7
|
+
onClick?: () => void;
|
|
8
|
+
children?: SidebarItem[];
|
|
9
|
+
badge?: ReactNode;
|
|
10
|
+
disabled?: boolean;
|
|
11
|
+
}
|
|
12
|
+
export interface SidebarProps {
|
|
13
|
+
items: SidebarItem[];
|
|
14
|
+
collapsed?: boolean;
|
|
15
|
+
onCollapsedChange?: (collapsed: boolean) => void;
|
|
16
|
+
width?: number | string;
|
|
17
|
+
collapsedWidth?: number | string;
|
|
18
|
+
header?: ReactNode;
|
|
19
|
+
footer?: ReactNode;
|
|
20
|
+
activeItemId?: string;
|
|
21
|
+
onItemClick?: (item: SidebarItem) => void;
|
|
22
|
+
variant?: 'default' | 'bordered' | 'floating';
|
|
23
|
+
position?: 'left' | 'right';
|
|
24
|
+
className?: string;
|
|
25
|
+
style?: CSSProperties;
|
|
26
|
+
}
|
|
27
|
+
export interface SidebarGroupProps {
|
|
28
|
+
title?: string;
|
|
29
|
+
children: ReactNode;
|
|
30
|
+
collapsible?: boolean;
|
|
31
|
+
defaultCollapsed?: boolean;
|
|
32
|
+
className?: string;
|
|
33
|
+
}
|
|
34
|
+
export interface SidebarItemProps {
|
|
35
|
+
item: SidebarItem;
|
|
36
|
+
isActive?: boolean;
|
|
37
|
+
collapsed?: boolean;
|
|
38
|
+
depth?: number;
|
|
39
|
+
onClick?: (item: SidebarItem) => void;
|
|
40
|
+
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const b=require("react/jsx-runtime"),u=require("react"),g=require("../../utils/cn.cjs"),U={xs:{track:"bear-h-1",thumb:"bear-w-3 bear-h-3",height:"bear-h-6"},sm:{track:"bear-h-1.5",thumb:"bear-w-4 bear-h-4",height:"bear-h-8"},md:{track:"bear-h-2",thumb:"bear-w-5 bear-h-5",height:"bear-h-10"},lg:{track:"bear-h-2.5",thumb:"bear-w-6 bear-h-6",height:"bear-h-12"},xl:{track:"bear-h-3",thumb:"bear-w-7 bear-h-7",height:"bear-h-14"}},X={primary:{track:"bear-bg-bear-500",thumb:"bear-bg-bear-500 bear-border-bear-600"},secondary:{track:"bear-bg-gray-500",thumb:"bear-bg-gray-500 bear-border-gray-600"},success:{track:"bear-bg-green-500",thumb:"bear-bg-green-500 bear-border-green-600"},warning:{track:"bear-bg-amber-500",thumb:"bear-bg-amber-500 bear-border-amber-600"},error:{track:"bear-bg-red-500",thumb:"bear-bg-red-500 bear-border-red-600"},danger:{track:"bear-bg-red-500",thumb:"bear-bg-red-500 bear-border-red-600"},info:{track:"bear-bg-blue-500",thumb:"bear-bg-blue-500 bear-border-blue-600"},ghost:{track:"bear-bg-gray-400",thumb:"bear-bg-gray-400 bear-border-gray-500"},outline:{track:"bear-bg-gray-600",thumb:"bear-bg-white bear-border-gray-600"}},Y=({value:N,defaultValue:L=0,min:r=0,max:t=100,step:c=1,size:A="md",color:R="primary",showValue:V=!1,marks:f=!1,disabled:s=!1,orientation:F="horizontal",onChange:n,onChangeCommitted:
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const b=require("react/jsx-runtime"),u=require("react"),g=require("../../utils/cn.cjs"),U={xs:{track:"bear-h-1",thumb:"bear-w-3 bear-h-3",height:"bear-h-6"},sm:{track:"bear-h-1.5",thumb:"bear-w-4 bear-h-4",height:"bear-h-8"},md:{track:"bear-h-2",thumb:"bear-w-5 bear-h-5",height:"bear-h-10"},lg:{track:"bear-h-2.5",thumb:"bear-w-6 bear-h-6",height:"bear-h-12"},xl:{track:"bear-h-3",thumb:"bear-w-7 bear-h-7",height:"bear-h-14"}},X={primary:{track:"bear-bg-bear-500",thumb:"bear-bg-bear-500 bear-border-bear-600"},secondary:{track:"bear-bg-gray-500",thumb:"bear-bg-gray-500 bear-border-gray-600"},success:{track:"bear-bg-green-500",thumb:"bear-bg-green-500 bear-border-green-600"},warning:{track:"bear-bg-amber-500",thumb:"bear-bg-amber-500 bear-border-amber-600"},error:{track:"bear-bg-red-500",thumb:"bear-bg-red-500 bear-border-red-600"},danger:{track:"bear-bg-red-500",thumb:"bear-bg-red-500 bear-border-red-600"},info:{track:"bear-bg-blue-500",thumb:"bear-bg-blue-500 bear-border-blue-600"},ghost:{track:"bear-bg-gray-400",thumb:"bear-bg-gray-400 bear-border-gray-500"},outline:{track:"bear-bg-gray-600",thumb:"bear-bg-white dark:bear-bg-gray-200 bear-border-gray-600 dark:bear-border-gray-400"}},Y=({value:N,defaultValue:L=0,min:r=0,max:t=100,step:c=1,size:A="md",color:R="primary",showValue:V=!1,marks:f=!1,disabled:s=!1,orientation:F="horizontal",onChange:n,onChangeCommitted:d,valueFormatter:T=y=>String(y),ariaLabel:I="Slider",className:q,testId:O,..._})=>{const[y,p]=u.useState(L),[l,S]=u.useState(!1),[$,h]=u.useState(!1),w=u.useRef(null),o=N??y,M=(o-r)/(t-r)*100,m=U[A],j=X[R],v=u.useCallback(a=>{if(!w.current||s)return;const e=w.current.getBoundingClientRect(),i=Math.max(0,Math.min(1,(a-e.left)/e.width)),K=r+i*(t-r),P=Math.round(K/c)*c,E=Math.max(r,Math.min(t,P));p(E),n==null||n(E)},[r,t,c,s,n]),D=a=>{s||(a.preventDefault(),S(!0),h(!0),v(a.clientX))},k=u.useCallback(a=>{l&&v(a.clientX)},[l,v]),x=u.useCallback(()=>{l&&(S(!1),h(!1),d==null||d(o))},[l,o,d]);u.useEffect(()=>{if(l)return document.addEventListener("mousemove",k),document.addEventListener("mouseup",x),()=>{document.removeEventListener("mousemove",k),document.removeEventListener("mouseup",x)}},[l,k,x]);const z=a=>{if(s)return;let e=o;switch(a.key){case"ArrowRight":case"ArrowUp":e=Math.min(t,o+c);break;case"ArrowLeft":case"ArrowDown":e=Math.max(r,o-c);break;case"Home":e=r;break;case"End":e=t;break;default:return}a.preventDefault(),p(e),n==null||n(e)},B=()=>{if(!f)return null;const a=Array.isArray(f)?f:Array.from({length:(t-r)/c+1},(e,i)=>({value:r+i*c}));return b.jsx("div",{className:"bear-absolute bear-inset-x-0 bear-top-1/2 bear--translate-y-1/2 bear-flex bear-justify-between",children:a.map(e=>{const i=(e.value-r)/(t-r)*100;return b.jsxs("div",{className:"bear-absolute bear-flex bear-flex-col bear-items-center",style:{left:`${i}%`},children:[b.jsx("div",{className:"bear-w-0.5 bear-h-2 bear-bg-gray-400 dark:bear-bg-gray-500"}),e.label&&b.jsx("span",{className:"bear-mt-1 bear-text-xs bear-text-gray-500",children:e.label})]},e.value)})})};return b.jsx("div",{className:g.cn("bear-relative bear-w-full bear-flex bear-items-center",m.height,s&&"bear-opacity-50 bear-cursor-not-allowed",q),"data-testid":O,..._,children:b.jsxs("div",{ref:w,className:g.cn("bear-relative bear-w-full bear-rounded-full bear-bg-gray-200 dark:bear-bg-gray-700",m.track,!s&&"bear-cursor-pointer"),onMouseDown:D,children:[b.jsx("div",{className:g.cn("bear-absolute bear-inset-y-0 bear-left-0 bear-rounded-full",j.track),style:{width:`${M}%`}}),B(),b.jsx("div",{role:"slider",tabIndex:s?-1:0,"aria-label":I,"aria-valuemin":r,"aria-valuemax":t,"aria-valuenow":o,className:g.cn("bear-absolute bear-top-1/2 bear--translate-y-1/2 bear--translate-x-1/2 bear-rounded-full","bear-border-2 bear-shadow-md bear-transition-transform","focus:bear-outline-none focus:bear-ring-2 focus:bear-ring-bear-500 focus:bear-ring-offset-2",m.thumb,j.thumb,!s&&"bear-cursor-grab active:bear-cursor-grabbing hover:bear-scale-110",l&&"bear-scale-125"),style:{left:`${M}%`},onMouseDown:D,onKeyDown:z,onFocus:()=>h(!0),onBlur:()=>!l&&h(!1),children:V&&$&&b.jsx("div",{className:"bear-absolute bear-bottom-full bear-left-1/2 bear--translate-x-1/2 bear-mb-2 bear-px-2 bear-py-1 bear-bg-gray-900 bear-text-white bear-text-xs bear-rounded bear-whitespace-nowrap",children:T(o)})})]})})};exports.Slider=Y;
|
|
@@ -42,7 +42,7 @@ const Z = {
|
|
|
42
42
|
},
|
|
43
43
|
outline: {
|
|
44
44
|
track: "bear-bg-gray-600",
|
|
45
|
-
thumb: "bear-bg-white bear-border-gray-600"
|
|
45
|
+
thumb: "bear-bg-white dark:bear-bg-gray-200 bear-border-gray-600 dark:bear-border-gray-400"
|
|
46
46
|
}
|
|
47
47
|
}, C = ({
|
|
48
48
|
value: V,
|
|
@@ -64,15 +64,15 @@ const Z = {
|
|
|
64
64
|
testId: B,
|
|
65
65
|
...K
|
|
66
66
|
}) => {
|
|
67
|
-
const [f, M] = k(R), [s, S] = k(!1), [O, h] = k(!1), m = H(null), l = V ?? f, D = (l - r) / (t - r) * 100,
|
|
67
|
+
const [f, M] = k(R), [s, S] = k(!1), [O, h] = k(!1), m = H(null), l = V ?? f, D = (l - r) / (t - r) * 100, y = Z[I], E = q[T], w = x((a) => {
|
|
68
68
|
if (!m.current || b) return;
|
|
69
69
|
const e = m.current.getBoundingClientRect(), n = Math.max(0, Math.min(1, (a - e.left) / e.width)), Y = r + n * (t - r), F = Math.round(Y / o) * o, L = Math.max(r, Math.min(t, F));
|
|
70
70
|
M(L), u == null || u(L);
|
|
71
71
|
}, [r, t, o, b, u]), N = (a) => {
|
|
72
|
-
b || (a.preventDefault(), S(!0), h(!0),
|
|
72
|
+
b || (a.preventDefault(), S(!0), h(!0), w(a.clientX));
|
|
73
73
|
}, v = x((a) => {
|
|
74
|
-
s &&
|
|
75
|
-
}, [s,
|
|
74
|
+
s && w(a.clientX);
|
|
75
|
+
}, [s, w]), p = x(() => {
|
|
76
76
|
s && (S(!1), h(!1), i == null || i(l));
|
|
77
77
|
}, [s, l, i]);
|
|
78
78
|
P(() => {
|
|
@@ -129,7 +129,7 @@ const Z = {
|
|
|
129
129
|
{
|
|
130
130
|
className: d(
|
|
131
131
|
"bear-relative bear-w-full bear-flex bear-items-center",
|
|
132
|
-
|
|
132
|
+
y.height,
|
|
133
133
|
b && "bear-opacity-50 bear-cursor-not-allowed",
|
|
134
134
|
z
|
|
135
135
|
),
|
|
@@ -141,7 +141,7 @@ const Z = {
|
|
|
141
141
|
ref: m,
|
|
142
142
|
className: d(
|
|
143
143
|
"bear-relative bear-w-full bear-rounded-full bear-bg-gray-200 dark:bear-bg-gray-700",
|
|
144
|
-
|
|
144
|
+
y.track,
|
|
145
145
|
!b && "bear-cursor-pointer"
|
|
146
146
|
),
|
|
147
147
|
onMouseDown: N,
|
|
@@ -167,7 +167,7 @@ const Z = {
|
|
|
167
167
|
"bear-absolute bear-top-1/2 bear--translate-y-1/2 bear--translate-x-1/2 bear-rounded-full",
|
|
168
168
|
"bear-border-2 bear-shadow-md bear-transition-transform",
|
|
169
169
|
"focus:bear-outline-none focus:bear-ring-2 focus:bear-ring-bear-500 focus:bear-ring-offset-2",
|
|
170
|
-
|
|
170
|
+
y.thumb,
|
|
171
171
|
E.thumb,
|
|
172
172
|
!b && "bear-cursor-grab active:bear-cursor-grabbing hover:bear-scale-110",
|
|
173
173
|
s && "bear-scale-125"
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("react/jsx-runtime"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("react/jsx-runtime"),i=require("react"),b=require("../../utils/cn.cjs"),v=require("../Button/Button.cjs"),z=require("../Tooltip/Tooltip.cjs"),P={"bottom-right":"bear-bottom-4 bear-right-4","bottom-left":"bear-bottom-4 bear-left-4","top-right":"bear-top-4 bear-right-4","top-left":"bear-top-4 bear-left-4"},w={up:"bear-flex-col-reverse bear-pb-2",down:"bear-flex-col bear-pt-2",left:"bear-flex-row-reverse bear-pr-2",right:"bear-flex-row bear-pl-2"},W=s.jsxs("svg",{width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[s.jsx("line",{x1:"12",y1:"5",x2:"12",y2:"19"}),s.jsx("line",{x1:"5",y1:"12",x2:"19",y2:"12"})]}),F=s.jsxs("svg",{width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[s.jsx("line",{x1:"18",y1:"6",x2:"6",y2:"18"}),s.jsx("line",{x1:"6",y1:"6",x2:"18",y2:"18"})]}),M=({actions:k,icon:j=W,openIcon:S=F,open:d,defaultOpen:p=!1,direction:o="up",variant:E="primary",size:h="lg",showTooltips:L=!0,tooltipPlacement:n="auto",closeOnAction:f=!0,position:x="bottom-right",fixed:m=!0,ariaLabel:N="SpeedDial",onOpenChange:r,className:T,testId:I,...D})=>{const[q,c]=i.useState(p),u=i.useRef(null),l=d!==void 0,t=l?d:q,B=i.useCallback(()=>{const e=!t;l||c(e),r==null||r(e)},[t,l,r]),R=i.useCallback(e=>{var a;(a=e.onClick)==null||a.call(e),f&&(l||c(!1),r==null||r(!1))},[f,l,r]);i.useEffect(()=>{const e=a=>{u.current&&!u.current.contains(a.target)&&t&&(l||c(!1),r==null||r(!1))};return document.addEventListener("mousedown",e),()=>document.removeEventListener("mousedown",e)},[t,l,r]),i.useEffect(()=>{const e=a=>{a.key==="Escape"&&t&&(l||c(!1),r==null||r(!1))};return document.addEventListener("keydown",e),()=>document.removeEventListener("keydown",e)},[t,l,r]);const A=()=>{if(n!=="auto")return n;switch(o){case"up":case"down":return x.includes("right")?"left":"right";case"left":case"right":return"top"}},_=(e,a)=>{const y=s.jsx(v.Button,{variant:"secondary",size:"md",onClick:()=>R(e),disabled:e.disabled,className:b.cn("bear-rounded-full bear-shadow-lg bear-transition-all bear-duration-200","bear-w-12 bear-h-12 bear-p-0 bear-flex bear-items-center bear-justify-center",t?"bear-opacity-100 bear-scale-100":"bear-opacity-0 bear-scale-75 bear-pointer-events-none"),style:{transitionDelay:t?`${a*50}ms`:"0ms"},"aria-label":e.label,children:e.icon},e.key);return L?s.jsx(z.Tooltip,{content:e.label,placement:A(),children:y},e.key):y};return s.jsxs("div",{ref:u,className:b.cn("bear-inline-flex bear-items-center",w[o],m&&"bear-fixed bear-z-50",m&&P[x],T),"data-testid":I,...D,children:[s.jsx("div",{className:b.cn("bear-flex bear-gap-3",w[o]),role:"menu","aria-orientation":o==="up"||o==="down"?"vertical":"horizontal",children:k.map((e,a)=>_(e,a))}),s.jsx(v.Button,{variant:E,size:h,onClick:B,className:b.cn("bear-rounded-full bear-shadow-xl bear-transition-transform bear-duration-300","bear-w-14 bear-h-14 bear-p-0 bear-flex bear-items-center bear-justify-center",t&&"bear-rotate-45"),"aria-label":N,"aria-expanded":t,"aria-haspopup":"menu",children:t?S:j})]})};exports.SpeedDial=M;
|