@mercury-fx/ui 2.4.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.
Files changed (179) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +44 -0
  3. package/dist/components/actions/Button/Button.d.ts +17 -0
  4. package/dist/components/actions/Button/index.d.ts +1 -0
  5. package/dist/components/actions/IconButton/IconButton.d.ts +24 -0
  6. package/dist/components/actions/IconButton/index.d.ts +1 -0
  7. package/dist/components/actions/Link/Link.d.ts +26 -0
  8. package/dist/components/actions/Link/index.d.ts +1 -0
  9. package/dist/components/data-display/Avatar/Avatar.d.ts +8 -0
  10. package/dist/components/data-display/Avatar/index.d.ts +1 -0
  11. package/dist/components/data-display/Badge/Badge.d.ts +8 -0
  12. package/dist/components/data-display/Badge/index.d.ts +1 -0
  13. package/dist/components/data-display/Blockquote/Blockquote.d.ts +18 -0
  14. package/dist/components/data-display/Blockquote/index.d.ts +1 -0
  15. package/dist/components/data-display/Card/Card.d.ts +9 -0
  16. package/dist/components/data-display/Card/index.d.ts +1 -0
  17. package/dist/components/data-display/Chart/Chart.d.ts +41 -0
  18. package/dist/components/data-display/Chart/index.d.ts +1 -0
  19. package/dist/components/data-display/Checklist/Checklist.d.ts +14 -0
  20. package/dist/components/data-display/Checklist/index.d.ts +1 -0
  21. package/dist/components/data-display/Chip/Chip.d.ts +13 -0
  22. package/dist/components/data-display/Chip/index.d.ts +1 -0
  23. package/dist/components/data-display/Code/Code.d.ts +22 -0
  24. package/dist/components/data-display/Code/index.d.ts +1 -0
  25. package/dist/components/data-display/DataList/DataList.d.ts +27 -0
  26. package/dist/components/data-display/DataList/index.d.ts +1 -0
  27. package/dist/components/data-display/Kbd/Kbd.d.ts +14 -0
  28. package/dist/components/data-display/Kbd/index.d.ts +1 -0
  29. package/dist/components/data-display/ListRow/ListRow.d.ts +16 -0
  30. package/dist/components/data-display/ListRow/index.d.ts +1 -0
  31. package/dist/components/data-display/Stat/Stat.d.ts +16 -0
  32. package/dist/components/data-display/Stat/index.d.ts +1 -0
  33. package/dist/components/data-display/Table/Table.d.ts +14 -0
  34. package/dist/components/data-display/Table/index.d.ts +1 -0
  35. package/dist/components/data-display/Tag/Tag.d.ts +9 -0
  36. package/dist/components/data-display/Tag/index.d.ts +1 -0
  37. package/dist/components/feedback/Alert/Alert.d.ts +11 -0
  38. package/dist/components/feedback/Alert/index.d.ts +1 -0
  39. package/dist/components/feedback/Callout/Callout.d.ts +26 -0
  40. package/dist/components/feedback/Callout/index.d.ts +1 -0
  41. package/dist/components/feedback/PasswordStrength/PasswordStrength.d.ts +13 -0
  42. package/dist/components/feedback/PasswordStrength/index.d.ts +1 -0
  43. package/dist/components/feedback/Progress/Progress.d.ts +9 -0
  44. package/dist/components/feedback/Progress/index.d.ts +1 -0
  45. package/dist/components/feedback/Skeleton/Skeleton.d.ts +19 -0
  46. package/dist/components/feedback/Skeleton/index.d.ts +1 -0
  47. package/dist/components/feedback/Spinner/Spinner.d.ts +18 -0
  48. package/dist/components/feedback/Spinner/index.d.ts +1 -0
  49. package/dist/components/foundations/Divider/Divider.d.ts +11 -0
  50. package/dist/components/foundations/Divider/index.d.ts +1 -0
  51. package/dist/components/foundations/Heading/Heading.d.ts +26 -0
  52. package/dist/components/foundations/Heading/index.d.ts +1 -0
  53. package/dist/components/foundations/Icon/Icon.d.ts +9 -0
  54. package/dist/components/foundations/Icon/index.d.ts +1 -0
  55. package/dist/components/foundations/Separator/Separator.d.ts +20 -0
  56. package/dist/components/foundations/Separator/index.d.ts +1 -0
  57. package/dist/components/foundations/Text/Text.d.ts +19 -0
  58. package/dist/components/foundations/Text/index.d.ts +1 -0
  59. package/dist/components/inputs/AuthCode/AuthCode.d.ts +10 -0
  60. package/dist/components/inputs/AuthCode/index.d.ts +1 -0
  61. package/dist/components/inputs/Calendar/Calendar.d.ts +24 -0
  62. package/dist/components/inputs/Calendar/index.d.ts +1 -0
  63. package/dist/components/inputs/DateField/DateField.d.ts +25 -0
  64. package/dist/components/inputs/DateField/index.d.ts +1 -0
  65. package/dist/components/inputs/Input/Input.d.ts +9 -0
  66. package/dist/components/inputs/Input/index.d.ts +1 -0
  67. package/dist/components/inputs/Label/Label.d.ts +20 -0
  68. package/dist/components/inputs/Label/index.d.ts +1 -0
  69. package/dist/components/inputs/MoneyInput/MoneyInput.d.ts +12 -0
  70. package/dist/components/inputs/MoneyInput/index.d.ts +1 -0
  71. package/dist/components/inputs/Search/Search.d.ts +7 -0
  72. package/dist/components/inputs/Search/index.d.ts +1 -0
  73. package/dist/components/inputs/Select/Select.d.ts +14 -0
  74. package/dist/components/inputs/Select/index.d.ts +1 -0
  75. package/dist/components/inputs/Textarea/Textarea.d.ts +9 -0
  76. package/dist/components/inputs/Textarea/index.d.ts +1 -0
  77. package/dist/components/layout/AspectRatio/AspectRatio.d.ts +14 -0
  78. package/dist/components/layout/AspectRatio/index.d.ts +1 -0
  79. package/dist/components/layout/AuthLayout/AuthLayout.d.ts +30 -0
  80. package/dist/components/layout/AuthLayout/index.d.ts +1 -0
  81. package/dist/components/layout/Box/Box.d.ts +35 -0
  82. package/dist/components/layout/Box/index.d.ts +1 -0
  83. package/dist/components/layout/Center/Center.d.ts +13 -0
  84. package/dist/components/layout/Center/index.d.ts +1 -0
  85. package/dist/components/layout/Cluster/Cluster.d.ts +18 -0
  86. package/dist/components/layout/Cluster/index.d.ts +1 -0
  87. package/dist/components/layout/Collapsible/Collapsible.d.ts +26 -0
  88. package/dist/components/layout/Collapsible/index.d.ts +1 -0
  89. package/dist/components/layout/Container/Container.d.ts +19 -0
  90. package/dist/components/layout/Container/index.d.ts +1 -0
  91. package/dist/components/layout/Flex/Flex.d.ts +24 -0
  92. package/dist/components/layout/Flex/index.d.ts +1 -0
  93. package/dist/components/layout/Grid/Grid.d.ts +26 -0
  94. package/dist/components/layout/Grid/index.d.ts +1 -0
  95. package/dist/components/layout/GridItem/GridItem.d.ts +19 -0
  96. package/dist/components/layout/GridItem/index.d.ts +1 -0
  97. package/dist/components/layout/ScrollArea/ScrollArea.d.ts +22 -0
  98. package/dist/components/layout/ScrollArea/index.d.ts +1 -0
  99. package/dist/components/layout/Section/Section.d.ts +18 -0
  100. package/dist/components/layout/Section/index.d.ts +1 -0
  101. package/dist/components/layout/Sidebar/Sidebar.d.ts +21 -0
  102. package/dist/components/layout/Sidebar/index.d.ts +1 -0
  103. package/dist/components/layout/Spacer/Spacer.d.ts +15 -0
  104. package/dist/components/layout/Spacer/index.d.ts +1 -0
  105. package/dist/components/layout/Stack/Stack.d.ts +20 -0
  106. package/dist/components/layout/Stack/index.d.ts +1 -0
  107. package/dist/components/layout/scales.d.ts +20 -0
  108. package/dist/components/navigation/Accordion/Accordion.d.ts +17 -0
  109. package/dist/components/navigation/Accordion/index.d.ts +1 -0
  110. package/dist/components/navigation/Menubar/Menubar.d.ts +53 -0
  111. package/dist/components/navigation/Menubar/index.d.ts +1 -0
  112. package/dist/components/navigation/Pagination/Pagination.d.ts +14 -0
  113. package/dist/components/navigation/Pagination/index.d.ts +1 -0
  114. package/dist/components/navigation/TabNav/TabNav.d.ts +38 -0
  115. package/dist/components/navigation/TabNav/index.d.ts +1 -0
  116. package/dist/components/navigation/Tabs/Tabs.d.ts +12 -0
  117. package/dist/components/navigation/Tabs/index.d.ts +1 -0
  118. package/dist/components/overlay/AlertDialog/AlertDialog.d.ts +33 -0
  119. package/dist/components/overlay/AlertDialog/index.d.ts +1 -0
  120. package/dist/components/overlay/ContextMenu/ContextMenu.d.ts +40 -0
  121. package/dist/components/overlay/ContextMenu/index.d.ts +1 -0
  122. package/dist/components/overlay/Dialog/Dialog.d.ts +33 -0
  123. package/dist/components/overlay/Dialog/index.d.ts +1 -0
  124. package/dist/components/overlay/Dropdown/Dropdown.d.ts +48 -0
  125. package/dist/components/overlay/Dropdown/index.d.ts +1 -0
  126. package/dist/components/overlay/HoverCard/HoverCard.d.ts +35 -0
  127. package/dist/components/overlay/HoverCard/index.d.ts +1 -0
  128. package/dist/components/overlay/LinkPreview/LinkPreview.d.ts +33 -0
  129. package/dist/components/overlay/LinkPreview/index.d.ts +1 -0
  130. package/dist/components/overlay/Modal/Modal.d.ts +10 -0
  131. package/dist/components/overlay/Modal/index.d.ts +1 -0
  132. package/dist/components/overlay/Popover/Popover.d.ts +35 -0
  133. package/dist/components/overlay/Popover/index.d.ts +1 -0
  134. package/dist/components/overlay/Tooltip/Tooltip.d.ts +6 -0
  135. package/dist/components/overlay/Tooltip/index.d.ts +1 -0
  136. package/dist/components/overlay/_overlay/Portal.d.ts +14 -0
  137. package/dist/components/selection/Checkbox/Checkbox.d.ts +12 -0
  138. package/dist/components/selection/Checkbox/index.d.ts +1 -0
  139. package/dist/components/selection/CheckboxCards/CheckboxCards.d.ts +20 -0
  140. package/dist/components/selection/CheckboxCards/index.d.ts +1 -0
  141. package/dist/components/selection/CheckboxGroup/CheckboxGroup.d.ts +17 -0
  142. package/dist/components/selection/CheckboxGroup/index.d.ts +1 -0
  143. package/dist/components/selection/Radio/Radio.d.ts +11 -0
  144. package/dist/components/selection/Radio/index.d.ts +1 -0
  145. package/dist/components/selection/RadioCards/RadioCards.d.ts +20 -0
  146. package/dist/components/selection/RadioCards/index.d.ts +1 -0
  147. package/dist/components/selection/RadioGroup/RadioGroup.d.ts +18 -0
  148. package/dist/components/selection/RadioGroup/index.d.ts +1 -0
  149. package/dist/components/selection/Segmented/Segmented.d.ts +13 -0
  150. package/dist/components/selection/Segmented/index.d.ts +1 -0
  151. package/dist/components/selection/Slider/Slider.d.ts +13 -0
  152. package/dist/components/selection/Slider/index.d.ts +1 -0
  153. package/dist/components/selection/Switch/Switch.d.ts +10 -0
  154. package/dist/components/selection/Switch/index.d.ts +1 -0
  155. package/dist/components/selection/Toggle/Toggle.d.ts +36 -0
  156. package/dist/components/selection/Toggle/index.d.ts +1 -0
  157. package/dist/index.d.ts +93 -0
  158. package/dist/mercury-ui.css +1 -0
  159. package/dist/mercury-ui.js +4049 -0
  160. package/package.json +58 -0
  161. package/src/styles/additions.css +1030 -0
  162. package/src/styles/fonts/DMMono-Italic.woff2 +0 -0
  163. package/src/styles/fonts/DMMono-Light.woff2 +0 -0
  164. package/src/styles/fonts/DMMono-LightItalic.woff2 +0 -0
  165. package/src/styles/fonts/DMMono-Medium.woff2 +0 -0
  166. package/src/styles/fonts/DMMono-MediumItalic.woff2 +0 -0
  167. package/src/styles/fonts/DMMono-Regular.woff2 +0 -0
  168. package/src/styles/fonts/DMSans-Bold.woff2 +0 -0
  169. package/src/styles/fonts/DMSans-BoldItalic.woff2 +0 -0
  170. package/src/styles/fonts/DMSans-Italic.woff2 +0 -0
  171. package/src/styles/fonts/DMSans-Medium.woff2 +0 -0
  172. package/src/styles/fonts/DMSans-MediumItalic.woff2 +0 -0
  173. package/src/styles/fonts/DMSans-Regular.woff2 +0 -0
  174. package/src/styles/fonts/DMSerifDisplay-Italic.woff2 +0 -0
  175. package/src/styles/fonts/DMSerifDisplay-Regular.woff2 +0 -0
  176. package/src/styles/index.css +5 -0
  177. package/src/styles/layout.css +55 -0
  178. package/src/styles/mercury.css +676 -0
  179. package/src/styles/tokens.css +438 -0
@@ -0,0 +1,13 @@
1
+ export interface Segment<T extends string> {
2
+ label: string;
3
+ value: T;
4
+ disabled?: boolean;
5
+ }
6
+ export interface SegmentedProps<T extends string> {
7
+ segments: Segment<T>[];
8
+ value: T;
9
+ onChange?: (value: T) => void;
10
+ size?: "sm" | "md" | "lg";
11
+ fullWidth?: boolean;
12
+ }
13
+ export declare function Segmented<T extends string>({ segments, value, onChange, size, fullWidth }: SegmentedProps<T>): import("react").JSX.Element;
@@ -0,0 +1 @@
1
+ export * from "./Segmented";
@@ -0,0 +1,13 @@
1
+ export interface SliderProps {
2
+ value: number;
3
+ onChange?: (value: number) => void;
4
+ min?: number;
5
+ max?: number;
6
+ step?: number;
7
+ label?: string;
8
+ unit?: string;
9
+ showValue?: boolean;
10
+ size?: "sm" | "md";
11
+ disabled?: boolean;
12
+ }
13
+ export declare function Slider({ value, onChange, min, max, step, label, unit, showValue, size, disabled }: SliderProps): import("react").JSX.Element;
@@ -0,0 +1 @@
1
+ export * from "./Slider";
@@ -0,0 +1,10 @@
1
+ import type { ReactNode } from "react";
2
+ export interface SwitchProps {
3
+ checked?: boolean;
4
+ onChange?: (checked: boolean) => void;
5
+ label?: ReactNode;
6
+ disabled?: boolean;
7
+ name?: string;
8
+ id?: string;
9
+ }
10
+ export declare function Switch({ checked, onChange, label, disabled, name, id }: SwitchProps): import("react").JSX.Element;
@@ -0,0 +1 @@
1
+ export * from "./Switch";
@@ -0,0 +1,36 @@
1
+ import type { ButtonHTMLAttributes, ReactNode } from "react";
2
+ export type ToggleSize = "sm" | "md" | "lg";
3
+ export interface ToggleProps extends Omit<ButtonHTMLAttributes<HTMLButtonElement>, "onChange"> {
4
+ /** Controlled pressed state. Omit for uncontrolled. */
5
+ pressed?: boolean;
6
+ defaultPressed?: boolean;
7
+ onPressedChange?: (pressed: boolean) => void;
8
+ size?: ToggleSize;
9
+ }
10
+ /** A single two-state pressable control (e.g. a bold/italic formatting toggle). */
11
+ export declare const Toggle: import("react").ForwardRefExoticComponent<ToggleProps & import("react").RefAttributes<HTMLButtonElement>>;
12
+ export type ToggleGroupType = "single" | "multiple";
13
+ export interface ToggleGroupItem {
14
+ value: string;
15
+ label?: ReactNode;
16
+ icon?: ReactNode;
17
+ disabled?: boolean;
18
+ /** Accessible name when the item is icon-only. */
19
+ ariaLabel?: string;
20
+ }
21
+ export interface ToggleGroupProps {
22
+ items: ToggleGroupItem[];
23
+ /** "single" (default) = one active value; "multiple" = a set. */
24
+ type?: ToggleGroupType;
25
+ value?: string | string[];
26
+ defaultValue?: string | string[];
27
+ onValueChange?: (value: string | string[]) => void;
28
+ size?: ToggleSize;
29
+ /** Recolors the on-state of every item; omit for the neutral fill. */
30
+ accent?: "iris" | "indigo" | "green" | "orange" | "plum" | "red";
31
+ /** Disables every item (composes with per-item `disabled`). */
32
+ disabled?: boolean;
33
+ className?: string;
34
+ }
35
+ /** A bordered row of toggles behaving as a single- or multiple-select group. */
36
+ export declare function ToggleGroup({ items, type, value, defaultValue, onValueChange, size, accent, disabled, className, }: ToggleGroupProps): import("react").JSX.Element;
@@ -0,0 +1 @@
1
+ export * from "./Toggle";
@@ -0,0 +1,93 @@
1
+ /**
2
+ * @mercury-fx/ui — Mercury Design System React component library.
3
+ * Token-driven, className-based components. Import the stylesheet once
4
+ * (this entry pulls it in) and consume components anywhere.
5
+ *
6
+ * Components live one-folder-per-component under `components/<group>/<Name>/`
7
+ * (the Claude-Design layout). The UI-free foundation (`cx`, the `date`
8
+ * formatters, headless hooks, shared types) lives in `@mercury-fx/core`; the
9
+ * cross-boundary symbols are re-exported below so this public surface is
10
+ * unchanged for consumers.
11
+ */
12
+ import "./styles/index.css";
13
+ export { cx } from "@mercury-fx/core";
14
+ export type { ClassValue } from "@mercury-fx/core";
15
+ export { createFormatter, createTimeFormatter } from "@mercury-fx/core";
16
+ export type { Formatter, TimeFormatter, FormatterOptions, TimeFormatterOptions, MonthFormat, YearFormat, DayPeriodValue, MaybeReadable, Readable, } from "@mercury-fx/core";
17
+ export * from "./components/actions/Button";
18
+ export * from "./components/actions/Link";
19
+ export * from "./components/actions/IconButton";
20
+ export * from "./components/foundations/Icon";
21
+ export * from "./components/foundations/Divider";
22
+ export * from "./components/foundations/Heading";
23
+ export * from "./components/foundations/Text";
24
+ export * from "./components/foundations/Separator";
25
+ export * from "./components/inputs/Input";
26
+ export * from "./components/inputs/Textarea";
27
+ export * from "./components/inputs/Search";
28
+ export * from "./components/inputs/Select";
29
+ export * from "./components/inputs/AuthCode";
30
+ export * from "./components/inputs/MoneyInput";
31
+ export * from "./components/inputs/Label";
32
+ export * from "./components/inputs/DateField";
33
+ export * from "./components/inputs/Calendar";
34
+ export * from "./components/selection/Checkbox";
35
+ export * from "./components/selection/Radio";
36
+ export * from "./components/selection/Switch";
37
+ export * from "./components/selection/Segmented";
38
+ export * from "./components/selection/Slider";
39
+ export * from "./components/selection/Toggle";
40
+ export * from "./components/selection/CheckboxGroup";
41
+ export * from "./components/selection/CheckboxCards";
42
+ export * from "./components/selection/RadioGroup";
43
+ export * from "./components/selection/RadioCards";
44
+ export * from "./components/feedback/Alert";
45
+ export * from "./components/feedback/Progress";
46
+ export * from "./components/feedback/PasswordStrength";
47
+ export * from "./components/feedback/Callout";
48
+ export * from "./components/feedback/Spinner";
49
+ export * from "./components/feedback/Skeleton";
50
+ export * from "./components/data-display/Chip";
51
+ export * from "./components/data-display/Tag";
52
+ export * from "./components/data-display/Badge";
53
+ export * from "./components/data-display/Avatar";
54
+ export * from "./components/data-display/Card";
55
+ export * from "./components/data-display/Table";
56
+ export * from "./components/data-display/Stat";
57
+ export * from "./components/data-display/Chart";
58
+ export * from "./components/data-display/Checklist";
59
+ export * from "./components/data-display/ListRow";
60
+ export * from "./components/data-display/Blockquote";
61
+ export * from "./components/data-display/DataList";
62
+ export * from "./components/data-display/Code";
63
+ export * from "./components/data-display/Kbd";
64
+ export * from "./components/navigation/Tabs";
65
+ export * from "./components/navigation/Accordion";
66
+ export * from "./components/navigation/Pagination";
67
+ export * from "./components/navigation/Menubar";
68
+ export * from "./components/navigation/TabNav";
69
+ export * from "./components/overlay/Modal";
70
+ export * from "./components/overlay/Tooltip";
71
+ export * from "./components/overlay/Dialog";
72
+ export * from "./components/overlay/AlertDialog";
73
+ export * from "./components/overlay/Popover";
74
+ export * from "./components/overlay/Dropdown";
75
+ export * from "./components/overlay/ContextMenu";
76
+ export * from "./components/overlay/HoverCard";
77
+ export * from "./components/overlay/LinkPreview";
78
+ export * from "./components/layout/AuthLayout";
79
+ export * from "./components/layout/Collapsible";
80
+ export * from "./components/layout/AspectRatio";
81
+ export * from "./components/layout/ScrollArea";
82
+ export * from "./components/layout/Box";
83
+ export * from "./components/layout/Stack";
84
+ export * from "./components/layout/Flex";
85
+ export * from "./components/layout/Grid";
86
+ export * from "./components/layout/Container";
87
+ export * from "./components/layout/Spacer";
88
+ export * from "./components/layout/GridItem";
89
+ export * from "./components/layout/Center";
90
+ export * from "./components/layout/Sidebar";
91
+ export * from "./components/layout/Cluster";
92
+ export * from "./components/layout/Section";
93
+ export type { SpaceScale, RadiusScale, Align, Justify } from "./components/layout/scales";