reshaped 3.2.6-rc.0 → 3.3.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 (160) hide show
  1. package/CHANGELOG.md +39 -0
  2. package/dist/bundle.css +1 -1
  3. package/dist/bundle.d.ts +2 -0
  4. package/dist/bundle.js +11 -11
  5. package/dist/cjs/themes/_generator/definitions/figma.js +1 -0
  6. package/dist/cjs/themes/_generator/definitions/reshaped.js +5 -4
  7. package/dist/cjs/themes/_generator/tokens/duration/duration.types.d.ts +1 -1
  8. package/dist/cjs/themes/_generator/transform.js +17 -7
  9. package/dist/cjs/themes/_generator/utilities/generateColors.js +6 -6
  10. package/dist/cjs/themes/_generator/utilities/resolveTokenReference.js +1 -1
  11. package/dist/cjs/themes/figma/theme.css +1 -1
  12. package/dist/cjs/themes/reshaped/theme.css +1 -1
  13. package/dist/cjs/themes/slate/theme.css +1 -1
  14. package/dist/components/Alert/tests/Alert.stories.d.ts +5 -4
  15. package/dist/components/Alert/tests/Alert.stories.js +3 -2
  16. package/dist/components/Autocomplete/Autocomplete.js +3 -3
  17. package/dist/components/Autocomplete/Autocomplete.types.d.ts +8 -9
  18. package/dist/components/Badge/Badge.module.css +1 -1
  19. package/dist/components/Button/Button.module.css +1 -1
  20. package/dist/components/Card/Card.js +1 -1
  21. package/dist/components/ContextMenu/ContextMenu.d.ts +10 -0
  22. package/dist/components/ContextMenu/ContextMenu.js +37 -0
  23. package/dist/components/ContextMenu/ContextMenu.module.css +1 -0
  24. package/dist/components/ContextMenu/ContextMenu.types.d.ts +2 -0
  25. package/dist/components/ContextMenu/ContextMenu.types.js +1 -0
  26. package/dist/components/ContextMenu/index.d.ts +2 -0
  27. package/dist/components/ContextMenu/index.js +1 -0
  28. package/dist/components/ContextMenu/tests/ContextMenu.stories.d.ts +18 -0
  29. package/dist/components/ContextMenu/tests/ContextMenu.stories.js +27 -0
  30. package/dist/components/DropdownMenu/DropdownMenu.d.ts +1 -2
  31. package/dist/components/DropdownMenu/DropdownMenu.js +2 -2
  32. package/dist/components/DropdownMenu/DropdownMenu.types.d.ts +4 -4
  33. package/dist/components/DropdownMenu/tests/DropdownMenu.stories.d.ts +1 -1
  34. package/dist/components/DropdownMenu/tests/DropdownMenu.stories.js +8 -0
  35. package/dist/components/FormControl/FormControl.context.d.ts +86 -86
  36. package/dist/components/Grid/Grid.js +5 -1
  37. package/dist/components/Hotkey/Hotkey.module.css +1 -1
  38. package/dist/components/Modal/Modal.js +3 -3
  39. package/dist/components/Modal/Modal.module.css +1 -1
  40. package/dist/components/Modal/Modal.types.d.ts +1 -1
  41. package/dist/components/Overlay/Overlay.js +5 -2
  42. package/dist/components/Overlay/Overlay.types.d.ts +2 -0
  43. package/dist/components/Popover/Popover.js +1 -1
  44. package/dist/components/Popover/Popover.types.d.ts +1 -1
  45. package/dist/components/Resizable/Resizable.js +2 -2
  46. package/dist/components/Resizable/Resizable.module.css +1 -1
  47. package/dist/components/Resizable/Resizable.types.d.ts +3 -1
  48. package/dist/components/Resizable/tests/Resizable.stories.js +34 -1
  49. package/dist/components/ScrollArea/ScrollArea.js +9 -9
  50. package/dist/components/ScrollArea/ScrollArea.module.css +1 -1
  51. package/dist/components/ScrollArea/ScrollArea.types.d.ts +1 -4
  52. package/dist/components/ScrollArea/tests/ScrollArea.stories.d.ts +6 -4
  53. package/dist/components/ScrollArea/tests/ScrollArea.stories.js +28 -2
  54. package/dist/components/Table/Table.js +4 -3
  55. package/dist/components/Table/Table.module.css +1 -1
  56. package/dist/components/Table/Table.types.d.ts +2 -0
  57. package/dist/components/Table/tests/Table.stories.d.ts +1 -1
  58. package/dist/components/Table/tests/Table.stories.js +13 -1
  59. package/dist/components/Tabs/Tabs.module.css +1 -1
  60. package/dist/components/Tabs/Tabs.types.d.ts +2 -0
  61. package/dist/components/Tabs/TabsContext.d.ts +2 -2
  62. package/dist/components/Tabs/TabsItem.js +16 -10
  63. package/dist/components/Tabs/TabsList.js +12 -3
  64. package/dist/components/Tabs/TabsPanel.js +3 -3
  65. package/dist/components/Text/Text.js +2 -1
  66. package/dist/components/TextField/TextField.js +4 -4
  67. package/dist/components/TextField/TextField.module.css +1 -1
  68. package/dist/components/TextField/TextField.types.d.ts +1 -0
  69. package/dist/components/Toast/Toast.js +3 -2
  70. package/dist/components/Tooltip/Tooltip.d.ts +1 -1
  71. package/dist/components/Tooltip/Tooltip.js +4 -4
  72. package/dist/components/Tooltip/Tooltip.types.d.ts +1 -1
  73. package/dist/components/Tooltip/tests/Tooltip.stories.d.ts +1 -1
  74. package/dist/components/View/View.js +8 -3
  75. package/dist/components/View/View.module.css +1 -1
  76. package/dist/components/View/View.types.d.ts +5 -5
  77. package/dist/components/View/tests/View.stories.js +6 -0
  78. package/dist/components/_private/Flyout/Flyout.module.css +1 -1
  79. package/dist/components/_private/Flyout/Flyout.types.d.ts +2 -1
  80. package/dist/components/_private/Flyout/FlyoutContent.js +6 -4
  81. package/dist/components/_private/Flyout/FlyoutControlled.js +12 -9
  82. package/dist/components/_private/Flyout/tests/Flyout.stories.d.ts +1 -0
  83. package/dist/components/_private/Flyout/tests/Flyout.stories.js +16 -1
  84. package/dist/components/_private/Flyout/useFlyout.d.ts +6 -11
  85. package/dist/components/_private/Flyout/useFlyout.js +19 -30
  86. package/dist/components/_private/Flyout/utilities/isFullyVisible.d.ts +6 -0
  87. package/dist/components/_private/Flyout/utilities/isFullyVisible.js +16 -0
  88. package/dist/components/_private/Portal/Portal.js +5 -2
  89. package/dist/hooks/_private/useOnClickOutside.d.ts +1 -1
  90. package/dist/hooks/_private/useOnClickOutside.js +8 -5
  91. package/dist/hooks/_private/useSingletonKeyboardMode.js +4 -0
  92. package/dist/index.d.ts +2 -0
  93. package/dist/index.js +1 -0
  94. package/dist/styles/align/align.css +1 -0
  95. package/dist/styles/align/index.d.ts +2 -1
  96. package/dist/styles/align/index.js +3 -3
  97. package/dist/styles/aspectRatio/aspectRatio.css +1 -0
  98. package/dist/styles/aspectRatio/index.d.ts +2 -1
  99. package/dist/styles/aspectRatio/index.js +2 -2
  100. package/dist/styles/bleed/bleed.module.css +1 -1
  101. package/dist/styles/bleed/index.js +2 -5
  102. package/dist/styles/height/height.module.css +1 -1
  103. package/dist/styles/height/index.js +2 -2
  104. package/dist/styles/inset/index.d.ts +2 -1
  105. package/dist/styles/inset/index.js +4 -7
  106. package/dist/styles/inset/inset.css +1 -0
  107. package/dist/styles/justify/index.d.ts +2 -1
  108. package/dist/styles/justify/index.js +3 -3
  109. package/dist/styles/justify/justify.css +1 -0
  110. package/dist/styles/maxHeight/index.js +2 -2
  111. package/dist/styles/maxHeight/maxHeight.module.css +1 -1
  112. package/dist/styles/maxWidth/index.js +2 -2
  113. package/dist/styles/maxWidth/maxWidth.module.css +1 -1
  114. package/dist/styles/minHeight/index.js +2 -2
  115. package/dist/styles/minHeight/minHeight.module.css +1 -1
  116. package/dist/styles/minWidth/index.js +2 -2
  117. package/dist/styles/minWidth/minWidth.module.css +1 -1
  118. package/dist/styles/padding/index.d.ts +2 -1
  119. package/dist/styles/padding/index.js +2 -2
  120. package/dist/styles/padding/padding.css +1 -0
  121. package/dist/styles/position/index.d.ts +2 -1
  122. package/dist/styles/position/index.js +4 -4
  123. package/dist/styles/position/position.css +1 -0
  124. package/dist/styles/textAlign/index.d.ts +2 -1
  125. package/dist/styles/textAlign/index.js +3 -3
  126. package/dist/styles/textAlign/textAlign.css +1 -0
  127. package/dist/styles/types.d.ts +5 -0
  128. package/dist/styles/width/index.js +2 -2
  129. package/dist/styles/width/width.module.css +1 -1
  130. package/dist/themes/_generator/definitions/figma.js +1 -0
  131. package/dist/themes/_generator/definitions/reshaped.js +5 -4
  132. package/dist/themes/_generator/tests/themes.stories.d.ts +4 -3
  133. package/dist/themes/_generator/tests/themes.stories.js +3 -2
  134. package/dist/themes/_generator/tokens/duration/duration.types.d.ts +1 -1
  135. package/dist/themes/_generator/utilities/generateColors.js +6 -6
  136. package/dist/themes/_generator/utilities/resolveTokenReference.js +1 -1
  137. package/dist/themes/figma/theme.css +1 -1
  138. package/dist/themes/reshaped/theme.css +1 -1
  139. package/dist/themes/slate/theme.css +1 -1
  140. package/dist/types/global.d.ts +4 -0
  141. package/dist/utilities/a11y/TrapFocus.js +1 -0
  142. package/dist/utilities/a11y/focus.d.ts +1 -1
  143. package/dist/utilities/a11y/focus.js +4 -1
  144. package/dist/utilities/a11y/tests/TrapFocus.stories.d.ts +6 -0
  145. package/dist/utilities/a11y/tests/TrapFocus.stories.js +59 -0
  146. package/dist/utilities/dom/find.d.ts +10 -0
  147. package/dist/utilities/dom/find.js +35 -0
  148. package/dist/utilities/dom/flyout.d.ts +2 -1
  149. package/dist/utilities/dom/flyout.js +13 -18
  150. package/dist/utilities/dom/index.d.ts +2 -1
  151. package/dist/utilities/dom/index.js +2 -1
  152. package/dist/utilities/scroll/lock.js +6 -2
  153. package/package.json +32 -32
  154. package/dist/styles/align/align.module.css +0 -1
  155. package/dist/styles/aspectRatio/aspectRatio.module.css +0 -1
  156. package/dist/styles/inset/inset.module.css +0 -1
  157. package/dist/styles/justify/justify.module.css +0 -1
  158. package/dist/styles/padding/padding.module.css +0 -1
  159. package/dist/styles/position/position.module.css +0 -1
  160. package/dist/styles/textAlign/textAlign.module.css +0 -1
@@ -12,6 +12,10 @@ export type ResponsiveOnly<T> = {
12
12
  [key in Viewport]?: T;
13
13
  };
14
14
  export type Responsive<T> = T | ResponsiveOnly<T>;
15
+ export type Coordinates = {
16
+ x: number;
17
+ y: number;
18
+ };
15
19
  /**
16
20
  * Form handlers
17
21
  */
@@ -21,6 +21,7 @@ class TrapFocus {
21
21
  * Handle keyboard navigation while focus is trapped
22
22
  */
23
23
  handleKeyDown = (event) => {
24
+ // if (event.defaultPrevented) return;
24
25
  if (TrapFocus.chain.tailId !== this.chainId)
25
26
  return;
26
27
  const { mode, onNavigateOutside, pseudoFocus, includeTrigger } = this.options;
@@ -1,5 +1,5 @@
1
1
  import type { FocusableElement } from "./types";
2
- export declare const focusableSelector = "a,button,input:not([type=\"hidden\"]),textarea,select,details,[tabindex]:not([tabindex=\"-1\"])";
2
+ export declare const focusableSelector = "a,button,input:not([type=\"hidden\"]),textarea,select,details,[tabindex],[contenteditable]";
3
3
  export declare const getActiveElement: (originEl?: HTMLElement | null) => HTMLButtonElement;
4
4
  export declare const focusElement: (el: FocusableElement, options?: {
5
5
  pseudoFocus?: boolean;
@@ -1,6 +1,6 @@
1
1
  import { getShadowRoot } from "../dom/index.js";
2
2
  const pseudoFocusAttribute = "data-rs-focus";
3
- export const focusableSelector = 'a,button,input:not([type="hidden"]),textarea,select,details,[tabindex]:not([tabindex="-1"])';
3
+ export const focusableSelector = 'a,button,input:not([type="hidden"]),textarea,select,details,[tabindex],[contenteditable]';
4
4
  export const getActiveElement = (originEl) => {
5
5
  const shadowRoot = originEl ? getShadowRoot(originEl) : null;
6
6
  const rootEl = shadowRoot ?? document;
@@ -25,6 +25,9 @@ export const getFocusableElements = (rootEl, options) => {
25
25
  return false;
26
26
  if (el.clientHeight === 0)
27
27
  return false;
28
+ // Using getAttribute here since browser sets el.tabIndex to -1 by default
29
+ if (el.getAttribute("tabindex") === "-1")
30
+ return false;
28
31
  if (el.type === "radio") {
29
32
  let sameNameRadioEls;
30
33
  if (el.form) {
@@ -0,0 +1,6 @@
1
+ import React from "react";
2
+ declare const _default: {
3
+ title: string;
4
+ };
5
+ export default _default;
6
+ export declare const base: () => React.JSX.Element;
@@ -0,0 +1,59 @@
1
+ import React from "react";
2
+ import { Example } from "../../storybook/index.js";
3
+ import TrapFocus from "../TrapFocus.js";
4
+ import Button from "../../../components/Button/index.js";
5
+ import useToggle from "../../../hooks/useToggle.js";
6
+ import View from "../../../components/View/index.js";
7
+ import TextField from "../../../components/TextField/index.js";
8
+ import RadioGroup from "../../../components/RadioGroup/index.js";
9
+ import Radio from "../../../components/Radio/index.js";
10
+ import * as keys from "../../../constants/keys.js";
11
+ export default {
12
+ title: "Internal/TrapFocus",
13
+ };
14
+ const Editor = () => {
15
+ const pressedCountRef = React.useRef(1);
16
+ const handleKeyDown = (e) => {
17
+ if (e.key !== keys.TAB)
18
+ return;
19
+ if (pressedCountRef.current % 5)
20
+ e.preventDefault();
21
+ pressedCountRef.current += 1;
22
+ };
23
+ return (<View backgroundColor="neutral-faded" borderColor="neutral-faded" borderRadius="medium" padding={4} attributes={{ contentEditable: true, onKeyDown: handleKeyDown }}/>);
24
+ };
25
+ const Demo = () => {
26
+ const rootRef = React.useRef(null);
27
+ const trapToggle = useToggle();
28
+ React.useEffect(() => {
29
+ if (!trapToggle.active)
30
+ return;
31
+ if (!rootRef.current)
32
+ return;
33
+ const trapFocus = new TrapFocus(rootRef.current);
34
+ trapFocus.trap();
35
+ return () => trapFocus.release();
36
+ }, [trapToggle.active]);
37
+ return (<View gap={4}>
38
+ <Button onClick={trapToggle.activate}>Activate</Button>
39
+ {trapToggle.active && (<View backgroundColor="neutral-faded" borderRadius="medium" padding={4} gap={4} attributes={{ ref: rootRef }}>
40
+ <Button onClick={() => { }}>Button</Button>
41
+ <Button href="#">Link</Button>
42
+ <TextField name="input" placeholder="Input"/>
43
+ <RadioGroup name="radio">
44
+ <Radio value="1">Option 1</Radio>
45
+ <Radio value="2">Option 1</Radio>
46
+ </RadioGroup>
47
+ <Editor />
48
+ <Button onClick={trapToggle.deactivate} attributes={{ tabIndex: -1 }}>
49
+ Excluded
50
+ </Button>
51
+ <Button onClick={trapToggle.deactivate}>Deactivate</Button>
52
+ </View>)}
53
+ </View>);
54
+ };
55
+ export const base = () => (<Example>
56
+ <Example.Item title="Default">
57
+ <Demo />
58
+ </Example.Item>
59
+ </Example>);
@@ -0,0 +1,10 @@
1
+ export declare const findParent: (element: HTMLElement, condition: (el: HTMLElement) => boolean) => HTMLElement | null;
2
+ /**
3
+ * Containers used for scoping the rendering,
4
+ * mostly used in flyouts since the have to accommodate for positioning and overflow
5
+ */
6
+ export declare const findClosestRenderContainer: (args: {
7
+ el: HTMLElement | null;
8
+ iteration?: number;
9
+ overflowOnly?: boolean;
10
+ }) => HTMLElement;
@@ -0,0 +1,35 @@
1
+ import { getShadowRoot } from "./shadowDom.js";
2
+ export const findParent = (element, condition) => {
3
+ let currentElement = element.parentElement;
4
+ while (currentElement) {
5
+ if (condition(currentElement))
6
+ return currentElement;
7
+ currentElement = currentElement.parentElement;
8
+ }
9
+ return null;
10
+ };
11
+ /**
12
+ * Containers used for scoping the rendering,
13
+ * mostly used in flyouts since the have to accommodate for positioning and overflow
14
+ */
15
+ export const findClosestRenderContainer = (args) => {
16
+ const { el, iteration = 0, overflowOnly } = args;
17
+ const style = el && window.getComputedStyle(el);
18
+ const overflowY = style?.overflowY;
19
+ const position = style?.position;
20
+ const isScrollable = overflowY?.includes("scroll") || overflowY?.includes("auto");
21
+ const isFixed = position === "fixed" || position === "sticky";
22
+ // Only check shadow root on the first run
23
+ if (iteration === 0) {
24
+ const shadowRoot = getShadowRoot(el);
25
+ if (shadowRoot?.firstElementChild)
26
+ return shadowRoot.firstElementChild;
27
+ }
28
+ if (el === document.body || !el)
29
+ return document.body;
30
+ if (isScrollable && el.scrollHeight > el.clientHeight)
31
+ return el;
32
+ if (isFixed && !overflowOnly)
33
+ return el;
34
+ return findClosestRenderContainer({ el: el.parentElement, iteration: iteration + 1 });
35
+ };
@@ -1 +1,2 @@
1
- export declare const getClosestFlyoutTarget: (el: HTMLElement | null, iteration?: number) => HTMLElement;
1
+ import type * as G from "../../types/global";
2
+ export declare const getRectFromCoordinates: (coordinates: DOMRect | G.Coordinates) => DOMRect;
@@ -1,19 +1,14 @@
1
- import { getShadowRoot } from "./shadowDom.js";
2
- export const getClosestFlyoutTarget = (el, iteration = 0) => {
3
- const style = el && window.getComputedStyle(el);
4
- const overflowY = style?.overflowY;
5
- const position = style?.position;
6
- const isScrollable = overflowY?.includes("scroll");
7
- const isFixed = position === "fixed" || position === "sticky";
8
- // Only check shadow root on the first run
9
- if (iteration === 0) {
10
- const shadowRoot = getShadowRoot(el);
11
- if (shadowRoot?.firstElementChild)
12
- return shadowRoot.firstElementChild;
13
- }
14
- if (el === document.body || !el)
15
- return document.body;
16
- if ((isScrollable && el.scrollHeight > el.clientHeight) || isFixed)
17
- return el;
18
- return getClosestFlyoutTarget(el.parentElement, iteration + 1);
1
+ export const getRectFromCoordinates = (coordinates) => {
2
+ if ("width" in coordinates && coordinates.width !== undefined)
3
+ return coordinates;
4
+ return {
5
+ ...coordinates,
6
+ width: 0,
7
+ height: 0,
8
+ left: coordinates.x,
9
+ right: coordinates.x,
10
+ top: coordinates.y,
11
+ bottom: coordinates.y,
12
+ toJSON: () => { },
13
+ };
19
14
  };
@@ -1,3 +1,4 @@
1
- export { getClosestFlyoutTarget } from "./flyout";
1
+ export { getRectFromCoordinates } from "./flyout";
2
2
  export { getShadowRoot } from "./shadowDom";
3
3
  export { enableUserSelect, disableUserSelect } from "./userSelect";
4
+ export { findParent, findClosestRenderContainer } from "./find";
@@ -1,3 +1,4 @@
1
- export { getClosestFlyoutTarget } from "./flyout.js";
1
+ export { getRectFromCoordinates } from "./flyout.js";
2
2
  export { getShadowRoot } from "./shadowDom.js";
3
3
  export { enableUserSelect, disableUserSelect } from "./userSelect.js";
4
+ export { findParent, findClosestRenderContainer } from "./find.js";
@@ -1,17 +1,21 @@
1
1
  import { isIOS } from "../platform.js";
2
2
  import lockSafariScroll from "./lockSafari.js";
3
3
  import lockStandardScroll from "./lockStandard.js";
4
+ import { findClosestRenderContainer } from "../dom/index.js";
4
5
  let lockedCount = 0;
5
6
  let reset = () => { };
6
7
  export const lockScroll = (args) => {
7
8
  lockedCount += 1;
8
9
  if (lockedCount > 1)
9
10
  return;
11
+ const customLockTargetEl = args.containerEl
12
+ ? findClosestRenderContainer({ el: args.containerEl, overflowOnly: true })
13
+ : undefined;
10
14
  if (isIOS()) {
11
- reset = lockSafariScroll();
15
+ reset = lockSafariScroll(customLockTargetEl);
12
16
  }
13
17
  else {
14
- reset = lockStandardScroll(args.containerEl);
18
+ reset = lockStandardScroll(customLockTargetEl);
15
19
  }
16
20
  args.cb?.();
17
21
  };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "reshaped",
3
3
  "description": "Professionally crafted design system in React & Figma for building products of any scale and complexity",
4
- "version": "3.2.6-rc.0",
4
+ "version": "3.3.0",
5
5
  "license": "MIT",
6
6
  "email": "hello@reshaped.so",
7
7
  "homepage": "https://reshaped.so",
@@ -93,65 +93,65 @@
93
93
  "defaults and not IE 11"
94
94
  ],
95
95
  "devDependencies": {
96
- "@commitlint/cli": "19.5.0",
97
- "@commitlint/config-conventional": "19.5.0",
96
+ "@commitlint/cli": "19.6.0",
97
+ "@commitlint/config-conventional": "19.6.0",
98
98
  "@commitlint/types": "19.5.0",
99
- "@eslint/js": "9.13.0",
99
+ "@eslint/js": "9.16.0",
100
100
  "@size-limit/preset-big-lib": "11.1.6",
101
- "@storybook/addon-a11y": "8.3.6",
102
- "@storybook/addon-controls": "8.3.6",
103
- "@storybook/addon-docs": "8.3.6",
104
- "@storybook/addon-storysource": "8.3.6",
105
- "@storybook/react": "8.3.6",
106
- "@storybook/react-vite": "8.3.6",
101
+ "@storybook/addon-a11y": "8.4.6",
102
+ "@storybook/addon-controls": "8.4.6",
103
+ "@storybook/addon-docs": "8.4.6",
104
+ "@storybook/addon-storysource": "8.4.6",
105
+ "@storybook/react": "8.4.6",
106
+ "@storybook/react-vite": "8.4.6",
107
107
  "@testing-library/dom": "10.4.0",
108
- "@testing-library/jest-dom": "6.6.2",
108
+ "@testing-library/jest-dom": "6.6.3",
109
109
  "@testing-library/react": "16.0.1",
110
110
  "@testing-library/user-event": "14.5.2",
111
111
  "@types/culori": "2.1.1",
112
112
  "@types/events": "3.0.3",
113
- "@types/jest": "29.5.13",
114
- "@types/node": "22.7.7",
115
- "@types/react": "18.3.11",
113
+ "@types/jest": "29.5.14",
114
+ "@types/node": "22.10.1",
115
+ "@types/react": "18.3.12",
116
116
  "@types/react-dom": "18.3.1",
117
117
  "@typescript-eslint/eslint-plugin": "7.18.0",
118
118
  "@typescript-eslint/parser": "7.18.0",
119
- "@vitejs/plugin-react": "4.3.3",
120
- "chromatic": "11.12.6",
119
+ "@vitejs/plugin-react": "4.3.4",
120
+ "chromatic": "11.19.0",
121
121
  "cz-conventional-changelog": "3.3.0",
122
122
  "eslint": "8.57.1",
123
123
  "eslint-config-prettier": "9.1.0",
124
124
  "eslint-plugin-import": "2.31.0",
125
- "eslint-plugin-jsx-a11y": "6.10.0",
125
+ "eslint-plugin-jsx-a11y": "6.10.2",
126
126
  "eslint-plugin-prettier": "5.2.1",
127
- "eslint-plugin-react": "7.37.1",
127
+ "eslint-plugin-react": "7.37.2",
128
128
  "eslint-plugin-react-hooks": "5.0.0",
129
- "globals": "15.11.0",
129
+ "globals": "15.12.0",
130
130
  "identity-obj-proxy": "3.0.0",
131
131
  "jest": "29.7.0",
132
132
  "jest-environment-jsdom": "29.7.0",
133
133
  "jest-matchmedia-mock": "1.1.0",
134
- "lefthook": "1.7.22",
135
- "postcss": "8.4.47",
134
+ "lefthook": "1.8.4",
135
+ "postcss": "8.4.49",
136
136
  "postcss-cli": "11.0.0",
137
137
  "postcss-each": "1.1.0",
138
- "postcss-nested": "6.2.0",
139
- "prettier": "3.3.3",
138
+ "postcss-nested": "7.0.2",
139
+ "prettier": "3.4.1",
140
140
  "react": "18.3.1",
141
141
  "react-dom": "18.3.1",
142
142
  "react-shadow": "20.5.0",
143
- "resolve-tspaths": "0.8.22",
143
+ "resolve-tspaths": "0.8.23",
144
144
  "size-limit": "11.1.6",
145
- "storybook": "8.3.6",
146
- "stylelint": "16.10.0",
145
+ "storybook": "8.4.6",
146
+ "stylelint": "16.11.0",
147
147
  "stylelint-config-prettier": "9.0.5",
148
148
  "stylelint-config-standard": "36.0.1",
149
149
  "ts-jest": "29.2.5",
150
150
  "ts-node": "10.9.2",
151
- "typescript": "5.6.3",
152
- "typescript-eslint": "8.10.0",
153
- "vite": "5.4.9",
154
- "vite-tsconfig-paths": "5.0.1"
151
+ "typescript": "5.7.2",
152
+ "typescript-eslint": "8.16.0",
153
+ "vite": "6.0.1",
154
+ "vite-tsconfig-paths": "5.1.3"
155
155
  },
156
156
  "peerDependencies": {
157
157
  "postcss": "^8",
@@ -163,9 +163,9 @@
163
163
  "chalk": "4.1.2",
164
164
  "commander": "12.1.0",
165
165
  "cssnano": "7.0.6",
166
- "csstype": "^3.1.3",
166
+ "csstype": "3.1.3",
167
167
  "culori": "4.0.1",
168
- "postcss-custom-media": "11.0.3"
168
+ "postcss-custom-media": "11.0.5"
169
169
  },
170
170
  "size-limit": [
171
171
  {
@@ -1 +0,0 @@
1
- .--align-start{align-items:flex-start!important}.--align-end{align-items:flex-end!important}.--align-center{align-items:center!important}.--align-stretch{align-items:stretch!important}.--align-baseline{align-items:baseline!important}@media (--rs-viewport-m ){.--align-start--m{align-items:flex-start!important}.--align-end--m{align-items:flex-end!important}.--align-center--m{align-items:center!important}.--align-stretch--m{align-items:stretch!important}.--align-baseline--m{align-items:baseline!important}}@media (--rs-viewport-l ){.--align-start--l{align-items:flex-start!important}.--align-end--l{align-items:flex-end!important}.--align-center--l{align-items:center!important}.--align-stretch--l{align-items:stretch!important}.--align-baseline--l{align-items:baseline!important}}@media (--rs-viewport-xl ){.--align-start--xl{align-items:flex-start!important}.--align-end--xl{align-items:flex-end!important}.--align-center--xl{align-items:center!important}.--align-stretch--xl{align-items:stretch!important}.--align-baseline--xl{align-items:baseline!important}}
@@ -1 +0,0 @@
1
- .root:empty,.root:not(:empty)>*{aspect-ratio:var(--rs-ratio)}.root>img{object-fit:cover}.root{--rs-ratio-s:0;--rs-ratio-m:var(--rs-ratio-s);--rs-ratio-l:var(--rs-ratio-m);--rs-ratio-xl:var(--rs-ratio-l);--rs-ratio:var(--rs-ratio-s)}@media (--rs-viewport-m ){.root{--rs-ratio:var(--rs-ratio-m)}}@media (--rs-viewport-l ){.root{--rs-ratio:var(--rs-ratio-l)}}@media (--rs-viewport-xl ){.root{--rs-ratio:var(--rs-ratio-xl)}}
@@ -1 +0,0 @@
1
- .--inset{inset:calc(var(--rs-inset) * var(--rs-unit-x1))}.--inset-end{inset-inline-end:calc(var(--rs-inset-end) * var(--rs-unit-x1))}.--inset-start{inset-inline-start:calc(var(--rs-inset-start) * var(--rs-unit-x1))}.--inset-top{inset-block-start:calc(var(--rs-inset-top) * var(--rs-unit-x1))}.--inset-bottom{inset-block-end:calc(var(--rs-inset-bottom) * var(--rs-unit-x1))}.--inset{--rs-inset-s:0;--rs-inset-m:var(--rs-inset-s);--rs-inset-l:var(--rs-inset-m);--rs-inset-xl:var(--rs-inset-l);--rs-inset:var(--rs-inset-s)}.--inset-end{--rs-inset-end-s:0;--rs-inset-end-m:var(--rs-inset-end-s);--rs-inset-end-l:var(--rs-inset-end-m);--rs-inset-end-xl:var(--rs-inset-end-l);--rs-inset-end:var(--rs-inset-end-s)}.--inset-start{--rs-inset-start-s:0;--rs-inset-start-m:var(--rs-inset-start-s);--rs-inset-start-l:var(--rs-inset-start-m);--rs-inset-start-xl:var(--rs-inset-start-l);--rs-inset-start:var(--rs-inset-start-s)}.--inset-top{--rs-inset-top-s:0;--rs-inset-top-m:var(--rs-inset-top-s);--rs-inset-top-l:var(--rs-inset-top-m);--rs-inset-top-xl:var(--rs-inset-top-l);--rs-inset-top:var(--rs-inset-top-s)}.--inset-bottom{--rs-inset-bottom-s:0;--rs-inset-bottom-m:var(--rs-inset-bottom-s);--rs-inset-bottom-l:var(--rs-inset-bottom-m);--rs-inset-bottom-xl:var(--rs-inset-bottom-l);--rs-inset-bottom:var(--rs-inset-bottom-s)}@media (--rs-viewport-m ){.--inset-end--m{inset-inline-end:calc(var(--rs-inset-end) * var(--rs-unit-x1))}.--inset-start--m{inset-inline-start:calc(var(--rs-inset-start) * var(--rs-unit-x1))}.--inset-top--m{inset-block-start:calc(var(--rs-inset-top) * var(--rs-unit-x1))}.--inset-bottom--m{inset-block-end:calc(var(--rs-inset-bottom) * var(--rs-unit-x1))}.--inset{--rs-inset:var(--rs-inset-m)}.--inset-end{--rs-inset-end:var(--rs-inset-end-m)}.--inset-start{--rs-inset-start:var(--rs-inset-start-m)}.--inset-top{--rs-inset-top:var(--rs-inset-top-m)}.--inset-bottom{--rs-inset-bottom:var(--rs-inset-bottom-m)}}@media (--rs-viewport-l ){.--inset-end--l{inset-inline-end:calc(var(--rs-inset-end) * var(--rs-unit-x1))}.--inset-start--l{inset-inline-start:calc(var(--rs-inset-start) * var(--rs-unit-x1))}.--inset-top--l{inset-block-start:calc(var(--rs-inset-top) * var(--rs-unit-x1))}.--inset-bottom--l{inset-block-end:calc(var(--rs-inset-bottom) * var(--rs-unit-x1))}.--inset{--rs-inset:var(--rs-inset-l)}.--inset-end{--rs-inset-end:var(--rs-inset-end-l)}.--inset-start{--rs-inset-start:var(--rs-inset-start-l)}.--inset-top{--rs-inset-top:var(--rs-inset-top-l)}.--inset-bottom{--rs-inset-bottom:var(--rs-inset-bottom-l)}}@media (--rs-viewport-xl ){.--inset-end--xl{inset-inline-end:calc(var(--rs-inset-end) * var(--rs-unit-x1))}.--inset-start--xl{inset-inline-start:calc(var(--rs-inset-start) * var(--rs-unit-x1))}.--inset-top--xl{inset-block-start:calc(var(--rs-inset-top) * var(--rs-unit-x1))}.--inset-bottom--xl{inset-block-end:calc(var(--rs-inset-bottom) * var(--rs-unit-x1))}.--inset{--rs-inset:var(--rs-inset-xl)}.--inset-end{--rs-inset-end:var(--rs-inset-end-xl)}.--inset-start{--rs-inset-start:var(--rs-inset-start-xl)}.--inset-top{--rs-inset-top:var(--rs-inset-top-xl)}.--inset-bottom{--rs-inset-bottom:var(--rs-inset-bottom-xl)}}
@@ -1 +0,0 @@
1
- .--justify-start{justify-content:flex-start!important}.--justify-end{justify-content:flex-end!important}.--justify-center{justify-content:center!important}.--justify-space-between{justify-content:space-between!important}@media (--rs-viewport-m ){.--justify-start--m{justify-content:flex-start!important}.--justify-end--m{justify-content:flex-end!important}.--justify-center--m{justify-content:center!important}.--justify-space-between--m{justify-content:space-between!important}}@media (--rs-viewport-l ){.--justify-start--l{justify-content:flex-start!important}.--justify-end--l{justify-content:flex-end!important}.--justify-center--l{justify-content:center!important}.--justify-space-between--l{justify-content:space-between!important}}@media (--rs-viewport-xl ){.--justify-start--xl{justify-content:flex-start!important}.--justify-end--xl{justify-content:flex-end!important}.--justify-center--xl{justify-content:center!important}.--justify-space-between--xl{justify-content:space-between!important}}
@@ -1 +0,0 @@
1
- .root{padding:calc(var(--rs-p) * var(--rs-unit-x1) - var(--rs-border-width, 0px));--rs-p-s:0;--rs-p-m:var(--rs-p-s);--rs-p-l:var(--rs-p-m);--rs-p-xl:var(--rs-p-l);--rs-p:var(--rs-p-s)}@media (--rs-viewport-m ){.root{--rs-p:var(--rs-p-m)}}@media (--rs-viewport-l ){.root{--rs-p:var(--rs-p-l)}}@media (--rs-viewport-xl ){.root{--rs-p:var(--rs-p-xl)}}
@@ -1 +0,0 @@
1
- .--position-static{position:static}.--position-relative{position:relative}.--position-absolute{position:absolute}.--position-fixed{position:fixed}.--position-sticky{position:sticky}@media (--rs-viewport-m ){.--position-static--m{position:static}.--position-relative--m{position:relative}.--position-absolute--m{position:absolute}.--position-fixed--m{position:fixed}.--position-sticky--m{position:sticky}}@media (--rs-viewport-l ){.--position-static--l{position:static}.--position-relative--l{position:relative}.--position-absolute--l{position:absolute}.--position-fixed--l{position:fixed}.--position-sticky--l{position:sticky}}@media (--rs-viewport-xl ){.--position-static--xl{position:static}.--position-relative--xl{position:relative}.--position-absolute--xl{position:absolute}.--position-fixed--xl{position:fixed}.--position-sticky--xl{position:sticky}}
@@ -1 +0,0 @@
1
- .--text-align-start{text-align:start}.--text-align-center{text-align:center}.--text-align-end{text-align:end}@media (--rs-viewport-m ){.--text-align-start--m{text-align:start}.--text-align-center--m{text-align:center}.--text-align-end--m{text-align:end}}@media (--rs-viewport-l ){.--text-align-start--l{text-align:start}.--text-align-center--l{text-align:center}.--text-align-end--l{text-align:end}}@media (--rs-viewport-xl ){.--text-align-start--xl{text-align:start}.--text-align-center--xl{text-align:center}.--text-align-end--xl{text-align:end}}