@refraction-ui/react 0.4.2 → 0.6.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/README.md +9 -1
- package/dist/chunk-O4453CBF.js +137 -0
- package/dist/chunk-O4453CBF.js.map +1 -0
- package/dist/chunk-XWP763SH.js +76 -0
- package/dist/chunk-XWP763SH.js.map +1 -0
- package/dist/faro-engine-47HGRAQH-JKINJPMH.js +3 -0
- package/dist/faro-engine-47HGRAQH-JKINJPMH.js.map +1 -0
- package/dist/form.cjs +340 -0
- package/dist/form.cjs.map +1 -0
- package/dist/form.d.cts +1 -0
- package/dist/form.d.ts +1 -0
- package/dist/form.js +204 -0
- package/dist/form.js.map +1 -0
- package/dist/index.cjs +1438 -237
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +76 -76
- package/dist/index.d.ts +76 -76
- package/dist/index.js +1317 -312
- package/dist/index.js.map +1 -1
- package/dist/internal/analytics/index.d.cts +448 -0
- package/dist/internal/analytics/index.d.ts +448 -0
- package/dist/internal/animated-text/index.d.cts +47 -0
- package/dist/internal/animated-text/index.d.ts +47 -0
- package/dist/internal/app-shell/index.d.cts +128 -0
- package/dist/internal/app-shell/index.d.ts +128 -0
- package/dist/internal/auth/index.d.cts +74 -0
- package/dist/internal/auth/index.d.ts +74 -0
- package/dist/internal/avatar/index.d.cts +53 -0
- package/dist/internal/avatar/index.d.ts +53 -0
- package/dist/internal/avatar-group/index.d.cts +70 -0
- package/dist/internal/avatar-group/index.d.ts +70 -0
- package/dist/internal/badge/index.d.cts +26 -0
- package/dist/internal/badge/index.d.ts +26 -0
- package/dist/internal/bottom-nav/index.d.cts +29 -0
- package/dist/internal/bottom-nav/index.d.ts +29 -0
- package/dist/internal/breadcrumbs/index.d.cts +38 -0
- package/dist/internal/breadcrumbs/index.d.ts +38 -0
- package/dist/internal/button/index.d.cts +34 -0
- package/dist/internal/button/index.d.ts +34 -0
- package/dist/internal/calendar/index.d.cts +73 -0
- package/dist/internal/calendar/index.d.ts +73 -0
- package/dist/internal/card/index.d.cts +62 -0
- package/dist/internal/card/index.d.ts +62 -0
- package/dist/internal/card-grid/index.d.cts +10 -0
- package/dist/internal/card-grid/index.d.ts +10 -0
- package/dist/internal/checkbox/index.d.cts +40 -0
- package/dist/internal/checkbox/index.d.ts +40 -0
- package/dist/internal/code-editor/index.d.cts +47 -0
- package/dist/internal/code-editor/index.d.ts +47 -0
- package/dist/internal/collapsible/index.d.cts +43 -0
- package/dist/internal/collapsible/index.d.ts +43 -0
- package/dist/internal/command/index.d.cts +80 -0
- package/dist/internal/command/index.d.ts +80 -0
- package/dist/internal/content-protection/index.d.cts +47 -0
- package/dist/internal/content-protection/index.d.ts +47 -0
- package/dist/internal/data-table/index.d.cts +73 -0
- package/dist/internal/data-table/index.d.ts +73 -0
- package/dist/internal/date-picker/index.d.cts +98 -0
- package/dist/internal/date-picker/index.d.ts +98 -0
- package/dist/internal/device-frame/index.d.cts +40 -0
- package/dist/internal/device-frame/index.d.ts +40 -0
- package/dist/internal/dialog/index.d.cts +54 -0
- package/dist/internal/dialog/index.d.ts +54 -0
- package/dist/internal/dropdown-menu/index.d.cts +55 -0
- package/dist/internal/dropdown-menu/index.d.ts +55 -0
- package/dist/internal/emoji-picker/index.d.cts +77 -0
- package/dist/internal/emoji-picker/index.d.ts +77 -0
- package/dist/internal/feedback-dialog/index.d.cts +55 -0
- package/dist/internal/feedback-dialog/index.d.ts +55 -0
- package/dist/internal/file-upload/index.d.cts +91 -0
- package/dist/internal/file-upload/index.d.ts +91 -0
- package/dist/internal/footer/index.d.cts +30 -0
- package/dist/internal/footer/index.d.ts +30 -0
- package/dist/internal/inline-editor/index.d.cts +52 -0
- package/dist/internal/inline-editor/index.d.ts +52 -0
- package/dist/internal/input/index.d.cts +38 -0
- package/dist/internal/input/index.d.ts +38 -0
- package/dist/internal/input-group/index.d.cts +35 -0
- package/dist/internal/input-group/index.d.ts +35 -0
- package/dist/internal/install-prompt/index.d.cts +36 -0
- package/dist/internal/install-prompt/index.d.ts +36 -0
- package/dist/internal/keyboard-shortcut/index.d.cts +49 -0
- package/dist/internal/keyboard-shortcut/index.d.ts +49 -0
- package/dist/internal/language-selector/index.d.cts +63 -0
- package/dist/internal/language-selector/index.d.ts +63 -0
- package/dist/internal/logger/index.d.cts +229 -0
- package/dist/internal/logger/index.d.ts +229 -0
- package/dist/internal/markdown-renderer/index.d.cts +40 -0
- package/dist/internal/markdown-renderer/index.d.ts +40 -0
- package/dist/internal/mobile-nav/index.d.cts +45 -0
- package/dist/internal/mobile-nav/index.d.ts +45 -0
- package/dist/internal/navbar/index.d.cts +30 -0
- package/dist/internal/navbar/index.d.ts +30 -0
- package/dist/internal/otp-input/index.d.cts +66 -0
- package/dist/internal/otp-input/index.d.ts +66 -0
- package/dist/internal/payment/index.d.cts +9 -0
- package/dist/internal/payment/index.d.ts +9 -0
- package/dist/internal/popover/index.d.cts +46 -0
- package/dist/internal/popover/index.d.ts +46 -0
- package/dist/internal/presence-indicator/index.d.cts +38 -0
- package/dist/internal/presence-indicator/index.d.ts +38 -0
- package/dist/internal/progress-display/index.d.cts +60 -0
- package/dist/internal/progress-display/index.d.ts +60 -0
- package/dist/internal/radio/index.d.ts +43 -0
- package/dist/internal/react-accordion/index.d.ts +22 -0
- package/dist/internal/react-analytics/index.d.cts +44 -0
- package/dist/internal/react-analytics/index.d.ts +44 -0
- package/dist/internal/react-animated-text/index.d.cts +12 -0
- package/dist/internal/react-animated-text/index.d.ts +12 -0
- package/dist/internal/react-app-shell/index.d.cts +169 -0
- package/dist/internal/react-app-shell/index.d.ts +169 -0
- package/dist/internal/react-auth/index.d.cts +59 -0
- package/dist/internal/react-auth/index.d.ts +59 -0
- package/dist/internal/react-avatar/index.d.cts +20 -0
- package/dist/internal/react-avatar/index.d.ts +20 -0
- package/dist/internal/react-avatar-group/index.d.cts +33 -0
- package/dist/internal/react-avatar-group/index.d.ts +33 -0
- package/dist/internal/react-badge/index.d.cts +17 -0
- package/dist/internal/react-badge/index.d.ts +17 -0
- package/dist/internal/react-bottom-nav/index.d.cts +19 -0
- package/dist/internal/react-bottom-nav/index.d.ts +19 -0
- package/dist/internal/react-breadcrumbs/index.d.cts +24 -0
- package/dist/internal/react-breadcrumbs/index.d.ts +24 -0
- package/dist/internal/react-button/index.d.cts +21 -0
- package/dist/internal/react-button/index.d.ts +21 -0
- package/dist/internal/react-calendar/index.d.cts +44 -0
- package/dist/internal/react-calendar/index.d.ts +44 -0
- package/dist/internal/react-callout/index.d.cts +12 -0
- package/dist/internal/react-callout/index.d.ts +12 -0
- package/dist/internal/react-card/index.d.cts +29 -0
- package/dist/internal/react-card/index.d.ts +29 -0
- package/dist/internal/react-card-grid/index.d.cts +8 -0
- package/dist/internal/react-card-grid/index.d.ts +8 -0
- package/dist/internal/react-carousel/index.d.ts +22 -0
- package/dist/internal/react-checkbox/index.d.cts +18 -0
- package/dist/internal/react-checkbox/index.d.ts +18 -0
- package/dist/internal/react-code-block/index.d.cts +7 -0
- package/dist/internal/react-code-block/index.d.ts +7 -0
- package/dist/internal/react-code-editor/index.d.cts +28 -0
- package/dist/internal/react-code-editor/index.d.ts +28 -0
- package/dist/internal/react-collapsible/index.d.cts +29 -0
- package/dist/internal/react-collapsible/index.d.ts +29 -0
- package/dist/internal/react-combobox/index.d.cts +94 -0
- package/dist/internal/react-combobox/index.d.ts +94 -0
- package/dist/internal/react-command/index.d.cts +51 -0
- package/dist/internal/react-command/index.d.ts +51 -0
- package/dist/internal/react-content-protection/index.d.cts +22 -0
- package/dist/internal/react-content-protection/index.d.ts +22 -0
- package/dist/internal/react-data-table/index.d.cts +22 -0
- package/dist/internal/react-data-table/index.d.ts +22 -0
- package/dist/internal/react-date-picker/index.d.cts +23 -0
- package/dist/internal/react-date-picker/index.d.ts +23 -0
- package/dist/internal/react-device-frame/index.d.cts +37 -0
- package/dist/internal/react-device-frame/index.d.ts +37 -0
- package/dist/internal/react-dialog/index.d.cts +49 -0
- package/dist/internal/react-dialog/index.d.ts +49 -0
- package/dist/internal/react-dropdown-menu/index.d.cts +37 -0
- package/dist/internal/react-dropdown-menu/index.d.ts +37 -0
- package/dist/internal/react-emoji-picker/index.d.cts +32 -0
- package/dist/internal/react-emoji-picker/index.d.ts +32 -0
- package/dist/internal/react-feedback-dialog/index.d.cts +40 -0
- package/dist/internal/react-feedback-dialog/index.d.ts +40 -0
- package/dist/internal/react-file-tree/index.d.cts +5 -0
- package/dist/internal/react-file-tree/index.d.ts +5 -0
- package/dist/internal/react-file-upload/index.d.cts +22 -0
- package/dist/internal/react-file-upload/index.d.ts +22 -0
- package/dist/internal/react-footer/index.d.cts +20 -0
- package/dist/internal/react-footer/index.d.ts +20 -0
- package/dist/internal/react-form/index.d.cts +85 -0
- package/dist/internal/react-form/index.d.ts +85 -0
- package/dist/internal/react-icon-system/index.d.cts +5 -0
- package/dist/internal/react-icon-system/index.d.ts +5 -0
- package/dist/internal/react-inline-editor/index.d.cts +17 -0
- package/dist/internal/react-inline-editor/index.d.ts +17 -0
- package/dist/internal/react-input/index.d.cts +31 -0
- package/dist/internal/react-input/index.d.ts +31 -0
- package/dist/internal/react-input-group/index.d.cts +34 -0
- package/dist/internal/react-input-group/index.d.ts +34 -0
- package/dist/internal/react-install-prompt/index.d.cts +24 -0
- package/dist/internal/react-install-prompt/index.d.ts +24 -0
- package/dist/internal/react-keyboard-shortcut/index.d.cts +57 -0
- package/dist/internal/react-keyboard-shortcut/index.d.ts +57 -0
- package/dist/internal/react-language-selector/index.d.cts +26 -0
- package/dist/internal/react-language-selector/index.d.ts +26 -0
- package/dist/internal/react-link-card/index.d.cts +5 -0
- package/dist/internal/react-link-card/index.d.ts +5 -0
- package/dist/internal/react-logger/index.d.cts +107 -0
- package/dist/internal/react-logger/index.d.ts +107 -0
- package/dist/internal/react-markdown-renderer/index.d.cts +20 -0
- package/dist/internal/react-markdown-renderer/index.d.ts +20 -0
- package/dist/internal/react-mobile-nav/index.d.cts +33 -0
- package/dist/internal/react-mobile-nav/index.d.ts +33 -0
- package/dist/internal/react-navbar/index.d.cts +25 -0
- package/dist/internal/react-navbar/index.d.ts +25 -0
- package/dist/internal/react-otp-input/index.d.cts +21 -0
- package/dist/internal/react-otp-input/index.d.ts +21 -0
- package/dist/internal/react-pagination/index.d.ts +7 -0
- package/dist/internal/react-payment/index.d.cts +9 -0
- package/dist/internal/react-payment/index.d.ts +9 -0
- package/dist/internal/react-popover/index.d.cts +33 -0
- package/dist/internal/react-popover/index.d.ts +33 -0
- package/dist/internal/react-presence-indicator/index.d.cts +34 -0
- package/dist/internal/react-presence-indicator/index.d.ts +34 -0
- package/dist/internal/react-progress-display/index.d.cts +21 -0
- package/dist/internal/react-progress-display/index.d.ts +21 -0
- package/dist/internal/react-radio/index.d.ts +33 -0
- package/dist/internal/react-reaction-bar/index.d.cts +34 -0
- package/dist/internal/react-reaction-bar/index.d.ts +34 -0
- package/dist/internal/react-resizable-layout/index.d.cts +36 -0
- package/dist/internal/react-resizable-layout/index.d.ts +36 -0
- package/dist/internal/react-rich-editor/index.d.cts +2 -0
- package/dist/internal/react-rich-editor/index.d.ts +2 -0
- package/dist/internal/react-search-bar/index.d.cts +32 -0
- package/dist/internal/react-search-bar/index.d.ts +32 -0
- package/dist/internal/react-select/index.d.cts +30 -0
- package/dist/internal/react-select/index.d.ts +30 -0
- package/dist/internal/react-sheet/index.d.cts +67 -0
- package/dist/internal/react-sheet/index.d.ts +67 -0
- package/dist/internal/react-sidebar/index.d.cts +23 -0
- package/dist/internal/react-sidebar/index.d.ts +23 -0
- package/dist/internal/react-skeleton/index.d.cts +31 -0
- package/dist/internal/react-skeleton/index.d.ts +31 -0
- package/dist/internal/react-skip-to-content/index.d.cts +9 -0
- package/dist/internal/react-skip-to-content/index.d.ts +9 -0
- package/dist/internal/react-slide-viewer/index.d.cts +23 -0
- package/dist/internal/react-slide-viewer/index.d.ts +23 -0
- package/dist/internal/react-slider/index.d.cts +1 -0
- package/dist/internal/react-slider/index.d.ts +1 -0
- package/dist/internal/react-status-indicator/index.d.cts +34 -0
- package/dist/internal/react-status-indicator/index.d.ts +34 -0
- package/dist/internal/react-steps/index.d.cts +19 -0
- package/dist/internal/react-steps/index.d.ts +19 -0
- package/dist/internal/react-switch/index.d.cts +17 -0
- package/dist/internal/react-switch/index.d.ts +17 -0
- package/dist/internal/react-table-of-contents/index.d.ts +10 -0
- package/dist/internal/react-tabs/index.d.cts +31 -0
- package/dist/internal/react-tabs/index.d.ts +31 -0
- package/dist/internal/react-textarea/index.d.cts +16 -0
- package/dist/internal/react-textarea/index.d.ts +16 -0
- package/dist/internal/react-theme/index.d.cts +44 -0
- package/dist/internal/react-theme/index.d.ts +44 -0
- package/dist/internal/react-thread-view/index.d.cts +34 -0
- package/dist/internal/react-thread-view/index.d.ts +34 -0
- package/dist/internal/react-toast/index.d.cts +36 -0
- package/dist/internal/react-toast/index.d.ts +36 -0
- package/dist/internal/react-tooltip/index.d.cts +33 -0
- package/dist/internal/react-tooltip/index.d.ts +33 -0
- package/dist/internal/react-version-selector/index.d.cts +24 -0
- package/dist/internal/react-version-selector/index.d.ts +24 -0
- package/dist/internal/react-video-player/index.d.cts +9 -0
- package/dist/internal/react-video-player/index.d.ts +9 -0
- package/dist/internal/react-voice-pill/index.d.cts +10 -0
- package/dist/internal/react-voice-pill/index.d.ts +10 -0
- package/dist/internal/react-waveform/index.d.cts +9 -0
- package/dist/internal/react-waveform/index.d.ts +9 -0
- package/dist/internal/reaction-bar/index.d.cts +50 -0
- package/dist/internal/reaction-bar/index.d.ts +50 -0
- package/dist/internal/resizable-layout/index.d.cts +47 -0
- package/dist/internal/resizable-layout/index.d.ts +47 -0
- package/dist/internal/search-bar/index.d.cts +51 -0
- package/dist/internal/search-bar/index.d.ts +51 -0
- package/dist/internal/select/index.d.cts +69 -0
- package/dist/internal/select/index.d.ts +69 -0
- package/dist/internal/shared/index.d.cts +419 -0
- package/dist/internal/shared/index.d.ts +419 -0
- package/dist/internal/sidebar/index.d.cts +40 -0
- package/dist/internal/sidebar/index.d.ts +40 -0
- package/dist/internal/skeleton/index.d.cts +27 -0
- package/dist/internal/skeleton/index.d.ts +27 -0
- package/dist/internal/slide-viewer/index.d.cts +72 -0
- package/dist/internal/slide-viewer/index.d.ts +72 -0
- package/dist/internal/slider/index.d.cts +4 -0
- package/dist/internal/slider/index.d.ts +4 -0
- package/dist/internal/status-indicator/index.d.cts +42 -0
- package/dist/internal/status-indicator/index.d.ts +42 -0
- package/dist/internal/switch/index.d.cts +41 -0
- package/dist/internal/switch/index.d.ts +41 -0
- package/dist/internal/tabs/index.d.cts +45 -0
- package/dist/internal/tabs/index.d.ts +45 -0
- package/dist/internal/textarea/index.d.cts +28 -0
- package/dist/internal/textarea/index.d.ts +28 -0
- package/dist/internal/theme/index.d.cts +60 -0
- package/dist/internal/theme/index.d.ts +60 -0
- package/dist/internal/thread-view/index.d.cts +95 -0
- package/dist/internal/thread-view/index.d.ts +95 -0
- package/dist/internal/toast/index.d.cts +64 -0
- package/dist/internal/toast/index.d.ts +64 -0
- package/dist/internal/tooltip/index.d.cts +45 -0
- package/dist/internal/tooltip/index.d.ts +45 -0
- package/dist/internal/version-selector/index.d.cts +68 -0
- package/dist/internal/version-selector/index.d.ts +68 -0
- package/dist/internal/video-player/index.d.cts +50 -0
- package/dist/internal/video-player/index.d.ts +50 -0
- package/dist/internal/voice-pill/index.d.cts +86 -0
- package/dist/internal/voice-pill/index.d.ts +86 -0
- package/dist/internal/waveform/index.d.cts +83 -0
- package/dist/internal/waveform/index.d.ts +83 -0
- package/dist/theme.cjs +23 -0
- package/dist/theme.cjs.map +1 -1
- package/dist/theme.d.cts +1 -1
- package/dist/theme.d.ts +1 -1
- package/dist/theme.js +5 -2
- package/dist/theme.js.map +1 -1
- package/package.json +10 -7
|
@@ -0,0 +1,419 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Framework-agnostic base prop types for all refraction-ui components.
|
|
3
|
+
* These are headless core types — no React, Angular, or Astro imports.
|
|
4
|
+
* Framework wrappers extend these with framework-specific types.
|
|
5
|
+
*/
|
|
6
|
+
/** Base props shared by all components */
|
|
7
|
+
interface BaseProps {
|
|
8
|
+
id?: string;
|
|
9
|
+
className?: string;
|
|
10
|
+
style?: Record<string, string | number>;
|
|
11
|
+
[dataAttr: `data-${string}`]: string | undefined;
|
|
12
|
+
}
|
|
13
|
+
/** Accessibility props */
|
|
14
|
+
interface AccessibilityProps {
|
|
15
|
+
role?: string;
|
|
16
|
+
tabIndex?: number;
|
|
17
|
+
'aria-label'?: string;
|
|
18
|
+
'aria-labelledby'?: string;
|
|
19
|
+
'aria-describedby'?: string;
|
|
20
|
+
'aria-controls'?: string;
|
|
21
|
+
'aria-expanded'?: boolean;
|
|
22
|
+
'aria-selected'?: boolean;
|
|
23
|
+
'aria-hidden'?: boolean;
|
|
24
|
+
'aria-disabled'?: boolean;
|
|
25
|
+
'aria-pressed'?: boolean | 'mixed';
|
|
26
|
+
'aria-checked'?: boolean | 'mixed';
|
|
27
|
+
'aria-current'?: boolean | 'page' | 'step' | 'location' | 'date' | 'time';
|
|
28
|
+
'aria-live'?: 'off' | 'assertive' | 'polite';
|
|
29
|
+
'aria-atomic'?: boolean;
|
|
30
|
+
}
|
|
31
|
+
/** Theme customization props (framework-agnostic) */
|
|
32
|
+
interface ThemeProps {
|
|
33
|
+
variant?: string;
|
|
34
|
+
size?: string;
|
|
35
|
+
colorScheme?: string;
|
|
36
|
+
disabled?: boolean;
|
|
37
|
+
}
|
|
38
|
+
/** Composition props (framework-agnostic) */
|
|
39
|
+
interface CompositionProps {
|
|
40
|
+
asChild?: boolean;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
/** Standard size scale */
|
|
44
|
+
type Size = 'xs' | 'sm' | 'md' | 'lg' | 'xl';
|
|
45
|
+
/** Standard component variants */
|
|
46
|
+
type Variant = 'default' | 'primary' | 'secondary' | 'destructive' | 'outline' | 'ghost' | 'link';
|
|
47
|
+
/** Layout orientation */
|
|
48
|
+
type Orientation = 'horizontal' | 'vertical';
|
|
49
|
+
/** Positioning side */
|
|
50
|
+
type Side = 'top' | 'right' | 'bottom' | 'left';
|
|
51
|
+
/** Alignment */
|
|
52
|
+
type Align = 'start' | 'center' | 'end';
|
|
53
|
+
/** Data state attribute values */
|
|
54
|
+
type DataState = 'open' | 'closed' | 'active' | 'inactive';
|
|
55
|
+
|
|
56
|
+
/** Defines the CSS custom properties a component reads */
|
|
57
|
+
interface TokenContract {
|
|
58
|
+
/** Component name */
|
|
59
|
+
name: string;
|
|
60
|
+
/** Map of token name → CSS custom property info */
|
|
61
|
+
tokens: Record<string, TokenDefinition>;
|
|
62
|
+
}
|
|
63
|
+
interface TokenDefinition {
|
|
64
|
+
/** CSS custom property name (e.g., '--rfr-button-bg') */
|
|
65
|
+
variable: string;
|
|
66
|
+
/** Fallback value when the variable is not set */
|
|
67
|
+
fallback: string;
|
|
68
|
+
/** Description of what this token controls */
|
|
69
|
+
description?: string;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
/** Standard keyboard key constants */
|
|
73
|
+
declare const Keys: {
|
|
74
|
+
readonly Enter: "Enter";
|
|
75
|
+
readonly Space: " ";
|
|
76
|
+
readonly Escape: "Escape";
|
|
77
|
+
readonly Tab: "Tab";
|
|
78
|
+
readonly ArrowUp: "ArrowUp";
|
|
79
|
+
readonly ArrowDown: "ArrowDown";
|
|
80
|
+
readonly ArrowLeft: "ArrowLeft";
|
|
81
|
+
readonly ArrowRight: "ArrowRight";
|
|
82
|
+
readonly Home: "Home";
|
|
83
|
+
readonly End: "End";
|
|
84
|
+
readonly PageUp: "PageUp";
|
|
85
|
+
readonly PageDown: "PageDown";
|
|
86
|
+
readonly Backspace: "Backspace";
|
|
87
|
+
readonly Delete: "Delete";
|
|
88
|
+
};
|
|
89
|
+
type KeyboardKey = (typeof Keys)[keyof typeof Keys];
|
|
90
|
+
/** Map of key → handler function */
|
|
91
|
+
type KeyboardHandlerMap = Partial<Record<string, (event: KeyboardEvent) => void>>;
|
|
92
|
+
/** Create a keyboard event handler from a handler map */
|
|
93
|
+
declare function createKeyboardHandler(handlers: KeyboardHandlerMap): (event: KeyboardEvent) => void;
|
|
94
|
+
|
|
95
|
+
/**
|
|
96
|
+
* Minimal state machine — zero dependencies, < 1KB.
|
|
97
|
+
* Inspired by XState concepts but dramatically simpler.
|
|
98
|
+
*/
|
|
99
|
+
interface MachineConfig<TState extends string, TEvent extends string> {
|
|
100
|
+
initial: TState;
|
|
101
|
+
states: Record<TState, {
|
|
102
|
+
on?: Partial<Record<TEvent, TState>>;
|
|
103
|
+
}>;
|
|
104
|
+
}
|
|
105
|
+
interface Machine<TState extends string, TEvent extends string> {
|
|
106
|
+
/** Current state */
|
|
107
|
+
state: TState;
|
|
108
|
+
/** Send an event to transition */
|
|
109
|
+
send(event: TEvent): void;
|
|
110
|
+
/** Subscribe to state changes. Returns unsubscribe function. */
|
|
111
|
+
subscribe(fn: (state: TState) => void): () => void;
|
|
112
|
+
/** Check if machine is in a given state */
|
|
113
|
+
matches(state: TState): boolean;
|
|
114
|
+
}
|
|
115
|
+
declare function createMachine<TState extends string, TEvent extends string>(config: MachineConfig<TState, TEvent>): Machine<TState, TEvent>;
|
|
116
|
+
|
|
117
|
+
/**
|
|
118
|
+
* Focus trap utilities — keeps keyboard focus within a container.
|
|
119
|
+
* Used by Dialog, DropdownMenu, and other overlay components.
|
|
120
|
+
* Pure TypeScript, no DOM dependency (accepts element via parameter).
|
|
121
|
+
*/
|
|
122
|
+
/** Selector for all natively focusable elements */
|
|
123
|
+
declare const FOCUSABLE_SELECTOR = "a[href], button:not([disabled]), input:not([disabled]), select:not([disabled]), textarea:not([disabled]), [tabindex]:not([tabindex=\"-1\"])";
|
|
124
|
+
/** Get all focusable elements within a container */
|
|
125
|
+
declare function getFocusableElements(container: Element): Element[];
|
|
126
|
+
/** Configuration for creating a focus trap */
|
|
127
|
+
interface FocusTrapConfig {
|
|
128
|
+
/** The container element */
|
|
129
|
+
container: Element;
|
|
130
|
+
/** Called to get the initial focus target */
|
|
131
|
+
initialFocus?: () => Element | null;
|
|
132
|
+
/** Called when Escape is pressed */
|
|
133
|
+
onEscape?: () => void;
|
|
134
|
+
/** Whether to return focus to trigger on deactivate */
|
|
135
|
+
returnFocusOnDeactivate?: boolean;
|
|
136
|
+
}
|
|
137
|
+
/** A focus trap instance */
|
|
138
|
+
interface FocusTrap {
|
|
139
|
+
activate(): void;
|
|
140
|
+
deactivate(): void;
|
|
141
|
+
isActive(): boolean;
|
|
142
|
+
}
|
|
143
|
+
/** Create a focus trap that keeps Tab/Shift+Tab within a container */
|
|
144
|
+
declare function createFocusTrap(config: FocusTrapConfig): FocusTrap;
|
|
145
|
+
|
|
146
|
+
/**
|
|
147
|
+
* Screen reader announcement utility.
|
|
148
|
+
* Creates and manages an aria-live region for dynamic content updates.
|
|
149
|
+
*/
|
|
150
|
+
interface LiveRegionConfig {
|
|
151
|
+
/** 'polite' (default) or 'assertive' */
|
|
152
|
+
politeness?: 'polite' | 'assertive';
|
|
153
|
+
/** Clear the announcement after this many ms. Default: 5000 */
|
|
154
|
+
clearAfterMs?: number;
|
|
155
|
+
}
|
|
156
|
+
interface LiveRegion {
|
|
157
|
+
announce(message: string): void;
|
|
158
|
+
clear(): void;
|
|
159
|
+
destroy(): void;
|
|
160
|
+
}
|
|
161
|
+
/** Create a live region that announces messages to screen readers */
|
|
162
|
+
declare function createLiveRegion(config?: LiveRegionConfig): LiveRegion;
|
|
163
|
+
|
|
164
|
+
interface EngineAdapter<TState = Record<string, unknown>, TMethods = Record<string, unknown>, TReturnProps = Record<string, unknown>> {
|
|
165
|
+
name: string;
|
|
166
|
+
state: TState;
|
|
167
|
+
methods: TMethods;
|
|
168
|
+
getProps: (elementName: string, props?: Record<string, unknown>) => TReturnProps;
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
/**
|
|
172
|
+
* Skip-to-content link utility.
|
|
173
|
+
* Provides a keyboard-accessible link that is visually hidden until focused.
|
|
174
|
+
*/
|
|
175
|
+
/** Props for a skip-to-content link */
|
|
176
|
+
interface SkipLinkProps {
|
|
177
|
+
/** ID of the target element. Default: 'main-content' */
|
|
178
|
+
targetId?: string;
|
|
179
|
+
/** Label text for the link. Default: 'Skip to main content' */
|
|
180
|
+
label?: string;
|
|
181
|
+
}
|
|
182
|
+
/** Create props for a skip-to-content link */
|
|
183
|
+
declare function createSkipLink(props?: SkipLinkProps): {
|
|
184
|
+
ariaProps: Record<string, string>;
|
|
185
|
+
href: string;
|
|
186
|
+
label: string;
|
|
187
|
+
/** CSS classes — visually hidden until focused */
|
|
188
|
+
className: string;
|
|
189
|
+
};
|
|
190
|
+
|
|
191
|
+
/**
|
|
192
|
+
* dev-feedback — zero-dependency `devWarn` / `devError` primitives.
|
|
193
|
+
*
|
|
194
|
+
* Design constraints (epic #247, issue #248):
|
|
195
|
+
* - Guarded by `process.env.NODE_ENV !== 'production'` so production bundlers
|
|
196
|
+
* dead-code-strip every call (the guard is a static string compare that
|
|
197
|
+
* minifiers fold to `false` in prod builds).
|
|
198
|
+
* - Warn-once dedupe per `code` — a footgun is reported once, not on every
|
|
199
|
+
* render.
|
|
200
|
+
* - NO import of `@refraction-ui/logger` (no hard dependency on the telemetry
|
|
201
|
+
* lib). Forwarding to a telemetry sink happens ONLY if the consumer
|
|
202
|
+
* explicitly injects one (dependency inversion, never an import).
|
|
203
|
+
*/
|
|
204
|
+
/**
|
|
205
|
+
* Minimal structural shape of the record a telemetry sink consumes. This is a
|
|
206
|
+
* deliberate structural mirror of `@refraction-ui/logger`'s `LogRecord` — it is
|
|
207
|
+
* NOT imported, so `@refraction-ui/shared` keeps zero dependency on the
|
|
208
|
+
* telemetry lib. A consumer that wires the real logger sink satisfies this
|
|
209
|
+
* shape structurally.
|
|
210
|
+
*/
|
|
211
|
+
interface DevFeedbackRecord {
|
|
212
|
+
level: 'warn' | 'error';
|
|
213
|
+
message: string;
|
|
214
|
+
timestamp: number;
|
|
215
|
+
/** Structured detail — the library-origin envelope lives here. */
|
|
216
|
+
context: Record<string, unknown>;
|
|
217
|
+
}
|
|
218
|
+
/**
|
|
219
|
+
* The narrow contract a consumer-injected telemetry sink must satisfy. Kept
|
|
220
|
+
* intentionally minimal and structural so the real `TelemetrySink` from
|
|
221
|
+
* `@refraction-ui/logger` is assignable WITHOUT shared importing the logger.
|
|
222
|
+
*/
|
|
223
|
+
interface DevFeedbackSink {
|
|
224
|
+
/** Receive a single dev-feedback record. Must never throw to the caller. */
|
|
225
|
+
log(record: DevFeedbackRecord): void;
|
|
226
|
+
}
|
|
227
|
+
/**
|
|
228
|
+
* Wire an optional telemetry sink that {@link devWarn} / {@link devError}
|
|
229
|
+
* forward to (in addition to the console). Inversion of control: the consumer
|
|
230
|
+
* owns the sink; this package never imports it. Pass `null` to unwire.
|
|
231
|
+
*
|
|
232
|
+
* Forwarding still only happens in non-production (the calls themselves are
|
|
233
|
+
* stripped in prod), and still respects warn-once dedupe.
|
|
234
|
+
*/
|
|
235
|
+
declare function setDevFeedbackSink(sink: DevFeedbackSink | null): void;
|
|
236
|
+
/** Test-only / consumer-only escape hatch to reset warn-once dedupe state. */
|
|
237
|
+
declare function resetDevFeedback(): void;
|
|
238
|
+
/**
|
|
239
|
+
* Emit a development-only warning for a refraction-ui footgun.
|
|
240
|
+
*
|
|
241
|
+
* @param code Stable, greppable identifier (e.g. `'react/no-controlled-prop'`).
|
|
242
|
+
* @param message Human-readable explanation.
|
|
243
|
+
* @param detail Optional structured detail (forwarded to an injected sink).
|
|
244
|
+
*
|
|
245
|
+
* Stripped entirely in production. Warned at most once per `code`.
|
|
246
|
+
*/
|
|
247
|
+
declare function devWarn(code: string, message: string, detail?: Record<string, unknown>): void;
|
|
248
|
+
/**
|
|
249
|
+
* Emit a development-only error for a refraction-ui misuse / invariant break.
|
|
250
|
+
*
|
|
251
|
+
* @param code Stable, greppable identifier.
|
|
252
|
+
* @param message Human-readable explanation.
|
|
253
|
+
* @param detail Optional structured detail (forwarded to an injected sink).
|
|
254
|
+
*
|
|
255
|
+
* Stripped entirely in production. Reported at most once per `code`.
|
|
256
|
+
*/
|
|
257
|
+
declare function devError(code: string, message: string, detail?: Record<string, unknown>): void;
|
|
258
|
+
|
|
259
|
+
/**
|
|
260
|
+
* library-origin-error — builds the **library-origin error envelope** for
|
|
261
|
+
* errors that originate inside a `@refraction-ui/*` package.
|
|
262
|
+
*
|
|
263
|
+
* The envelope is expressed THROUGH the existing telemetry record contract
|
|
264
|
+
* (`@refraction-ui/logger`'s `LogRecord`) — the contract is reused, NOT
|
|
265
|
+
* redefined. To keep `@refraction-ui/shared` zero-dependency, the record is
|
|
266
|
+
* mirrored structurally (see {@link DevFeedbackRecord}) rather than imported;
|
|
267
|
+
* a consumer wiring the real logger sink satisfies it structurally.
|
|
268
|
+
*
|
|
269
|
+
* Aggressive redaction (epic #247 guardrails): the payload is package,
|
|
270
|
+
* componentName, version, a normalized stack **fingerprint hash**, and
|
|
271
|
+
* framework only. Never app state, props values, user data, PII, or full app
|
|
272
|
+
* stack frames.
|
|
273
|
+
*/
|
|
274
|
+
|
|
275
|
+
/** Frameworks a refraction-ui adapter can run under. */
|
|
276
|
+
type LibraryFramework = 'react' | 'angular' | 'astro' | 'vue' | 'svelte' | 'vanilla' | 'unknown';
|
|
277
|
+
/** Inputs describing where a library-origin error came from. */
|
|
278
|
+
interface LibraryOriginErrorInput {
|
|
279
|
+
/** Originating package, e.g. `@refraction-ui/react`. */
|
|
280
|
+
package: string;
|
|
281
|
+
/** refraction-ui component the error originated in, e.g. `Dialog`. */
|
|
282
|
+
componentName: string;
|
|
283
|
+
/** Originating package version, e.g. `0.1.5`. */
|
|
284
|
+
version: string;
|
|
285
|
+
/** Host framework the component was running under. */
|
|
286
|
+
framework: LibraryFramework;
|
|
287
|
+
/** The thrown error (or its stack string). Used ONLY to derive a hash. */
|
|
288
|
+
error?: unknown;
|
|
289
|
+
}
|
|
290
|
+
/**
|
|
291
|
+
* The redacted, library-origin payload carried in `LogRecord.context`. Contains
|
|
292
|
+
* NO app data — only the five identifying fields plus a stack fingerprint hash.
|
|
293
|
+
*/
|
|
294
|
+
interface LibraryOriginEnvelope {
|
|
295
|
+
/** Marks this record as a library-origin error (for downstream routing). */
|
|
296
|
+
origin: 'refraction-ui';
|
|
297
|
+
package: string;
|
|
298
|
+
componentName: string;
|
|
299
|
+
version: string;
|
|
300
|
+
framework: LibraryFramework;
|
|
301
|
+
/** Stable, app-data-free hash of the normalized stack. */
|
|
302
|
+
fingerprint: string;
|
|
303
|
+
}
|
|
304
|
+
/**
|
|
305
|
+
* Compute the stable stack fingerprint for a library-origin error. Exposed
|
|
306
|
+
* separately so capture seams / tests can assert fingerprint stability without
|
|
307
|
+
* building the whole record.
|
|
308
|
+
*/
|
|
309
|
+
declare function stackFingerprint(error: unknown): string;
|
|
310
|
+
/**
|
|
311
|
+
* Build the redacted library-origin envelope for an error.
|
|
312
|
+
*/
|
|
313
|
+
declare function libraryOriginEnvelope(input: LibraryOriginErrorInput): LibraryOriginEnvelope;
|
|
314
|
+
/**
|
|
315
|
+
* Build the full library-origin error record, expressed THROUGH the existing
|
|
316
|
+
* telemetry record contract (`LogRecord`, mirrored as {@link DevFeedbackRecord}
|
|
317
|
+
* to avoid a hard logger dependency). The redacted envelope rides in
|
|
318
|
+
* `context`; no app data, props, PII, or app stack frames are included.
|
|
319
|
+
*
|
|
320
|
+
* This record is exactly what a consumer-wired telemetry sink (or the
|
|
321
|
+
* `devWarn`/`devError` injected sink) consumes.
|
|
322
|
+
*/
|
|
323
|
+
declare function libraryOriginError(input: LibraryOriginErrorInput): DevFeedbackRecord;
|
|
324
|
+
/**
|
|
325
|
+
* Library-origin predicate — `true` iff the error's stack contains at least
|
|
326
|
+
* one frame that references a `@refraction-ui/*` package. This is the gate
|
|
327
|
+
* every per-framework capture seam uses: only library-origin errors are
|
|
328
|
+
* eligible; the app's own errors return `false` and pass through untouched.
|
|
329
|
+
*
|
|
330
|
+
* Mirrors exactly the frame-detection rule {@link stackFingerprint} normalizes
|
|
331
|
+
* by — no new contract, just the companion predicate the seams need. Never
|
|
332
|
+
* throws for a missing/odd error (returns `false`).
|
|
333
|
+
*/
|
|
334
|
+
declare function isLibraryOriginError(error: unknown): boolean;
|
|
335
|
+
/**
|
|
336
|
+
* The fixed identity of the refraction-ui package/component a seam tags an
|
|
337
|
+
* error with. The seam supplies this; the stack itself supplies the
|
|
338
|
+
* fingerprint. Never carries app data.
|
|
339
|
+
*/
|
|
340
|
+
type LibraryOriginIdentity = Pick<LibraryOriginErrorInput, 'package' | 'componentName' | 'version' | 'framework'>;
|
|
341
|
+
/**
|
|
342
|
+
* The single capture primitive shared by every per-framework seam (React error
|
|
343
|
+
* boundary, Angular `ErrorHandler`, Astro middleware). It performs the entire
|
|
344
|
+
* guarded flow in one place so the seams stay thin and identical in behavior:
|
|
345
|
+
*
|
|
346
|
+
* 1. **Library-origin filter** — if the error's stack has no
|
|
347
|
+
* `@refraction-ui/*` frame it is the app's own error: return `null` and do
|
|
348
|
+
* NOT touch, capture, or forward it.
|
|
349
|
+
* 2. **Tag** — build the redacted {@link libraryOriginError} record
|
|
350
|
+
* (package/componentName/version/framework + app-data-free fingerprint).
|
|
351
|
+
* 3. **Route to the optional sink** — forward the record to the
|
|
352
|
+
* consumer-injected sink ONLY if one was wired; a broken sink can never
|
|
353
|
+
* break the consumer app. With no sink this is a no-op beyond returning
|
|
354
|
+
* the record (so a seam can still surface it locally).
|
|
355
|
+
*
|
|
356
|
+
* @returns the tagged record for a library-origin error, or `null` when the
|
|
357
|
+
* error is app-origin (the "pass through untouched" signal).
|
|
358
|
+
*/
|
|
359
|
+
declare function captureLibraryOriginError(error: unknown, identity: LibraryOriginIdentity, sink: DevFeedbackSink | null | undefined): DevFeedbackRecord | null;
|
|
360
|
+
|
|
361
|
+
/** Merge multiple ARIA prop objects, later values override earlier ones */
|
|
362
|
+
declare function mergeAriaProps(...propSets: Array<Record<string, unknown>>): Record<string, unknown>;
|
|
363
|
+
/**
|
|
364
|
+
* Generate a unique ID, safe for SSR (deterministic within a render pass).
|
|
365
|
+
* In browsers, uses crypto.randomUUID when available.
|
|
366
|
+
*/
|
|
367
|
+
declare function generateId(prefix?: string): string;
|
|
368
|
+
/** Reset the ID counter (useful for tests) */
|
|
369
|
+
declare function resetIdCounter(): void;
|
|
370
|
+
|
|
371
|
+
/**
|
|
372
|
+
* Lightweight class name utility — our own implementation.
|
|
373
|
+
* Handles conditional classes, arrays, and falsy values.
|
|
374
|
+
* No external dependencies (no clsx, no tailwind-merge).
|
|
375
|
+
*
|
|
376
|
+
* For Tailwind class conflict resolution (e.g., 'p-2 p-4' → 'p-4'),
|
|
377
|
+
* consumers can use @refraction-ui/tailwind-config which provides
|
|
378
|
+
* a tw-merge-aware variant of this function.
|
|
379
|
+
*/
|
|
380
|
+
type ClassValue = string | number | boolean | undefined | null | ClassValue[];
|
|
381
|
+
type ClassRecord = Record<string, boolean | undefined | null>;
|
|
382
|
+
declare function cn(...inputs: Array<ClassValue | ClassRecord>): string;
|
|
383
|
+
|
|
384
|
+
/**
|
|
385
|
+
* Lightweight class-variance-authority alternative — zero dependencies.
|
|
386
|
+
* Creates variant-driven class name functions for components.
|
|
387
|
+
*/
|
|
388
|
+
interface VariantConfig {
|
|
389
|
+
[variant: string]: Record<string, string>;
|
|
390
|
+
}
|
|
391
|
+
interface CVAConfig<V extends VariantConfig> {
|
|
392
|
+
base?: string;
|
|
393
|
+
variants?: V;
|
|
394
|
+
defaultVariants?: {
|
|
395
|
+
[K in keyof V]?: keyof V[K];
|
|
396
|
+
};
|
|
397
|
+
compoundVariants?: Array<{
|
|
398
|
+
[K in keyof V]?: keyof V[K];
|
|
399
|
+
} & {
|
|
400
|
+
class: string;
|
|
401
|
+
}>;
|
|
402
|
+
}
|
|
403
|
+
type VariantProps<V extends VariantConfig> = {
|
|
404
|
+
[K in keyof V]?: keyof V[K];
|
|
405
|
+
};
|
|
406
|
+
declare function cva<V extends VariantConfig>(config: CVAConfig<V>): (props?: VariantProps<V> & {
|
|
407
|
+
className?: string;
|
|
408
|
+
}) => string;
|
|
409
|
+
|
|
410
|
+
/**
|
|
411
|
+
* Reduced motion utilities.
|
|
412
|
+
* Respects user preferences for reduced motion.
|
|
413
|
+
*/
|
|
414
|
+
/** Check if user prefers reduced motion */
|
|
415
|
+
declare function prefersReducedMotion(): boolean;
|
|
416
|
+
/** Get animation duration — returns '0ms' if reduced motion preferred */
|
|
417
|
+
declare function getAnimationDuration(normalDuration: string): string;
|
|
418
|
+
|
|
419
|
+
export { type AccessibilityProps, type Align, type BaseProps, type CompositionProps, type DataState, type DevFeedbackRecord, type DevFeedbackSink, type EngineAdapter, FOCUSABLE_SELECTOR, type FocusTrap, type FocusTrapConfig, type KeyboardHandlerMap, type KeyboardKey, Keys, type LibraryFramework, type LibraryOriginEnvelope, type LibraryOriginErrorInput, type LibraryOriginIdentity, type LiveRegion, type LiveRegionConfig, type Machine, type MachineConfig, type Orientation, type Side, type Size, type SkipLinkProps, type ThemeProps, type TokenContract, type TokenDefinition, type Variant, captureLibraryOriginError, cn, createFocusTrap, createKeyboardHandler, createLiveRegion, createMachine, createSkipLink, cva, devError, devWarn, generateId, getAnimationDuration, getFocusableElements, isLibraryOriginError, libraryOriginEnvelope, libraryOriginError, mergeAriaProps, prefersReducedMotion, resetDevFeedback, resetIdCounter, setDevFeedbackSink, stackFingerprint };
|