@hyperpackai/hyperui 0.1.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 +82 -0
- package/dist/components/Accordion/index.d.ts +17 -0
- package/dist/components/Accordion/index.d.ts.map +1 -0
- package/dist/components/Accordion/index.js +46 -0
- package/dist/components/Alert/index.d.ts +13 -0
- package/dist/components/Alert/index.d.ts.map +1 -0
- package/dist/components/Alert/index.js +46 -0
- package/dist/components/AppBar/index.d.ts +19 -0
- package/dist/components/AppBar/index.d.ts.map +1 -0
- package/dist/components/AppBar/index.js +48 -0
- package/dist/components/AspectRatio/index.d.ts +8 -0
- package/dist/components/AspectRatio/index.d.ts.map +1 -0
- package/dist/components/AspectRatio/index.js +32 -0
- package/dist/components/Autocomplete/index.d.ts +21 -0
- package/dist/components/Autocomplete/index.d.ts.map +1 -0
- package/dist/components/Autocomplete/index.js +94 -0
- package/dist/components/Avatar/index.d.ts +12 -0
- package/dist/components/Avatar/index.d.ts.map +1 -0
- package/dist/components/Avatar/index.js +32 -0
- package/dist/components/AvatarGroup/index.d.ts +9 -0
- package/dist/components/AvatarGroup/index.d.ts.map +1 -0
- package/dist/components/AvatarGroup/index.js +24 -0
- package/dist/components/Backdrop/index.d.ts +10 -0
- package/dist/components/Backdrop/index.d.ts.map +1 -0
- package/dist/components/Backdrop/index.js +25 -0
- package/dist/components/Badge/index.d.ts +10 -0
- package/dist/components/Badge/index.d.ts.map +1 -0
- package/dist/components/Badge/index.js +30 -0
- package/dist/components/BottomNavigation/index.d.ts +16 -0
- package/dist/components/BottomNavigation/index.d.ts.map +1 -0
- package/dist/components/BottomNavigation/index.js +43 -0
- package/dist/components/Box/index.d.ts +21 -0
- package/dist/components/Box/index.d.ts.map +1 -0
- package/dist/components/Box/index.js +30 -0
- package/dist/components/Breadcrumb/index.d.ts +13 -0
- package/dist/components/Breadcrumb/index.d.ts.map +1 -0
- package/dist/components/Breadcrumb/index.js +19 -0
- package/dist/components/Button/index.d.ts +22 -0
- package/dist/components/Button/index.d.ts.map +1 -0
- package/dist/components/Button/index.js +93 -0
- package/dist/components/ButtonGroup/index.d.ts +9 -0
- package/dist/components/ButtonGroup/index.d.ts.map +1 -0
- package/dist/components/ButtonGroup/index.js +27 -0
- package/dist/components/Card/index.d.ts +14 -0
- package/dist/components/Card/index.d.ts.map +1 -0
- package/dist/components/Card/index.js +33 -0
- package/dist/components/Checkbox/index.d.ts +17 -0
- package/dist/components/Checkbox/index.d.ts.map +1 -0
- package/dist/components/Checkbox/index.js +42 -0
- package/dist/components/Chip/index.d.ts +18 -0
- package/dist/components/Chip/index.d.ts.map +1 -0
- package/dist/components/Chip/index.js +60 -0
- package/dist/components/CircularProgress/index.d.ts +14 -0
- package/dist/components/CircularProgress/index.d.ts.map +1 -0
- package/dist/components/CircularProgress/index.js +58 -0
- package/dist/components/ClickAwayListener/index.d.ts +11 -0
- package/dist/components/ClickAwayListener/index.d.ts.map +1 -0
- package/dist/components/ClickAwayListener/index.js +31 -0
- package/dist/components/Code/index.d.ts +9 -0
- package/dist/components/Code/index.d.ts.map +1 -0
- package/dist/components/Code/index.js +50 -0
- package/dist/components/Collapse/index.d.ts +11 -0
- package/dist/components/Collapse/index.d.ts.map +1 -0
- package/dist/components/Collapse/index.js +30 -0
- package/dist/components/CommandPalette/index.d.ts +26 -0
- package/dist/components/CommandPalette/index.d.ts.map +1 -0
- package/dist/components/CommandPalette/index.js +141 -0
- package/dist/components/Container/index.d.ts +11 -0
- package/dist/components/Container/index.d.ts.map +1 -0
- package/dist/components/Container/index.js +18 -0
- package/dist/components/DashboardLayout/index.d.ts +15 -0
- package/dist/components/DashboardLayout/index.d.ts.map +1 -0
- package/dist/components/DashboardLayout/index.js +67 -0
- package/dist/components/DataTable/index.d.ts +27 -0
- package/dist/components/DataTable/index.d.ts.map +1 -0
- package/dist/components/DataTable/index.js +59 -0
- package/dist/components/Dialog/index.d.ts +19 -0
- package/dist/components/Dialog/index.d.ts.map +1 -0
- package/dist/components/Dialog/index.js +96 -0
- package/dist/components/Divider/index.d.ts +13 -0
- package/dist/components/Divider/index.d.ts.map +1 -0
- package/dist/components/Divider/index.js +40 -0
- package/dist/components/Drawer/index.d.ts +17 -0
- package/dist/components/Drawer/index.d.ts.map +1 -0
- package/dist/components/Drawer/index.js +77 -0
- package/dist/components/DropdownMenu/index.d.ts +25 -0
- package/dist/components/DropdownMenu/index.d.ts.map +1 -0
- package/dist/components/DropdownMenu/index.js +67 -0
- package/dist/components/EmptyState/index.d.ts +11 -0
- package/dist/components/EmptyState/index.d.ts.map +1 -0
- package/dist/components/EmptyState/index.js +53 -0
- package/dist/components/ErrorState/index.d.ts +12 -0
- package/dist/components/ErrorState/index.d.ts.map +1 -0
- package/dist/components/ErrorState/index.js +54 -0
- package/dist/components/Fab/index.d.ts +16 -0
- package/dist/components/Fab/index.d.ts.map +1 -0
- package/dist/components/Fab/index.js +39 -0
- package/dist/components/Fade/index.d.ts +10 -0
- package/dist/components/Fade/index.d.ts.map +1 -0
- package/dist/components/Fade/index.js +13 -0
- package/dist/components/FocusTrap/index.d.ts +11 -0
- package/dist/components/FocusTrap/index.d.ts.map +1 -0
- package/dist/components/FocusTrap/index.js +69 -0
- package/dist/components/FormControl/index.d.ts +34 -0
- package/dist/components/FormControl/index.d.ts.map +1 -0
- package/dist/components/FormControl/index.js +52 -0
- package/dist/components/GlobalSearch/index.d.ts +23 -0
- package/dist/components/GlobalSearch/index.d.ts.map +1 -0
- package/dist/components/GlobalSearch/index.js +91 -0
- package/dist/components/Grid/index.d.ts +19 -0
- package/dist/components/Grid/index.d.ts.map +1 -0
- package/dist/components/Grid/index.js +30 -0
- package/dist/components/Grow/index.d.ts +10 -0
- package/dist/components/Grow/index.d.ts.map +1 -0
- package/dist/components/Grow/index.js +13 -0
- package/dist/components/IconButton/index.d.ts +16 -0
- package/dist/components/IconButton/index.d.ts.map +1 -0
- package/dist/components/IconButton/index.js +43 -0
- package/dist/components/ImageList/index.d.ts +21 -0
- package/dist/components/ImageList/index.d.ts.map +1 -0
- package/dist/components/ImageList/index.js +39 -0
- package/dist/components/Input/index.d.ts +33 -0
- package/dist/components/Input/index.d.ts.map +1 -0
- package/dist/components/Input/index.js +45 -0
- package/dist/components/Kbd/index.d.ts +8 -0
- package/dist/components/Kbd/index.d.ts.map +1 -0
- package/dist/components/Kbd/index.js +41 -0
- package/dist/components/KeyboardShortcut/index.d.ts +20 -0
- package/dist/components/KeyboardShortcut/index.d.ts.map +1 -0
- package/dist/components/KeyboardShortcut/index.js +63 -0
- package/dist/components/Label/index.d.ts +10 -0
- package/dist/components/Label/index.d.ts.map +1 -0
- package/dist/components/Label/index.js +17 -0
- package/dist/components/LinearProgress/index.d.ts +13 -0
- package/dist/components/LinearProgress/index.d.ts.map +1 -0
- package/dist/components/LinearProgress/index.js +69 -0
- package/dist/components/Link/index.d.ts +16 -0
- package/dist/components/Link/index.d.ts.map +1 -0
- package/dist/components/Link/index.js +25 -0
- package/dist/components/List/index.d.ts +40 -0
- package/dist/components/List/index.d.ts.map +1 -0
- package/dist/components/List/index.js +70 -0
- package/dist/components/LoadingState/index.d.ts +11 -0
- package/dist/components/LoadingState/index.d.ts.map +1 -0
- package/dist/components/LoadingState/index.js +66 -0
- package/dist/components/Menu/index.d.ts +40 -0
- package/dist/components/Menu/index.d.ts.map +1 -0
- package/dist/components/Menu/index.js +103 -0
- package/dist/components/MobileStepper/index.d.ts +16 -0
- package/dist/components/MobileStepper/index.d.ts.map +1 -0
- package/dist/components/MobileStepper/index.js +67 -0
- package/dist/components/Modal/index.d.ts +14 -0
- package/dist/components/Modal/index.d.ts.map +1 -0
- package/dist/components/Modal/index.js +51 -0
- package/dist/components/Navbar/index.d.ts +14 -0
- package/dist/components/Navbar/index.d.ts.map +1 -0
- package/dist/components/Navbar/index.js +27 -0
- package/dist/components/NoSSR/index.d.ts +7 -0
- package/dist/components/NoSSR/index.d.ts.map +1 -0
- package/dist/components/NoSSR/index.js +9 -0
- package/dist/components/PageLayout/index.d.ts +13 -0
- package/dist/components/PageLayout/index.d.ts.map +1 -0
- package/dist/components/PageLayout/index.js +41 -0
- package/dist/components/Pagination/index.d.ts +11 -0
- package/dist/components/Pagination/index.d.ts.map +1 -0
- package/dist/components/Pagination/index.js +56 -0
- package/dist/components/Paper/index.d.ts +12 -0
- package/dist/components/Paper/index.d.ts.map +1 -0
- package/dist/components/Paper/index.js +24 -0
- package/dist/components/Popover/index.d.ts +13 -0
- package/dist/components/Popover/index.d.ts.map +1 -0
- package/dist/components/Popover/index.js +34 -0
- package/dist/components/Progress/index.d.ts +13 -0
- package/dist/components/Progress/index.d.ts.map +1 -0
- package/dist/components/Progress/index.js +40 -0
- package/dist/components/Radio/index.d.ts +7 -0
- package/dist/components/Radio/index.d.ts.map +1 -0
- package/dist/components/Radio/index.js +28 -0
- package/dist/components/Rating/index.d.ts +15 -0
- package/dist/components/Rating/index.d.ts.map +1 -0
- package/dist/components/Rating/index.js +41 -0
- package/dist/components/ResizablePanel/index.d.ts +16 -0
- package/dist/components/ResizablePanel/index.d.ts.map +1 -0
- package/dist/components/ResizablePanel/index.js +41 -0
- package/dist/components/ScrollArea/index.d.ts +12 -0
- package/dist/components/ScrollArea/index.d.ts.map +1 -0
- package/dist/components/ScrollArea/index.js +50 -0
- package/dist/components/Select/index.d.ts +23 -0
- package/dist/components/Select/index.d.ts.map +1 -0
- package/dist/components/Select/index.js +52 -0
- package/dist/components/Sheet/index.d.ts +15 -0
- package/dist/components/Sheet/index.d.ts.map +1 -0
- package/dist/components/Sheet/index.js +61 -0
- package/dist/components/Sidebar/index.d.ts +23 -0
- package/dist/components/Sidebar/index.d.ts.map +1 -0
- package/dist/components/Sidebar/index.js +37 -0
- package/dist/components/Skeleton/index.d.ts +9 -0
- package/dist/components/Skeleton/index.d.ts.map +1 -0
- package/dist/components/Skeleton/index.js +22 -0
- package/dist/components/Slide/index.d.ts +12 -0
- package/dist/components/Slide/index.d.ts.map +1 -0
- package/dist/components/Slide/index.js +21 -0
- package/dist/components/Slider/index.d.ts +19 -0
- package/dist/components/Slider/index.d.ts.map +1 -0
- package/dist/components/Slider/index.js +49 -0
- package/dist/components/Snackbar/index.d.ts +28 -0
- package/dist/components/Snackbar/index.d.ts.map +1 -0
- package/dist/components/Snackbar/index.js +71 -0
- package/dist/components/SpeedDial/index.d.ts +18 -0
- package/dist/components/SpeedDial/index.d.ts.map +1 -0
- package/dist/components/SpeedDial/index.js +71 -0
- package/dist/components/Spinner/index.d.ts +10 -0
- package/dist/components/Spinner/index.d.ts.map +1 -0
- package/dist/components/Spinner/index.js +67 -0
- package/dist/components/SplitPane/index.d.ts +11 -0
- package/dist/components/SplitPane/index.d.ts.map +1 -0
- package/dist/components/SplitPane/index.js +46 -0
- package/dist/components/Stack/index.d.ts +17 -0
- package/dist/components/Stack/index.d.ts.map +1 -0
- package/dist/components/Stack/index.js +30 -0
- package/dist/components/Stepper/index.d.ts +20 -0
- package/dist/components/Stepper/index.d.ts.map +1 -0
- package/dist/components/Stepper/index.js +66 -0
- package/dist/components/Switch/index.d.ts +13 -0
- package/dist/components/Switch/index.d.ts.map +1 -0
- package/dist/components/Switch/index.js +38 -0
- package/dist/components/Tabs/index.d.ts +20 -0
- package/dist/components/Tabs/index.d.ts.map +1 -0
- package/dist/components/Tabs/index.js +62 -0
- package/dist/components/TextField/index.d.ts +35 -0
- package/dist/components/TextField/index.d.ts.map +1 -0
- package/dist/components/TextField/index.js +69 -0
- package/dist/components/Textarea/index.d.ts +22 -0
- package/dist/components/Textarea/index.d.ts.map +1 -0
- package/dist/components/Textarea/index.js +27 -0
- package/dist/components/Timeline/index.d.ts +16 -0
- package/dist/components/Timeline/index.d.ts.map +1 -0
- package/dist/components/Timeline/index.js +30 -0
- package/dist/components/Toast/index.d.ts +34 -0
- package/dist/components/Toast/index.d.ts.map +1 -0
- package/dist/components/Toast/index.js +106 -0
- package/dist/components/ToggleButton/index.d.ts +21 -0
- package/dist/components/ToggleButton/index.d.ts.map +1 -0
- package/dist/components/ToggleButton/index.js +81 -0
- package/dist/components/Tooltip/index.d.ts +14 -0
- package/dist/components/Tooltip/index.d.ts.map +1 -0
- package/dist/components/Tooltip/index.js +47 -0
- package/dist/components/TreeView/index.d.ts +19 -0
- package/dist/components/TreeView/index.d.ts.map +1 -0
- package/dist/components/TreeView/index.js +50 -0
- package/dist/components/Typography/index.d.ts +17 -0
- package/dist/components/Typography/index.d.ts.map +1 -0
- package/dist/components/Typography/index.js +44 -0
- package/dist/components/VisuallyHidden/index.d.ts +7 -0
- package/dist/components/VisuallyHidden/index.d.ts.map +1 -0
- package/dist/components/VisuallyHidden/index.js +18 -0
- package/dist/components/Zoom/index.d.ts +10 -0
- package/dist/components/Zoom/index.d.ts.map +1 -0
- package/dist/components/Zoom/index.js +13 -0
- package/dist/components/ai.d.ts +133 -0
- package/dist/components/ai.d.ts.map +1 -0
- package/dist/components/ai.js +184 -0
- package/dist/components/charts.d.ts +143 -0
- package/dist/components/charts.d.ts.map +1 -0
- package/dist/components/charts.js +435 -0
- package/dist/components/data.d.ts +192 -0
- package/dist/components/data.d.ts.map +1 -0
- package/dist/components/data.js +581 -0
- package/dist/components/date.d.ts +73 -0
- package/dist/components/date.d.ts.map +1 -0
- package/dist/components/date.js +199 -0
- package/dist/components/enterprise.d.ts +246 -0
- package/dist/components/enterprise.d.ts.map +1 -0
- package/dist/components/enterprise.js +428 -0
- package/dist/components/form.d.ts +132 -0
- package/dist/components/form.d.ts.map +1 -0
- package/dist/components/form.js +380 -0
- package/dist/components/index.d.ts +173 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +107 -0
- package/dist/components/inputs.d.ts +169 -0
- package/dist/components/inputs.d.ts.map +1 -0
- package/dist/components/inputs.js +437 -0
- package/dist/components/layout.d.ts +224 -0
- package/dist/components/layout.d.ts.map +1 -0
- package/dist/components/layout.js +644 -0
- package/dist/components/overlay.d.ts +102 -0
- package/dist/components/overlay.d.ts.map +1 -0
- package/dist/components/overlay.js +318 -0
- package/dist/components/surfaces.d.ts +180 -0
- package/dist/components/surfaces.d.ts.map +1 -0
- package/dist/components/surfaces.js +423 -0
- package/dist/components/typography.d.ts +69 -0
- package/dist/components/typography.d.ts.map +1 -0
- package/dist/components/typography.js +206 -0
- package/dist/index.d.ts +23 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +29 -0
- package/dist/portal.d.ts +3 -0
- package/dist/portal.d.ts.map +1 -0
- package/dist/portal.js +17 -0
- package/dist/theme/index.d.ts +31 -0
- package/dist/theme/index.d.ts.map +1 -0
- package/dist/theme/index.js +258 -0
- package/dist/tokens/component.d.ts +124 -0
- package/dist/tokens/component.d.ts.map +1 -0
- package/dist/tokens/component.js +113 -0
- package/dist/tokens/index.d.ts +494 -0
- package/dist/tokens/index.d.ts.map +1 -0
- package/dist/tokens/index.js +345 -0
- package/dist/tokens/primitives.d.ts +675 -0
- package/dist/tokens/primitives.d.ts.map +1 -0
- package/dist/tokens/primitives.js +356 -0
- package/dist/tokens/semantic.d.ts +252 -0
- package/dist/tokens/semantic.d.ts.map +1 -0
- package/dist/tokens/semantic.js +242 -0
- package/dist/tokens/themes.d.ts +18 -0
- package/dist/tokens/themes.d.ts.map +1 -0
- package/dist/tokens/themes.js +316 -0
- package/package.json +69 -0
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { injectCSS, cn, h } from "../../theme/index.js";
|
|
2
|
+
const CSS = `
|
|
3
|
+
.hu-circular-progress { display: inline-flex; align-items: center; justify-content: center; }
|
|
4
|
+
.hu-circular-progress--indeterminate .hu-circular-progress__svg { animation: hu-cp-rotate 1.4s linear infinite; }
|
|
5
|
+
.hu-circular-progress--indeterminate .hu-circular-progress__circle {
|
|
6
|
+
animation: hu-cp-dash 1.4s ease-in-out infinite;
|
|
7
|
+
stroke-dasharray: 80px,200px; stroke-dashoffset: 0;
|
|
8
|
+
}
|
|
9
|
+
.hu-circular-progress--determinate .hu-circular-progress__circle {
|
|
10
|
+
transition: stroke-dashoffset 300ms cubic-bezier(.4,0,.2,1);
|
|
11
|
+
transform: rotate(-90deg); transform-origin: 50% 50%;
|
|
12
|
+
}
|
|
13
|
+
.hu-circular-progress__svg { display: block; }
|
|
14
|
+
.hu-circular-progress__circle { stroke-linecap: round; }
|
|
15
|
+
.hu-circular-progress--primary { color: var(--hu-primary); }
|
|
16
|
+
.hu-circular-progress--secondary { color: var(--hu-text-2); }
|
|
17
|
+
.hu-circular-progress--error { color: var(--hu-error); }
|
|
18
|
+
.hu-circular-progress--warning { color: var(--hu-warning); }
|
|
19
|
+
.hu-circular-progress--success { color: var(--hu-success); }
|
|
20
|
+
.hu-circular-progress--inherit { color: inherit; }
|
|
21
|
+
.hu-circular-progress__track { stroke: var(--hu-border-2); }
|
|
22
|
+
.hu-circular-progress__label {
|
|
23
|
+
position: absolute; font-size: var(--hu-font-size-xs); font-weight: var(--hu-font-weight-semibold);
|
|
24
|
+
color: var(--hu-text);
|
|
25
|
+
}
|
|
26
|
+
.hu-circular-progress--with-label { position: relative; }
|
|
27
|
+
@keyframes hu-cp-rotate { 100% { transform: rotate(360deg); } }
|
|
28
|
+
@keyframes hu-cp-dash {
|
|
29
|
+
0% { stroke-dasharray: 1px,200px; stroke-dashoffset: 0; }
|
|
30
|
+
50% { stroke-dasharray: 100px,200px; stroke-dashoffset: -15px; }
|
|
31
|
+
100% { stroke-dasharray: 100px,200px; stroke-dashoffset: -125px; }
|
|
32
|
+
}
|
|
33
|
+
`;
|
|
34
|
+
export function CircularProgress(props) {
|
|
35
|
+
injectCSS("hu-circular-progress", CSS);
|
|
36
|
+
const { variant = "indeterminate", color = "primary", size = 40, thickness = 3.6, showLabel, value = 0 } = props;
|
|
37
|
+
const radius = (size - thickness) / 2;
|
|
38
|
+
const circumference = 2 * Math.PI * radius;
|
|
39
|
+
const dashOffset = variant === "determinate" ? circumference * (1 - value / 100) : undefined;
|
|
40
|
+
return h("span", {
|
|
41
|
+
class: cn("hu-circular-progress", `hu-circular-progress--${variant}`, `hu-circular-progress--${color}`, showLabel && "hu-circular-progress--with-label", props.class),
|
|
42
|
+
role: "progressbar",
|
|
43
|
+
"aria-valuenow": variant === "determinate" ? value : undefined,
|
|
44
|
+
"aria-valuemin": variant === "determinate" ? "0" : undefined,
|
|
45
|
+
"aria-valuemax": variant === "determinate" ? "100" : undefined,
|
|
46
|
+
style: `width:${size}px;height:${size}px;`
|
|
47
|
+
}, h("svg", { class: "hu-circular-progress__svg", viewBox: `${size / 2} ${size / 2} ${size} ${size}`, style: `width:${size}px;height:${size}px;` }, variant === "determinate" && h("circle", {
|
|
48
|
+
class: "hu-circular-progress__track",
|
|
49
|
+
cx: size, cy: size, r: radius,
|
|
50
|
+
fill: "none", "stroke-width": thickness
|
|
51
|
+
}), h("circle", {
|
|
52
|
+
class: "hu-circular-progress__circle",
|
|
53
|
+
cx: size, cy: size, r: radius,
|
|
54
|
+
fill: "none", stroke: "currentColor", "stroke-width": thickness,
|
|
55
|
+
"stroke-dasharray": variant === "determinate" ? `${circumference}px` : undefined,
|
|
56
|
+
"stroke-dashoffset": dashOffset !== undefined ? `${dashOffset}px` : undefined
|
|
57
|
+
})), showLabel && variant === "determinate" && h("span", { class: "hu-circular-progress__label" }, `${Math.round(value)}%`));
|
|
58
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { type VNode } from "../../theme/index.js";
|
|
2
|
+
export interface ClickAwayListenerProps {
|
|
3
|
+
disabled?: boolean;
|
|
4
|
+
mouseEvent?: "mousedown" | "mouseup" | "click";
|
|
5
|
+
touchEvent?: "touchstart" | "touchend";
|
|
6
|
+
onClickAway: (event: Event) => void;
|
|
7
|
+
class?: string;
|
|
8
|
+
children?: unknown;
|
|
9
|
+
}
|
|
10
|
+
export declare function ClickAwayListener(props: ClickAwayListenerProps): VNode;
|
|
11
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/ClickAwayListener/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAK,KAAK,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAErD,MAAM,WAAW,sBAAsB;IACrC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,UAAU,CAAC,EAAE,WAAW,GAAG,SAAS,GAAG,OAAO,CAAC;IAC/C,UAAU,CAAC,EAAE,YAAY,GAAG,UAAU,CAAC;IACvC,WAAW,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;IACpC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,wBAAgB,iBAAiB,CAAC,KAAK,EAAE,sBAAsB,GAAG,KAAK,CA8BtE"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { onCleanup, onMount } from "@hyperpackai/hyperion";
|
|
2
|
+
import { h } from "../../theme/index.js";
|
|
3
|
+
export function ClickAwayListener(props) {
|
|
4
|
+
let root = null;
|
|
5
|
+
if (typeof document !== "undefined" && !props.disabled) {
|
|
6
|
+
const handle = (event) => {
|
|
7
|
+
if (!root)
|
|
8
|
+
return;
|
|
9
|
+
const target = event.target;
|
|
10
|
+
if (target && root.contains(target))
|
|
11
|
+
return;
|
|
12
|
+
props.onClickAway(event);
|
|
13
|
+
};
|
|
14
|
+
onMount(() => {
|
|
15
|
+
const mouseEvent = props.mouseEvent ?? "mousedown";
|
|
16
|
+
const touchEvent = props.touchEvent ?? "touchstart";
|
|
17
|
+
document.addEventListener(mouseEvent, handle, true);
|
|
18
|
+
document.addEventListener(touchEvent, handle, true);
|
|
19
|
+
});
|
|
20
|
+
onCleanup(() => {
|
|
21
|
+
const mouseEvent = props.mouseEvent ?? "mousedown";
|
|
22
|
+
const touchEvent = props.touchEvent ?? "touchstart";
|
|
23
|
+
document.removeEventListener(mouseEvent, handle, true);
|
|
24
|
+
document.removeEventListener(touchEvent, handle, true);
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
return h("div", {
|
|
28
|
+
class: props.class,
|
|
29
|
+
ref: (node) => { root = node; }
|
|
30
|
+
}, props.children);
|
|
31
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Code/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,KAAK,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAsCpE,MAAM,WAAW,SAAS;IACxB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,wBAAgB,IAAI,CAAC,KAAK,GAAE,SAAc,GAAG,KAAK,CAcjD"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { injectCSS, cn, h } from "../../theme/index.js";
|
|
2
|
+
const CODE_CSS = `
|
|
3
|
+
.hu-code {
|
|
4
|
+
font-family: var(--hu-font-mono);
|
|
5
|
+
color: var(--hu-code-fg, var(--hu-primary));
|
|
6
|
+
}
|
|
7
|
+
.hu-code--inline {
|
|
8
|
+
display: inline;
|
|
9
|
+
padding: 2px 6px;
|
|
10
|
+
border: 1px solid var(--hu-border);
|
|
11
|
+
border-radius: var(--hu-radius);
|
|
12
|
+
background: var(--hu-bg-2);
|
|
13
|
+
font-size: .88em;
|
|
14
|
+
}
|
|
15
|
+
.hu-code-block {
|
|
16
|
+
margin: 0;
|
|
17
|
+
max-width: 100%;
|
|
18
|
+
overflow: auto;
|
|
19
|
+
padding: var(--hu-space-4);
|
|
20
|
+
border: 1px solid var(--hu-border);
|
|
21
|
+
border-radius: var(--hu-radius-lg);
|
|
22
|
+
background: var(--hu-bg-2);
|
|
23
|
+
color: var(--hu-text);
|
|
24
|
+
font-family: var(--hu-font-mono);
|
|
25
|
+
font-size: var(--hu-font-size-sm);
|
|
26
|
+
line-height: 1.65;
|
|
27
|
+
white-space: pre;
|
|
28
|
+
scrollbar-width: thin;
|
|
29
|
+
}
|
|
30
|
+
.hu-code-block .hu-code {
|
|
31
|
+
color: inherit;
|
|
32
|
+
background: transparent;
|
|
33
|
+
border: 0;
|
|
34
|
+
padding: 0;
|
|
35
|
+
}
|
|
36
|
+
`;
|
|
37
|
+
export function Code(props = {}) {
|
|
38
|
+
injectCSS("hu-code", CODE_CSS);
|
|
39
|
+
const inline = props.inline ?? true;
|
|
40
|
+
const code = h("code", {
|
|
41
|
+
class: cn("hu-code", inline && "hu-code--inline", props.class),
|
|
42
|
+
"data-language": props.language
|
|
43
|
+
}, props.children);
|
|
44
|
+
if (inline)
|
|
45
|
+
return code;
|
|
46
|
+
return h("pre", {
|
|
47
|
+
class: "hu-code-block",
|
|
48
|
+
"data-language": props.language
|
|
49
|
+
}, code);
|
|
50
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { type VNode } from "../../theme/index.js";
|
|
2
|
+
export interface CollapseProps {
|
|
3
|
+
in: boolean;
|
|
4
|
+
orientation?: "vertical" | "horizontal";
|
|
5
|
+
timeout?: number;
|
|
6
|
+
unmountOnExit?: boolean;
|
|
7
|
+
class?: string;
|
|
8
|
+
children?: unknown;
|
|
9
|
+
}
|
|
10
|
+
export declare function Collapse(props: CollapseProps): VNode | null;
|
|
11
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Collapse/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,KAAK,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAqBpE,MAAM,WAAW,aAAa;IAC5B,EAAE,EAAE,OAAO,CAAC;IACZ,WAAW,CAAC,EAAE,UAAU,GAAG,YAAY,CAAC;IACxC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,wBAAgB,QAAQ,CAAC,KAAK,EAAE,aAAa,GAAG,KAAK,GAAG,IAAI,CAS3D"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { injectCSS, cn, h } from "../../theme/index.js";
|
|
2
|
+
const CSS = `
|
|
3
|
+
.hu-collapse {
|
|
4
|
+
display: grid;
|
|
5
|
+
overflow: hidden;
|
|
6
|
+
transition: grid-template-rows var(--hu-duration) cubic-bezier(.4,0,.2,1), opacity var(--hu-duration) var(--hu-ease);
|
|
7
|
+
}
|
|
8
|
+
.hu-collapse--in { grid-template-rows: 1fr; opacity: 1; }
|
|
9
|
+
.hu-collapse--out { grid-template-rows: 0fr; opacity: .35; pointer-events: none; }
|
|
10
|
+
.hu-collapse__inner { min-height: 0; overflow: hidden; }
|
|
11
|
+
.hu-collapse--orientation-horizontal {
|
|
12
|
+
display: inline-grid;
|
|
13
|
+
grid-template-rows: none;
|
|
14
|
+
transition: grid-template-columns var(--hu-duration) cubic-bezier(.4,0,.2,1), opacity var(--hu-duration) var(--hu-ease);
|
|
15
|
+
}
|
|
16
|
+
.hu-collapse--orientation-horizontal.hu-collapse--in { grid-template-columns: 1fr; }
|
|
17
|
+
.hu-collapse--orientation-horizontal.hu-collapse--out { grid-template-columns: 0fr; }
|
|
18
|
+
.hu-collapse--orientation-horizontal .hu-collapse__inner { min-width: 0; min-height: auto; }
|
|
19
|
+
`;
|
|
20
|
+
export function Collapse(props) {
|
|
21
|
+
injectCSS("hu-collapse", CSS);
|
|
22
|
+
const { in: isIn, orientation = "vertical", unmountOnExit, children } = props;
|
|
23
|
+
if (!isIn && unmountOnExit)
|
|
24
|
+
return null;
|
|
25
|
+
const style = props.timeout ? `transition-duration:${props.timeout}ms` : undefined;
|
|
26
|
+
return h("div", {
|
|
27
|
+
class: cn("hu-collapse", isIn ? "hu-collapse--in" : "hu-collapse--out", orientation === "horizontal" && "hu-collapse--orientation-horizontal", props.class),
|
|
28
|
+
style
|
|
29
|
+
}, h("div", { class: "hu-collapse__inner" }, children));
|
|
30
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { type VNode } from "../../theme/index.js";
|
|
2
|
+
export interface CommandPaletteItem {
|
|
3
|
+
id: string;
|
|
4
|
+
title: string;
|
|
5
|
+
description?: string;
|
|
6
|
+
section?: string;
|
|
7
|
+
keywords?: string[];
|
|
8
|
+
disabled?: boolean;
|
|
9
|
+
}
|
|
10
|
+
export interface CommandPaletteProps {
|
|
11
|
+
open: boolean;
|
|
12
|
+
items: CommandPaletteItem[];
|
|
13
|
+
query?: string;
|
|
14
|
+
title?: string;
|
|
15
|
+
placeholder?: string;
|
|
16
|
+
emptyText?: string;
|
|
17
|
+
activeId?: string;
|
|
18
|
+
shortcut?: string[];
|
|
19
|
+
class?: string;
|
|
20
|
+
onQueryChange?: (query: string) => void;
|
|
21
|
+
onSelect?: (item: CommandPaletteItem) => void;
|
|
22
|
+
onOpenChange?: (open: boolean) => void;
|
|
23
|
+
onClose?: () => void;
|
|
24
|
+
}
|
|
25
|
+
export declare function CommandPalette(props: CommandPaletteProps): VNode | null;
|
|
26
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/CommandPalette/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,KAAK,KAAK,EAAE,MAAM,sBAAsB,CAAC;AA0FpE,MAAM,WAAW,kBAAkB;IACjC,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IACpB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,WAAW,mBAAmB;IAClC,IAAI,EAAE,OAAO,CAAC;IACd,KAAK,EAAE,kBAAkB,EAAE,CAAC;IAC5B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACxC,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,kBAAkB,KAAK,IAAI,CAAC;IAC9C,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAC;IACvC,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;CACtB;AAUD,wBAAgB,cAAc,CAAC,KAAK,EAAE,mBAAmB,GAAG,KAAK,GAAG,IAAI,CA8DvE"}
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
import { injectCSS, cn, h } from "../../theme/index.js";
|
|
2
|
+
import { Modal } from "../Modal/index.js";
|
|
3
|
+
import { Input } from "../Input/index.js";
|
|
4
|
+
import { Kbd } from "../Kbd/index.js";
|
|
5
|
+
const COMMAND_PALETTE_CSS = `
|
|
6
|
+
.hu-command-palette {
|
|
7
|
+
width: min(680px, calc(100vw - 32px));
|
|
8
|
+
max-height: min(720px, calc(100vh - 64px));
|
|
9
|
+
overflow: hidden;
|
|
10
|
+
border: 1px solid var(--hu-border);
|
|
11
|
+
border-radius: var(--hu-radius-xl);
|
|
12
|
+
background: var(--hu-bg);
|
|
13
|
+
box-shadow: var(--hu-shadow-xl);
|
|
14
|
+
}
|
|
15
|
+
.hu-command-palette__header {
|
|
16
|
+
padding: var(--hu-space-4);
|
|
17
|
+
border-bottom: 1px solid var(--hu-border);
|
|
18
|
+
}
|
|
19
|
+
.hu-command-palette__title-row {
|
|
20
|
+
display: flex;
|
|
21
|
+
align-items: center;
|
|
22
|
+
justify-content: space-between;
|
|
23
|
+
gap: var(--hu-space-3);
|
|
24
|
+
margin-bottom: var(--hu-space-3);
|
|
25
|
+
}
|
|
26
|
+
.hu-command-palette__title {
|
|
27
|
+
margin: 0;
|
|
28
|
+
color: var(--hu-text);
|
|
29
|
+
font-size: var(--hu-font-size-md);
|
|
30
|
+
font-weight: var(--hu-font-weight-bold);
|
|
31
|
+
}
|
|
32
|
+
.hu-command-palette__hint {
|
|
33
|
+
display: flex;
|
|
34
|
+
align-items: center;
|
|
35
|
+
gap: var(--hu-space-2);
|
|
36
|
+
color: var(--hu-text-3);
|
|
37
|
+
font-size: var(--hu-font-size-xs);
|
|
38
|
+
}
|
|
39
|
+
.hu-command-palette__list {
|
|
40
|
+
max-height: 440px;
|
|
41
|
+
overflow-y: auto;
|
|
42
|
+
padding: var(--hu-space-2);
|
|
43
|
+
margin: 0;
|
|
44
|
+
list-style: none;
|
|
45
|
+
}
|
|
46
|
+
.hu-command-palette__item {
|
|
47
|
+
display: grid;
|
|
48
|
+
grid-template-columns: minmax(0, 1fr) auto;
|
|
49
|
+
gap: var(--hu-space-3);
|
|
50
|
+
align-items: center;
|
|
51
|
+
width: 100%;
|
|
52
|
+
padding: var(--hu-space-3);
|
|
53
|
+
border: 0;
|
|
54
|
+
border-radius: var(--hu-radius-lg);
|
|
55
|
+
background: transparent;
|
|
56
|
+
color: var(--hu-text);
|
|
57
|
+
text-align: left;
|
|
58
|
+
cursor: pointer;
|
|
59
|
+
}
|
|
60
|
+
.hu-command-palette__item:hover,
|
|
61
|
+
.hu-command-palette__item:focus-visible,
|
|
62
|
+
.hu-command-palette__item--active {
|
|
63
|
+
outline: none;
|
|
64
|
+
background: var(--hu-primary-bg);
|
|
65
|
+
}
|
|
66
|
+
.hu-command-palette__item-title {
|
|
67
|
+
display: block;
|
|
68
|
+
color: var(--hu-text);
|
|
69
|
+
font-size: var(--hu-font-size-sm);
|
|
70
|
+
font-weight: var(--hu-font-weight-semibold);
|
|
71
|
+
}
|
|
72
|
+
.hu-command-palette__item-description {
|
|
73
|
+
display: block;
|
|
74
|
+
margin-top: 2px;
|
|
75
|
+
color: var(--hu-text-2);
|
|
76
|
+
font-size: var(--hu-font-size-xs);
|
|
77
|
+
line-height: 1.45;
|
|
78
|
+
}
|
|
79
|
+
.hu-command-palette__item-section {
|
|
80
|
+
color: var(--hu-text-3);
|
|
81
|
+
font-size: var(--hu-font-size-xs);
|
|
82
|
+
}
|
|
83
|
+
.hu-command-palette__empty {
|
|
84
|
+
padding: var(--hu-space-8) var(--hu-space-4);
|
|
85
|
+
color: var(--hu-text-2);
|
|
86
|
+
text-align: center;
|
|
87
|
+
}
|
|
88
|
+
`;
|
|
89
|
+
function matchesItem(item, query) {
|
|
90
|
+
const needle = query.trim().toLowerCase();
|
|
91
|
+
if (!needle)
|
|
92
|
+
return true;
|
|
93
|
+
return [item.title, item.description, item.section, ...(item.keywords ?? [])]
|
|
94
|
+
.filter(Boolean)
|
|
95
|
+
.some((value) => String(value).toLowerCase().includes(needle));
|
|
96
|
+
}
|
|
97
|
+
export function CommandPalette(props) {
|
|
98
|
+
injectCSS("hu-command-palette", COMMAND_PALETTE_CSS);
|
|
99
|
+
const query = props.query ?? "";
|
|
100
|
+
const items = props.items.filter((item) => matchesItem(item, query));
|
|
101
|
+
const close = () => {
|
|
102
|
+
props.onOpenChange?.(false);
|
|
103
|
+
props.onClose?.();
|
|
104
|
+
};
|
|
105
|
+
return Modal({
|
|
106
|
+
open: props.open,
|
|
107
|
+
align: "top",
|
|
108
|
+
onClose: close,
|
|
109
|
+
onOpenChange: (open) => {
|
|
110
|
+
if (!open)
|
|
111
|
+
close();
|
|
112
|
+
else
|
|
113
|
+
props.onOpenChange?.(true);
|
|
114
|
+
},
|
|
115
|
+
children: h("section", {
|
|
116
|
+
class: cn("hu-command-palette", props.class),
|
|
117
|
+
role: "search",
|
|
118
|
+
"aria-label": props.title ?? "Command palette"
|
|
119
|
+
}, h("div", { class: "hu-command-palette__header" }, h("div", { class: "hu-command-palette__title-row" }, h("h2", { class: "hu-command-palette__title" }, props.title ?? "Command palette"), props.shortcut?.length ? h("span", { class: "hu-command-palette__hint" }, "Shortcut", Kbd({ keys: props.shortcut })) : undefined), Input({
|
|
120
|
+
value: query,
|
|
121
|
+
placeholder: props.placeholder ?? "Search commands...",
|
|
122
|
+
autoComplete: "off",
|
|
123
|
+
"aria-label": "Search commands",
|
|
124
|
+
onInput: (event) => props.onQueryChange?.(event.target.value),
|
|
125
|
+
onKeyDown: (event) => {
|
|
126
|
+
if (event.key === "Escape")
|
|
127
|
+
close();
|
|
128
|
+
}
|
|
129
|
+
})), items.length > 0
|
|
130
|
+
? h("ul", { class: "hu-command-palette__list", role: "listbox", "aria-label": "Command results" }, ...items.map((item) => h("li", { role: "option", "aria-selected": item.id === props.activeId ? "true" : "false" }, h("button", {
|
|
131
|
+
type: "button",
|
|
132
|
+
class: cn("hu-command-palette__item", item.id === props.activeId && "hu-command-palette__item--active"),
|
|
133
|
+
disabled: item.disabled,
|
|
134
|
+
onClick: () => {
|
|
135
|
+
if (!item.disabled)
|
|
136
|
+
props.onSelect?.(item);
|
|
137
|
+
}
|
|
138
|
+
}, h("span", {}, h("span", { class: "hu-command-palette__item-title" }, item.title), item.description ? h("span", { class: "hu-command-palette__item-description" }, item.description) : undefined), item.section ? h("span", { class: "hu-command-palette__item-section" }, item.section) : undefined))))
|
|
139
|
+
: h("div", { class: "hu-command-palette__empty", role: "status" }, props.emptyText ?? "No commands found"))
|
|
140
|
+
});
|
|
141
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { type VNode } from "../../theme/index.js";
|
|
2
|
+
export type ContainerMaxWidth = "xs" | "sm" | "md" | "lg" | "xl" | "fluid";
|
|
3
|
+
export interface ContainerProps {
|
|
4
|
+
maxWidth?: ContainerMaxWidth;
|
|
5
|
+
disableGutters?: boolean;
|
|
6
|
+
fixed?: boolean;
|
|
7
|
+
class?: string;
|
|
8
|
+
children?: unknown;
|
|
9
|
+
}
|
|
10
|
+
export declare function Container(props: ContainerProps): VNode;
|
|
11
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Container/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,KAAK,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAapE,MAAM,MAAM,iBAAiB,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,OAAO,CAAC;AAE3E,MAAM,WAAW,cAAc;IAC7B,QAAQ,CAAC,EAAE,iBAAiB,CAAC;IAC7B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,wBAAgB,SAAS,CAAC,KAAK,EAAE,cAAc,GAAG,KAAK,CAMtD"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { injectCSS, cn, h } from "../../theme/index.js";
|
|
2
|
+
const CONTAINER_CSS = `
|
|
3
|
+
.hu-container { width: 100%; margin-left: auto; margin-right: auto; padding-left: var(--hu-space-4); padding-right: var(--hu-space-4); box-sizing: border-box; }
|
|
4
|
+
.hu-container--xs { max-width: 444px; }
|
|
5
|
+
.hu-container--sm { max-width: 600px; }
|
|
6
|
+
.hu-container--md { max-width: 900px; }
|
|
7
|
+
.hu-container--lg { max-width: 1200px; }
|
|
8
|
+
.hu-container--xl { max-width: 1536px; }
|
|
9
|
+
.hu-container--fluid { max-width: 100%; }
|
|
10
|
+
.hu-container--disableGutters { padding-left: 0; padding-right: 0; }
|
|
11
|
+
`;
|
|
12
|
+
export function Container(props) {
|
|
13
|
+
injectCSS("hu-container", CONTAINER_CSS);
|
|
14
|
+
const { maxWidth = "lg", disableGutters } = props;
|
|
15
|
+
return h("div", {
|
|
16
|
+
class: cn("hu-container", `hu-container--${maxWidth}`, disableGutters && "hu-container--disableGutters", props.class)
|
|
17
|
+
}, props.children);
|
|
18
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { type VNode } from "../../theme/index.js";
|
|
2
|
+
export interface DashboardLayoutProps {
|
|
3
|
+
header?: unknown;
|
|
4
|
+
sidebar?: unknown;
|
|
5
|
+
aside?: unknown;
|
|
6
|
+
sidebarWidth?: string | number;
|
|
7
|
+
collapsedSidebarWidth?: string | number;
|
|
8
|
+
asideWidth?: string | number;
|
|
9
|
+
collapsed?: boolean;
|
|
10
|
+
padding?: string | number;
|
|
11
|
+
class?: string;
|
|
12
|
+
children?: unknown;
|
|
13
|
+
}
|
|
14
|
+
export declare function DashboardLayout(props: DashboardLayoutProps): VNode;
|
|
15
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/DashboardLayout/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,KAAK,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAsDpE,MAAM,WAAW,oBAAoB;IACnC,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,YAAY,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC/B,qBAAqB,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACxC,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC7B,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,wBAAgB,eAAe,CAAC,KAAK,EAAE,oBAAoB,GAAG,KAAK,CAsBlE"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { injectCSS, cn, h } from "../../theme/index.js";
|
|
2
|
+
const DASHBOARD_LAYOUT_CSS = `
|
|
3
|
+
.hu-dashboard-layout {
|
|
4
|
+
min-height: 100dvh; display: grid; color: var(--hu-text); background: var(--hu-bg-2);
|
|
5
|
+
grid-template-areas:
|
|
6
|
+
"sidebar header"
|
|
7
|
+
"sidebar main";
|
|
8
|
+
grid-template-columns: var(--hu-dashboard-sidebar, 280px) minmax(0, 1fr);
|
|
9
|
+
grid-template-rows: auto minmax(0, 1fr);
|
|
10
|
+
}
|
|
11
|
+
.hu-dashboard-layout--collapsed { grid-template-columns: var(--hu-dashboard-sidebar-collapsed, 72px) minmax(0, 1fr); }
|
|
12
|
+
.hu-dashboard-layout__header {
|
|
13
|
+
grid-area: header; min-width: 0; position: sticky; inset-block-start: 0;
|
|
14
|
+
z-index: var(--hu-z-sticky); background: var(--hu-bg);
|
|
15
|
+
border-block-end: 1px solid var(--hu-border);
|
|
16
|
+
}
|
|
17
|
+
.hu-dashboard-layout__sidebar {
|
|
18
|
+
grid-area: sidebar; min-width: 0; min-height: 0; overflow: auto;
|
|
19
|
+
background: var(--hu-bg); border-inline-end: 1px solid var(--hu-border);
|
|
20
|
+
}
|
|
21
|
+
.hu-dashboard-layout__main {
|
|
22
|
+
grid-area: main; min-width: 0; min-height: 0; overflow: auto;
|
|
23
|
+
padding: var(--hu-dashboard-padding, var(--hu-space-6));
|
|
24
|
+
}
|
|
25
|
+
.hu-dashboard-layout__aside {
|
|
26
|
+
border-inline-start: 1px solid var(--hu-border); background: var(--hu-bg);
|
|
27
|
+
min-width: 0; overflow: auto;
|
|
28
|
+
}
|
|
29
|
+
.hu-dashboard-layout--with-aside {
|
|
30
|
+
grid-template-areas:
|
|
31
|
+
"sidebar header header"
|
|
32
|
+
"sidebar main aside";
|
|
33
|
+
grid-template-columns: var(--hu-dashboard-sidebar, 280px) minmax(0, 1fr) var(--hu-dashboard-aside, 320px);
|
|
34
|
+
}
|
|
35
|
+
@media (max-width: 768px) {
|
|
36
|
+
.hu-dashboard-layout,
|
|
37
|
+
.hu-dashboard-layout--with-aside {
|
|
38
|
+
grid-template-areas:
|
|
39
|
+
"header"
|
|
40
|
+
"main";
|
|
41
|
+
grid-template-columns: minmax(0, 1fr);
|
|
42
|
+
grid-template-rows: auto minmax(0, 1fr);
|
|
43
|
+
}
|
|
44
|
+
.hu-dashboard-layout__sidebar,
|
|
45
|
+
.hu-dashboard-layout__aside { display: none; }
|
|
46
|
+
.hu-dashboard-layout__main { padding: var(--hu-space-4); }
|
|
47
|
+
}
|
|
48
|
+
`;
|
|
49
|
+
function toCssUnit(value) {
|
|
50
|
+
return typeof value === "number" ? `${value}px` : value;
|
|
51
|
+
}
|
|
52
|
+
export function DashboardLayout(props) {
|
|
53
|
+
injectCSS("hu-dashboard-layout", DASHBOARD_LAYOUT_CSS);
|
|
54
|
+
const styles = [];
|
|
55
|
+
if (props.sidebarWidth !== undefined)
|
|
56
|
+
styles.push(`--hu-dashboard-sidebar:${toCssUnit(props.sidebarWidth)}`);
|
|
57
|
+
if (props.collapsedSidebarWidth !== undefined)
|
|
58
|
+
styles.push(`--hu-dashboard-sidebar-collapsed:${toCssUnit(props.collapsedSidebarWidth)}`);
|
|
59
|
+
if (props.asideWidth !== undefined)
|
|
60
|
+
styles.push(`--hu-dashboard-aside:${toCssUnit(props.asideWidth)}`);
|
|
61
|
+
if (props.padding !== undefined)
|
|
62
|
+
styles.push(`--hu-dashboard-padding:${toCssUnit(props.padding)}`);
|
|
63
|
+
return h("div", {
|
|
64
|
+
class: cn("hu-dashboard-layout", props.collapsed && "hu-dashboard-layout--collapsed", props.aside != null && "hu-dashboard-layout--with-aside", props.class),
|
|
65
|
+
style: styles.join(";") || undefined
|
|
66
|
+
}, props.header && h("header", { class: "hu-dashboard-layout__header" }, props.header), props.sidebar && h("aside", { class: "hu-dashboard-layout__sidebar", "aria-label": "Primary navigation" }, props.sidebar), h("main", { class: "hu-dashboard-layout__main" }, props.children), props.aside && h("aside", { class: "hu-dashboard-layout__aside", "aria-label": "Secondary panel" }, props.aside));
|
|
67
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { type VNode } from "../../theme/index.js";
|
|
2
|
+
export interface TableColumn<T> {
|
|
3
|
+
key: string;
|
|
4
|
+
header: string;
|
|
5
|
+
width?: string;
|
|
6
|
+
sortable?: boolean;
|
|
7
|
+
render?: (row: T, i: number) => unknown;
|
|
8
|
+
align?: "left" | "center" | "right";
|
|
9
|
+
}
|
|
10
|
+
export interface DataTableProps<T extends Record<string, unknown>> {
|
|
11
|
+
columns: TableColumn<T>[];
|
|
12
|
+
rows: T[];
|
|
13
|
+
rowKey?: (row: T) => string;
|
|
14
|
+
sortColumn?: string;
|
|
15
|
+
sortDir?: "asc" | "desc";
|
|
16
|
+
onSort?: (key: string) => void;
|
|
17
|
+
onRowClick?: (row: T) => void;
|
|
18
|
+
emptyMessage?: string;
|
|
19
|
+
footer?: unknown;
|
|
20
|
+
selectable?: boolean;
|
|
21
|
+
selectedRows?: Set<string>;
|
|
22
|
+
onSelectRow?: (key: string, selected: boolean) => void;
|
|
23
|
+
onSelectAll?: (selected: boolean) => void;
|
|
24
|
+
class?: string;
|
|
25
|
+
}
|
|
26
|
+
export declare function DataTable<T extends Record<string, unknown>>(props: DataTableProps<T>): VNode;
|
|
27
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/DataTable/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,KAAK,KAAK,EAAE,MAAM,sBAAsB,CAAC;AA8BpE,MAAM,WAAW,WAAW,CAAC,CAAC;IAC5B,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC;IACxC,KAAK,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC;CACrC;AAED,MAAM,WAAW,cAAc,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAC/D,OAAO,EAAE,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC;IAC1B,IAAI,EAAE,CAAC,EAAE,CAAC;IACV,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,MAAM,CAAC;IAC5B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,KAAK,GAAG,MAAM,CAAC;IACzB,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI,CAAC;IAC/B,UAAU,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,CAAC;IAC9B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,YAAY,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IAC3B,WAAW,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,KAAK,IAAI,CAAC;IACvD,WAAW,CAAC,EAAE,CAAC,QAAQ,EAAE,OAAO,KAAK,IAAI,CAAC;IAC1C,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,wBAAgB,SAAS,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC,GAAG,KAAK,CAkE5F"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { injectCSS, cn, h } from "../../theme/index.js";
|
|
2
|
+
const TABLE_CSS = `
|
|
3
|
+
.hu-table-wrap {
|
|
4
|
+
overflow-x: auto; border-radius: var(--hu-radius-lg);
|
|
5
|
+
border: 1px solid color-mix(in srgb, var(--hu-border) 82%, transparent);
|
|
6
|
+
background: var(--hu-bg); box-shadow: var(--hu-shadow-sm);
|
|
7
|
+
}
|
|
8
|
+
.hu-table { width: 100%; border-collapse: separate; border-spacing: 0; font-size: var(--hu-font-size-sm); min-width: 560px; }
|
|
9
|
+
.hu-table th {
|
|
10
|
+
padding: 10px 16px; text-align: left; font-size: 11px; font-weight: var(--hu-font-weight-semibold);
|
|
11
|
+
color: var(--hu-text-3); text-transform: uppercase; letter-spacing: .05em;
|
|
12
|
+
background: linear-gradient(180deg, var(--hu-bg-2), color-mix(in srgb, var(--hu-bg-3) 70%, var(--hu-bg-2)));
|
|
13
|
+
border-bottom: 1px solid var(--hu-border);
|
|
14
|
+
white-space: nowrap;
|
|
15
|
+
}
|
|
16
|
+
.hu-table th.hu-table-sortable { cursor: pointer; user-select: none; }
|
|
17
|
+
.hu-table th.hu-table-sortable:hover { background: var(--hu-bg-3); color: var(--hu-text); }
|
|
18
|
+
.hu-table-sort-icon { display: inline-flex; align-items: center; margin-left: 4px; opacity: .4; vertical-align: middle; }
|
|
19
|
+
.hu-table-sort-icon--asc, .hu-table-sort-icon--desc { opacity: 1; color: var(--hu-primary); }
|
|
20
|
+
.hu-table td { padding: 12px 16px; border-bottom: 1px solid var(--hu-border); color: var(--hu-text); vertical-align: middle; background: var(--hu-bg); }
|
|
21
|
+
.hu-table tr:last-child td { border-bottom: none; }
|
|
22
|
+
.hu-table tbody tr { transition: background var(--hu-duration) var(--hu-ease); }
|
|
23
|
+
.hu-table tbody tr:hover td { background: color-mix(in srgb, var(--hu-primary-bg) 28%, var(--hu-bg-2)); }
|
|
24
|
+
.hu-table-empty { text-align: center; padding: var(--hu-space-12) var(--hu-space-6); color: var(--hu-text-3); }
|
|
25
|
+
.hu-table-footer { display: flex; align-items: center; justify-content: space-between; gap: var(--hu-space-3); flex-wrap: wrap; padding: var(--hu-space-3) var(--hu-space-4); border-top: 1px solid var(--hu-border); background: var(--hu-bg-2); font-size: var(--hu-font-size-xs); color: var(--hu-text-3); }
|
|
26
|
+
.hu-table-checkbox-col { width: 40px; padding-left: 16px !important; }
|
|
27
|
+
.hu-table input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--hu-primary); }
|
|
28
|
+
`;
|
|
29
|
+
export function DataTable(props) {
|
|
30
|
+
injectCSS("hu-table", TABLE_CSS);
|
|
31
|
+
const { columns, rows, rowKey, sortColumn, sortDir, onSort, onRowClick, emptyMessage = "No data available.", footer, selectable, selectedRows, onSelectRow, onSelectAll } = props;
|
|
32
|
+
const sortSVG = (dir) => dir === "asc"
|
|
33
|
+
? `<svg width="12" height="12" viewBox="0 0 12 12" fill="currentColor"><path d="M6 3l4 5H2l4-5z"/></svg>`
|
|
34
|
+
: dir === "desc"
|
|
35
|
+
? `<svg width="12" height="12" viewBox="0 0 12 12" fill="currentColor"><path d="M6 9L2 4h8L6 9z"/></svg>`
|
|
36
|
+
: `<svg width="12" height="12" viewBox="0 0 12 12" fill="currentColor" opacity=".4"><path d="M6 3l3 3H3l3-3zM6 9L3 6h6L6 9z"/></svg>`;
|
|
37
|
+
const allSelected = rows.length > 0 && rows.every((r) => selectedRows?.has(rowKey?.(r) ?? String(r["id"] ?? "")));
|
|
38
|
+
return h("div", { class: cn("hu-table-wrap", props.class) }, h("table", { class: "hu-table", role: "table" }, h("thead", {}, h("tr", {}, selectable && h("th", { class: "hu-table-checkbox-col" }, h("input", { type: "checkbox", checked: allSelected, onChange: (e) => onSelectAll?.(e.target.checked) })), ...columns.map((col) => h("th", {
|
|
39
|
+
key: col.key,
|
|
40
|
+
class: col.sortable ? "hu-table-sortable" : undefined,
|
|
41
|
+
style: [col.width && `width:${col.width}`, col.align && `text-align:${col.align}`].filter(Boolean).join(";"),
|
|
42
|
+
onClick: col.sortable ? () => onSort?.(col.key) : undefined
|
|
43
|
+
}, col.header, col.sortable && h("span", {
|
|
44
|
+
class: cn("hu-table-sort-icon", sortColumn === col.key && `hu-table-sort-icon--${sortDir}`),
|
|
45
|
+
innerHTML: sortSVG(sortColumn === col.key ? sortDir ?? "" : ""),
|
|
46
|
+
"aria-hidden": "true"
|
|
47
|
+
}))))), h("tbody", {}, rows.length === 0
|
|
48
|
+
? h("tr", {}, h("td", { colspan: columns.length + (selectable ? 1 : 0), class: "hu-table-empty" }, emptyMessage))
|
|
49
|
+
: rows.map((row, i) => {
|
|
50
|
+
const key = rowKey?.(row) ?? String(row["id"] ?? i);
|
|
51
|
+
return h("tr", {
|
|
52
|
+
key, style: onRowClick ? "cursor:pointer" : undefined,
|
|
53
|
+
onClick: onRowClick ? () => onRowClick(row) : undefined
|
|
54
|
+
}, selectable && h("td", { class: "hu-table-checkbox-col" }, h("input", {
|
|
55
|
+
type: "checkbox", checked: selectedRows?.has(key) ?? false,
|
|
56
|
+
onChange: (e) => { e.stopPropagation(); onSelectRow?.(key, e.target.checked); }
|
|
57
|
+
})), ...columns.map((col) => h("td", { key: col.key, style: col.align ? `text-align:${col.align}` : undefined }, col.render ? col.render(row, i) : row[col.key])));
|
|
58
|
+
}))), footer && h("div", { class: "hu-table-footer" }, footer));
|
|
59
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { type Signal } from "@hyperpackai/hyperion";
|
|
2
|
+
import { type VNode } from "../../theme/index.js";
|
|
3
|
+
export interface DialogProps {
|
|
4
|
+
open: boolean | Signal<boolean>;
|
|
5
|
+
onClose?: (reason?: "backdrop" | "escape" | "close-button") => void;
|
|
6
|
+
onOpenChange?: (open: boolean, reason?: "backdrop" | "escape" | "close-button") => void;
|
|
7
|
+
title?: string;
|
|
8
|
+
description?: string;
|
|
9
|
+
size?: "sm" | "md" | "lg" | "xl" | "full";
|
|
10
|
+
closeOnBackdrop?: boolean;
|
|
11
|
+
closeOnEscape?: boolean;
|
|
12
|
+
showClose?: boolean;
|
|
13
|
+
footer?: unknown;
|
|
14
|
+
footerAlign?: "start" | "end" | "between";
|
|
15
|
+
class?: string;
|
|
16
|
+
children?: unknown;
|
|
17
|
+
}
|
|
18
|
+
export declare function Dialog(props: DialogProps): VNode;
|
|
19
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Dialog/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,MAAM,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAoB,KAAK,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAsDpE,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC;IAChC,OAAO,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,UAAU,GAAG,QAAQ,GAAG,cAAc,KAAK,IAAI,CAAC;IACpE,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,OAAO,EAAE,MAAM,CAAC,EAAE,UAAU,GAAG,QAAQ,GAAG,cAAc,KAAK,IAAI,CAAC;IACxF,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,MAAM,CAAC;IAC1C,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,WAAW,CAAC,EAAE,OAAO,GAAG,KAAK,GAAG,SAAS,CAAC;IAC1C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,wBAAgB,MAAM,CAAC,KAAK,EAAE,WAAW,GAAG,KAAK,CAiEhD"}
|