entangle-ui 0.6.2 → 0.7.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 (152) hide show
  1. package/CHANGELOG.md +45 -0
  2. package/README.md +5 -3
  3. package/dist/esm/_virtual/_commonjsHelpers.js +6 -0
  4. package/dist/esm/_virtual/_commonjsHelpers.js.map +1 -0
  5. package/dist/esm/_virtual/cssesc.js +5 -1
  6. package/dist/esm/_virtual/cssesc.js.map +1 -1
  7. package/dist/esm/_virtual/picocolors.js +8 -0
  8. package/dist/esm/_virtual/picocolors.js.map +1 -0
  9. package/dist/esm/_virtual/picocolors2.js +4 -0
  10. package/dist/esm/_virtual/picocolors2.js.map +1 -0
  11. package/dist/esm/assets/src/components/editor/ChatPanel/{ChatPanel.css.ts.vanilla-DPIGnZ4A.css → ChatPanel.css.ts.vanilla-BI5569ZO.css} +81 -1
  12. package/dist/esm/assets/src/components/feedback/EmptyState/EmptyState.css.ts.vanilla-B_TWsTOW.css +58 -0
  13. package/dist/esm/assets/src/components/feedback/Spinner/Spinner.css.ts.vanilla-DEUewqdK.css +80 -0
  14. package/dist/esm/assets/src/components/layout/Divider/Divider.css.ts.vanilla-CPvd_RW9.css +72 -0
  15. package/dist/esm/assets/src/components/layout/ListItem/ListItem.css.ts.vanilla-BwAZrX2f.css +68 -0
  16. package/dist/esm/assets/src/components/layout/PageHeader/PageHeader.css.ts.vanilla-DdbyyWAN.css +70 -0
  17. package/dist/esm/assets/src/components/layout/SplitPane/{SplitPane.css.ts.vanilla-BFxdvwyI.css → SplitPane.css.ts.vanilla-BGFZ7zDa.css} +5 -0
  18. package/dist/esm/assets/src/components/primitives/Badge/Badge.css.ts.vanilla-DxCUcxYW.css +95 -0
  19. package/dist/esm/assets/src/components/primitives/Code/Code.css.ts.vanilla-mayBqLDM.css +19 -0
  20. package/dist/esm/assets/src/components/primitives/TextArea/TextArea.css.ts.vanilla-DTOMjGkp.css +85 -0
  21. package/dist/esm/assets/src/theme/{darkTheme.css.ts.vanilla-DCe89yCJ.css → darkTheme.css.ts.vanilla-ab1WD4dr.css} +3 -0
  22. package/dist/esm/assets/src/theme/globalScrollbars.css.ts.vanilla-BAJwnUEJ.css +21 -0
  23. package/dist/esm/assets/src/utils/animations.css.ts.vanilla-DOVlpljP.css +58 -0
  24. package/dist/esm/components/editor/ChatPanel/ChatInput.js +18 -7
  25. package/dist/esm/components/editor/ChatPanel/ChatInput.js.map +1 -1
  26. package/dist/esm/components/editor/ChatPanel/ChatMarkdownRenderer.js +268 -0
  27. package/dist/esm/components/editor/ChatPanel/ChatMarkdownRenderer.js.map +1 -0
  28. package/dist/esm/components/editor/ChatPanel/ChatMessage.js +15 -3
  29. package/dist/esm/components/editor/ChatPanel/ChatMessage.js.map +1 -1
  30. package/dist/esm/components/editor/ChatPanel/ChatMessageList.js +19 -5
  31. package/dist/esm/components/editor/ChatPanel/ChatMessageList.js.map +1 -1
  32. package/dist/esm/components/editor/ChatPanel/ChatPanel.css.js +14 -2
  33. package/dist/esm/components/editor/ChatPanel/ChatPanel.css.js.map +1 -1
  34. package/dist/esm/components/editor/ChatPanel/ChatPanel.js +15 -3
  35. package/dist/esm/components/editor/ChatPanel/ChatPanel.js.map +1 -1
  36. package/dist/esm/components/editor/ChatPanel/useChatInput.js +3 -3
  37. package/dist/esm/components/editor/ChatPanel/useChatInput.js.map +1 -1
  38. package/dist/esm/components/editor/ChatPanel/useChatScroll.js +59 -2
  39. package/dist/esm/components/editor/ChatPanel/useChatScroll.js.map +1 -1
  40. package/dist/esm/components/feedback/EmptyState/EmptyState.css.js +13 -0
  41. package/dist/esm/components/feedback/EmptyState/EmptyState.css.js.map +1 -0
  42. package/dist/esm/components/feedback/EmptyState/EmptyState.js +43 -0
  43. package/dist/esm/components/feedback/EmptyState/EmptyState.js.map +1 -0
  44. package/dist/esm/components/feedback/Spinner/Spinner.css.js +16 -0
  45. package/dist/esm/components/feedback/Spinner/Spinner.css.js.map +1 -0
  46. package/dist/esm/components/feedback/Spinner/Spinner.js +50 -0
  47. package/dist/esm/components/feedback/Spinner/Spinner.js.map +1 -0
  48. package/dist/esm/components/layout/Divider/Divider.css.js +9 -0
  49. package/dist/esm/components/layout/Divider/Divider.css.js.map +1 -0
  50. package/dist/esm/components/layout/Divider/Divider.js +51 -0
  51. package/dist/esm/components/layout/Divider/Divider.js.map +1 -0
  52. package/dist/esm/components/layout/ListItem/ListItem.css.js +10 -0
  53. package/dist/esm/components/layout/ListItem/ListItem.css.js.map +1 -0
  54. package/dist/esm/components/layout/ListItem/ListItem.js +45 -0
  55. package/dist/esm/components/layout/ListItem/ListItem.js.map +1 -0
  56. package/dist/esm/components/layout/PageHeader/PageHeader.css.js +13 -0
  57. package/dist/esm/components/layout/PageHeader/PageHeader.css.js.map +1 -0
  58. package/dist/esm/components/layout/PageHeader/PageHeader.js +29 -0
  59. package/dist/esm/components/layout/PageHeader/PageHeader.js.map +1 -0
  60. package/dist/esm/components/layout/SplitPane/SplitPane.css.js +1 -1
  61. package/dist/esm/components/navigation/Tabs/TabPanel.js +6 -3
  62. package/dist/esm/components/navigation/Tabs/TabPanel.js.map +1 -1
  63. package/dist/esm/components/navigation/Tabs/Tabs.js +3 -1
  64. package/dist/esm/components/navigation/Tabs/Tabs.js.map +1 -1
  65. package/dist/esm/components/primitives/Badge/Badge.css.js +12 -0
  66. package/dist/esm/components/primitives/Badge/Badge.css.js.map +1 -0
  67. package/dist/esm/components/primitives/Badge/Badge.js +67 -0
  68. package/dist/esm/components/primitives/Badge/Badge.js.map +1 -0
  69. package/dist/esm/components/primitives/Code/Code.css.js +7 -0
  70. package/dist/esm/components/primitives/Code/Code.css.js.map +1 -0
  71. package/dist/esm/components/primitives/Code/Code.js +24 -0
  72. package/dist/esm/components/primitives/Code/Code.js.map +1 -0
  73. package/dist/esm/components/primitives/TextArea/TextArea.css.js +10 -0
  74. package/dist/esm/components/primitives/TextArea/TextArea.css.js.map +1 -0
  75. package/dist/esm/components/primitives/TextArea/TextArea.js +97 -0
  76. package/dist/esm/components/primitives/TextArea/TextArea.js.map +1 -0
  77. package/dist/esm/index.js +12 -1
  78. package/dist/esm/index.js.map +1 -1
  79. package/dist/esm/node_modules/@emotion/hash/dist/emotion-hash.esm.js +56 -0
  80. package/dist/esm/node_modules/@emotion/hash/dist/emotion-hash.esm.js.map +1 -0
  81. package/dist/esm/node_modules/@vanilla-extract/css/adapter/dist/vanilla-extract-css-adapter.esm.js +32 -1
  82. package/dist/esm/node_modules/@vanilla-extract/css/adapter/dist/vanilla-extract-css-adapter.esm.js.map +1 -1
  83. package/dist/esm/node_modules/@vanilla-extract/css/dist/taggedTemplateLiteral-10998315.esm.js +13 -0
  84. package/dist/esm/node_modules/@vanilla-extract/css/dist/taggedTemplateLiteral-10998315.esm.js.map +1 -0
  85. package/dist/esm/node_modules/@vanilla-extract/css/dist/transformCss-fd0786e1.esm.js +837 -3
  86. package/dist/esm/node_modules/@vanilla-extract/css/dist/transformCss-fd0786e1.esm.js.map +1 -1
  87. package/dist/esm/node_modules/@vanilla-extract/css/dist/vanilla-extract-css.esm.js +244 -5
  88. package/dist/esm/node_modules/@vanilla-extract/css/dist/vanilla-extract-css.esm.js.map +1 -1
  89. package/dist/esm/node_modules/@vanilla-extract/css/fileScope/dist/vanilla-extract-css-fileScope.esm.js +18 -0
  90. package/dist/esm/node_modules/@vanilla-extract/css/fileScope/dist/vanilla-extract-css-fileScope.esm.js.map +1 -0
  91. package/dist/esm/node_modules/@vanilla-extract/css/injectStyles/dist/vanilla-extract-css-injectStyles.esm.js +23 -0
  92. package/dist/esm/node_modules/@vanilla-extract/css/injectStyles/dist/vanilla-extract-css-injectStyles.esm.js.map +1 -0
  93. package/dist/esm/node_modules/@vanilla-extract/private/dist/vanilla-extract-private.esm.js +38 -0
  94. package/dist/esm/node_modules/@vanilla-extract/private/dist/vanilla-extract-private.esm.js.map +1 -0
  95. package/dist/esm/node_modules/css-what/lib/es/parse.js +424 -0
  96. package/dist/esm/node_modules/css-what/lib/es/parse.js.map +1 -0
  97. package/dist/esm/node_modules/css-what/lib/es/types.js +29 -0
  98. package/dist/esm/node_modules/css-what/lib/es/types.js.map +1 -0
  99. package/dist/esm/node_modules/dedent/dist/dedent.js +3 -1
  100. package/dist/esm/node_modules/dedent/dist/dedent.js.map +1 -1
  101. package/dist/esm/node_modules/deep-object-diff/mjs/diff.js +40 -0
  102. package/dist/esm/node_modules/deep-object-diff/mjs/diff.js.map +1 -0
  103. package/dist/esm/node_modules/deep-object-diff/mjs/utils.js +9 -0
  104. package/dist/esm/node_modules/deep-object-diff/mjs/utils.js.map +1 -0
  105. package/dist/esm/node_modules/media-query-parser/dist/media-query-parser.esm.js +1386 -0
  106. package/dist/esm/node_modules/media-query-parser/dist/media-query-parser.esm.js.map +1 -0
  107. package/dist/esm/node_modules/modern-ahocorasick/dist/index.js +102 -0
  108. package/dist/esm/node_modules/modern-ahocorasick/dist/index.js.map +1 -0
  109. package/dist/esm/node_modules/picocolors/picocolors.js +87 -0
  110. package/dist/esm/node_modules/picocolors/picocolors.js.map +1 -0
  111. package/dist/esm/theme/ThemeProvider.js +17 -3
  112. package/dist/esm/theme/ThemeProvider.js.map +1 -1
  113. package/dist/esm/theme/contract.css.js +1 -1
  114. package/dist/esm/theme/createCustomTheme.js +33 -0
  115. package/dist/esm/theme/createCustomTheme.js.map +1 -0
  116. package/dist/esm/theme/darkTheme.css.js +2 -2
  117. package/dist/esm/theme/globalScrollbars.css.js +6 -0
  118. package/dist/esm/theme/globalScrollbars.css.js.map +1 -0
  119. package/dist/esm/utils/animations.css.js +13 -0
  120. package/dist/esm/utils/animations.css.js.map +1 -0
  121. package/dist/esm/utils/objects.js +22 -0
  122. package/dist/esm/utils/objects.js.map +1 -0
  123. package/dist/types/components/editor/ChatPanel/ChatMarkdownRenderer.d.ts +323 -0
  124. package/dist/types/components/editor/ChatPanel/ChatMarkdownRenderer.types.d.ts +46 -0
  125. package/dist/types/components/editor/ChatPanel/ChatMessage.d.ts +1 -0
  126. package/dist/types/components/editor/ChatPanel/ChatMessageList.d.ts +2 -1
  127. package/dist/types/components/editor/ChatPanel/ChatPanel.d.ts +1 -0
  128. package/dist/types/components/editor/ChatPanel/ChatPanel.types.d.ts +82 -1
  129. package/dist/types/components/feedback/EmptyState/EmptyState.d.ts +313 -0
  130. package/dist/types/components/feedback/EmptyState/EmptyState.types.d.ts +31 -0
  131. package/dist/types/components/feedback/Spinner/Spinner.d.ts +306 -0
  132. package/dist/types/components/feedback/Spinner/Spinner.types.d.ts +41 -0
  133. package/dist/types/components/layout/Divider/Divider.d.ts +307 -0
  134. package/dist/types/components/layout/Divider/Divider.types.d.ts +50 -0
  135. package/dist/types/components/layout/ListItem/ListItem.d.ts +312 -0
  136. package/dist/types/components/layout/ListItem/ListItem.types.d.ts +35 -0
  137. package/dist/types/components/layout/PageHeader/PageHeader.d.ts +311 -0
  138. package/dist/types/components/layout/PageHeader/PageHeader.types.d.ts +30 -0
  139. package/dist/types/components/navigation/Tabs/Tabs.types.d.ts +10 -0
  140. package/dist/types/components/primitives/Badge/Badge.d.ts +310 -0
  141. package/dist/types/components/primitives/Badge/Badge.types.d.ts +67 -0
  142. package/dist/types/components/primitives/Code/Code.d.ts +301 -0
  143. package/dist/types/components/primitives/Code/Code.types.d.ts +17 -0
  144. package/dist/types/components/primitives/TextArea/TextArea.d.ts +26 -0
  145. package/dist/types/components/primitives/TextArea/TextArea.types.d.ts +76 -0
  146. package/dist/types/index.d.ts +22 -2
  147. package/dist/types/theme/ThemeProvider.d.ts +14 -2
  148. package/dist/types/theme/contract.css.d.ts +3 -0
  149. package/dist/types/theme/createCustomTheme.d.ts +29 -0
  150. package/dist/types/theme/darkTheme.css.d.ts +3 -0
  151. package/dist/types/utils/animations.css.d.ts +18 -0
  152. package/package.json +1 -1
@@ -0,0 +1,12 @@
1
+ import './../../../assets/src/components/primitives/Badge/Badge.css.ts.vanilla-DxCUcxYW.css';
2
+ import { createRuntimeFn } from '@vanilla-extract/recipes/createRuntimeFn';
3
+
4
+ var badgeColorVar = 'var(--badgeColorVar__6943by0)';
5
+ var badgeContrastVar = 'var(--badgeContrastVar__6943by1)';
6
+ var badgeDotStyle = 'Badge_badgeDotStyle__6943byd';
7
+ var badgeIconStyle = 'Badge_badgeIconStyle__6943byc';
8
+ var badgeRecipe = createRuntimeFn({defaultClassName:'Badge_badgeRecipe__6943by2',variantClassNames:{size:{xs:'Badge_badgeRecipe_size_xs__6943by3',sm:'Badge_badgeRecipe_size_sm__6943by4',md:'Badge_badgeRecipe_size_md__6943by5',lg:'Badge_badgeRecipe_size_lg__6943by6'},variant:{subtle:'Badge_badgeRecipe_variant_subtle__6943by7',solid:'Badge_badgeRecipe_variant_solid__6943by8',outline:'Badge_badgeRecipe_variant_outline__6943by9',dot:'Badge_badgeRecipe_variant_dot__6943bya'},uppercase:{true:'Badge_badgeRecipe_uppercase_true__6943byb'}},defaultVariants:{size:'sm',variant:'subtle'},compoundVariants:[]});
9
+ var badgeRemoveButtonStyle = 'Badge_badgeRemoveButtonStyle__6943bye';
10
+
11
+ export { badgeColorVar, badgeContrastVar, badgeDotStyle, badgeIconStyle, badgeRecipe, badgeRemoveButtonStyle };
12
+ //# sourceMappingURL=Badge.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Badge.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;"}
@@ -0,0 +1,67 @@
1
+ "use client";
2
+ import { jsxs, jsx } from 'react/jsx-runtime';
3
+ import React, { useCallback } from 'react';
4
+ import { assignInlineVars } from '@vanilla-extract/dynamic';
5
+ import { vars } from '../../../theme/contract.css.js';
6
+ import { cx } from '../../../utils/cx.js';
7
+ import { badgeContrastVar, badgeColorVar, badgeDotStyle, badgeIconStyle, badgeRemoveButtonStyle, badgeRecipe } from './Badge.css.js';
8
+
9
+ const NAMED_COLOR_MAP = {
10
+ neutral: vars.colors.text.muted,
11
+ primary: vars.colors.accent.primary,
12
+ info: vars.colors.accent.primary,
13
+ success: vars.colors.accent.success,
14
+ warning: vars.colors.accent.warning,
15
+ error: vars.colors.accent.error,
16
+ };
17
+ /**
18
+ * Resolve a `BadgeColor` to a CSS color value.
19
+ *
20
+ * Named values produce a `var(...)` reference into the theme; everything
21
+ * else is treated as a raw CSS color string (hex, rgb, hsl, …).
22
+ */
23
+ function resolveBadgeColor(color) {
24
+ const named = NAMED_COLOR_MAP[color];
25
+ if (named) {
26
+ // For neutral we keep contrast as the text primary so solid reads well.
27
+ const contrast = color === 'neutral' ? vars.colors.text.primary : vars.colors.text.primary;
28
+ return { color: named, contrast };
29
+ }
30
+ return { color, contrast: '#ffffff' };
31
+ }
32
+ const RemoveIcon = () => (jsx("svg", { width: "10", height: "10", viewBox: "0 0 10 10", "aria-hidden": "true", focusable: "false", children: jsx("path", { d: "M2 2 L8 8 M8 2 L2 8", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round" }) }));
33
+ /**
34
+ * A small inline status indicator / tag.
35
+ *
36
+ * Badges are visual labels for status, counts, or tags. Pair with an
37
+ * editor item to indicate its state (e.g. "DRAFT", "ERROR", "3 NEW").
38
+ *
39
+ * @example
40
+ * ```tsx
41
+ * <Badge color="success">Saved</Badge>
42
+ * <Badge variant="outline" color="warning" icon={<WarningIcon />}>
43
+ * Warning
44
+ * </Badge>
45
+ * <Badge removable onRemove={handleRemove}>feature/foo</Badge>
46
+ * ```
47
+ */
48
+ const Badge = /*#__PURE__*/ React.memo(({ variant = 'subtle', size = 'sm', color = 'neutral', uppercase = false, icon, removable = false, onRemove, children, className, style, testId, ref, ...rest }) => {
49
+ const resolved = resolveBadgeColor(color);
50
+ const handleRemoveClick = useCallback((event) => {
51
+ event.stopPropagation();
52
+ onRemove?.(event);
53
+ }, [onRemove]);
54
+ const inlineVars = assignInlineVars({
55
+ [badgeColorVar]: resolved.color,
56
+ [badgeContrastVar]: resolved.contrast,
57
+ });
58
+ return (jsxs("span", { ref: ref, className: cx(badgeRecipe({
59
+ variant,
60
+ size,
61
+ uppercase: uppercase || undefined,
62
+ }), className), style: { ...inlineVars, ...style }, "data-testid": testId, ...rest, children: [variant === 'dot' && jsx("span", { className: badgeDotStyle, "aria-hidden": true }), icon && (jsx("span", { className: badgeIconStyle, "aria-hidden": true, children: icon })), children && jsx("span", { children: children }), removable && (jsx("button", { type: "button", className: badgeRemoveButtonStyle, onClick: handleRemoveClick, "aria-label": "Remove", children: jsx(RemoveIcon, {}) }))] }));
63
+ });
64
+ Badge.displayName = 'Badge';
65
+
66
+ export { Badge };
67
+ //# sourceMappingURL=Badge.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Badge.js","sources":["../../../../../../src/components/primitives/Badge/Badge.tsx"],"sourcesContent":[null],"names":[],"mappings":";;;;;;;;AAgBA;AACE;AACA;AACA;AACA;AACA;AACA;;AAGF;;;;;AAKG;AACH;AAIE;;;;AAKE;;AAEF;AACF;AAEA;AAiBA;;;;;;;;;;;;;;AAcG;;AAiBC;AAEA;;AAGI;AACF;;AAKA;AACA;AACD;;;;;AAUM;AA0BT;AAGF;;"}
@@ -0,0 +1,7 @@
1
+ import './../../../assets/src/components/primitives/Code/Code.css.ts.vanilla-mayBqLDM.css';
2
+ import { createRuntimeFn } from '@vanilla-extract/recipes/createRuntimeFn';
3
+
4
+ var codeRecipe = createRuntimeFn({defaultClassName:'Code_codeRecipe__13vd650',variantClassNames:{size:{xs:'Code_codeRecipe_size_xs__13vd651',sm:'Code_codeRecipe_size_sm__13vd652',md:'Code_codeRecipe_size_md__13vd653'}},defaultVariants:{size:'sm'},compoundVariants:[]});
5
+
6
+ export { codeRecipe };
7
+ //# sourceMappingURL=Code.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Code.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;"}
@@ -0,0 +1,24 @@
1
+ "use client";
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import React from 'react';
4
+ import { cx } from '../../../utils/cx.js';
5
+ import { codeRecipe } from './Code.css.js';
6
+
7
+ /**
8
+ * Small inline `<code>` primitive with theme-aware background and font.
9
+ *
10
+ * Complements `ChatCodeBlock` (block-level) — use `Code` for short inline
11
+ * snippets inside sentences and markdown renderers.
12
+ *
13
+ * @example
14
+ * ```tsx
15
+ * <Text>Run <Code>npm install</Code> to add the package.</Text>
16
+ * ```
17
+ */
18
+ const Code = /*#__PURE__*/ React.memo(({ children, size = 'sm', className, style, testId, ref, ...rest }) => {
19
+ return (jsx("code", { ref: ref, className: cx(codeRecipe({ size }), className), style: style, "data-testid": testId, ...rest, children: children }));
20
+ });
21
+ Code.displayName = 'Code';
22
+
23
+ export { Code };
24
+ //# sourceMappingURL=Code.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Code.js","sources":["../../../../../../src/components/primitives/Code/Code.tsx"],"sourcesContent":[null],"names":[],"mappings":";;;;;;AAOA;;;;;;;;;;AAUG;AACI;AAEH;AAWF;AAGF;;"}
@@ -0,0 +1,10 @@
1
+ import './../../../assets/src/components/primitives/TextArea/TextArea.css.ts.vanilla-DTOMjGkp.css';
2
+ import { createRuntimeFn } from '@vanilla-extract/recipes/createRuntimeFn';
3
+
4
+ var textAreaContainerStyle = 'TextArea_textAreaContainerStyle__nwf0m90';
5
+ var textAreaFooterStyle = 'TextArea_textAreaFooterStyle__nwf0m9j';
6
+ var textAreaRecipe = createRuntimeFn({defaultClassName:'TextArea_textAreaRecipe__nwf0m9e',variantClassNames:{size:{sm:'TextArea_textAreaRecipe_size_sm__nwf0m9f',md:'TextArea_textAreaRecipe_size_md__nwf0m9g',lg:'TextArea_textAreaRecipe_size_lg__nwf0m9h'},monospace:{true:'TextArea_textAreaRecipe_monospace_true__nwf0m9i'}},defaultVariants:{size:'md'},compoundVariants:[]});
7
+ var textAreaWrapperRecipe = createRuntimeFn({defaultClassName:'TextArea_textAreaWrapperRecipe__nwf0m91',variantClassNames:{size:{sm:'TextArea_textAreaWrapperRecipe_size_sm__nwf0m92',md:'TextArea_textAreaWrapperRecipe_size_md__nwf0m93',lg:'TextArea_textAreaWrapperRecipe_size_lg__nwf0m94'},error:{true:'TextArea_textAreaWrapperRecipe_error_true__nwf0m95',false:'TextArea_textAreaWrapperRecipe_error_false__nwf0m96'},disabled:{true:'TextArea_textAreaWrapperRecipe_disabled_true__nwf0m97',false:'TextArea_textAreaWrapperRecipe_disabled_false__nwf0m98'},focused:{true:'TextArea_textAreaWrapperRecipe_focused_true__nwf0m99',false:'TextArea_textAreaWrapperRecipe_focused_false__nwf0m9a'}},defaultVariants:{size:'md',error:false,disabled:false,focused:false},compoundVariants:[[{focused:true,error:false},'TextArea_textAreaWrapperRecipe_compound_0__nwf0m9b'],[{focused:false,error:false,disabled:false},'TextArea_textAreaWrapperRecipe_compound_1__nwf0m9c'],[{focused:false,error:false,disabled:true},'TextArea_textAreaWrapperRecipe_compound_2__nwf0m9d']]});
8
+
9
+ export { textAreaContainerStyle, textAreaFooterStyle, textAreaRecipe, textAreaWrapperRecipe };
10
+ //# sourceMappingURL=TextArea.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TextArea.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;"}
@@ -0,0 +1,97 @@
1
+ "use client";
2
+ import { jsxs, jsx } from 'react/jsx-runtime';
3
+ import React, { useRef, useId, useCallback, useEffect } from 'react';
4
+ import { cx } from '../../../utils/cx.js';
5
+ import { FormHelperText } from '../../form/FormHelperText.js';
6
+ import { FormLabel } from '../../form/FormLabel.js';
7
+ import { textAreaRecipe, textAreaWrapperRecipe, textAreaFooterStyle, textAreaContainerStyle } from './TextArea.css.js';
8
+
9
+ /**
10
+ * Multi-line text input with optional auto-resize.
11
+ *
12
+ * Visual parity with `Input` — uses the same border, focus ring, and error
13
+ * states. Auto-resize activates when `minRows` or `maxRows` is set and
14
+ * disables the native resize handle.
15
+ *
16
+ * @example
17
+ * ```tsx
18
+ * <TextArea
19
+ * label="Description"
20
+ * minRows={3}
21
+ * maxRows={8}
22
+ * value={value}
23
+ * onChange={setValue}
24
+ * showCount
25
+ * maxLength={500}
26
+ * />
27
+ * ```
28
+ */
29
+ const TextArea = ({ value, defaultValue, placeholder, size = 'md', disabled = false, error = false, required = false, readOnly = false, label, helperText, errorMessage, resize = 'vertical', rows = 3, minRows, maxRows, monospace = false, maxLength, showCount = false, className, style, onChange, onFocus, onBlur, onKeyDown, testId, ref, id, name, ...rest }) => {
30
+ const [focused, setFocused] = React.useState(false);
31
+ const [internalValue, setInternalValue] = React.useState(defaultValue ?? '');
32
+ const textareaRef = useRef(null);
33
+ const autoId = useId();
34
+ const inputId = id ?? autoId;
35
+ const isControlled = value !== undefined;
36
+ const currentValue = isControlled ? value : internalValue;
37
+ const autoSizeEnabled = minRows !== undefined || maxRows !== undefined;
38
+ const effectiveResize = autoSizeEnabled ? 'none' : resize;
39
+ const setRef = useCallback((node) => {
40
+ textareaRef.current = node;
41
+ if (typeof ref === 'function')
42
+ ref(node);
43
+ else if (ref)
44
+ ref.current =
45
+ node;
46
+ }, [ref]);
47
+ const autoResize = useCallback(() => {
48
+ if (!autoSizeEnabled)
49
+ return;
50
+ const el = textareaRef.current;
51
+ if (!el)
52
+ return;
53
+ el.style.height = 'auto';
54
+ const measuredLineHeight = parseFloat(getComputedStyle(el).lineHeight);
55
+ const lineHeight = Number.isFinite(measuredLineHeight)
56
+ ? measuredLineHeight
57
+ : 18;
58
+ const minHeight = (minRows ?? 1) * lineHeight;
59
+ const maxHeight = maxRows ? maxRows * lineHeight : Infinity;
60
+ const next = Math.min(Math.max(el.scrollHeight, minHeight), maxHeight);
61
+ el.style.height = `${next}px`;
62
+ el.style.overflowY = el.scrollHeight > maxHeight ? 'auto' : 'hidden';
63
+ }, [autoSizeEnabled, minRows, maxRows]);
64
+ useEffect(() => {
65
+ autoResize();
66
+ }, [currentValue, autoResize]);
67
+ const handleFocus = (event) => {
68
+ setFocused(true);
69
+ onFocus?.(event);
70
+ };
71
+ const handleBlur = (event) => {
72
+ setFocused(false);
73
+ onBlur?.(event);
74
+ };
75
+ const handleChange = (event) => {
76
+ const next = event.target.value;
77
+ if (!isControlled)
78
+ setInternalValue(next);
79
+ onChange?.(next);
80
+ };
81
+ const effectiveHelper = error && errorMessage ? errorMessage : helperText;
82
+ const count = currentValue?.length ?? 0;
83
+ return (jsxs("div", { className: cx(textAreaContainerStyle, className), style: style, children: [label && (jsx(FormLabel, { htmlFor: inputId, disabled: disabled, required: required, children: label })), jsx("div", { className: textAreaWrapperRecipe({ size, error, disabled, focused }), children: jsx("textarea", { ref: setRef, id: inputId, name: name, placeholder: placeholder, disabled: disabled, required: required, readOnly: readOnly, value: isControlled ? value : undefined, defaultValue: isControlled ? undefined : defaultValue, rows: autoSizeEnabled ? (minRows ?? rows) : rows, maxLength: maxLength, className: textAreaRecipe({
84
+ size,
85
+ monospace: monospace || undefined,
86
+ }), style: { resize: effectiveResize }, onChange: handleChange, onFocus: handleFocus, onBlur: handleBlur, onKeyDown: onKeyDown, "data-testid": testId, "aria-invalid": error || undefined, ...rest }) }), (effectiveHelper !== undefined && effectiveHelper !== '') ||
87
+ showCount ? (jsxs("div", { style: {
88
+ display: 'flex',
89
+ justifyContent: 'space-between',
90
+ alignItems: 'flex-start',
91
+ gap: 8,
92
+ }, children: [effectiveHelper !== undefined && effectiveHelper !== '' ? (jsx(FormHelperText, { error: error, children: effectiveHelper })) : (jsx("span", {})), showCount && (jsx("div", { className: textAreaFooterStyle, children: maxLength !== undefined ? `${count}/${maxLength}` : count }))] })) : null] }));
93
+ };
94
+ TextArea.displayName = 'TextArea';
95
+
96
+ export { TextArea };
97
+ //# sourceMappingURL=TextArea.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TextArea.js","sources":["../../../../../../src/components/primitives/TextArea/TextArea.tsx"],"sourcesContent":[null],"names":[],"mappings":";;;;;;;;AAcA;;;;;;;;;;;;;;;;;;;AAmBG;AACI;AA+BL;AACA;AACA;AACA;AACA;AAEA;;;;AAMA;AAEI;;;AAEK;AACF;AACC;AACN;AAIF;AACE;;AACA;AACA;;AAEA;;AAGA;AACE;;;AAGF;AAEA;;AAEA;;;AAIA;AACF;AAEA;;AAEE;AACF;AACA;;AAEE;AACF;AACA;AACE;AACA;;AACA;AACF;AAEA;AACA;AAEA;;;AA0BS;AAaL;AAGM;AACA;AACA;AACA;AACD;AAgBX;AAEA;;"}
package/dist/esm/index.js CHANGED
@@ -1,23 +1,29 @@
1
1
  export { vars } from './theme/contract.css.js';
2
2
  export { darkThemeValues } from './theme/darkTheme.css.js';
3
- import './node_modules/@vanilla-extract/css/dist/vanilla-extract-css.esm.js';
3
+ export { createCustomTheme } from './theme/createCustomTheme.js';
4
4
  export { VanillaThemeProvider } from './theme/VanillaThemeProvider.js';
5
5
  export { ThemeProvider } from './theme/ThemeProvider.js';
6
+ import './assets/src/theme/globalScrollbars.css.ts.vanilla-BAJwnUEJ.css';
6
7
  export { Accordion } from './components/layout/Accordion/Accordion.js';
7
8
  export { AccordionItem } from './components/layout/Accordion/AccordionItem.js';
8
9
  export { AccordionTrigger } from './components/layout/Accordion/AccordionTrigger.js';
9
10
  export { AccordionContent } from './components/layout/Accordion/AccordionContent.js';
11
+ export { Divider } from './components/layout/Divider/Divider.js';
10
12
  export { Flex } from './components/layout/Flex/Flex.js';
11
13
  export { Grid } from './components/layout/Grid/Grid.js';
14
+ export { ListItem } from './components/layout/ListItem/ListItem.js';
15
+ export { PageHeader } from './components/layout/PageHeader/PageHeader.js';
12
16
  export { PanelSurface } from './components/layout/PanelSurface/PanelSurface.js';
13
17
  export { ScrollArea } from './components/layout/ScrollArea/ScrollArea.js';
14
18
  export { Spacer } from './components/layout/Spacer/Spacer.js';
15
19
  export { SplitPane } from './components/layout/SplitPane/SplitPane.js';
16
20
  export { SplitPanePanel } from './components/layout/SplitPane/SplitPanePanel.js';
17
21
  export { Stack } from './components/layout/Stack/Stack.js';
22
+ export { Badge } from './components/primitives/Badge/Badge.js';
18
23
  export { Button } from './components/primitives/Button/Button.js';
19
24
  export { Checkbox } from './components/primitives/Checkbox/Checkbox.js';
20
25
  export { CheckboxGroup } from './components/primitives/Checkbox/CheckboxGroup.js';
26
+ export { Code } from './components/primitives/Code/Code.js';
21
27
  export { Collapsible } from './components/primitives/Collapsible/Collapsible.js';
22
28
  export { Icon } from './components/primitives/Icon/Icon.js';
23
29
  export { IconButton } from './components/primitives/IconButton/IconButton.js';
@@ -29,6 +35,7 @@ export { PopoverContent } from './components/primitives/Popover/PopoverContent.j
29
35
  export { PopoverTrigger } from './components/primitives/Popover/PopoverTrigger.js';
30
36
  export { Switch } from './components/primitives/Switch/Switch.js';
31
37
  export { Text } from './components/primitives/Text/Text.js';
38
+ export { TextArea } from './components/primitives/TextArea/TextArea.js';
32
39
  export { Tooltip } from './components/primitives/Tooltip/Tooltip.js';
33
40
  import 'react';
34
41
  import './components/primitives/canvas/CanvasContainer.js';
@@ -66,6 +73,8 @@ export { DialogHeader } from './components/feedback/Dialog/DialogHeader.js';
66
73
  export { DialogBody } from './components/feedback/Dialog/DialogBody.js';
67
74
  export { DialogFooter } from './components/feedback/Dialog/DialogFooter.js';
68
75
  export { DialogClose } from './components/feedback/Dialog/DialogClose.js';
76
+ export { EmptyState } from './components/feedback/EmptyState/EmptyState.js';
77
+ export { Spinner } from './components/feedback/Spinner/Spinner.js';
69
78
  export { ToastProvider } from './components/feedback/Toast/ToastProvider.js';
70
79
  export { useToast } from './components/feedback/Toast/useToast.js';
71
80
  export { PropertyPanel } from './components/editor/PropertyInspector/PropertyPanel.js';
@@ -88,6 +97,7 @@ export { ChatContextChip } from './components/editor/ChatPanel/ChatContextChip.j
88
97
  export { ChatEmptyState } from './components/editor/ChatPanel/ChatEmptyState.js';
89
98
  export { ChatActionBar } from './components/editor/ChatPanel/ChatActionBar.js';
90
99
  export { ChatInputToolbar } from './components/editor/ChatPanel/ChatInputToolbar.js';
100
+ export { ChatMarkdownRenderer } from './components/editor/ChatPanel/ChatMarkdownRenderer.js';
91
101
  export { useChatMessages } from './components/editor/ChatPanel/useChatMessages.js';
92
102
  export { useChatInput } from './components/editor/ChatPanel/useChatInput.js';
93
103
  export { useChatScroll } from './components/editor/ChatPanel/useChatScroll.js';
@@ -97,4 +107,5 @@ export { MenuBar } from './components/shell/MenuBar/MenuBar.js';
97
107
  export { StatusBar } from './components/shell/StatusBar/StatusBar.js';
98
108
  export { Toolbar } from './components/shell/Toolbar/Toolbar.js';
99
109
  export { cx as cn, cx } from './utils/cx.js';
110
+ export { animBlink, animFadeIn, animPulse, animSpin, blinkKeyframe, fadeInKeyframe, pulseKeyframe, spinKeyframe } from './utils/animations.css.js';
100
111
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,56 @@
1
+ /* eslint-disable */
2
+ // Inspired by https://github.com/garycourt/murmurhash-js
3
+ // Ported from https://github.com/aappleby/smhasher/blob/61a0530f28277f2e850bfc39600ce61d02b518de/src/MurmurHash2.cpp#L37-L86
4
+ function murmur2(str) {
5
+ // 'm' and 'r' are mixing constants generated offline.
6
+ // They're not really 'magic', they just happen to work well.
7
+ // const m = 0x5bd1e995;
8
+ // const r = 24;
9
+ // Initialize the hash
10
+ var h = 0; // Mix 4 bytes at a time into the hash
11
+
12
+ var k,
13
+ i = 0,
14
+ len = str.length;
15
+
16
+ for (; len >= 4; ++i, len -= 4) {
17
+ k = str.charCodeAt(i) & 0xff | (str.charCodeAt(++i) & 0xff) << 8 | (str.charCodeAt(++i) & 0xff) << 16 | (str.charCodeAt(++i) & 0xff) << 24;
18
+ k =
19
+ /* Math.imul(k, m): */
20
+ (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16);
21
+ k ^=
22
+ /* k >>> r: */
23
+ k >>> 24;
24
+ h =
25
+ /* Math.imul(k, m): */
26
+ (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16) ^
27
+ /* Math.imul(h, m): */
28
+ (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);
29
+ } // Handle the last few bytes of the input array
30
+
31
+
32
+ switch (len) {
33
+ case 3:
34
+ h ^= (str.charCodeAt(i + 2) & 0xff) << 16;
35
+
36
+ case 2:
37
+ h ^= (str.charCodeAt(i + 1) & 0xff) << 8;
38
+
39
+ case 1:
40
+ h ^= str.charCodeAt(i) & 0xff;
41
+ h =
42
+ /* Math.imul(h, m): */
43
+ (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);
44
+ } // Do a few final mixes of the hash to ensure the last few
45
+ // bytes are well-incorporated.
46
+
47
+
48
+ h ^= h >>> 13;
49
+ h =
50
+ /* Math.imul(h, m): */
51
+ (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);
52
+ return ((h ^ h >>> 15) >>> 0).toString(36);
53
+ }
54
+
55
+ export { murmur2 as default };
56
+ //# sourceMappingURL=emotion-hash.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"emotion-hash.esm.js","sources":["../../../../../../node_modules/@emotion/hash/dist/emotion-hash.esm.js"],"sourcesContent":["/* eslint-disable */\n// Inspired by https://github.com/garycourt/murmurhash-js\n// Ported from https://github.com/aappleby/smhasher/blob/61a0530f28277f2e850bfc39600ce61d02b518de/src/MurmurHash2.cpp#L37-L86\nfunction murmur2(str) {\n // 'm' and 'r' are mixing constants generated offline.\n // They're not really 'magic', they just happen to work well.\n // const m = 0x5bd1e995;\n // const r = 24;\n // Initialize the hash\n var h = 0; // Mix 4 bytes at a time into the hash\n\n var k,\n i = 0,\n len = str.length;\n\n for (; len >= 4; ++i, len -= 4) {\n k = str.charCodeAt(i) & 0xff | (str.charCodeAt(++i) & 0xff) << 8 | (str.charCodeAt(++i) & 0xff) << 16 | (str.charCodeAt(++i) & 0xff) << 24;\n k =\n /* Math.imul(k, m): */\n (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16);\n k ^=\n /* k >>> r: */\n k >>> 24;\n h =\n /* Math.imul(k, m): */\n (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16) ^\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n } // Handle the last few bytes of the input array\n\n\n switch (len) {\n case 3:\n h ^= (str.charCodeAt(i + 2) & 0xff) << 16;\n\n case 2:\n h ^= (str.charCodeAt(i + 1) & 0xff) << 8;\n\n case 1:\n h ^= str.charCodeAt(i) & 0xff;\n h =\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n } // Do a few final mixes of the hash to ensure the last few\n // bytes are well-incorporated.\n\n\n h ^= h >>> 13;\n h =\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n return ((h ^ h >>> 15) >>> 0).toString(36);\n}\n\nexport { murmur2 as default };\n"],"names":[],"mappings":"AAAA;AACA;AACA;AACA,SAAS,OAAO,CAAC,GAAG,EAAE;AACtB;AACA;AACA;AACA;AACA;AACA,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;;AAEZ,EAAE,IAAI,CAAC;AACP,MAAM,CAAC,GAAG,CAAC;AACX,MAAM,GAAG,GAAG,GAAG,CAAC,MAAM;;AAEtB,EAAE,OAAO,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE;AAClC,IAAI,CAAC,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,KAAK,EAAE,GAAG,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,KAAK,EAAE;AAC9I,IAAI,CAAC;AACL;AACA,IAAI,CAAC,CAAC,GAAG,MAAM,IAAI,UAAU,IAAI,CAAC,CAAC,KAAK,EAAE,IAAI,MAAM,IAAI,EAAE,CAAC;AAC3D,IAAI,CAAC;AACL;AACA,IAAI,CAAC,KAAK,EAAE;AACZ,IAAI,CAAC;AACL;AACA,IAAI,CAAC,CAAC,GAAG,MAAM,IAAI,UAAU,IAAI,CAAC,CAAC,KAAK,EAAE,IAAI,MAAM,IAAI,EAAE,CAAC;AAC3D;AACA,IAAI,CAAC,CAAC,GAAG,MAAM,IAAI,UAAU,IAAI,CAAC,CAAC,KAAK,EAAE,IAAI,MAAM,IAAI,EAAE,CAAC;AAC3D,EAAE,CAAC;;;AAGH,EAAE,QAAQ,GAAG;AACb,IAAI,KAAK,CAAC;AACV,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,KAAK,EAAE;;AAE/C,IAAI,KAAK,CAAC;AACV,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,KAAK,CAAC;;AAE9C,IAAI,KAAK,CAAC;AACV,MAAM,CAAC,IAAI,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI;AACnC,MAAM,CAAC;AACP;AACA,MAAM,CAAC,CAAC,GAAG,MAAM,IAAI,UAAU,IAAI,CAAC,CAAC,KAAK,EAAE,IAAI,MAAM,IAAI,EAAE,CAAC;AAC7D,GAAG;AACH;;;AAGA,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE;AACf,EAAE,CAAC;AACH;AACA,EAAE,CAAC,CAAC,GAAG,MAAM,IAAI,UAAU,IAAI,CAAC,CAAC,KAAK,EAAE,IAAI,MAAM,IAAI,EAAE,CAAC;AACzD,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,MAAM,CAAC,EAAE,QAAQ,CAAC,EAAE,CAAC;AAC5C;;;;","x_google_ignoreList":[0]}
@@ -1,3 +1,18 @@
1
+ var mockAdapter = {
2
+ appendCss: () => {},
3
+ registerClassName: () => {},
4
+ onEndFileScope: () => {},
5
+ registerComposition: () => {},
6
+ markCompositionUsed: () => {},
7
+ getIdentOption: () => process.env.NODE_ENV === 'production' ? 'short' : 'debug'
8
+ };
9
+ var adapterStack = [mockAdapter];
10
+ var currentAdapter = () => {
11
+ if (adapterStack.length < 1) {
12
+ throw new Error('No adapter configured');
13
+ }
14
+ return adapterStack[adapterStack.length - 1];
15
+ };
1
16
  var hasConfiguredAdapter = false;
2
17
  var setAdapterIfNotSet = newAdapter => {
3
18
  if (!hasConfiguredAdapter) {
@@ -9,7 +24,23 @@ var setAdapter = newAdapter => {
9
24
  throw new Error('No adapter provided when calling "setAdapter"');
10
25
  }
11
26
  hasConfiguredAdapter = true;
27
+ adapterStack.push(newAdapter);
28
+ };
29
+ var appendCss = function appendCss() {
30
+ return currentAdapter().appendCss(...arguments);
31
+ };
32
+ var markCompositionUsed = function markCompositionUsed() {
33
+ return currentAdapter().markCompositionUsed(...arguments);
34
+ };
35
+ var getIdentOption = function getIdentOption() {
36
+ var adapter = currentAdapter();
37
+
38
+ // Backwards compatibility with old versions of the integration package
39
+ if (!('getIdentOption' in adapter)) {
40
+ return process.env.NODE_ENV === 'production' ? 'short' : 'debug';
41
+ }
42
+ return adapter.getIdentOption(...arguments);
12
43
  };
13
44
 
14
- export { setAdapter, setAdapterIfNotSet };
45
+ export { appendCss, getIdentOption, markCompositionUsed, mockAdapter, setAdapter, setAdapterIfNotSet };
15
46
  //# sourceMappingURL=vanilla-extract-css-adapter.esm.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"vanilla-extract-css-adapter.esm.js","sources":["../../../../../../../node_modules/@vanilla-extract/css/adapter/dist/vanilla-extract-css-adapter.esm.js"],"sourcesContent":["var mockAdapter = {\n appendCss: () => {},\n registerClassName: () => {},\n onEndFileScope: () => {},\n registerComposition: () => {},\n markCompositionUsed: () => {},\n getIdentOption: () => process.env.NODE_ENV === 'production' ? 'short' : 'debug'\n};\nvar adapterStack = [mockAdapter];\nvar currentAdapter = () => {\n if (adapterStack.length < 1) {\n throw new Error('No adapter configured');\n }\n return adapterStack[adapterStack.length - 1];\n};\nvar hasConfiguredAdapter = false;\nvar setAdapterIfNotSet = newAdapter => {\n if (!hasConfiguredAdapter) {\n setAdapter(newAdapter);\n }\n};\nvar setAdapter = newAdapter => {\n if (!newAdapter) {\n throw new Error('No adapter provided when calling \"setAdapter\"');\n }\n hasConfiguredAdapter = true;\n adapterStack.push(newAdapter);\n};\nvar removeAdapter = () => {\n adapterStack.pop();\n};\nvar appendCss = function appendCss() {\n return currentAdapter().appendCss(...arguments);\n};\nvar registerClassName = function registerClassName() {\n return currentAdapter().registerClassName(...arguments);\n};\nvar registerComposition = function registerComposition() {\n return currentAdapter().registerComposition(...arguments);\n};\nvar markCompositionUsed = function markCompositionUsed() {\n return currentAdapter().markCompositionUsed(...arguments);\n};\nvar onBeginFileScope = function onBeginFileScope() {\n var _currentAdapter$onBeg, _currentAdapter;\n for (var _len = arguments.length, props = new Array(_len), _key = 0; _key < _len; _key++) {\n props[_key] = arguments[_key];\n }\n return (_currentAdapter$onBeg = (_currentAdapter = currentAdapter()).onBeginFileScope) === null || _currentAdapter$onBeg === void 0 ? void 0 : _currentAdapter$onBeg.call(_currentAdapter, ...props);\n};\nvar onEndFileScope = function onEndFileScope() {\n return currentAdapter().onEndFileScope(...arguments);\n};\nvar getIdentOption = function getIdentOption() {\n var adapter = currentAdapter();\n\n // Backwards compatibility with old versions of the integration package\n if (!('getIdentOption' in adapter)) {\n return process.env.NODE_ENV === 'production' ? 'short' : 'debug';\n }\n return adapter.getIdentOption(...arguments);\n};\n\nexport { appendCss, getIdentOption, markCompositionUsed, mockAdapter, onBeginFileScope, onEndFileScope, registerClassName, registerComposition, removeAdapter, setAdapter, setAdapterIfNotSet };\n"],"names":[],"mappings":"AAeA,IAAI,oBAAoB,GAAG,KAAK;AAC7B,IAAC,kBAAkB,GAAG,UAAU,IAAI;AACvC,EAAE,IAAI,CAAC,oBAAoB,EAAE;AAC7B,IAAI,UAAU,CAAC,UAAU,CAAC;AAC1B,EAAE;AACF;AACG,IAAC,UAAU,GAAG,UAAU,IAAI;AAC/B,EAAE,IAAI,CAAC,UAAU,EAAE;AACnB,IAAI,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC;AACpE,EAAE;AACF,EAAE,oBAAoB,GAAG,IAAI;AAE7B;;;;","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"vanilla-extract-css-adapter.esm.js","sources":["../../../../../../../node_modules/@vanilla-extract/css/adapter/dist/vanilla-extract-css-adapter.esm.js"],"sourcesContent":["var mockAdapter = {\n appendCss: () => {},\n registerClassName: () => {},\n onEndFileScope: () => {},\n registerComposition: () => {},\n markCompositionUsed: () => {},\n getIdentOption: () => process.env.NODE_ENV === 'production' ? 'short' : 'debug'\n};\nvar adapterStack = [mockAdapter];\nvar currentAdapter = () => {\n if (adapterStack.length < 1) {\n throw new Error('No adapter configured');\n }\n return adapterStack[adapterStack.length - 1];\n};\nvar hasConfiguredAdapter = false;\nvar setAdapterIfNotSet = newAdapter => {\n if (!hasConfiguredAdapter) {\n setAdapter(newAdapter);\n }\n};\nvar setAdapter = newAdapter => {\n if (!newAdapter) {\n throw new Error('No adapter provided when calling \"setAdapter\"');\n }\n hasConfiguredAdapter = true;\n adapterStack.push(newAdapter);\n};\nvar removeAdapter = () => {\n adapterStack.pop();\n};\nvar appendCss = function appendCss() {\n return currentAdapter().appendCss(...arguments);\n};\nvar registerClassName = function registerClassName() {\n return currentAdapter().registerClassName(...arguments);\n};\nvar registerComposition = function registerComposition() {\n return currentAdapter().registerComposition(...arguments);\n};\nvar markCompositionUsed = function markCompositionUsed() {\n return currentAdapter().markCompositionUsed(...arguments);\n};\nvar onBeginFileScope = function onBeginFileScope() {\n var _currentAdapter$onBeg, _currentAdapter;\n for (var _len = arguments.length, props = new Array(_len), _key = 0; _key < _len; _key++) {\n props[_key] = arguments[_key];\n }\n return (_currentAdapter$onBeg = (_currentAdapter = currentAdapter()).onBeginFileScope) === null || _currentAdapter$onBeg === void 0 ? void 0 : _currentAdapter$onBeg.call(_currentAdapter, ...props);\n};\nvar onEndFileScope = function onEndFileScope() {\n return currentAdapter().onEndFileScope(...arguments);\n};\nvar getIdentOption = function getIdentOption() {\n var adapter = currentAdapter();\n\n // Backwards compatibility with old versions of the integration package\n if (!('getIdentOption' in adapter)) {\n return process.env.NODE_ENV === 'production' ? 'short' : 'debug';\n }\n return adapter.getIdentOption(...arguments);\n};\n\nexport { appendCss, getIdentOption, markCompositionUsed, mockAdapter, onBeginFileScope, onEndFileScope, registerClassName, registerComposition, removeAdapter, setAdapter, setAdapterIfNotSet };\n"],"names":[],"mappings":"AAAG,IAAC,WAAW,GAAG;AAClB,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;AACrB,EAAE,iBAAiB,EAAE,MAAM,CAAC,CAAC;AAC7B,EAAE,cAAc,EAAE,MAAM,CAAC,CAAC;AAC1B,EAAE,mBAAmB,EAAE,MAAM,CAAC,CAAC;AAC/B,EAAE,mBAAmB,EAAE,MAAM,CAAC,CAAC;AAC/B,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,YAAY,GAAG,OAAO,GAAG;AAC1E;AACA,IAAI,YAAY,GAAG,CAAC,WAAW,CAAC;AAChC,IAAI,cAAc,GAAG,MAAM;AAC3B,EAAE,IAAI,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE;AAC/B,IAAI,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC;AAC5C,EAAE;AACF,EAAE,OAAO,YAAY,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC;AAC9C,CAAC;AACD,IAAI,oBAAoB,GAAG,KAAK;AAC7B,IAAC,kBAAkB,GAAG,UAAU,IAAI;AACvC,EAAE,IAAI,CAAC,oBAAoB,EAAE;AAC7B,IAAI,UAAU,CAAC,UAAU,CAAC;AAC1B,EAAE;AACF;AACG,IAAC,UAAU,GAAG,UAAU,IAAI;AAC/B,EAAE,IAAI,CAAC,UAAU,EAAE;AACnB,IAAI,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC;AACpE,EAAE;AACF,EAAE,oBAAoB,GAAG,IAAI;AAC7B,EAAE,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC;AAC/B;AAIG,IAAC,SAAS,GAAG,SAAS,SAAS,GAAG;AACrC,EAAE,OAAO,cAAc,EAAE,CAAC,SAAS,CAAC,GAAG,SAAS,CAAC;AACjD;AAOG,IAAC,mBAAmB,GAAG,SAAS,mBAAmB,GAAG;AACzD,EAAE,OAAO,cAAc,EAAE,CAAC,mBAAmB,CAAC,GAAG,SAAS,CAAC;AAC3D;AAWG,IAAC,cAAc,GAAG,SAAS,cAAc,GAAG;AAC/C,EAAE,IAAI,OAAO,GAAG,cAAc,EAAE;;AAEhC;AACA,EAAE,IAAI,EAAE,gBAAgB,IAAI,OAAO,CAAC,EAAE;AACtC,IAAI,OAAO,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,YAAY,GAAG,OAAO,GAAG,OAAO;AACpE,EAAE;AACF,EAAE,OAAO,OAAO,CAAC,cAAc,CAAC,GAAG,SAAS,CAAC;AAC7C;;;;","x_google_ignoreList":[0]}
@@ -0,0 +1,13 @@
1
+ function _taggedTemplateLiteral(strings, raw) {
2
+ if (!raw) {
3
+ raw = strings.slice(0);
4
+ }
5
+ return Object.freeze(Object.defineProperties(strings, {
6
+ raw: {
7
+ value: Object.freeze(raw)
8
+ }
9
+ }));
10
+ }
11
+
12
+ export { _taggedTemplateLiteral as _ };
13
+ //# sourceMappingURL=taggedTemplateLiteral-10998315.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"taggedTemplateLiteral-10998315.esm.js","sources":["../../../../../../node_modules/@vanilla-extract/css/dist/taggedTemplateLiteral-10998315.esm.js"],"sourcesContent":["function _taggedTemplateLiteral(strings, raw) {\n if (!raw) {\n raw = strings.slice(0);\n }\n return Object.freeze(Object.defineProperties(strings, {\n raw: {\n value: Object.freeze(raw)\n }\n }));\n}\n\nexport { _taggedTemplateLiteral as _ };\n"],"names":[],"mappings":"AAAA,SAAS,sBAAsB,CAAC,OAAO,EAAE,GAAG,EAAE;AAC9C,EAAE,IAAI,CAAC,GAAG,EAAE;AACZ,IAAI,GAAG,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;AAC1B,EAAE;AACF,EAAE,OAAO,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE;AACxD,IAAI,GAAG,EAAE;AACT,MAAM,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC,GAAG;AAC9B;AACA,GAAG,CAAC,CAAC;AACL;;;;","x_google_ignoreList":[0]}