mythik-react 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 +201 -0
- package/NOTICE +4 -0
- package/README.md +83 -0
- package/dist/MythikApp.d.ts +61 -0
- package/dist/MythikApp.d.ts.map +1 -0
- package/dist/MythikApp.js +381 -0
- package/dist/MythikApp.js.map +1 -0
- package/dist/MythikRenderer.d.ts +31 -0
- package/dist/MythikRenderer.d.ts.map +1 -0
- package/dist/MythikRenderer.js +900 -0
- package/dist/MythikRenderer.js.map +1 -0
- package/dist/animation/index.d.ts +7 -0
- package/dist/animation/index.d.ts.map +1 -0
- package/dist/animation/index.js +5 -0
- package/dist/animation/index.js.map +1 -0
- package/dist/animation/stylesheet-singleton.d.ts +12 -0
- package/dist/animation/stylesheet-singleton.d.ts.map +1 -0
- package/dist/animation/stylesheet-singleton.js +107 -0
- package/dist/animation/stylesheet-singleton.js.map +1 -0
- package/dist/animation/useElementAnimations.d.ts +30 -0
- package/dist/animation/useElementAnimations.d.ts.map +1 -0
- package/dist/animation/useElementAnimations.js +254 -0
- package/dist/animation/useElementAnimations.js.map +1 -0
- package/dist/animation/usePrefersReducedMotion.d.ts +2 -0
- package/dist/animation/usePrefersReducedMotion.d.ts.map +1 -0
- package/dist/animation/usePrefersReducedMotion.js +29 -0
- package/dist/animation/usePrefersReducedMotion.js.map +1 -0
- package/dist/animation/useShapeAnimations.d.ts +21 -0
- package/dist/animation/useShapeAnimations.d.ts.map +1 -0
- package/dist/animation/useShapeAnimations.js +119 -0
- package/dist/animation/useShapeAnimations.js.map +1 -0
- package/dist/app-context.d.ts +15 -0
- package/dist/app-context.d.ts.map +1 -0
- package/dist/app-context.js +9 -0
- package/dist/app-context.js.map +1 -0
- package/dist/background/BackgroundLayer.d.ts +7 -0
- package/dist/background/BackgroundLayer.d.ts.map +1 -0
- package/dist/background/BackgroundLayer.js +50 -0
- package/dist/background/BackgroundLayer.js.map +1 -0
- package/dist/background/BackgroundStack.d.ts +19 -0
- package/dist/background/BackgroundStack.d.ts.map +1 -0
- package/dist/background/BackgroundStack.js +59 -0
- package/dist/background/BackgroundStack.js.map +1 -0
- package/dist/background/BlobLayer.d.ts +12 -0
- package/dist/background/BlobLayer.d.ts.map +1 -0
- package/dist/background/BlobLayer.js +60 -0
- package/dist/background/BlobLayer.js.map +1 -0
- package/dist/background/index.d.ts +3 -0
- package/dist/background/index.d.ts.map +1 -0
- package/dist/background/index.js +3 -0
- package/dist/background/index.js.map +1 -0
- package/dist/css-hover.d.ts +15 -0
- package/dist/css-hover.d.ts.map +1 -0
- package/dist/css-hover.js +51 -0
- package/dist/css-hover.js.map +1 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +11 -0
- package/dist/index.js.map +1 -0
- package/dist/primitives/accordion.d.ts +12 -0
- package/dist/primitives/accordion.d.ts.map +1 -0
- package/dist/primitives/accordion.js +25 -0
- package/dist/primitives/accordion.js.map +1 -0
- package/dist/primitives/area-chart.d.ts +14 -0
- package/dist/primitives/area-chart.d.ts.map +1 -0
- package/dist/primitives/area-chart.js +18 -0
- package/dist/primitives/area-chart.js.map +1 -0
- package/dist/primitives/audio-player.d.ts +9 -0
- package/dist/primitives/audio-player.d.ts.map +1 -0
- package/dist/primitives/audio-player.js +5 -0
- package/dist/primitives/audio-player.js.map +1 -0
- package/dist/primitives/bar-chart.d.ts +14 -0
- package/dist/primitives/bar-chart.d.ts.map +1 -0
- package/dist/primitives/bar-chart.js +22 -0
- package/dist/primitives/bar-chart.js.map +1 -0
- package/dist/primitives/box.d.ts +21 -0
- package/dist/primitives/box.d.ts.map +1 -0
- package/dist/primitives/box.js +54 -0
- package/dist/primitives/box.js.map +1 -0
- package/dist/primitives/button.d.ts +14 -0
- package/dist/primitives/button.d.ts.map +1 -0
- package/dist/primitives/button.js +28 -0
- package/dist/primitives/button.js.map +1 -0
- package/dist/primitives/camera.d.ts +15 -0
- package/dist/primitives/camera.d.ts.map +1 -0
- package/dist/primitives/camera.js +25 -0
- package/dist/primitives/camera.js.map +1 -0
- package/dist/primitives/checkbox.d.ts +12 -0
- package/dist/primitives/checkbox.d.ts.map +1 -0
- package/dist/primitives/checkbox.js +24 -0
- package/dist/primitives/checkbox.js.map +1 -0
- package/dist/primitives/divider.d.ts +9 -0
- package/dist/primitives/divider.d.ts.map +1 -0
- package/dist/primitives/divider.js +10 -0
- package/dist/primitives/divider.js.map +1 -0
- package/dist/primitives/drawer.d.ts +21 -0
- package/dist/primitives/drawer.d.ts.map +1 -0
- package/dist/primitives/drawer.js +38 -0
- package/dist/primitives/drawer.js.map +1 -0
- package/dist/primitives/file-upload.d.ts +27 -0
- package/dist/primitives/file-upload.d.ts.map +1 -0
- package/dist/primitives/file-upload.js +225 -0
- package/dist/primitives/file-upload.js.map +1 -0
- package/dist/primitives/grid.d.ts +13 -0
- package/dist/primitives/grid.d.ts.map +1 -0
- package/dist/primitives/grid.js +13 -0
- package/dist/primitives/grid.js.map +1 -0
- package/dist/primitives/icon.d.ts +22 -0
- package/dist/primitives/icon.d.ts.map +1 -0
- package/dist/primitives/icon.js +52 -0
- package/dist/primitives/icon.js.map +1 -0
- package/dist/primitives/image.d.ts +13 -0
- package/dist/primitives/image.d.ts.map +1 -0
- package/dist/primitives/image.js +38 -0
- package/dist/primitives/image.js.map +1 -0
- package/dist/primitives/index.d.ts +57 -0
- package/dist/primitives/index.d.ts.map +1 -0
- package/dist/primitives/index.js +106 -0
- package/dist/primitives/index.js.map +1 -0
- package/dist/primitives/input.d.ts +32 -0
- package/dist/primitives/input.d.ts.map +1 -0
- package/dist/primitives/input.js +192 -0
- package/dist/primitives/input.js.map +1 -0
- package/dist/primitives/kanban-board.d.ts +13 -0
- package/dist/primitives/kanban-board.d.ts.map +1 -0
- package/dist/primitives/kanban-board.js +5 -0
- package/dist/primitives/kanban-board.js.map +1 -0
- package/dist/primitives/line-chart.d.ts +14 -0
- package/dist/primitives/line-chart.d.ts.map +1 -0
- package/dist/primitives/line-chart.js +17 -0
- package/dist/primitives/line-chart.js.map +1 -0
- package/dist/primitives/list.d.ts +13 -0
- package/dist/primitives/list.d.ts.map +1 -0
- package/dist/primitives/list.js +10 -0
- package/dist/primitives/list.js.map +1 -0
- package/dist/primitives/modal.d.ts +20 -0
- package/dist/primitives/modal.d.ts.map +1 -0
- package/dist/primitives/modal.js +60 -0
- package/dist/primitives/modal.js.map +1 -0
- package/dist/primitives/pie-chart.d.ts +15 -0
- package/dist/primitives/pie-chart.d.ts.map +1 -0
- package/dist/primitives/pie-chart.js +36 -0
- package/dist/primitives/pie-chart.js.map +1 -0
- package/dist/primitives/screen-outlet.d.ts +9 -0
- package/dist/primitives/screen-outlet.d.ts.map +1 -0
- package/dist/primitives/screen-outlet.js +92 -0
- package/dist/primitives/screen-outlet.js.map +1 -0
- package/dist/primitives/screen.d.ts +9 -0
- package/dist/primitives/screen.d.ts.map +1 -0
- package/dist/primitives/screen.js +10 -0
- package/dist/primitives/screen.js.map +1 -0
- package/dist/primitives/scroll.d.ts +11 -0
- package/dist/primitives/scroll.d.ts.map +1 -0
- package/dist/primitives/scroll.js +10 -0
- package/dist/primitives/scroll.js.map +1 -0
- package/dist/primitives/select.d.ts +19 -0
- package/dist/primitives/select.d.ts.map +1 -0
- package/dist/primitives/select.js +109 -0
- package/dist/primitives/select.js.map +1 -0
- package/dist/primitives/signature.d.ts +13 -0
- package/dist/primitives/signature.d.ts.map +1 -0
- package/dist/primitives/signature.js +45 -0
- package/dist/primitives/signature.js.map +1 -0
- package/dist/primitives/skeleton.d.ts +14 -0
- package/dist/primitives/skeleton.d.ts.map +1 -0
- package/dist/primitives/skeleton.js +41 -0
- package/dist/primitives/skeleton.js.map +1 -0
- package/dist/primitives/slider.d.ts +15 -0
- package/dist/primitives/slider.d.ts.map +1 -0
- package/dist/primitives/slider.js +7 -0
- package/dist/primitives/slider.js.map +1 -0
- package/dist/primitives/spacer.d.ts +9 -0
- package/dist/primitives/spacer.d.ts.map +1 -0
- package/dist/primitives/spacer.js +9 -0
- package/dist/primitives/spacer.js.map +1 -0
- package/dist/primitives/spatial-map-editing.d.ts +472 -0
- package/dist/primitives/spatial-map-editing.d.ts.map +1 -0
- package/dist/primitives/spatial-map-editing.js +886 -0
- package/dist/primitives/spatial-map-editing.js.map +1 -0
- package/dist/primitives/spatial-map.d.ts +1073 -0
- package/dist/primitives/spatial-map.d.ts.map +1 -0
- package/dist/primitives/spatial-map.js +1705 -0
- package/dist/primitives/spatial-map.js.map +1 -0
- package/dist/primitives/stack.d.ts +13 -0
- package/dist/primitives/stack.d.ts.map +1 -0
- package/dist/primitives/stack.js +12 -0
- package/dist/primitives/stack.js.map +1 -0
- package/dist/primitives/table.d.ts +115 -0
- package/dist/primitives/table.d.ts.map +1 -0
- package/dist/primitives/table.js +498 -0
- package/dist/primitives/table.js.map +1 -0
- package/dist/primitives/tabs.d.ts +17 -0
- package/dist/primitives/tabs.d.ts.map +1 -0
- package/dist/primitives/tabs.js +13 -0
- package/dist/primitives/tabs.js.map +1 -0
- package/dist/primitives/text.d.ts +11 -0
- package/dist/primitives/text.d.ts.map +1 -0
- package/dist/primitives/text.js +69 -0
- package/dist/primitives/text.js.map +1 -0
- package/dist/primitives/textarea.d.ts +15 -0
- package/dist/primitives/textarea.d.ts.map +1 -0
- package/dist/primitives/textarea.js +23 -0
- package/dist/primitives/textarea.js.map +1 -0
- package/dist/primitives/toast-container.d.ts +15 -0
- package/dist/primitives/toast-container.d.ts.map +1 -0
- package/dist/primitives/toast-container.js +160 -0
- package/dist/primitives/toast-container.js.map +1 -0
- package/dist/primitives/toggle.d.ts +12 -0
- package/dist/primitives/toggle.d.ts.map +1 -0
- package/dist/primitives/toggle.js +18 -0
- package/dist/primitives/toggle.js.map +1 -0
- package/dist/primitives/touchable.d.ts +10 -0
- package/dist/primitives/touchable.d.ts.map +1 -0
- package/dist/primitives/touchable.js +6 -0
- package/dist/primitives/touchable.js.map +1 -0
- package/dist/primitives/use-design-tokens.d.ts +127 -0
- package/dist/primitives/use-design-tokens.d.ts.map +1 -0
- package/dist/primitives/use-design-tokens.js +251 -0
- package/dist/primitives/use-design-tokens.js.map +1 -0
- package/dist/primitives/use-theme.d.ts +11 -0
- package/dist/primitives/use-theme.d.ts.map +1 -0
- package/dist/primitives/use-theme.js +17 -0
- package/dist/primitives/use-theme.js.map +1 -0
- package/dist/primitives/wizard.d.ts +11 -0
- package/dist/primitives/wizard.d.ts.map +1 -0
- package/dist/primitives/wizard.js +15 -0
- package/dist/primitives/wizard.js.map +1 -0
- package/dist/runtime/context-dispatcher.d.ts +3 -0
- package/dist/runtime/context-dispatcher.d.ts.map +1 -0
- package/dist/runtime/context-dispatcher.js +11 -0
- package/dist/runtime/context-dispatcher.js.map +1 -0
- package/dist/runtime/row-dispatcher.d.ts +19 -0
- package/dist/runtime/row-dispatcher.d.ts.map +1 -0
- package/dist/runtime/row-dispatcher.js +25 -0
- package/dist/runtime/row-dispatcher.js.map +1 -0
- package/dist/types.d.ts +10 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/dist/use-device-context.d.ts +8 -0
- package/dist/use-device-context.d.ts.map +1 -0
- package/dist/use-device-context.js +54 -0
- package/dist/use-device-context.js.map +1 -0
- package/package.json +59 -0
|
@@ -0,0 +1,225 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { useDesignTokens } from './use-design-tokens.js';
|
|
3
|
+
function formatFileSize(bytes) {
|
|
4
|
+
if (bytes >= 1_048_576)
|
|
5
|
+
return `${(bytes / 1_048_576).toFixed(1)} MB`;
|
|
6
|
+
if (bytes >= 1024)
|
|
7
|
+
return `${(bytes / 1024).toFixed(0)} KB`;
|
|
8
|
+
return `${bytes} B`;
|
|
9
|
+
}
|
|
10
|
+
function getFileExtension(name) {
|
|
11
|
+
const dot = name.lastIndexOf('.');
|
|
12
|
+
if (dot < 0)
|
|
13
|
+
return '';
|
|
14
|
+
return name.slice(dot + 1).toUpperCase();
|
|
15
|
+
}
|
|
16
|
+
function isImageType(type) {
|
|
17
|
+
return type.startsWith('image/');
|
|
18
|
+
}
|
|
19
|
+
// --- Inline SVG Icons ---
|
|
20
|
+
function UploadIcon({ color }) {
|
|
21
|
+
return React.createElement('svg', { width: 24, height: 24, viewBox: '0 0 24 24', fill: 'none', stroke: color, strokeWidth: 2 }, React.createElement('path', { d: 'M21 15v4a2 2 0 01-2 2H5a2 2 0 01-2-2v-4' }), React.createElement('polyline', { points: '17 8 12 3 7 8' }), React.createElement('line', { x1: 12, y1: 3, x2: 12, y2: 15 }));
|
|
22
|
+
}
|
|
23
|
+
function CheckIcon({ color }) {
|
|
24
|
+
return React.createElement('svg', { width: 16, height: 16, viewBox: '0 0 24 24', fill: 'none', stroke: color, strokeWidth: 3 }, React.createElement('polyline', { points: '20 6 9 17 4 12' }));
|
|
25
|
+
}
|
|
26
|
+
function XIcon({ color, size = 14 }) {
|
|
27
|
+
return React.createElement('svg', { width: size, height: size, viewBox: '0 0 24 24', fill: 'none', stroke: color, strokeWidth: 2.5 }, React.createElement('line', { x1: 18, y1: 6, x2: 6, y2: 18 }), React.createElement('line', { x1: 6, y1: 6, x2: 18, y2: 18 }));
|
|
28
|
+
}
|
|
29
|
+
function RetryIcon({ color }) {
|
|
30
|
+
return React.createElement('svg', { width: 14, height: 14, viewBox: '0 0 24 24', fill: 'none', stroke: color, strokeWidth: 2.5 }, React.createElement('polyline', { points: '23 4 23 10 17 10' }), React.createElement('path', { d: 'M20.49 15a9 9 0 11-2.12-9.36L23 10' }));
|
|
31
|
+
}
|
|
32
|
+
function SpinnerIcon({ color }) {
|
|
33
|
+
return React.createElement('svg', {
|
|
34
|
+
width: 16, height: 16, viewBox: '0 0 24 24', fill: 'none', stroke: color, strokeWidth: 2.5,
|
|
35
|
+
style: { animation: 'spin 0.8s linear infinite' },
|
|
36
|
+
}, React.createElement('path', { d: 'M12 2a10 10 0 0110 10', strokeLinecap: 'round' }));
|
|
37
|
+
}
|
|
38
|
+
function FileIcon({ ext, color }) {
|
|
39
|
+
return React.createElement('div', {
|
|
40
|
+
style: {
|
|
41
|
+
width: 40, height: 40, borderRadius: 6, backgroundColor: color + '18',
|
|
42
|
+
display: 'flex', alignItems: 'center', justifyContent: 'center',
|
|
43
|
+
fontSize: 10, fontWeight: 700, color, textTransform: 'uppercase',
|
|
44
|
+
},
|
|
45
|
+
}, ext || '?');
|
|
46
|
+
}
|
|
47
|
+
export function FileUpload({ accept, multiple = false, maxSize = 10_485_760, maxFiles = 10, preview = true, dropZone = false, autoUpload = true, label = 'Choose file', disabled = false, style, _tokens, uploadState, onFiles, onRemove, onRetry, }) {
|
|
48
|
+
const inputRef = React.useRef(null);
|
|
49
|
+
const [dragActive, setDragActive] = React.useState(false);
|
|
50
|
+
const t = useDesignTokens(_tokens);
|
|
51
|
+
const borderColor = dragActive ? t.colors.primary : t.colors.border;
|
|
52
|
+
const primaryColor = t.colors.primary;
|
|
53
|
+
const errorColor = t.colors.error;
|
|
54
|
+
const successColor = t.colors.success;
|
|
55
|
+
const textColor = t.colors.text;
|
|
56
|
+
const mutedColor = t.colors.textMuted;
|
|
57
|
+
const surfaceColor = t.colors.surface;
|
|
58
|
+
const handleFiles = React.useCallback((fileList) => {
|
|
59
|
+
const files = Array.from(fileList);
|
|
60
|
+
onFiles?.(files);
|
|
61
|
+
}, [onFiles]);
|
|
62
|
+
const handleInputChange = React.useCallback((e) => {
|
|
63
|
+
if (e.target.files && e.target.files.length > 0) {
|
|
64
|
+
handleFiles(e.target.files);
|
|
65
|
+
// Reset input so same file can be re-selected
|
|
66
|
+
e.target.value = '';
|
|
67
|
+
}
|
|
68
|
+
}, [handleFiles]);
|
|
69
|
+
const handleDragOver = React.useCallback((e) => {
|
|
70
|
+
e.preventDefault();
|
|
71
|
+
e.stopPropagation();
|
|
72
|
+
if (!disabled)
|
|
73
|
+
setDragActive(true);
|
|
74
|
+
}, [disabled]);
|
|
75
|
+
const handleDragLeave = React.useCallback((e) => {
|
|
76
|
+
e.preventDefault();
|
|
77
|
+
e.stopPropagation();
|
|
78
|
+
setDragActive(false);
|
|
79
|
+
}, []);
|
|
80
|
+
const handleDrop = React.useCallback((e) => {
|
|
81
|
+
e.preventDefault();
|
|
82
|
+
e.stopPropagation();
|
|
83
|
+
setDragActive(false);
|
|
84
|
+
if (!disabled && e.dataTransfer.files.length > 0) {
|
|
85
|
+
handleFiles(e.dataTransfer.files);
|
|
86
|
+
}
|
|
87
|
+
}, [disabled, handleFiles]);
|
|
88
|
+
// Hidden input element
|
|
89
|
+
const inputEl = React.createElement('input', {
|
|
90
|
+
ref: inputRef,
|
|
91
|
+
type: 'file',
|
|
92
|
+
accept,
|
|
93
|
+
multiple,
|
|
94
|
+
disabled,
|
|
95
|
+
onChange: handleInputChange,
|
|
96
|
+
style: { display: 'none' },
|
|
97
|
+
});
|
|
98
|
+
// Trigger zone (button or drop zone)
|
|
99
|
+
const triggerEl = dropZone
|
|
100
|
+
? React.createElement('div', {
|
|
101
|
+
onDragOver: handleDragOver,
|
|
102
|
+
onDragEnter: handleDragOver,
|
|
103
|
+
onDragLeave: handleDragLeave,
|
|
104
|
+
onDrop: handleDrop,
|
|
105
|
+
onClick: () => !disabled && inputRef.current?.click(),
|
|
106
|
+
style: {
|
|
107
|
+
padding: `${t.spacing.scale.lg}px ${t.spacing.scale.md}px`,
|
|
108
|
+
border: `2px dashed ${borderColor}`,
|
|
109
|
+
borderRadius: t.radius(t.shape.radius.lg),
|
|
110
|
+
backgroundColor: dragActive ? primaryColor + '08' : 'transparent',
|
|
111
|
+
cursor: disabled ? 'default' : 'pointer',
|
|
112
|
+
display: 'flex', flexDirection: 'column', alignItems: 'center', gap: t.spacing.scale.sm,
|
|
113
|
+
transition: `all ${t.motion.duration.fast}ms ${t.motion.easing.default}`,
|
|
114
|
+
opacity: disabled ? 0.5 : 1,
|
|
115
|
+
},
|
|
116
|
+
}, React.createElement(UploadIcon, { color: mutedColor }), React.createElement('span', { style: { fontSize: t.typography.scale.sm.fontSize, color: mutedColor } }, label))
|
|
117
|
+
: React.createElement('button', {
|
|
118
|
+
type: 'button',
|
|
119
|
+
disabled,
|
|
120
|
+
onClick: () => inputRef.current?.click(),
|
|
121
|
+
style: {
|
|
122
|
+
padding: `${t.spacing.scale.sm}px ${t.spacing.scale.md}px`,
|
|
123
|
+
border: `2px dashed ${borderColor}`,
|
|
124
|
+
borderRadius: t.radius(t.shape.radius.md),
|
|
125
|
+
backgroundColor: 'transparent',
|
|
126
|
+
cursor: disabled ? 'default' : 'pointer',
|
|
127
|
+
fontSize: t.typography.scale.sm.fontSize,
|
|
128
|
+
color: mutedColor,
|
|
129
|
+
transition: `all ${t.motion.duration.fast}ms ${t.motion.easing.default}`,
|
|
130
|
+
opacity: disabled ? 0.5 : 1,
|
|
131
|
+
},
|
|
132
|
+
}, label);
|
|
133
|
+
// File list — uploadState comes from /ui/uploads/{elementId}/files in state store
|
|
134
|
+
const validUploadState = Array.isArray(uploadState) ? uploadState : undefined;
|
|
135
|
+
const fileListEl = validUploadState && validUploadState.length > 0
|
|
136
|
+
? React.createElement('div', { style: { display: 'flex', flexDirection: 'column', gap: t.spacing.unit + 2 } }, validUploadState.map((file, i) => {
|
|
137
|
+
if (!file || typeof file !== 'object')
|
|
138
|
+
return null;
|
|
139
|
+
const isImg = isImageType(file.type ?? '');
|
|
140
|
+
const ext = getFileExtension(file.name ?? '');
|
|
141
|
+
// Preview column
|
|
142
|
+
const previewEl = preview
|
|
143
|
+
? (isImg && file.previewUrl
|
|
144
|
+
? React.createElement('img', {
|
|
145
|
+
src: file.previewUrl,
|
|
146
|
+
alt: file.name,
|
|
147
|
+
style: { width: 40, height: 40, borderRadius: 6, objectFit: 'cover' },
|
|
148
|
+
})
|
|
149
|
+
: React.createElement(FileIcon, { ext, color: primaryColor }))
|
|
150
|
+
: null;
|
|
151
|
+
// Progress bar
|
|
152
|
+
const progressEl = file.status === 'uploading'
|
|
153
|
+
? React.createElement('div', {
|
|
154
|
+
role: 'progressbar',
|
|
155
|
+
'aria-valuenow': file.progress,
|
|
156
|
+
'aria-valuemin': 0,
|
|
157
|
+
'aria-valuemax': 100,
|
|
158
|
+
style: { height: 4, backgroundColor: '#E5E7EB', borderRadius: 2, overflow: 'hidden', marginTop: 4 },
|
|
159
|
+
}, React.createElement('div', {
|
|
160
|
+
style: {
|
|
161
|
+
height: '100%', width: `${file.progress}%`,
|
|
162
|
+
backgroundColor: primaryColor,
|
|
163
|
+
borderRadius: 2,
|
|
164
|
+
transition: 'width 0.3s ease',
|
|
165
|
+
},
|
|
166
|
+
}))
|
|
167
|
+
: null;
|
|
168
|
+
// Status indicator
|
|
169
|
+
let statusEl = null;
|
|
170
|
+
if (file.status === 'uploading') {
|
|
171
|
+
statusEl = React.createElement(SpinnerIcon, { color: primaryColor });
|
|
172
|
+
}
|
|
173
|
+
else if (file.status === 'done') {
|
|
174
|
+
statusEl = React.createElement(CheckIcon, { color: successColor });
|
|
175
|
+
}
|
|
176
|
+
else if (file.status === 'error') {
|
|
177
|
+
statusEl = onRetry
|
|
178
|
+
? React.createElement('button', {
|
|
179
|
+
type: 'button',
|
|
180
|
+
'aria-label': `Retry ${file.name}`,
|
|
181
|
+
onClick: () => onRetry(i),
|
|
182
|
+
style: {
|
|
183
|
+
background: 'none', border: 'none', cursor: 'pointer', padding: 2,
|
|
184
|
+
display: 'flex', alignItems: 'center',
|
|
185
|
+
},
|
|
186
|
+
}, React.createElement(RetryIcon, { color: errorColor }))
|
|
187
|
+
: React.createElement(XIcon, { color: errorColor });
|
|
188
|
+
}
|
|
189
|
+
// Remove button
|
|
190
|
+
const removeEl = onRemove
|
|
191
|
+
? React.createElement('button', {
|
|
192
|
+
type: 'button',
|
|
193
|
+
'aria-label': `Remove ${file.name}`,
|
|
194
|
+
onClick: () => onRemove(i),
|
|
195
|
+
style: {
|
|
196
|
+
background: 'none', border: 'none', cursor: 'pointer', padding: 2,
|
|
197
|
+
display: 'flex', alignItems: 'center', marginLeft: 4,
|
|
198
|
+
},
|
|
199
|
+
}, React.createElement(XIcon, { color: mutedColor, size: 12 }))
|
|
200
|
+
: null;
|
|
201
|
+
return React.createElement('div', {
|
|
202
|
+
key: `${file.name}-${i}`,
|
|
203
|
+
style: {
|
|
204
|
+
display: 'flex', alignItems: 'center', gap: 10,
|
|
205
|
+
padding: `${t.spacing.scale.sm}px 10px`, borderRadius: t.radius(t.shape.radius.md),
|
|
206
|
+
backgroundColor: file.status === 'error' ? errorColor + '08' : surfaceColor,
|
|
207
|
+
border: `1px solid ${file.status === 'error' ? errorColor + '30' : borderColor + '40'}`,
|
|
208
|
+
},
|
|
209
|
+
}, previewEl, React.createElement('div', { style: { flex: 1, minWidth: 0 } }, React.createElement('div', {
|
|
210
|
+
style: {
|
|
211
|
+
fontSize: 13, fontWeight: 500, color: textColor,
|
|
212
|
+
whiteSpace: 'nowrap', overflow: 'hidden', textOverflow: 'ellipsis',
|
|
213
|
+
},
|
|
214
|
+
}, file.name), React.createElement('div', { style: { fontSize: 11, color: mutedColor } }, formatFileSize(file.size ?? 0)), progressEl, file.status === 'error' && file.error
|
|
215
|
+
? React.createElement('div', {
|
|
216
|
+
style: { fontSize: 11, color: errorColor, marginTop: 2 },
|
|
217
|
+
}, file.error)
|
|
218
|
+
: null), statusEl, removeEl);
|
|
219
|
+
}))
|
|
220
|
+
: null;
|
|
221
|
+
return React.createElement('div', {
|
|
222
|
+
style: { display: 'flex', flexDirection: 'column', gap: t.spacing.scale.sm, ...style },
|
|
223
|
+
}, inputEl, triggerEl, fileListEl);
|
|
224
|
+
}
|
|
225
|
+
//# sourceMappingURL=file-upload.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file-upload.js","sourceRoot":"","sources":["../../src/primitives/file-upload.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { CSSProperties, ReactNode } from 'react';
|
|
2
|
+
interface GridProps {
|
|
3
|
+
columns?: number | string;
|
|
4
|
+
rows?: string;
|
|
5
|
+
gap?: number | string;
|
|
6
|
+
areas?: string;
|
|
7
|
+
style?: CSSProperties;
|
|
8
|
+
className?: string;
|
|
9
|
+
children?: ReactNode;
|
|
10
|
+
}
|
|
11
|
+
export declare function Grid({ columns, rows, gap, areas, style, className, children }: GridProps): import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
export {};
|
|
13
|
+
//# sourceMappingURL=grid.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"grid.d.ts","sourceRoot":"","sources":["../../src/primitives/grid.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEtD,UAAU,SAAS;IACjB,OAAO,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC1B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,aAAa,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,SAAS,CAAC;CACtB;AAED,wBAAgB,IAAI,CAAC,EAAE,OAAW,EAAE,IAAI,EAAE,GAAO,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,SAAS,2CAkBhG"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
export function Grid({ columns = 1, rows, gap = 0, areas, style, className, children }) {
|
|
3
|
+
const gridTemplateColumns = typeof columns === 'number' ? `repeat(${columns}, 1fr)` : columns;
|
|
4
|
+
return (_jsx("div", { className: className, style: {
|
|
5
|
+
display: 'grid',
|
|
6
|
+
gridTemplateColumns,
|
|
7
|
+
...(rows ? { gridTemplateRows: rows } : {}),
|
|
8
|
+
...(areas ? { gridTemplateAreas: areas } : {}),
|
|
9
|
+
gap,
|
|
10
|
+
...style,
|
|
11
|
+
}, children: children }));
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=grid.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"grid.js","sourceRoot":"","sources":["../../src/primitives/grid.tsx"],"names":[],"mappings":";AAYA,MAAM,UAAU,IAAI,CAAC,EAAE,OAAO,GAAG,CAAC,EAAE,IAAI,EAAE,GAAG,GAAG,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAa;IAC/F,MAAM,mBAAmB,GAAG,OAAO,OAAO,KAAK,QAAQ,CAAC,CAAC,CAAC,UAAU,OAAO,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC;IAE9F,OAAO,CACL,cACE,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE;YACL,OAAO,EAAE,MAAM;YACf,mBAAmB;YACnB,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,gBAAgB,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YAC3C,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,iBAAiB,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YAC9C,GAAG;YACH,GAAG,KAAK;SACT,YAEA,QAAQ,GACL,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { CSSProperties } from 'react';
|
|
2
|
+
interface IconProps {
|
|
3
|
+
name?: string;
|
|
4
|
+
size?: number;
|
|
5
|
+
weight?: 'thin' | 'light' | 'regular' | 'bold' | 'fill' | 'duotone';
|
|
6
|
+
color?: string;
|
|
7
|
+
style?: CSSProperties;
|
|
8
|
+
container?: false;
|
|
9
|
+
_tokens?: Record<string, unknown>;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Generic icon primitive — renders a placeholder circle or a custom icon renderer.
|
|
13
|
+
*
|
|
14
|
+
* Custom icon renderers are registered via plugins.setIconRenderer(Component).
|
|
15
|
+
* The renderer receives { name, size, weight, color, style } and renders the actual icon.
|
|
16
|
+
* icon.tsx handles identity wrapping (container, weight default) regardless of renderer.
|
|
17
|
+
*
|
|
18
|
+
* Legacy: plugins.overridePrimitive('icon', ...) still works but bypasses identity features.
|
|
19
|
+
*/
|
|
20
|
+
export declare function Icon({ name, size, weight, color, style, container, _tokens }: IconProps): import("react/jsx-runtime").JSX.Element;
|
|
21
|
+
export {};
|
|
22
|
+
//# sourceMappingURL=icon.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"icon.d.ts","sourceRoot":"","sources":["../../src/primitives/icon.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AAG3C,UAAU,SAAS;IACjB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,GAAG,MAAM,GAAG,SAAS,CAAC;IACpE,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,aAAa,CAAC;IACtB,SAAS,CAAC,EAAE,KAAK,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACnC;AAED;;;;;;;;GAQG;AACH,wBAAgB,IAAI,CAAC,EAAE,IAAe,EAAE,IAAS,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE,SAAS,2CA4DvG"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { useDesignTokens } from './use-design-tokens.js';
|
|
4
|
+
/**
|
|
5
|
+
* Generic icon primitive — renders a placeholder circle or a custom icon renderer.
|
|
6
|
+
*
|
|
7
|
+
* Custom icon renderers are registered via plugins.setIconRenderer(Component).
|
|
8
|
+
* The renderer receives { name, size, weight, color, style } and renders the actual icon.
|
|
9
|
+
* icon.tsx handles identity wrapping (container, weight default) regardless of renderer.
|
|
10
|
+
*
|
|
11
|
+
* Legacy: plugins.overridePrimitive('icon', ...) still works but bypasses identity features.
|
|
12
|
+
*/
|
|
13
|
+
export function Icon({ name = 'circle', size = 24, weight, color, style, container, _tokens }) {
|
|
14
|
+
const t = useDesignTokens(_tokens);
|
|
15
|
+
const resolvedWeight = weight ?? t.identity.icons.weight ?? 'regular';
|
|
16
|
+
const containerShape = container === false ? 'none' : (t.identity.icons.container ?? 'none');
|
|
17
|
+
const containerColorKey = t.identity.icons.containerColor ?? 'primary';
|
|
18
|
+
const containerBg = containerColorKey === 'primary' ? t.colors.primary
|
|
19
|
+
: containerColorKey === 'accent' ? t.colors.accent
|
|
20
|
+
: containerColorKey === 'muted' ? t.colors.border
|
|
21
|
+
: t.colors.surface;
|
|
22
|
+
// Use custom icon renderer if registered, otherwise placeholder
|
|
23
|
+
const IconRenderer = _tokens?._iconRenderer;
|
|
24
|
+
const iconElement = IconRenderer
|
|
25
|
+
? React.createElement(IconRenderer, { name, size, weight: resolvedWeight, color: color ?? 'inherit', style })
|
|
26
|
+
: (_jsx("span", { role: "img", "aria-label": name, "data-weight": resolvedWeight, style: {
|
|
27
|
+
fontSize: size,
|
|
28
|
+
lineHeight: 1,
|
|
29
|
+
display: 'inline-flex',
|
|
30
|
+
alignItems: 'center',
|
|
31
|
+
justifyContent: 'center',
|
|
32
|
+
width: size,
|
|
33
|
+
height: size,
|
|
34
|
+
color: color ?? 'inherit',
|
|
35
|
+
...style,
|
|
36
|
+
}, children: "\u25CF" }));
|
|
37
|
+
if (containerShape === 'none')
|
|
38
|
+
return iconElement;
|
|
39
|
+
const padding = Math.round(size * 0.35);
|
|
40
|
+
const containerRadius = containerShape === 'circle' ? '50%'
|
|
41
|
+
: containerShape === 'square' ? '0'
|
|
42
|
+
: `${Math.round(size * 0.2)}px`;
|
|
43
|
+
return (_jsx("span", { style: {
|
|
44
|
+
display: 'inline-flex',
|
|
45
|
+
alignItems: 'center',
|
|
46
|
+
justifyContent: 'center',
|
|
47
|
+
padding,
|
|
48
|
+
borderRadius: containerRadius,
|
|
49
|
+
backgroundColor: containerBg,
|
|
50
|
+
}, children: iconElement }));
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=icon.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"icon.js","sourceRoot":"","sources":["../../src/primitives/icon.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAYzD;;;;;;;;GAQG;AACH,MAAM,UAAU,IAAI,CAAC,EAAE,IAAI,GAAG,QAAQ,EAAE,IAAI,GAAG,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO,EAAa;IACtG,MAAM,CAAC,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC;IAEnC,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,IAAI,SAAS,CAAC;IAEtE,MAAM,cAAc,GAAG,SAAS,KAAK,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,SAAS,IAAI,MAAM,CAAC,CAAC;IAC7F,MAAM,iBAAiB,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,IAAI,SAAS,CAAC;IACvE,MAAM,WAAW,GAAG,iBAAiB,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO;QACpE,CAAC,CAAC,iBAAiB,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM;YAClD,CAAC,CAAC,iBAAiB,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM;gBACjD,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC;IAErB,gEAAgE;IAChE,MAAM,YAAY,GAAI,OAA+C,EAAE,aACiD,CAAC;IAEzH,MAAM,WAAW,GAAG,YAAY;QAC9B,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,YAAY,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,cAAc,EAAE,KAAK,EAAE,KAAK,IAAI,SAAS,EAAE,KAAK,EAAE,CAAC;QAC7G,CAAC,CAAC,CACA,eACE,IAAI,EAAC,KAAK,gBACE,IAAI,iBACH,cAAc,EAC3B,KAAK,EAAE;gBACL,QAAQ,EAAE,IAAI;gBACd,UAAU,EAAE,CAAC;gBACb,OAAO,EAAE,aAAa;gBACtB,UAAU,EAAE,QAAQ;gBACpB,cAAc,EAAE,QAAQ;gBACxB,KAAK,EAAE,IAAI;gBACX,MAAM,EAAE,IAAI;gBACZ,KAAK,EAAE,KAAK,IAAI,SAAS;gBACzB,GAAG,KAAK;aACT,uBAGI,CACR,CAAC;IAEJ,IAAI,cAAc,KAAK,MAAM;QAAE,OAAO,WAAW,CAAC;IAElD,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;IACxC,MAAM,eAAe,GAAG,cAAc,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK;QACzD,CAAC,CAAC,cAAc,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG;YACnC,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,CAAC,IAAI,CAAC;IAElC,OAAO,CACL,eACE,KAAK,EAAE;YACL,OAAO,EAAE,aAAa;YACtB,UAAU,EAAE,QAAQ;YACpB,cAAc,EAAE,QAAQ;YACxB,OAAO;YACP,YAAY,EAAE,eAAe;YAC7B,eAAe,EAAE,WAAW;SAC7B,YAEA,WAAW,GACP,CACR,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { CSSProperties } from 'react';
|
|
2
|
+
interface ImageProps {
|
|
3
|
+
src?: string;
|
|
4
|
+
alt?: string;
|
|
5
|
+
aspectRatio?: number;
|
|
6
|
+
placeholder?: string;
|
|
7
|
+
overlay?: 'none' | 'gradient-bottom' | 'color-tint';
|
|
8
|
+
style?: CSSProperties;
|
|
9
|
+
_tokens?: Record<string, unknown>;
|
|
10
|
+
}
|
|
11
|
+
export declare function Image({ src, alt, aspectRatio, placeholder, overlay, style, _tokens }: ImageProps): import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
export {};
|
|
13
|
+
//# sourceMappingURL=image.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"image.d.ts","sourceRoot":"","sources":["../../src/primitives/image.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AAG3C,UAAU,UAAU;IAClB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,GAAG,iBAAiB,GAAG,YAAY,CAAC;IACpD,KAAK,CAAC,EAAE,aAAa,CAAC;IACtB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACnC;AAED,wBAAgB,KAAK,CAAC,EAAE,GAAG,EAAE,GAAQ,EAAE,WAAW,EAAE,WAAW,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE,UAAU,2CAmDrG"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useDesignTokens } from './use-design-tokens.js';
|
|
3
|
+
export function Image({ src, alt = '', aspectRatio, placeholder, overlay, style, _tokens }) {
|
|
4
|
+
const t = useDesignTokens(_tokens);
|
|
5
|
+
const cornersId = t.identity.images.corners ?? 'rounded';
|
|
6
|
+
const borderRadius = style?.borderRadius ?? (cornersId === 'circle' ? '50%'
|
|
7
|
+
: cornersId === 'square' ? 0
|
|
8
|
+
: cornersId === 'match-card' ? t.radius(t.shape.radius.md)
|
|
9
|
+
: 8);
|
|
10
|
+
const identityBorder = t.identity.images.border ? `1px solid ${t.colors.border}` : undefined;
|
|
11
|
+
const isCircle = cornersId === 'circle';
|
|
12
|
+
// For circle: compute the height the image would have had, use that as circle diameter
|
|
13
|
+
const circleSize = isCircle && style?.width && aspectRatio
|
|
14
|
+
? Math.round(Number(style.width) / aspectRatio)
|
|
15
|
+
: undefined;
|
|
16
|
+
const imgStyle = {
|
|
17
|
+
borderRadius,
|
|
18
|
+
...(identityBorder && !style?.border ? { border: identityBorder } : {}),
|
|
19
|
+
...(isCircle
|
|
20
|
+
? { aspectRatio: '1', objectFit: 'cover', ...(circleSize ? { width: circleSize, height: circleSize } : {}) }
|
|
21
|
+
: { ...(aspectRatio ? { aspectRatio: String(aspectRatio) } : {}), objectFit: 'cover', width: '100%' }),
|
|
22
|
+
display: 'block',
|
|
23
|
+
...style,
|
|
24
|
+
...(isCircle && circleSize ? { width: circleSize, height: circleSize } : {}),
|
|
25
|
+
};
|
|
26
|
+
const overlayType = overlay ?? (t.identity.images.overlay ?? 'none');
|
|
27
|
+
if (!src && placeholder) {
|
|
28
|
+
return _jsx("div", { style: { ...imgStyle, backgroundColor: '#e5e7eb', display: 'flex', alignItems: 'center', justifyContent: 'center' }, children: placeholder });
|
|
29
|
+
}
|
|
30
|
+
if (overlayType === 'none') {
|
|
31
|
+
return _jsx("img", { src: src, alt: alt, style: imgStyle });
|
|
32
|
+
}
|
|
33
|
+
const overlayStyle = overlayType === 'gradient-bottom'
|
|
34
|
+
? { position: 'absolute', inset: 0, borderRadius, background: 'linear-gradient(transparent 60%, rgba(0,0,0,0.4))', pointerEvents: 'none' }
|
|
35
|
+
: { position: 'absolute', inset: 0, borderRadius, backgroundColor: `${t.colors.primary}26`, mixBlendMode: 'multiply', pointerEvents: 'none' };
|
|
36
|
+
return (_jsxs("div", { style: { position: 'relative', display: 'inline-block' }, children: [_jsx("img", { src: src, alt: alt, style: imgStyle }), _jsx("div", { style: overlayStyle })] }));
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=image.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"image.js","sourceRoot":"","sources":["../../src/primitives/image.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import type { PluginLoader } from 'mythik';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { Box } from './box.js';
|
|
4
|
+
import { Text } from './text.js';
|
|
5
|
+
import { Image } from './image.js';
|
|
6
|
+
import { Icon } from './icon.js';
|
|
7
|
+
import { Stack } from './stack.js';
|
|
8
|
+
import { Grid } from './grid.js';
|
|
9
|
+
import { Scroll } from './scroll.js';
|
|
10
|
+
import { Divider } from './divider.js';
|
|
11
|
+
import { Spacer } from './spacer.js';
|
|
12
|
+
import { Input } from './input.js';
|
|
13
|
+
import { Textarea } from './textarea.js';
|
|
14
|
+
import { Select } from './select.js';
|
|
15
|
+
import { Checkbox } from './checkbox.js';
|
|
16
|
+
import { Toggle } from './toggle.js';
|
|
17
|
+
import { Slider } from './slider.js';
|
|
18
|
+
import { Button } from './button.js';
|
|
19
|
+
import { Touchable } from './touchable.js';
|
|
20
|
+
import { List } from './list.js';
|
|
21
|
+
import { Modal } from './modal.js';
|
|
22
|
+
import { Drawer } from './drawer.js';
|
|
23
|
+
import { Tabs } from './tabs.js';
|
|
24
|
+
import { Accordion } from './accordion.js';
|
|
25
|
+
import { Wizard } from './wizard.js';
|
|
26
|
+
import { Screen } from './screen.js';
|
|
27
|
+
import { BarChart } from './bar-chart.js';
|
|
28
|
+
import { LineChart } from './line-chart.js';
|
|
29
|
+
import { PieChart } from './pie-chart.js';
|
|
30
|
+
import { AreaChart } from './area-chart.js';
|
|
31
|
+
import { SpatialMap } from './spatial-map.js';
|
|
32
|
+
import { Table } from './table.js';
|
|
33
|
+
import { KanbanBoard } from './kanban-board.js';
|
|
34
|
+
import { FileUpload } from './file-upload.js';
|
|
35
|
+
import { Camera } from './camera.js';
|
|
36
|
+
import { Signature } from './signature.js';
|
|
37
|
+
import { AudioPlayer } from './audio-player.js';
|
|
38
|
+
import { ToastContainer } from './toast-container.js';
|
|
39
|
+
/** Map of primitive name → React component */
|
|
40
|
+
declare const PRIMITIVES: Record<string, React.ComponentType<Record<string, unknown>>>;
|
|
41
|
+
/**
|
|
42
|
+
* Register all built-in React primitives with the plugin loader.
|
|
43
|
+
* Each primitive converts (props, children: RenderNode[]) → RenderNode
|
|
44
|
+
* where the RenderNode carries the React component reference.
|
|
45
|
+
*/
|
|
46
|
+
export declare function registerReactPrimitives(plugins: PluginLoader): void;
|
|
47
|
+
/** Primitives that accept a `className` prop for CSS-based hover/active/focus. */
|
|
48
|
+
export declare const CSS_HOVER_SUPPORTED: Set<string>;
|
|
49
|
+
export { PRIMITIVES };
|
|
50
|
+
export { Box, Text, Image, Icon, Stack, Grid, Scroll, Divider, Spacer };
|
|
51
|
+
export { Input, Textarea, Select, Checkbox, Toggle, Slider };
|
|
52
|
+
export { Button, Touchable, List };
|
|
53
|
+
export { Modal, Drawer, Tabs, Accordion, Wizard, Screen };
|
|
54
|
+
export { BarChart, LineChart, PieChart, AreaChart, SpatialMap, Table, KanbanBoard };
|
|
55
|
+
export { FileUpload, Camera, Signature, AudioPlayer };
|
|
56
|
+
export { ToastContainer };
|
|
57
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/primitives/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import { Box } from './box.js';
|
|
2
|
+
import { Text } from './text.js';
|
|
3
|
+
import { Image } from './image.js';
|
|
4
|
+
import { Icon } from './icon.js';
|
|
5
|
+
import { Stack } from './stack.js';
|
|
6
|
+
import { Grid } from './grid.js';
|
|
7
|
+
import { Scroll } from './scroll.js';
|
|
8
|
+
import { Divider } from './divider.js';
|
|
9
|
+
import { Spacer } from './spacer.js';
|
|
10
|
+
import { Input } from './input.js';
|
|
11
|
+
import { Textarea } from './textarea.js';
|
|
12
|
+
import { Select } from './select.js';
|
|
13
|
+
import { Checkbox } from './checkbox.js';
|
|
14
|
+
import { Toggle } from './toggle.js';
|
|
15
|
+
import { Slider } from './slider.js';
|
|
16
|
+
import { Button } from './button.js';
|
|
17
|
+
import { Touchable } from './touchable.js';
|
|
18
|
+
import { List } from './list.js';
|
|
19
|
+
import { Modal } from './modal.js';
|
|
20
|
+
import { Drawer } from './drawer.js';
|
|
21
|
+
import { Tabs } from './tabs.js';
|
|
22
|
+
import { Accordion } from './accordion.js';
|
|
23
|
+
import { Wizard } from './wizard.js';
|
|
24
|
+
import { Screen } from './screen.js';
|
|
25
|
+
import { BarChart } from './bar-chart.js';
|
|
26
|
+
import { LineChart } from './line-chart.js';
|
|
27
|
+
import { PieChart } from './pie-chart.js';
|
|
28
|
+
import { AreaChart } from './area-chart.js';
|
|
29
|
+
import { SpatialMap } from './spatial-map.js';
|
|
30
|
+
import { Table } from './table.js';
|
|
31
|
+
import { KanbanBoard } from './kanban-board.js';
|
|
32
|
+
import { FileUpload } from './file-upload.js';
|
|
33
|
+
import { Camera } from './camera.js';
|
|
34
|
+
import { Signature } from './signature.js';
|
|
35
|
+
import { AudioPlayer } from './audio-player.js';
|
|
36
|
+
import { ScreenOutlet } from './screen-outlet.js';
|
|
37
|
+
import { ToastContainer } from './toast-container.js';
|
|
38
|
+
import { Skeleton } from './skeleton.js';
|
|
39
|
+
/** Map of primitive name → React component */
|
|
40
|
+
const PRIMITIVES = {
|
|
41
|
+
box: Box,
|
|
42
|
+
text: Text,
|
|
43
|
+
image: Image,
|
|
44
|
+
icon: Icon,
|
|
45
|
+
stack: Stack,
|
|
46
|
+
grid: Grid,
|
|
47
|
+
scroll: Scroll,
|
|
48
|
+
divider: Divider,
|
|
49
|
+
spacer: Spacer,
|
|
50
|
+
input: Input,
|
|
51
|
+
textarea: Textarea,
|
|
52
|
+
select: Select,
|
|
53
|
+
checkbox: Checkbox,
|
|
54
|
+
toggle: Toggle,
|
|
55
|
+
slider: Slider,
|
|
56
|
+
button: Button,
|
|
57
|
+
touchable: Touchable,
|
|
58
|
+
list: List,
|
|
59
|
+
modal: Modal,
|
|
60
|
+
drawer: Drawer,
|
|
61
|
+
tabs: Tabs,
|
|
62
|
+
accordion: Accordion,
|
|
63
|
+
wizard: Wizard,
|
|
64
|
+
screen: Screen,
|
|
65
|
+
'bar-chart': BarChart,
|
|
66
|
+
'line-chart': LineChart,
|
|
67
|
+
'pie-chart': PieChart,
|
|
68
|
+
'area-chart': AreaChart,
|
|
69
|
+
'spatial-map': SpatialMap,
|
|
70
|
+
table: Table,
|
|
71
|
+
'kanban-board': KanbanBoard,
|
|
72
|
+
'file-upload': FileUpload,
|
|
73
|
+
camera: Camera,
|
|
74
|
+
signature: Signature,
|
|
75
|
+
'audio-player': AudioPlayer,
|
|
76
|
+
'screen-outlet': ScreenOutlet,
|
|
77
|
+
'toast-container': ToastContainer,
|
|
78
|
+
skeleton: Skeleton,
|
|
79
|
+
};
|
|
80
|
+
/**
|
|
81
|
+
* Register all built-in React primitives with the plugin loader.
|
|
82
|
+
* Each primitive converts (props, children: RenderNode[]) → RenderNode
|
|
83
|
+
* where the RenderNode carries the React component reference.
|
|
84
|
+
*/
|
|
85
|
+
export function registerReactPrimitives(plugins) {
|
|
86
|
+
for (const [name, Component] of Object.entries(PRIMITIVES)) {
|
|
87
|
+
plugins.registerPrimitive(name, (props, children) => ({
|
|
88
|
+
type: name,
|
|
89
|
+
props: { ...props, _component: Component },
|
|
90
|
+
children,
|
|
91
|
+
}));
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
/** Primitives that accept a `className` prop for CSS-based hover/active/focus. */
|
|
95
|
+
export const CSS_HOVER_SUPPORTED = new Set([
|
|
96
|
+
'box', 'text', 'stack', 'grid', 'scroll', 'button', 'touchable', 'table',
|
|
97
|
+
]);
|
|
98
|
+
export { PRIMITIVES };
|
|
99
|
+
export { Box, Text, Image, Icon, Stack, Grid, Scroll, Divider, Spacer };
|
|
100
|
+
export { Input, Textarea, Select, Checkbox, Toggle, Slider };
|
|
101
|
+
export { Button, Touchable, List };
|
|
102
|
+
export { Modal, Drawer, Tabs, Accordion, Wizard, Screen };
|
|
103
|
+
export { BarChart, LineChart, PieChart, AreaChart, SpatialMap, Table, KanbanBoard };
|
|
104
|
+
export { FileUpload, Camera, Signature, AudioPlayer };
|
|
105
|
+
export { ToastContainer };
|
|
106
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/primitives/index.ts"],"names":[],"mappings":"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"}
|