@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,206 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* HyperUI Typography Components
|
|
3
|
+
* Typography · Chip · Divider · Link · AvatarGroup
|
|
4
|
+
*/
|
|
5
|
+
import { injectCSS, cn, h } from "../theme/index.js";
|
|
6
|
+
// ============================================================
|
|
7
|
+
// TYPOGRAPHY
|
|
8
|
+
// ============================================================
|
|
9
|
+
const TYPOGRAPHY_CSS = `
|
|
10
|
+
.hu-typography { margin: 0; color: var(--hu-text); font-family: var(--hu-font-sans); }
|
|
11
|
+
.hu-typography--h1 { font-size: var(--hu-font-size-5xl); font-weight: var(--hu-font-weight-bold); letter-spacing: -.025em; line-height: 1.1; }
|
|
12
|
+
.hu-typography--h2 { font-size: var(--hu-font-size-4xl); font-weight: var(--hu-font-weight-bold); letter-spacing: -.02em; line-height: 1.15; }
|
|
13
|
+
.hu-typography--h3 { font-size: var(--hu-font-size-3xl); font-weight: var(--hu-font-weight-semibold); letter-spacing: -.015em; line-height: 1.2; }
|
|
14
|
+
.hu-typography--h4 { font-size: var(--hu-font-size-2xl); font-weight: var(--hu-font-weight-semibold); line-height: 1.25; }
|
|
15
|
+
.hu-typography--h5 { font-size: var(--hu-font-size-xl); font-weight: var(--hu-font-weight-semibold); line-height: 1.3; }
|
|
16
|
+
.hu-typography--h6 { font-size: var(--hu-font-size-md); font-weight: var(--hu-font-weight-semibold); line-height: 1.4; }
|
|
17
|
+
.hu-typography--subtitle1 { font-size: var(--hu-font-size-base); font-weight: var(--hu-font-weight-medium); line-height: 1.6; }
|
|
18
|
+
.hu-typography--subtitle2 { font-size: var(--hu-font-size-sm); font-weight: var(--hu-font-weight-medium); line-height: 1.6; }
|
|
19
|
+
.hu-typography--body1 { font-size: var(--hu-font-size-base); line-height: 1.7; }
|
|
20
|
+
.hu-typography--body2 { font-size: var(--hu-font-size-sm); line-height: 1.65; }
|
|
21
|
+
.hu-typography--caption { font-size: var(--hu-font-size-xs); line-height: 1.5; color: var(--hu-text-2); }
|
|
22
|
+
.hu-typography--overline { font-size: 11px; font-weight: var(--hu-font-weight-semibold); letter-spacing: .1em; text-transform: uppercase; color: var(--hu-text-2); }
|
|
23
|
+
.hu-typography--inherit { font-size: inherit; font-weight: inherit; line-height: inherit; }
|
|
24
|
+
.hu-typography--gutterBottom { margin-bottom: .35em; }
|
|
25
|
+
.hu-typography--noWrap { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
|
|
26
|
+
.hu-typography--paragraph { margin-bottom: var(--hu-space-4); }
|
|
27
|
+
.hu-typography--color-primary { color: var(--hu-primary); }
|
|
28
|
+
.hu-typography--color-secondary { color: var(--hu-text-2); }
|
|
29
|
+
.hu-typography--color-error { color: var(--hu-error); }
|
|
30
|
+
.hu-typography--color-warning { color: var(--hu-warning); }
|
|
31
|
+
.hu-typography--color-info { color: var(--hu-info); }
|
|
32
|
+
.hu-typography--color-success { color: var(--hu-success); }
|
|
33
|
+
.hu-typography--align-left { text-align: left; }
|
|
34
|
+
.hu-typography--align-center { text-align: center; }
|
|
35
|
+
.hu-typography--align-right { text-align: right; }
|
|
36
|
+
.hu-typography--align-justify { text-align: justify; }
|
|
37
|
+
`;
|
|
38
|
+
const VARIANT_TAGS = {
|
|
39
|
+
h1: "h1", h2: "h2", h3: "h3", h4: "h4", h5: "h5", h6: "h6",
|
|
40
|
+
subtitle1: "h6", subtitle2: "h6",
|
|
41
|
+
body1: "p", body2: "p",
|
|
42
|
+
caption: "span", overline: "span", inherit: "span"
|
|
43
|
+
};
|
|
44
|
+
export function Typography(props) {
|
|
45
|
+
injectCSS("hu-typography", TYPOGRAPHY_CSS);
|
|
46
|
+
const { variant = "body1", color, align, gutterBottom, noWrap, paragraph, children } = props;
|
|
47
|
+
const tag = props.component ?? (paragraph ? "p" : VARIANT_TAGS[variant] ?? "span");
|
|
48
|
+
return h(tag, {
|
|
49
|
+
class: cn("hu-typography", `hu-typography--${variant}`, color && `hu-typography--color-${color}`, align && `hu-typography--align-${align}`, gutterBottom && "hu-typography--gutterBottom", noWrap && "hu-typography--noWrap", paragraph && "hu-typography--paragraph", props.class)
|
|
50
|
+
}, children);
|
|
51
|
+
}
|
|
52
|
+
// ============================================================
|
|
53
|
+
// CHIP
|
|
54
|
+
// ============================================================
|
|
55
|
+
const CHIP_CSS = `
|
|
56
|
+
.hu-chip {
|
|
57
|
+
display: inline-flex; align-items: center; gap: var(--hu-space-1);
|
|
58
|
+
font-size: var(--hu-font-size-xs); font-weight: var(--hu-font-weight-medium);
|
|
59
|
+
font-family: var(--hu-font-sans); border-radius: 9999px;
|
|
60
|
+
border: 1px solid transparent; white-space: nowrap;
|
|
61
|
+
user-select: none; transition: all var(--hu-duration) var(--hu-ease);
|
|
62
|
+
vertical-align: middle;
|
|
63
|
+
}
|
|
64
|
+
.hu-chip--sm { height: 24px; padding: 0 var(--hu-space-2); font-size: 11px; }
|
|
65
|
+
.hu-chip--md { height: 32px; padding: 0 var(--hu-space-3); }
|
|
66
|
+
.hu-chip--lg { height: 40px; padding: 0 var(--hu-space-4); font-size: var(--hu-font-size-sm); }
|
|
67
|
+
|
|
68
|
+
.hu-chip--filled-default { background: var(--hu-bg-3); color: var(--hu-text); border-color: var(--hu-border); }
|
|
69
|
+
.hu-chip--filled-primary { background: var(--hu-primary); color: var(--hu-primary-text); }
|
|
70
|
+
.hu-chip--filled-secondary { background: var(--hu-bg-4); color: var(--hu-text-2); border-color: var(--hu-border); }
|
|
71
|
+
.hu-chip--filled-error { background: var(--hu-error); color: #fff; }
|
|
72
|
+
.hu-chip--filled-warning { background: var(--hu-warning); color: #fff; }
|
|
73
|
+
.hu-chip--filled-info { background: var(--hu-info); color: #fff; }
|
|
74
|
+
.hu-chip--filled-success { background: var(--hu-success); color: #fff; }
|
|
75
|
+
|
|
76
|
+
.hu-chip--outlined-default { background: transparent; border-color: var(--hu-border); color: var(--hu-text); }
|
|
77
|
+
.hu-chip--outlined-primary { background: transparent; border-color: var(--hu-primary); color: var(--hu-primary); }
|
|
78
|
+
.hu-chip--outlined-error { background: transparent; border-color: var(--hu-error); color: var(--hu-error); }
|
|
79
|
+
.hu-chip--outlined-warning { background: transparent; border-color: var(--hu-warning); color: var(--hu-warning); }
|
|
80
|
+
.hu-chip--outlined-info { background: transparent; border-color: var(--hu-info); color: var(--hu-info); }
|
|
81
|
+
.hu-chip--outlined-success { background: transparent; border-color: var(--hu-success); color: var(--hu-success); }
|
|
82
|
+
|
|
83
|
+
.hu-chip--clickable { cursor: pointer; }
|
|
84
|
+
.hu-chip--clickable:hover { filter: brightness(.92); }
|
|
85
|
+
.hu-chip--clickable:active { transform: scale(.97); }
|
|
86
|
+
.hu-chip--disabled { opacity: .5; pointer-events: none; }
|
|
87
|
+
|
|
88
|
+
.hu-chip__avatar { width: 24px; height: 24px; border-radius: 50%; object-fit: cover; margin-left: -4px; }
|
|
89
|
+
.hu-chip__icon { width: 16px; height: 16px; flex-shrink: 0; }
|
|
90
|
+
.hu-chip__delete {
|
|
91
|
+
display: flex; align-items: center; justify-content: center;
|
|
92
|
+
width: 18px; height: 18px; border-radius: 50%; margin-right: -4px;
|
|
93
|
+
background: none; border: none; cursor: pointer; color: inherit; opacity: .7; padding: 0;
|
|
94
|
+
font-size: 14px; line-height: 1;
|
|
95
|
+
}
|
|
96
|
+
.hu-chip__delete:hover { opacity: 1; background: rgba(0,0,0,.1); }
|
|
97
|
+
`;
|
|
98
|
+
export function Chip(props) {
|
|
99
|
+
injectCSS("hu-chip", CHIP_CSS);
|
|
100
|
+
const { label, color = "default", variant = "filled", size = "md", icon, avatar, onDelete, onClick, disabled } = props;
|
|
101
|
+
return h("div", {
|
|
102
|
+
class: cn("hu-chip", `hu-chip--${size}`, `hu-chip--${variant}-${color}`, onClick && "hu-chip--clickable", disabled && "hu-chip--disabled", props.class),
|
|
103
|
+
onClick,
|
|
104
|
+
role: onClick ? "button" : undefined,
|
|
105
|
+
tabindex: onClick ? "0" : undefined
|
|
106
|
+
}, avatar && h("img", { class: "hu-chip__avatar", src: avatar, alt: "" }), icon && h("span", { class: "hu-chip__icon" }, icon), h("span", {}, label), onDelete && h("button", {
|
|
107
|
+
class: "hu-chip__delete",
|
|
108
|
+
onClick: (e) => { e.stopPropagation(); onDelete(); },
|
|
109
|
+
"aria-label": "delete"
|
|
110
|
+
}, "×"));
|
|
111
|
+
}
|
|
112
|
+
// ============================================================
|
|
113
|
+
// DIVIDER
|
|
114
|
+
// ============================================================
|
|
115
|
+
const DIVIDER_CSS = `
|
|
116
|
+
.hu-divider {
|
|
117
|
+
border: none; flex-shrink: 0;
|
|
118
|
+
}
|
|
119
|
+
.hu-divider--horizontal {
|
|
120
|
+
width: 100%; height: 1px; background: var(--hu-border); margin: var(--hu-space-2) 0;
|
|
121
|
+
}
|
|
122
|
+
.hu-divider--vertical {
|
|
123
|
+
width: 1px; height: auto; align-self: stretch; background: var(--hu-border); margin: 0 var(--hu-space-2);
|
|
124
|
+
display: inline-block;
|
|
125
|
+
}
|
|
126
|
+
.hu-divider--dashed { background: none; border-top: 1px dashed var(--hu-border); }
|
|
127
|
+
.hu-divider--vertical.hu-divider--dashed { border-top: none; border-left: 1px dashed var(--hu-border); }
|
|
128
|
+
|
|
129
|
+
.hu-divider--with-text {
|
|
130
|
+
display: flex; align-items: center; gap: var(--hu-space-3);
|
|
131
|
+
height: auto; background: none;
|
|
132
|
+
}
|
|
133
|
+
.hu-divider--with-text::before,
|
|
134
|
+
.hu-divider--with-text::after { content: ""; flex: 1; height: 1px; background: var(--hu-border); }
|
|
135
|
+
.hu-divider--with-text--left::before { flex: 0 0 16px; }
|
|
136
|
+
.hu-divider--with-text--right::after { flex: 0 0 16px; }
|
|
137
|
+
.hu-divider__text { font-size: var(--hu-font-size-xs); color: var(--hu-text-2); white-space: nowrap; font-weight: var(--hu-font-weight-medium); }
|
|
138
|
+
`;
|
|
139
|
+
export function Divider(props) {
|
|
140
|
+
injectCSS("hu-divider", DIVIDER_CSS);
|
|
141
|
+
const { orientation = "horizontal", textAlign = "center", dashed, children } = props;
|
|
142
|
+
if (children) {
|
|
143
|
+
return h("div", {
|
|
144
|
+
class: cn("hu-divider", "hu-divider--horizontal", "hu-divider--with-text", textAlign !== "center" && `hu-divider--with-text--${textAlign}`, props.class),
|
|
145
|
+
role: "separator"
|
|
146
|
+
}, h("span", { class: "hu-divider__text" }, children));
|
|
147
|
+
}
|
|
148
|
+
return h("hr", {
|
|
149
|
+
class: cn("hu-divider", `hu-divider--${orientation}`, dashed && "hu-divider--dashed", props.class),
|
|
150
|
+
role: "separator",
|
|
151
|
+
"aria-orientation": orientation
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
// ============================================================
|
|
155
|
+
// LINK
|
|
156
|
+
// ============================================================
|
|
157
|
+
const LINK_CSS = `
|
|
158
|
+
.hu-link {
|
|
159
|
+
color: var(--hu-primary); text-decoration: underline; text-underline-offset: 3px;
|
|
160
|
+
text-decoration-color: transparent; transition: all var(--hu-duration) var(--hu-ease);
|
|
161
|
+
cursor: pointer; font-family: var(--hu-font-sans);
|
|
162
|
+
}
|
|
163
|
+
.hu-link:hover { text-decoration-color: var(--hu-primary); }
|
|
164
|
+
.hu-link--inherit { color: inherit; }
|
|
165
|
+
.hu-link--secondary { color: var(--hu-text-2); }
|
|
166
|
+
.hu-link--error { color: var(--hu-error); }
|
|
167
|
+
.hu-link--underline-always { text-decoration-color: currentColor; }
|
|
168
|
+
.hu-link--underline-none { text-decoration: none; }
|
|
169
|
+
.hu-link--underline-none:hover { text-decoration: underline; text-underline-offset: 3px; }
|
|
170
|
+
`;
|
|
171
|
+
export function Link(props) {
|
|
172
|
+
injectCSS("hu-link", LINK_CSS);
|
|
173
|
+
const { href, target, rel, color = "primary", underline = "hover", component = "a", onClick, children } = props;
|
|
174
|
+
return h(component, {
|
|
175
|
+
class: cn("hu-link", color !== "primary" && `hu-link--${color}`, underline !== "hover" && `hu-link--underline-${underline}`, props.class),
|
|
176
|
+
href, target,
|
|
177
|
+
rel: target === "_blank" ? (rel ?? "noopener noreferrer") : rel,
|
|
178
|
+
onClick
|
|
179
|
+
}, children);
|
|
180
|
+
}
|
|
181
|
+
// ============================================================
|
|
182
|
+
// AVATAR GROUP
|
|
183
|
+
// ============================================================
|
|
184
|
+
const AVATAR_GROUP_CSS = `
|
|
185
|
+
.hu-avatar-group { display: flex; flex-direction: row-reverse; }
|
|
186
|
+
.hu-avatar-group .hu-avatar { margin-left: -8px; border: 2px solid var(--hu-bg); ring: none; }
|
|
187
|
+
.hu-avatar-group .hu-avatar:last-child { margin-left: 0; }
|
|
188
|
+
.hu-avatar-group__extra {
|
|
189
|
+
display: flex; align-items: center; justify-content: center;
|
|
190
|
+
border-radius: 50%; background: var(--hu-bg-3); border: 2px solid var(--hu-bg);
|
|
191
|
+
font-size: var(--hu-font-size-xs); font-weight: var(--hu-font-weight-semibold);
|
|
192
|
+
color: var(--hu-text-2); flex-shrink: 0; margin-left: -8px;
|
|
193
|
+
}
|
|
194
|
+
`;
|
|
195
|
+
const AVATAR_SIZES = { sm: "24px", md: "32px", lg: "40px", xl: "48px" };
|
|
196
|
+
export function AvatarGroup(props) {
|
|
197
|
+
injectCSS("hu-avatar-group", AVATAR_GROUP_CSS);
|
|
198
|
+
const { max = 5, size = "md", children = [] } = props;
|
|
199
|
+
const sz = AVATAR_SIZES[size] ?? "32px";
|
|
200
|
+
const visible = children.slice(0, max);
|
|
201
|
+
const extra = children.length - max;
|
|
202
|
+
return h("div", { class: cn("hu-avatar-group", props.class) }, ...visible, extra > 0 && h("div", {
|
|
203
|
+
class: "hu-avatar-group__extra",
|
|
204
|
+
style: `width:${sz};height:${sz};`
|
|
205
|
+
}, `+${extra}`));
|
|
206
|
+
}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @hyperpackai/hyperui — Rich, accessible, enterprise-grade UI component library
|
|
3
|
+
* for Hyperion applications. Framework-agnostic, zero external dependencies.
|
|
4
|
+
*
|
|
5
|
+
* Quick start:
|
|
6
|
+
* import { initHyperUI, Button, Dialog, DataTable } from "@hyperpackai/hyperui";
|
|
7
|
+
* import { applyTheme, createTheme, tokens, useTokens } from "@hyperpackai/hyperui/tokens";
|
|
8
|
+
* initHyperUI({ theme: "system" });
|
|
9
|
+
*/
|
|
10
|
+
export { initHyperUI, injectCSS, cn, h } from "./theme/index.js";
|
|
11
|
+
export type { HyperUIConfig, VNode } from "./theme/index.js";
|
|
12
|
+
export { tokens, primitives, applyTheme, createTheme, setColorMode, ThemeProvider, useTheme, useTokens, getCSSVar, tokenToCSS, exportTokens, getAllCSSVars, themes, getDarkVariant, lightSemanticTokens, darkSemanticTokens, defaultComponentTokens } from "./tokens/index.js";
|
|
13
|
+
export type { FullTokens, ThemeInput, ColorMode, ThemeOverrides, BuiltinTheme, ThemeDirection, ThemeDensity, ThemeProviderProps, ThemeState, SemanticTokens, SemanticColors, ComponentTokens, ButtonTokens, InputTokens, CardTokens } from "./tokens/index.js";
|
|
14
|
+
export * from "./components/index.js";
|
|
15
|
+
export * from "./components/ai.js";
|
|
16
|
+
export * from "./components/charts.js";
|
|
17
|
+
export * from "./components/data.js";
|
|
18
|
+
export * from "./components/date.js";
|
|
19
|
+
export * from "./components/enterprise.js";
|
|
20
|
+
export * from "./components/form.js";
|
|
21
|
+
export { ColorPicker, Dropzone, FileUpload, OTPInput, PinInput } from "./components/form.js";
|
|
22
|
+
export type { ColorPickerProps, DropzoneProps, FileUploadFile, FileUploadProps, OTPInputProps, PinInputProps } from "./components/form.js";
|
|
23
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAGH,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC,EAAE,MAAM,kBAAkB,CAAC;AACjE,YAAY,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAG7D,OAAO,EACL,MAAM,EAAE,UAAU,EAClB,UAAU,EAAE,WAAW,EAAE,YAAY,EACrC,aAAa,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAE,aAAa,EACtF,MAAM,EAAE,cAAc,EACtB,mBAAmB,EAAE,kBAAkB,EACvC,sBAAsB,EACvB,MAAM,mBAAmB,CAAC;AAC3B,YAAY,EACV,UAAU,EAAE,UAAU,EAAE,SAAS,EAAE,cAAc,EAAE,YAAY,EAC/D,cAAc,EAAE,YAAY,EAAE,kBAAkB,EAAE,UAAU,EAC5D,cAAc,EAAE,cAAc,EAAE,eAAe,EAC/C,YAAY,EAAE,WAAW,EAAE,UAAU,EACtC,MAAM,mBAAmB,CAAC;AAO3B,cAAc,uBAAuB,CAAC;AAItC,cAAc,oBAAoB,CAAC;AACnC,cAAc,wBAAwB,CAAC;AACvC,cAAc,sBAAsB,CAAC;AACrC,cAAc,sBAAsB,CAAC;AACrC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,sBAAsB,CAAC;AACrC,OAAO,EACL,WAAW,EACX,QAAQ,EACR,UAAU,EACV,QAAQ,EACR,QAAQ,EACT,MAAM,sBAAsB,CAAC;AAC9B,YAAY,EACV,gBAAgB,EAChB,aAAa,EACb,cAAc,EACd,eAAe,EACf,aAAa,EACb,aAAa,EACd,MAAM,sBAAsB,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @hyperpackai/hyperui — Rich, accessible, enterprise-grade UI component library
|
|
3
|
+
* for Hyperion applications. Framework-agnostic, zero external dependencies.
|
|
4
|
+
*
|
|
5
|
+
* Quick start:
|
|
6
|
+
* import { initHyperUI, Button, Dialog, DataTable } from "@hyperpackai/hyperui";
|
|
7
|
+
* import { applyTheme, createTheme, tokens, useTokens } from "@hyperpackai/hyperui/tokens";
|
|
8
|
+
* initHyperUI({ theme: "system" });
|
|
9
|
+
*/
|
|
10
|
+
// Theme system (CSS injection engine + initHyperUI)
|
|
11
|
+
export { initHyperUI, injectCSS, cn, h } from "./theme/index.js";
|
|
12
|
+
// Design token system
|
|
13
|
+
export { tokens, primitives, applyTheme, createTheme, setColorMode, ThemeProvider, useTheme, useTokens, getCSSVar, tokenToCSS, exportTokens, getAllCSSVars, themes, getDarkVariant, lightSemanticTokens, darkSemanticTokens, defaultComponentTokens } from "./tokens/index.js";
|
|
14
|
+
// All UI components — re-export the entire component barrel so every
|
|
15
|
+
// component (including SpeedDial, Menu, AppBar, Modal, Drawer, Backdrop,
|
|
16
|
+
// BottomNavigation, MobileStepper, Circular/LinearProgress, transitions,
|
|
17
|
+
// etc.) is available from the package root. Using `export *` keeps this
|
|
18
|
+
// in sync automatically as new components are added to the barrel.
|
|
19
|
+
export * from "./components/index.js";
|
|
20
|
+
// Specialist component files (AI, charts, data grid, date pickers, enterprise,
|
|
21
|
+
// advanced forms) — these export distinct symbols with no overlap.
|
|
22
|
+
export * from "./components/ai.js";
|
|
23
|
+
export * from "./components/charts.js";
|
|
24
|
+
export * from "./components/data.js";
|
|
25
|
+
export * from "./components/date.js";
|
|
26
|
+
export * from "./components/enterprise.js";
|
|
27
|
+
export * from "./components/form.js";
|
|
28
|
+
export { ColorPicker, Dropzone, FileUpload, OTPInput, PinInput } from "./components/form.js";
|
|
29
|
+
// All component prop/variant types flow through `export *` from the barrel above.
|
package/dist/portal.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"portal.d.ts","sourceRoot":"","sources":["../src/portal.ts"],"names":[],"mappings":"AACA,OAAO,EAAK,KAAK,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAIjD,wBAAgB,cAAc,CAAC,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,GAAG,KAAK,CAgBtE"}
|
package/dist/portal.js
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { createPortal, onCleanup } from "@hyperpackai/hyperion";
|
|
2
|
+
import { h } from "./theme/index.js";
|
|
3
|
+
let portalId = 0;
|
|
4
|
+
export function renderInPortal(children, layer) {
|
|
5
|
+
if (typeof document === "undefined" || !document.body) {
|
|
6
|
+
return h("span", { "data-hu-portal": layer }, children);
|
|
7
|
+
}
|
|
8
|
+
const root = document.createElement("div");
|
|
9
|
+
root.className = "hu-portal-root";
|
|
10
|
+
root.dataset.huPortal = layer;
|
|
11
|
+
root.dataset.huPortalId = String(++portalId);
|
|
12
|
+
document.body.appendChild(root);
|
|
13
|
+
onCleanup(() => {
|
|
14
|
+
root.remove();
|
|
15
|
+
});
|
|
16
|
+
return createPortal(children, root);
|
|
17
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* HyperUI Design System
|
|
3
|
+
*
|
|
4
|
+
* All component styles flow from CSS custom properties defined here.
|
|
5
|
+
* Override any token to customise the entire system — no build step needed.
|
|
6
|
+
*
|
|
7
|
+
* document.documentElement.style.setProperty("--hu-primary", "#7c3aed");
|
|
8
|
+
*/
|
|
9
|
+
export declare function injectCSS(id: string, css: string): void;
|
|
10
|
+
export declare const BASE_CSS = "\n/* ------------------------------------------------------------------ */\n/* HyperUI Design Tokens */\n/* ------------------------------------------------------------------ */\n:root {\n /* Radius */\n --hu-radius-xs: 3px;\n --hu-radius-sm: 5px;\n --hu-radius: 8px;\n --hu-radius-md: 10px;\n --hu-radius-lg: 14px;\n --hu-radius-xl: 20px;\n --hu-radius-full: 9999px;\n\n /* Spacing (4-pt grid) */\n --hu-space-1: 4px;\n --hu-space-2: 8px;\n --hu-space-3: 12px;\n --hu-space-4: 16px;\n --hu-space-5: 20px;\n --hu-space-6: 24px;\n --hu-space-8: 32px;\n --hu-space-10: 40px;\n --hu-space-12: 48px;\n --hu-space-16: 64px;\n\n /* Typography */\n --hu-font-sans: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, \"Helvetica Neue\", Arial, sans-serif;\n --hu-font-mono: ui-monospace, SFMono-Regular, Menlo, Consolas, \"Liberation Mono\", monospace;\n --hu-font-size-xs: 11px;\n --hu-font-size-sm: 13px;\n --hu-font-size-base: 14px;\n --hu-font-size-md: 15px;\n --hu-font-size-lg: 18px;\n --hu-font-size-xl: 22px;\n --hu-font-size-2xl: 28px;\n --hu-font-size-3xl: 36px;\n --hu-line-height: 1.5;\n --hu-font-weight-normal: 400;\n --hu-font-weight-medium: 500;\n --hu-font-weight-semibold: 600;\n --hu-font-weight-bold: 700;\n\n /* Colours \u2014 Light */\n --hu-bg: #ffffff;\n --hu-bg-2: #f8fafc;\n --hu-bg-3: #f1f5f9;\n --hu-bg-4: #e8edf5;\n --hu-border: #e2e8f0;\n --hu-border-2: #cbd5e1;\n --hu-text: #0f172a;\n --hu-text-2: #475569;\n --hu-text-3: #94a3b8;\n --hu-text-inv: #ffffff;\n\n /* Primary \u2014 Indigo */\n --hu-primary: #6366f1;\n --hu-primary-dk: #4f46e5;\n --hu-primary-lt: #818cf8;\n --hu-primary-bg: #eef2ff;\n --hu-primary-text: #ffffff;\n\n /* Semantic */\n --hu-success: #22c55e;\n --hu-success-bg: #f0fdf4;\n --hu-success-text:#15803d;\n --hu-warning: #f59e0b;\n --hu-warning-bg: #fffbeb;\n --hu-warning-text:#92400e;\n --hu-error: #ef4444;\n --hu-error-bg: #fef2f2;\n --hu-error-text: #b91c1c;\n --hu-info: #3b82f6;\n --hu-info-bg: #eff6ff;\n --hu-info-text: #1d4ed8;\n\n /* Shadows */\n --hu-shadow-xs: 0 1px 2px rgb(0 0 0/6%);\n --hu-shadow-sm: 0 1px 3px rgb(0 0 0/8%), 0 1px 2px rgb(0 0 0/4%);\n --hu-shadow: 0 4px 6px -1px rgb(0 0 0/8%), 0 2px 4px -2px rgb(0 0 0/4%);\n --hu-shadow-md: 0 10px 15px -3px rgb(0 0 0/8%), 0 4px 6px -4px rgb(0 0 0/4%);\n --hu-shadow-lg: 0 20px 25px -5px rgb(0 0 0/8%), 0 8px 10px -6px rgb(0 0 0/4%);\n --hu-shadow-xl: 0 25px 50px -12px rgb(0 0 0/20%);\n\n /* Overlays */\n --hu-overlay: rgb(0 0 0/50%);\n\n /* Transitions */\n --hu-duration-fast: 100ms;\n --hu-duration: 150ms;\n --hu-duration-slow: 250ms;\n --hu-ease: cubic-bezier(0.4, 0, 0.2, 1);\n --hu-ease-in: cubic-bezier(0.4, 0, 1, 1);\n --hu-ease-out: cubic-bezier(0, 0, 0.2, 1);\n --hu-ease-spring: cubic-bezier(0.175, 0.885, 0.32, 1.275);\n\n /* Z-index */\n --hu-z-dropdown: 1000;\n --hu-z-sticky: 1020;\n --hu-z-fixed: 1030;\n --hu-z-backdrop: 1040;\n --hu-z-modal: 1050;\n --hu-z-popover: 1060;\n --hu-z-tooltip: 1070;\n --hu-z-toast: 1080;\n}\n\n/* Dark mode */\n[data-theme=\"dark\"], .hu-dark {\n --hu-bg: #0a0a0f;\n --hu-bg-2: #111118;\n --hu-bg-3: #1a1a24;\n --hu-bg-4: #22222f;\n --hu-border: #2a2a38;\n --hu-border-2: #3a3a4a;\n --hu-text: #f0f0ff;\n --hu-text-2: #a0a0c0;\n --hu-text-3: #606080;\n --hu-text-inv: #0a0a0f;\n\n --hu-primary: #818cf8;\n --hu-primary-dk: #6366f1;\n --hu-primary-lt: #a5b4fc;\n --hu-primary-bg: #1e1b4b30;\n --hu-primary-text: #ffffff;\n\n --hu-success: #4ade80;\n --hu-success-bg: #052e16;\n --hu-success-text:#86efac;\n --hu-warning: #fbbf24;\n --hu-warning-bg: #1c1500;\n --hu-warning-text:#fde68a;\n --hu-error: #f87171;\n --hu-error-bg: #1f0505;\n --hu-error-text: #fca5a5;\n --hu-info: #60a5fa;\n --hu-info-bg: #030d1a;\n --hu-info-text: #93c5fd;\n\n --hu-shadow-xs: 0 1px 2px rgb(0 0 0/30%);\n --hu-shadow-sm: 0 1px 3px rgb(0 0 0/40%), 0 1px 2px rgb(0 0 0/24%);\n --hu-shadow: 0 4px 6px -1px rgb(0 0 0/40%), 0 2px 4px -2px rgb(0 0 0/24%);\n --hu-shadow-md: 0 10px 15px -3px rgb(0 0 0/40%), 0 4px 6px -4px rgb(0 0 0/24%);\n --hu-shadow-lg: 0 20px 25px -5px rgb(0 0 0/40%), 0 8px 10px -6px rgb(0 0 0/24%);\n --hu-shadow-xl: 0 25px 50px -12px rgb(0 0 0/60%);\n\n --hu-overlay: rgb(0 0 0/70%);\n}\n\n/* Base reset */\n*, *::before, *::after { box-sizing: border-box; }\n[data-hu-root] {\n font-family: var(--hu-font-sans);\n font-size: var(--hu-font-size-base);\n line-height: var(--hu-line-height);\n color: var(--hu-text);\n background: var(--hu-bg);\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n\n/* Focus ring */\n.hu-focus:focus-visible {\n outline: 2px solid var(--hu-primary);\n outline-offset: 2px;\n}\n\n/* Screen-reader only */\n.hu-sr-only {\n position: absolute; width: 1px; height: 1px; padding: 0;\n margin: -1px; overflow: hidden; clip: rect(0,0,0,0);\n white-space: nowrap; border: 0;\n}\n\n/* Animations */\n@keyframes hu-spin { to { transform: rotate(360deg); } }\n@keyframes hu-pulse { 0%,100%{opacity:1} 50%{opacity:.5} }\n@keyframes hu-ping { 75%,100%{transform:scale(2);opacity:0} }\n@keyframes hu-bounce { 0%,100%{transform:translateY(-25%);animation-timing-function:cubic-bezier(.8,0,1,1)} 50%{transform:none;animation-timing-function:cubic-bezier(0,0,.2,1)} }\n@keyframes hu-fade-in { from{opacity:0} to{opacity:1} }\n@keyframes hu-fade-out { from{opacity:1} to{opacity:0} }\n@keyframes hu-slide-up { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }\n@keyframes hu-slide-down { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:translateY(0)} }\n@keyframes hu-slide-in-right { from{opacity:0;transform:translateX(100%)} to{opacity:1;transform:translateX(0)} }\n@keyframes hu-slide-in-left { from{opacity:0;transform:translateX(-100%)} to{opacity:1;transform:translateX(0)} }\n@keyframes hu-scale-in { from{opacity:0;transform:scale(.95)} to{opacity:1;transform:scale(1)} }\n@keyframes hu-shimmer { from{background-position:-200% 0} to{background-position:200% 0} }\n";
|
|
11
|
+
export interface HyperUIConfig {
|
|
12
|
+
theme?: "light" | "dark" | "system";
|
|
13
|
+
primaryColor?: string;
|
|
14
|
+
radius?: string;
|
|
15
|
+
fontFamily?: string;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Initialises HyperUI — injects base CSS tokens and optionally applies
|
|
19
|
+
* theme overrides. Call once at app startup before rendering.
|
|
20
|
+
*
|
|
21
|
+
* initHyperUI({ theme: "system", primaryColor: "#7c3aed" });
|
|
22
|
+
*/
|
|
23
|
+
export declare function initHyperUI(config?: HyperUIConfig): void;
|
|
24
|
+
export declare function cn(...classes: (string | false | null | undefined)[]): string;
|
|
25
|
+
export interface VNode {
|
|
26
|
+
type: string | symbol | ((...args: unknown[]) => unknown);
|
|
27
|
+
props: Record<string, unknown>;
|
|
28
|
+
children: unknown[];
|
|
29
|
+
}
|
|
30
|
+
export declare function h(type: VNode["type"], props: Record<string, unknown> | null, ...children: unknown[]): VNode;
|
|
31
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/theme/index.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAQH,wBAAgB,SAAS,CAAC,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,IAAI,CAOvD;AAMD,eAAO,MAAM,QAAQ,i1MA2LpB,CAAC;AAMF,MAAM,WAAW,aAAa;IAC5B,KAAK,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,QAAQ,CAAC;IACpC,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED;;;;;GAKG;AACH,wBAAgB,WAAW,CAAC,MAAM,GAAE,aAAkB,GAAG,IAAI,CA8B5D;AAMD,wBAAgB,EAAE,CAAC,GAAG,OAAO,EAAE,CAAC,MAAM,GAAG,KAAK,GAAG,IAAI,GAAG,SAAS,CAAC,EAAE,GAAG,MAAM,CAE5E;AAMD,MAAM,WAAW,KAAK;IACpB,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,CAAC,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,OAAO,CAAC,CAAC;IAC1D,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC/B,QAAQ,EAAE,OAAO,EAAE,CAAC;CACrB;AAED,wBAAgB,CAAC,CACf,IAAI,EAAE,KAAK,CAAC,MAAM,CAAC,EACnB,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,EACrC,GAAG,QAAQ,EAAE,OAAO,EAAE,GACrB,KAAK,CAIP"}
|
|
@@ -0,0 +1,258 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* HyperUI Design System
|
|
3
|
+
*
|
|
4
|
+
* All component styles flow from CSS custom properties defined here.
|
|
5
|
+
* Override any token to customise the entire system — no build step needed.
|
|
6
|
+
*
|
|
7
|
+
* document.documentElement.style.setProperty("--hu-primary", "#7c3aed");
|
|
8
|
+
*/
|
|
9
|
+
// ---------------------------------------------------------------------------
|
|
10
|
+
// CSS injection engine — each style block is injected at most once
|
|
11
|
+
// ---------------------------------------------------------------------------
|
|
12
|
+
const _injected = new Set();
|
|
13
|
+
export function injectCSS(id, css) {
|
|
14
|
+
if (typeof document === "undefined" || _injected.has(id))
|
|
15
|
+
return;
|
|
16
|
+
const el = document.createElement("style");
|
|
17
|
+
el.setAttribute("data-hu", id);
|
|
18
|
+
el.textContent = css;
|
|
19
|
+
document.head.appendChild(el);
|
|
20
|
+
_injected.add(id);
|
|
21
|
+
}
|
|
22
|
+
// ---------------------------------------------------------------------------
|
|
23
|
+
// Base reset + design tokens (inject once via initHyperUI)
|
|
24
|
+
// ---------------------------------------------------------------------------
|
|
25
|
+
export const BASE_CSS = `
|
|
26
|
+
/* ------------------------------------------------------------------ */
|
|
27
|
+
/* HyperUI Design Tokens */
|
|
28
|
+
/* ------------------------------------------------------------------ */
|
|
29
|
+
:root {
|
|
30
|
+
/* Radius */
|
|
31
|
+
--hu-radius-xs: 3px;
|
|
32
|
+
--hu-radius-sm: 5px;
|
|
33
|
+
--hu-radius: 8px;
|
|
34
|
+
--hu-radius-md: 10px;
|
|
35
|
+
--hu-radius-lg: 14px;
|
|
36
|
+
--hu-radius-xl: 20px;
|
|
37
|
+
--hu-radius-full: 9999px;
|
|
38
|
+
|
|
39
|
+
/* Spacing (4-pt grid) */
|
|
40
|
+
--hu-space-1: 4px;
|
|
41
|
+
--hu-space-2: 8px;
|
|
42
|
+
--hu-space-3: 12px;
|
|
43
|
+
--hu-space-4: 16px;
|
|
44
|
+
--hu-space-5: 20px;
|
|
45
|
+
--hu-space-6: 24px;
|
|
46
|
+
--hu-space-8: 32px;
|
|
47
|
+
--hu-space-10: 40px;
|
|
48
|
+
--hu-space-12: 48px;
|
|
49
|
+
--hu-space-16: 64px;
|
|
50
|
+
|
|
51
|
+
/* Typography */
|
|
52
|
+
--hu-font-sans: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
|
|
53
|
+
--hu-font-mono: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
|
|
54
|
+
--hu-font-size-xs: 11px;
|
|
55
|
+
--hu-font-size-sm: 13px;
|
|
56
|
+
--hu-font-size-base: 14px;
|
|
57
|
+
--hu-font-size-md: 15px;
|
|
58
|
+
--hu-font-size-lg: 18px;
|
|
59
|
+
--hu-font-size-xl: 22px;
|
|
60
|
+
--hu-font-size-2xl: 28px;
|
|
61
|
+
--hu-font-size-3xl: 36px;
|
|
62
|
+
--hu-line-height: 1.5;
|
|
63
|
+
--hu-font-weight-normal: 400;
|
|
64
|
+
--hu-font-weight-medium: 500;
|
|
65
|
+
--hu-font-weight-semibold: 600;
|
|
66
|
+
--hu-font-weight-bold: 700;
|
|
67
|
+
|
|
68
|
+
/* Colours — Light */
|
|
69
|
+
--hu-bg: #ffffff;
|
|
70
|
+
--hu-bg-2: #f8fafc;
|
|
71
|
+
--hu-bg-3: #f1f5f9;
|
|
72
|
+
--hu-bg-4: #e8edf5;
|
|
73
|
+
--hu-border: #e2e8f0;
|
|
74
|
+
--hu-border-2: #cbd5e1;
|
|
75
|
+
--hu-text: #0f172a;
|
|
76
|
+
--hu-text-2: #475569;
|
|
77
|
+
--hu-text-3: #94a3b8;
|
|
78
|
+
--hu-text-inv: #ffffff;
|
|
79
|
+
|
|
80
|
+
/* Primary — Indigo */
|
|
81
|
+
--hu-primary: #6366f1;
|
|
82
|
+
--hu-primary-dk: #4f46e5;
|
|
83
|
+
--hu-primary-lt: #818cf8;
|
|
84
|
+
--hu-primary-bg: #eef2ff;
|
|
85
|
+
--hu-primary-text: #ffffff;
|
|
86
|
+
|
|
87
|
+
/* Semantic */
|
|
88
|
+
--hu-success: #22c55e;
|
|
89
|
+
--hu-success-bg: #f0fdf4;
|
|
90
|
+
--hu-success-text:#15803d;
|
|
91
|
+
--hu-warning: #f59e0b;
|
|
92
|
+
--hu-warning-bg: #fffbeb;
|
|
93
|
+
--hu-warning-text:#92400e;
|
|
94
|
+
--hu-error: #ef4444;
|
|
95
|
+
--hu-error-bg: #fef2f2;
|
|
96
|
+
--hu-error-text: #b91c1c;
|
|
97
|
+
--hu-info: #3b82f6;
|
|
98
|
+
--hu-info-bg: #eff6ff;
|
|
99
|
+
--hu-info-text: #1d4ed8;
|
|
100
|
+
|
|
101
|
+
/* Shadows */
|
|
102
|
+
--hu-shadow-xs: 0 1px 2px rgb(0 0 0/6%);
|
|
103
|
+
--hu-shadow-sm: 0 1px 3px rgb(0 0 0/8%), 0 1px 2px rgb(0 0 0/4%);
|
|
104
|
+
--hu-shadow: 0 4px 6px -1px rgb(0 0 0/8%), 0 2px 4px -2px rgb(0 0 0/4%);
|
|
105
|
+
--hu-shadow-md: 0 10px 15px -3px rgb(0 0 0/8%), 0 4px 6px -4px rgb(0 0 0/4%);
|
|
106
|
+
--hu-shadow-lg: 0 20px 25px -5px rgb(0 0 0/8%), 0 8px 10px -6px rgb(0 0 0/4%);
|
|
107
|
+
--hu-shadow-xl: 0 25px 50px -12px rgb(0 0 0/20%);
|
|
108
|
+
|
|
109
|
+
/* Overlays */
|
|
110
|
+
--hu-overlay: rgb(0 0 0/50%);
|
|
111
|
+
|
|
112
|
+
/* Transitions */
|
|
113
|
+
--hu-duration-fast: 100ms;
|
|
114
|
+
--hu-duration: 150ms;
|
|
115
|
+
--hu-duration-slow: 250ms;
|
|
116
|
+
--hu-ease: cubic-bezier(0.4, 0, 0.2, 1);
|
|
117
|
+
--hu-ease-in: cubic-bezier(0.4, 0, 1, 1);
|
|
118
|
+
--hu-ease-out: cubic-bezier(0, 0, 0.2, 1);
|
|
119
|
+
--hu-ease-spring: cubic-bezier(0.175, 0.885, 0.32, 1.275);
|
|
120
|
+
|
|
121
|
+
/* Z-index */
|
|
122
|
+
--hu-z-dropdown: 1000;
|
|
123
|
+
--hu-z-sticky: 1020;
|
|
124
|
+
--hu-z-fixed: 1030;
|
|
125
|
+
--hu-z-backdrop: 1040;
|
|
126
|
+
--hu-z-modal: 1050;
|
|
127
|
+
--hu-z-popover: 1060;
|
|
128
|
+
--hu-z-tooltip: 1070;
|
|
129
|
+
--hu-z-toast: 1080;
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
/* Dark mode */
|
|
133
|
+
[data-theme="dark"], .hu-dark {
|
|
134
|
+
--hu-bg: #0a0a0f;
|
|
135
|
+
--hu-bg-2: #111118;
|
|
136
|
+
--hu-bg-3: #1a1a24;
|
|
137
|
+
--hu-bg-4: #22222f;
|
|
138
|
+
--hu-border: #2a2a38;
|
|
139
|
+
--hu-border-2: #3a3a4a;
|
|
140
|
+
--hu-text: #f0f0ff;
|
|
141
|
+
--hu-text-2: #a0a0c0;
|
|
142
|
+
--hu-text-3: #606080;
|
|
143
|
+
--hu-text-inv: #0a0a0f;
|
|
144
|
+
|
|
145
|
+
--hu-primary: #818cf8;
|
|
146
|
+
--hu-primary-dk: #6366f1;
|
|
147
|
+
--hu-primary-lt: #a5b4fc;
|
|
148
|
+
--hu-primary-bg: #1e1b4b30;
|
|
149
|
+
--hu-primary-text: #ffffff;
|
|
150
|
+
|
|
151
|
+
--hu-success: #4ade80;
|
|
152
|
+
--hu-success-bg: #052e16;
|
|
153
|
+
--hu-success-text:#86efac;
|
|
154
|
+
--hu-warning: #fbbf24;
|
|
155
|
+
--hu-warning-bg: #1c1500;
|
|
156
|
+
--hu-warning-text:#fde68a;
|
|
157
|
+
--hu-error: #f87171;
|
|
158
|
+
--hu-error-bg: #1f0505;
|
|
159
|
+
--hu-error-text: #fca5a5;
|
|
160
|
+
--hu-info: #60a5fa;
|
|
161
|
+
--hu-info-bg: #030d1a;
|
|
162
|
+
--hu-info-text: #93c5fd;
|
|
163
|
+
|
|
164
|
+
--hu-shadow-xs: 0 1px 2px rgb(0 0 0/30%);
|
|
165
|
+
--hu-shadow-sm: 0 1px 3px rgb(0 0 0/40%), 0 1px 2px rgb(0 0 0/24%);
|
|
166
|
+
--hu-shadow: 0 4px 6px -1px rgb(0 0 0/40%), 0 2px 4px -2px rgb(0 0 0/24%);
|
|
167
|
+
--hu-shadow-md: 0 10px 15px -3px rgb(0 0 0/40%), 0 4px 6px -4px rgb(0 0 0/24%);
|
|
168
|
+
--hu-shadow-lg: 0 20px 25px -5px rgb(0 0 0/40%), 0 8px 10px -6px rgb(0 0 0/24%);
|
|
169
|
+
--hu-shadow-xl: 0 25px 50px -12px rgb(0 0 0/60%);
|
|
170
|
+
|
|
171
|
+
--hu-overlay: rgb(0 0 0/70%);
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
/* Base reset */
|
|
175
|
+
*, *::before, *::after { box-sizing: border-box; }
|
|
176
|
+
[data-hu-root] {
|
|
177
|
+
font-family: var(--hu-font-sans);
|
|
178
|
+
font-size: var(--hu-font-size-base);
|
|
179
|
+
line-height: var(--hu-line-height);
|
|
180
|
+
color: var(--hu-text);
|
|
181
|
+
background: var(--hu-bg);
|
|
182
|
+
-webkit-font-smoothing: antialiased;
|
|
183
|
+
-moz-osx-font-smoothing: grayscale;
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
/* Focus ring */
|
|
187
|
+
.hu-focus:focus-visible {
|
|
188
|
+
outline: 2px solid var(--hu-primary);
|
|
189
|
+
outline-offset: 2px;
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
/* Screen-reader only */
|
|
193
|
+
.hu-sr-only {
|
|
194
|
+
position: absolute; width: 1px; height: 1px; padding: 0;
|
|
195
|
+
margin: -1px; overflow: hidden; clip: rect(0,0,0,0);
|
|
196
|
+
white-space: nowrap; border: 0;
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
/* Animations */
|
|
200
|
+
@keyframes hu-spin { to { transform: rotate(360deg); } }
|
|
201
|
+
@keyframes hu-pulse { 0%,100%{opacity:1} 50%{opacity:.5} }
|
|
202
|
+
@keyframes hu-ping { 75%,100%{transform:scale(2);opacity:0} }
|
|
203
|
+
@keyframes hu-bounce { 0%,100%{transform:translateY(-25%);animation-timing-function:cubic-bezier(.8,0,1,1)} 50%{transform:none;animation-timing-function:cubic-bezier(0,0,.2,1)} }
|
|
204
|
+
@keyframes hu-fade-in { from{opacity:0} to{opacity:1} }
|
|
205
|
+
@keyframes hu-fade-out { from{opacity:1} to{opacity:0} }
|
|
206
|
+
@keyframes hu-slide-up { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }
|
|
207
|
+
@keyframes hu-slide-down { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:translateY(0)} }
|
|
208
|
+
@keyframes hu-slide-in-right { from{opacity:0;transform:translateX(100%)} to{opacity:1;transform:translateX(0)} }
|
|
209
|
+
@keyframes hu-slide-in-left { from{opacity:0;transform:translateX(-100%)} to{opacity:1;transform:translateX(0)} }
|
|
210
|
+
@keyframes hu-scale-in { from{opacity:0;transform:scale(.95)} to{opacity:1;transform:scale(1)} }
|
|
211
|
+
@keyframes hu-shimmer { from{background-position:-200% 0} to{background-position:200% 0} }
|
|
212
|
+
`;
|
|
213
|
+
/**
|
|
214
|
+
* Initialises HyperUI — injects base CSS tokens and optionally applies
|
|
215
|
+
* theme overrides. Call once at app startup before rendering.
|
|
216
|
+
*
|
|
217
|
+
* initHyperUI({ theme: "system", primaryColor: "#7c3aed" });
|
|
218
|
+
*/
|
|
219
|
+
export function initHyperUI(config = {}) {
|
|
220
|
+
injectCSS("hu-base", BASE_CSS);
|
|
221
|
+
const root = typeof document !== "undefined" ? document.documentElement : null;
|
|
222
|
+
if (!root)
|
|
223
|
+
return;
|
|
224
|
+
root.setAttribute("data-hu-root", "");
|
|
225
|
+
// Apply custom overrides
|
|
226
|
+
if (config.primaryColor) {
|
|
227
|
+
root.style.setProperty("--hu-primary", config.primaryColor);
|
|
228
|
+
}
|
|
229
|
+
if (config.radius) {
|
|
230
|
+
root.style.setProperty("--hu-radius", config.radius);
|
|
231
|
+
}
|
|
232
|
+
if (config.fontFamily) {
|
|
233
|
+
root.style.setProperty("--hu-font-sans", config.fontFamily);
|
|
234
|
+
}
|
|
235
|
+
// Theme
|
|
236
|
+
const theme = config.theme ?? "system";
|
|
237
|
+
if (theme === "system") {
|
|
238
|
+
const mq = window.matchMedia("(prefers-color-scheme: dark)");
|
|
239
|
+
root.setAttribute("data-theme", mq.matches ? "dark" : "light");
|
|
240
|
+
mq.addEventListener("change", (e) => {
|
|
241
|
+
root.setAttribute("data-theme", e.matches ? "dark" : "light");
|
|
242
|
+
});
|
|
243
|
+
}
|
|
244
|
+
else {
|
|
245
|
+
root.setAttribute("data-theme", theme);
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
// ---------------------------------------------------------------------------
|
|
249
|
+
// Utility — merge class names (handles undefined/false gracefully)
|
|
250
|
+
// ---------------------------------------------------------------------------
|
|
251
|
+
export function cn(...classes) {
|
|
252
|
+
return classes.filter(Boolean).join(" ");
|
|
253
|
+
}
|
|
254
|
+
export function h(type, props, ...children) {
|
|
255
|
+
const { children: propsChildren, ...rest } = props ?? {};
|
|
256
|
+
const allChildren = children.length > 0 ? children.flat() : (propsChildren ? (Array.isArray(propsChildren) ? propsChildren : [propsChildren]) : []);
|
|
257
|
+
return { type, props: rest, children: allChildren };
|
|
258
|
+
}
|