@ultraviolet/ui 3.0.0-beta.20 → 3.0.0-beta.21

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 (79) hide show
  1. package/dist/components/ActionBar/styles.css.cjs +1 -0
  2. package/dist/components/ActionBar/styles.css.js +1 -0
  3. package/dist/components/Avatar/styles.css.cjs +0 -1
  4. package/dist/components/Avatar/styles.css.js +0 -1
  5. package/dist/components/Avatar/variables.css.cjs +1 -0
  6. package/dist/components/Avatar/variables.css.js +1 -0
  7. package/dist/components/Breadcrumbs/styles.css.cjs +0 -1
  8. package/dist/components/Breadcrumbs/styles.css.js +0 -1
  9. package/dist/components/Carousel/index.cjs +9 -64
  10. package/dist/components/Carousel/index.js +9 -62
  11. package/dist/components/Carousel/styles.css.cjs +15 -0
  12. package/dist/components/Carousel/styles.css.d.ts +6 -0
  13. package/dist/components/Carousel/styles.css.js +15 -0
  14. package/dist/components/Drawer/index.cjs +14 -105
  15. package/dist/components/Drawer/index.d.ts +9 -16
  16. package/dist/components/Drawer/index.js +11 -100
  17. package/dist/components/Drawer/styles.css.cjs +17 -0
  18. package/dist/components/Drawer/styles.css.d.ts +12 -0
  19. package/dist/components/Drawer/styles.css.js +17 -0
  20. package/dist/components/Modal/ModalContent.cjs +2 -14
  21. package/dist/components/Modal/ModalContent.js +2 -12
  22. package/dist/components/Modal/components/Dialog.cjs +18 -82
  23. package/dist/components/Modal/components/Dialog.d.ts +1 -13
  24. package/dist/components/Modal/components/Dialog.js +19 -81
  25. package/dist/components/Modal/constants.d.ts +42 -2
  26. package/dist/components/Modal/styles.css.cjs +21 -0
  27. package/dist/components/Modal/styles.css.d.ts +78 -0
  28. package/dist/components/Modal/styles.css.js +21 -0
  29. package/dist/components/Notification/index.cjs +2 -19
  30. package/dist/components/Notification/index.js +3 -20
  31. package/dist/components/Notification/styles.css.cjs +5 -0
  32. package/dist/components/Notification/styles.css.d.ts +1 -0
  33. package/dist/components/Notification/styles.css.js +5 -0
  34. package/dist/components/Pagination/PaginationButtons.cjs +4 -41
  35. package/dist/components/Pagination/PaginationButtons.js +4 -39
  36. package/dist/components/Pagination/PerPage.cjs +3 -20
  37. package/dist/components/Pagination/PerPage.js +3 -18
  38. package/dist/components/Pagination/styles.css.cjs +9 -0
  39. package/dist/components/Pagination/styles.css.d.ts +3 -0
  40. package/dist/components/Pagination/styles.css.js +9 -0
  41. package/dist/components/SelectInput/components/SearchBarDropdown.cjs +4 -4
  42. package/dist/components/SelectInput/components/SearchBarDropdown.js +1 -1
  43. package/dist/components/Snippet/index.cjs +20 -154
  44. package/dist/components/Snippet/index.js +18 -150
  45. package/dist/components/Snippet/styles.css.cjs +26 -0
  46. package/dist/components/Snippet/styles.css.d.ts +48 -0
  47. package/dist/components/Snippet/styles.css.js +26 -0
  48. package/dist/components/Stepper/Step.cjs +43 -113
  49. package/dist/components/Stepper/Step.js +41 -109
  50. package/dist/components/Stepper/index.cjs +10 -65
  51. package/dist/components/Stepper/index.js +10 -63
  52. package/dist/components/Stepper/styles.css.cjs +20 -0
  53. package/dist/components/Stepper/styles.css.d.ts +122 -0
  54. package/dist/components/Stepper/styles.css.js +20 -0
  55. package/dist/components/Table/Row.cjs +6 -6
  56. package/dist/components/Table/Row.js +6 -6
  57. package/dist/components/Text/style.css.cjs +0 -1
  58. package/dist/components/Text/style.css.js +0 -1
  59. package/dist/components/Text/variables.css.cjs +1 -0
  60. package/dist/components/Text/variables.css.js +1 -0
  61. package/dist/components/Toaster/index.cjs +3 -23
  62. package/dist/components/Toaster/index.js +3 -21
  63. package/dist/components/Toaster/styles.css.cjs +7 -0
  64. package/dist/components/Toaster/styles.css.d.ts +2 -0
  65. package/dist/components/Toaster/styles.css.js +7 -0
  66. package/dist/components/UnitInput/index.cjs +2 -1
  67. package/dist/components/UnitInput/index.d.ts +2 -1
  68. package/dist/components/UnitInput/index.js +2 -1
  69. package/dist/theme/ThemeProvider.cjs +16 -0
  70. package/dist/theme/ThemeProvider.js +16 -0
  71. package/dist/ui.css +1 -1
  72. package/dist/utils/animationVanillaExtract.css.d.ts +1 -0
  73. package/dist/utils/index.d.ts +1 -1
  74. package/package.json +2 -1
  75. package/dist/components/Modal/constants.cjs +0 -53
  76. package/dist/components/Modal/constants.js +0 -53
  77. package/dist/utils/searchAlgorithm.cjs +0 -40
  78. package/dist/utils/searchAlgorithm.d.ts +0 -12
  79. package/dist/utils/searchAlgorithm.js +0 -40
@@ -2,15 +2,9 @@
2
2
  "use strict";
3
3
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
4
  const jsxRuntime = require("@emotion/react/jsx-runtime");
5
- const _styled = require("@emotion/styled/base");
6
5
  const index$2 = require("../SelectInput/index.cjs");
7
6
  const index = require("../Stack/index.cjs");
8
7
  const index$1 = require("../Text/index.cjs");
9
- const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
10
- const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
11
- function _EMOTION_STRINGIFIED_CSS_ERROR__() {
12
- return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
13
- }
14
8
  const optionsItemsPerPage = [{
15
9
  label: "10",
16
10
  value: "10"
@@ -24,19 +18,6 @@ const optionsItemsPerPage = [{
24
18
  label: "100",
25
19
  value: "100"
26
20
  }];
27
- const StyledSelectInput = /* @__PURE__ */ _styled__default.default(index$2.SelectInput, process.env.NODE_ENV === "production" ? {
28
- target: "ehm0l0i0"
29
- } : {
30
- target: "ehm0l0i0",
31
- label: "StyledSelectInput"
32
- })(process.env.NODE_ENV === "production" ? {
33
- name: "1vwd1t",
34
- styles: "width:fit-content;min-width:none"
35
- } : {
36
- name: "1vwd1t",
37
- styles: "width:fit-content;min-width:none/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BhZ2luYXRpb24vUGVyUGFnZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkI2QyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9QYWdpbmF0aW9uL1BlclBhZ2UudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBEaXNwYXRjaCwgU2V0U3RhdGVBY3Rpb24gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFNlbGVjdElucHV0IH0gZnJvbSAnLi4vU2VsZWN0SW5wdXQnXG5pbXBvcnQgeyBTdGFjayB9IGZyb20gJy4uL1N0YWNrJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5cbmNvbnN0IG9wdGlvbnNJdGVtc1BlclBhZ2UgPSBbXG4gIHtcbiAgICBsYWJlbDogJzEwJyxcbiAgICB2YWx1ZTogJzEwJyxcbiAgfSxcbiAge1xuICAgIGxhYmVsOiAnMjUnLFxuICAgIHZhbHVlOiAnMjUnLFxuICB9LFxuICB7XG4gICAgbGFiZWw6ICc1MCcsXG4gICAgdmFsdWU6ICc1MCcsXG4gIH0sXG4gIHtcbiAgICBsYWJlbDogJzEwMCcsXG4gICAgdmFsdWU6ICcxMDAnLFxuICB9LFxuXVxuXG5jb25zdCBTdHlsZWRTZWxlY3RJbnB1dCA9IHN0eWxlZChTZWxlY3RJbnB1dClgXG4gIHdpZHRoOiBmaXQtY29udGVudDtcbiAgbWluLXdpZHRoOiBub25lO1xuYFxuXG50eXBlIFBlclBhZ2VQcm9wcyA9IHtcbiAgcGVyUGFnZTogbnVtYmVyXG4gIG9uQ2hhbmdlUGVyUGFnZT86IChwZXJQYWdlOiBudW1iZXIpID0+IHZvaWRcbiAgcGVyUGFnZVRleHQ/OiBzdHJpbmdcbiAgc2V0UGVyUGFnZTogRGlzcGF0Y2g8U2V0U3RhdGVBY3Rpb248bnVtYmVyPj5cbiAgbnVtYmVyT2ZJdGVtc1RleHQ/OiBzdHJpbmdcbiAgcGFnZTogbnVtYmVyXG4gIG51bWJlck9mSXRlbXM6IG51bWJlclxufVxuXG5leHBvcnQgY29uc3QgUGVyUGFnZSA9ICh7XG4gIHBlclBhZ2UsXG4gIG9uQ2hhbmdlUGVyUGFnZSxcbiAgcGVyUGFnZVRleHQsXG4gIHNldFBlclBhZ2UsXG4gIG51bWJlck9mSXRlbXNUZXh0LFxuICBwYWdlLFxuICBudW1iZXJPZkl0ZW1zLFxufTogUGVyUGFnZVByb3BzKSA9PiB7XG4gIGNvbnN0IGhhbmRsZUNoYW5nZSA9ICh2YWx1ZTogc3RyaW5nKSA9PiB7XG4gICAgY29uc3QgaW50VmFsdWUgPSBOdW1iZXIucGFyc2VJbnQodmFsdWUsIDEwKVxuICAgIG9uQ2hhbmdlUGVyUGFnZT8uKGludFZhbHVlKVxuICAgIHNldFBlclBhZ2UoaW50VmFsdWUpXG4gIH1cblxuICByZXR1cm4gKFxuICAgIDxTdGFjayBhbGlnbkl0ZW1zPVwiY2VudGVyXCIgZGlyZWN0aW9uPVwicm93XCIgZ2FwPVwiMlwiPlxuICAgICAgPFRleHQgYXM9XCJzcGFuXCIgcHJvbWluZW5jZT1cIndlYWtcIiBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgdmFyaWFudD1cImJvZHlcIj5cbiAgICAgICAge3BlclBhZ2VUZXh0ID8/ICdJdGVtcyBwZXIgcGFnZSd9XG4gICAgICA8L1RleHQ+XG4gICAgICA8U3R5bGVkU2VsZWN0SW5wdXRcbiAgICAgICAgbmFtZT1cInNlbGVjdC1pdGVtcy1wZXItcGFnZVwiXG4gICAgICAgIG9uQ2hhbmdlPXtoYW5kbGVDaGFuZ2V9XG4gICAgICAgIG9wdGlvbnM9e29wdGlvbnNJdGVtc1BlclBhZ2V9XG4gICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgIHZhbHVlPXtwZXJQYWdlLnRvU3RyaW5nKCl9XG4gICAgICAvPlxuICAgICAgPFRleHQgYXM9XCJzcGFuXCIgcHJvbWluZW5jZT1cIndlYWtcIiBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgdmFyaWFudD1cImJvZHlcIj5cbiAgICAgICAgeyhwYWdlIC0gMSkgKiBwZXJQYWdlICsgMX0te01hdGgubWluKHBhZ2UgKiBwZXJQYWdlLCBudW1iZXJPZkl0ZW1zKX17JyAnfVxuICAgICAgICB7bnVtYmVyT2ZJdGVtc1RleHQgPz8gYG9mICR7bnVtYmVyT2ZJdGVtc30gaXRlbXNcImB9XG4gICAgICA8L1RleHQ+XG4gICAgPC9TdGFjaz5cbiAgKVxufVxuIl19 */",
38
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
39
- });
40
21
  const PerPage = ({
41
22
  perPage,
42
23
  onChangePerPage,
@@ -53,7 +34,9 @@ const PerPage = ({
53
34
  };
54
35
  return /* @__PURE__ */ jsxRuntime.jsxs(index.Stack, { alignItems: "center", direction: "row", gap: "2", children: [
55
36
  /* @__PURE__ */ jsxRuntime.jsx(index$1.Text, { as: "span", prominence: "weak", sentiment: "neutral", variant: "body", children: perPageText ?? "Items per page" }),
56
- /* @__PURE__ */ jsxRuntime.jsx(StyledSelectInput, { name: "select-items-per-page", onChange: handleChange, options: optionsItemsPerPage, size: "small", value: perPage.toString() }),
37
+ /* @__PURE__ */ jsxRuntime.jsx(index$2.SelectInput, { name: "select-items-per-page", onChange: handleChange, options: optionsItemsPerPage, size: "small", style: {
38
+ width: "fit-content"
39
+ }, value: perPage.toString() }),
57
40
  /* @__PURE__ */ jsxRuntime.jsxs(index$1.Text, { as: "span", prominence: "weak", sentiment: "neutral", variant: "body", children: [
58
41
  (page - 1) * perPage + 1,
59
42
  "-",
@@ -1,12 +1,8 @@
1
1
  "use client";
2
2
  import { jsxs, jsx } from "@emotion/react/jsx-runtime";
3
- import _styled from "@emotion/styled/base";
4
3
  import { SelectInput } from "../SelectInput/index.js";
5
4
  import { Stack } from "../Stack/index.js";
6
5
  import { Text } from "../Text/index.js";
7
- function _EMOTION_STRINGIFIED_CSS_ERROR__() {
8
- return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
9
- }
10
6
  const optionsItemsPerPage = [{
11
7
  label: "10",
12
8
  value: "10"
@@ -20,19 +16,6 @@ const optionsItemsPerPage = [{
20
16
  label: "100",
21
17
  value: "100"
22
18
  }];
23
- const StyledSelectInput = /* @__PURE__ */ _styled(SelectInput, process.env.NODE_ENV === "production" ? {
24
- target: "ehm0l0i0"
25
- } : {
26
- target: "ehm0l0i0",
27
- label: "StyledSelectInput"
28
- })(process.env.NODE_ENV === "production" ? {
29
- name: "1vwd1t",
30
- styles: "width:fit-content;min-width:none"
31
- } : {
32
- name: "1vwd1t",
33
- styles: "width:fit-content;min-width:none/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BhZ2luYXRpb24vUGVyUGFnZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkI2QyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9QYWdpbmF0aW9uL1BlclBhZ2UudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBEaXNwYXRjaCwgU2V0U3RhdGVBY3Rpb24gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFNlbGVjdElucHV0IH0gZnJvbSAnLi4vU2VsZWN0SW5wdXQnXG5pbXBvcnQgeyBTdGFjayB9IGZyb20gJy4uL1N0YWNrJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5cbmNvbnN0IG9wdGlvbnNJdGVtc1BlclBhZ2UgPSBbXG4gIHtcbiAgICBsYWJlbDogJzEwJyxcbiAgICB2YWx1ZTogJzEwJyxcbiAgfSxcbiAge1xuICAgIGxhYmVsOiAnMjUnLFxuICAgIHZhbHVlOiAnMjUnLFxuICB9LFxuICB7XG4gICAgbGFiZWw6ICc1MCcsXG4gICAgdmFsdWU6ICc1MCcsXG4gIH0sXG4gIHtcbiAgICBsYWJlbDogJzEwMCcsXG4gICAgdmFsdWU6ICcxMDAnLFxuICB9LFxuXVxuXG5jb25zdCBTdHlsZWRTZWxlY3RJbnB1dCA9IHN0eWxlZChTZWxlY3RJbnB1dClgXG4gIHdpZHRoOiBmaXQtY29udGVudDtcbiAgbWluLXdpZHRoOiBub25lO1xuYFxuXG50eXBlIFBlclBhZ2VQcm9wcyA9IHtcbiAgcGVyUGFnZTogbnVtYmVyXG4gIG9uQ2hhbmdlUGVyUGFnZT86IChwZXJQYWdlOiBudW1iZXIpID0+IHZvaWRcbiAgcGVyUGFnZVRleHQ/OiBzdHJpbmdcbiAgc2V0UGVyUGFnZTogRGlzcGF0Y2g8U2V0U3RhdGVBY3Rpb248bnVtYmVyPj5cbiAgbnVtYmVyT2ZJdGVtc1RleHQ/OiBzdHJpbmdcbiAgcGFnZTogbnVtYmVyXG4gIG51bWJlck9mSXRlbXM6IG51bWJlclxufVxuXG5leHBvcnQgY29uc3QgUGVyUGFnZSA9ICh7XG4gIHBlclBhZ2UsXG4gIG9uQ2hhbmdlUGVyUGFnZSxcbiAgcGVyUGFnZVRleHQsXG4gIHNldFBlclBhZ2UsXG4gIG51bWJlck9mSXRlbXNUZXh0LFxuICBwYWdlLFxuICBudW1iZXJPZkl0ZW1zLFxufTogUGVyUGFnZVByb3BzKSA9PiB7XG4gIGNvbnN0IGhhbmRsZUNoYW5nZSA9ICh2YWx1ZTogc3RyaW5nKSA9PiB7XG4gICAgY29uc3QgaW50VmFsdWUgPSBOdW1iZXIucGFyc2VJbnQodmFsdWUsIDEwKVxuICAgIG9uQ2hhbmdlUGVyUGFnZT8uKGludFZhbHVlKVxuICAgIHNldFBlclBhZ2UoaW50VmFsdWUpXG4gIH1cblxuICByZXR1cm4gKFxuICAgIDxTdGFjayBhbGlnbkl0ZW1zPVwiY2VudGVyXCIgZGlyZWN0aW9uPVwicm93XCIgZ2FwPVwiMlwiPlxuICAgICAgPFRleHQgYXM9XCJzcGFuXCIgcHJvbWluZW5jZT1cIndlYWtcIiBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgdmFyaWFudD1cImJvZHlcIj5cbiAgICAgICAge3BlclBhZ2VUZXh0ID8/ICdJdGVtcyBwZXIgcGFnZSd9XG4gICAgICA8L1RleHQ+XG4gICAgICA8U3R5bGVkU2VsZWN0SW5wdXRcbiAgICAgICAgbmFtZT1cInNlbGVjdC1pdGVtcy1wZXItcGFnZVwiXG4gICAgICAgIG9uQ2hhbmdlPXtoYW5kbGVDaGFuZ2V9XG4gICAgICAgIG9wdGlvbnM9e29wdGlvbnNJdGVtc1BlclBhZ2V9XG4gICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgIHZhbHVlPXtwZXJQYWdlLnRvU3RyaW5nKCl9XG4gICAgICAvPlxuICAgICAgPFRleHQgYXM9XCJzcGFuXCIgcHJvbWluZW5jZT1cIndlYWtcIiBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgdmFyaWFudD1cImJvZHlcIj5cbiAgICAgICAgeyhwYWdlIC0gMSkgKiBwZXJQYWdlICsgMX0te01hdGgubWluKHBhZ2UgKiBwZXJQYWdlLCBudW1iZXJPZkl0ZW1zKX17JyAnfVxuICAgICAgICB7bnVtYmVyT2ZJdGVtc1RleHQgPz8gYG9mICR7bnVtYmVyT2ZJdGVtc30gaXRlbXNcImB9XG4gICAgICA8L1RleHQ+XG4gICAgPC9TdGFjaz5cbiAgKVxufVxuIl19 */",
34
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
35
- });
36
19
  const PerPage = ({
37
20
  perPage,
38
21
  onChangePerPage,
@@ -49,7 +32,9 @@ const PerPage = ({
49
32
  };
50
33
  return /* @__PURE__ */ jsxs(Stack, { alignItems: "center", direction: "row", gap: "2", children: [
51
34
  /* @__PURE__ */ jsx(Text, { as: "span", prominence: "weak", sentiment: "neutral", variant: "body", children: perPageText ?? "Items per page" }),
52
- /* @__PURE__ */ jsx(StyledSelectInput, { name: "select-items-per-page", onChange: handleChange, options: optionsItemsPerPage, size: "small", value: perPage.toString() }),
35
+ /* @__PURE__ */ jsx(SelectInput, { name: "select-items-per-page", onChange: handleChange, options: optionsItemsPerPage, size: "small", style: {
36
+ width: "fit-content"
37
+ }, value: perPage.toString() }),
53
38
  /* @__PURE__ */ jsxs(Text, { as: "span", prominence: "weak", sentiment: "neutral", variant: "body", children: [
54
39
  (page - 1) * perPage + 1,
55
40
  "-",
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ ;/* empty css */
4
+ var pageNumbersContainer = "uv_a0295u0";
5
+ var pageButton = { small: "uv_a0295u1", medium: "uv_a0295u2" };
6
+ var ellipsisClass = { small: "uv_a0295u4 uv_a0295u3", medium: "uv_a0295u5 uv_a0295u3" };
7
+ exports.ellipsisClass = ellipsisClass;
8
+ exports.pageButton = pageButton;
9
+ exports.pageNumbersContainer = pageNumbersContainer;
@@ -0,0 +1,3 @@
1
+ export declare const pageNumbersContainer: string;
2
+ export declare const pageButton: Record<"medium" | "small", string>;
3
+ export declare const ellipsisClass: Record<"medium" | "small", string>;
@@ -0,0 +1,9 @@
1
+ /* empty css */
2
+ var pageNumbersContainer = "uv_a0295u0";
3
+ var pageButton = { small: "uv_a0295u1", medium: "uv_a0295u2" };
4
+ var ellipsisClass = { small: "uv_a0295u4 uv_a0295u3", medium: "uv_a0295u5 uv_a0295u3" };
5
+ export {
6
+ ellipsisClass,
7
+ pageButton,
8
+ pageNumbersContainer
9
+ };
@@ -2,25 +2,25 @@
2
2
  "use strict";
3
3
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
4
  const jsxRuntime = require("@emotion/react/jsx-runtime");
5
+ const fuzzySearch = require("@scaleway/fuzzy-search");
5
6
  const Icon = require("@ultraviolet/icons");
6
7
  const react = require("react");
7
- const searchAlgorithm = require("../../../utils/searchAlgorithm.cjs");
8
8
  const index = require("../../TextInput/index.cjs");
9
9
  const SelectInputProvider = require("../SelectInputProvider.cjs");
10
10
  const dropdown_css = require("./dropdown.css.cjs");
11
11
  const getReferenceText = (option) => {
12
12
  if (option.searchText) {
13
- return searchAlgorithm.normalizeString(option.searchText);
13
+ return fuzzySearch.normalizeString(option.searchText);
14
14
  }
15
15
  if (typeof option.label === "string") {
16
- return searchAlgorithm.normalizeString(option.label);
16
+ return fuzzySearch.normalizeString(option.label);
17
17
  }
18
18
  return "";
19
19
  };
20
20
  const searchRegex = (data, query) => data.filter((option) => {
21
21
  const referenceText = getReferenceText(option);
22
22
  const regex = new RegExp(query, "i");
23
- return (query.length > 2 ? searchAlgorithm.isFuzzyMatch(query, referenceText) : referenceText.match(regex)) || typeof option.description === "string" && option.description.match(regex) || option.value.match(regex);
23
+ return (query.length > 2 ? fuzzySearch.isFuzzyMatch(query, referenceText) : referenceText.match(regex)) || typeof option.description === "string" && option.description.match(regex) || option.value.match(regex);
24
24
  });
25
25
  const findClosestOption = (options, searchInput) => {
26
26
  if (searchInput) {
@@ -1,8 +1,8 @@
1
1
  "use client";
2
2
  import { jsx } from "@emotion/react/jsx-runtime";
3
+ import { isFuzzyMatch, normalizeString } from "@scaleway/fuzzy-search";
3
4
  import { SearchIcon } from "@ultraviolet/icons";
4
5
  import { useRef, useEffect } from "react";
5
- import { isFuzzyMatch, normalizeString } from "../../../utils/searchAlgorithm.js";
6
6
  import { TextInput } from "../../TextInput/index.js";
7
7
  import { useSelectInput } from "../SelectInputProvider.js";
8
8
  import { searchBar } from "./dropdown.css.js";
@@ -2,157 +2,16 @@
2
2
  "use strict";
3
3
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
4
  const jsxRuntime = require("@emotion/react/jsx-runtime");
5
- const _styled = require("@emotion/styled/base");
6
5
  const Icon = require("@ultraviolet/icons");
7
- const themes = require("@ultraviolet/themes");
6
+ const dynamic = require("@vanilla-extract/dynamic");
8
7
  const react = require("react");
9
- const index$1 = require("../CopyButton/index.cjs");
10
- const index = require("../Expandable/index.cjs");
11
- const index$2 = require("../Stack/index.cjs");
8
+ const ThemeProvider = require("../../theme/ThemeProvider.cjs");
9
+ const index$2 = require("../CopyButton/index.cjs");
10
+ const index$1 = require("../Expandable/index.cjs");
11
+ const index = require("../Stack/index.cjs");
12
12
  const index$3 = require("../Text/index.cjs");
13
- const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
14
- const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
15
- function _EMOTION_STRINGIFIED_CSS_ERROR__() {
16
- return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
17
- }
13
+ const styles_css = require("./styles.css.cjs");
18
14
  const LINES_BREAK_REGEX = /\r\n|\r|\n/;
19
- const PreText = /* @__PURE__ */ _styled__default.default(index$3.Text, process.env.NODE_ENV === "production" ? {
20
- shouldForwardProp: (prop) => !["hasShowMoreButton", "showMore", "rows", "noExpandable"].includes(prop),
21
- target: "e1q0gj908"
22
- } : {
23
- shouldForwardProp: (prop) => !["hasShowMoreButton", "showMore", "rows", "noExpandable"].includes(prop),
24
- target: "e1q0gj908",
25
- label: "PreText"
26
- })("margin:0;padding:", ({
27
- theme
28
- }) => theme.space["2"], ";padding-right:", ({
29
- theme
30
- }) => theme.space["9"], ";overflow-x:", ({
31
- hasShowMoreButton,
32
- showMore
33
- }) => hasShowMoreButton && !showMore ? "hidden" : "auto", ";height:auto;counter-reset:section;", ({
34
- theme,
35
- noExpandable,
36
- rows
37
- }) => noExpandable ? `
38
- max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space["3"]});
39
- overflow-y: scroll;` : `overflow-y: hidden;
40
- `, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AAwBE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport { useTheme } from '@ultraviolet/themes'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n  white-space: pre;\n\n  &:not([data-multiline]):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  &[data-multiline=\"true\"]:nth-child(-n+2):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan data-multiline=\"true\" key={child} prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
41
- const StyledSpan = /* @__PURE__ */ _styled__default.default("span", process.env.NODE_ENV === "production" ? {
42
- shouldForwardProp: (prop) => !["linePrefix", "multiline", "prefix"].includes(prop),
43
- target: "e1q0gj907"
44
- } : {
45
- shouldForwardProp: (prop) => !["linePrefix", "multiline", "prefix"].includes(prop),
46
- target: "e1q0gj907",
47
- label: "StyledSpan"
48
- })('display:block;white-space:pre;&:not([data-multiline]):after{content:"";', ({
49
- theme
50
- }) => `padding-right: ${theme.space["8"]}`, ';}&[data-multiline="true"]:nth-child(-n+2):after{content:"";', ({
51
- theme
52
- }) => `padding-right: ${theme.space["8"]}`, ";}", ({
53
- prefix,
54
- theme
55
- }) => prefix ? `
56
- &:before {
57
- color: ${theme.colors.neutral.textWeak};
58
- width: ${prefix === "lines" ? "35px" : ""};
59
- display: inline-flex;
60
- justify-content: flex-end;
61
- counter-increment: section;
62
- content: ${prefix === "lines" ? "counter(section)" : "'$'"};
63
- padding-right: ${theme.space["1"]};
64
- }
65
- ` : null, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AA8CmE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport { useTheme } from '@ultraviolet/themes'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n  white-space: pre;\n\n  &:not([data-multiline]):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  &[data-multiline=\"true\"]:nth-child(-n+2):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan data-multiline=\"true\" key={child} prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
66
- const Container = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
67
- shouldForwardProp: (prop) => !["multiline"].includes(prop),
68
- target: "e1q0gj906"
69
- } : {
70
- shouldForwardProp: (prop) => !["multiline"].includes(prop),
71
- target: "e1q0gj906",
72
- label: "Container"
73
- })("position:relative;display:flex;justify-content:start;max-width:100%;", ({
74
- multiline
75
- }) => multiline ? "width: 100%;" : "", " background:", ({
76
- theme
77
- }) => theme.colors.neutral.backgroundWeak, ";border-radius:", ({
78
- theme
79
- }) => theme.radii.default, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AA8E2B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport { useTheme } from '@ultraviolet/themes'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n  white-space: pre;\n\n  &:not([data-multiline]):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  &[data-multiline=\"true\"]:nth-child(-n+2):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan data-multiline=\"true\" key={child} prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
80
- const StyledStack = /* @__PURE__ */ _styled__default.default(index$2.Stack, process.env.NODE_ENV === "production" ? {
81
- target: "e1q0gj905"
82
- } : {
83
- target: "e1q0gj905",
84
- label: "StyledStack"
85
- })(process.env.NODE_ENV === "production" ? {
86
- name: "1d3w5wq",
87
- styles: "width:100%"
88
- } : {
89
- name: "1d3w5wq",
90
- styles: "width:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AAwFiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport { useTheme } from '@ultraviolet/themes'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n  white-space: pre;\n\n  &:not([data-multiline]):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  &[data-multiline=\"true\"]:nth-child(-n+2):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan data-multiline=\"true\" key={child} prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */",
91
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
92
- });
93
- const ButtonContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
94
- shouldForwardProp: (prop) => !["multiline"].includes(prop),
95
- target: "e1q0gj904"
96
- } : {
97
- shouldForwardProp: (prop) => !["multiline"].includes(prop),
98
- target: "e1q0gj904",
99
- label: "ButtonContainer"
100
- })("position:absolute;top:0;right:0;padding:", ({
101
- theme,
102
- multiline
103
- }) => `${theme.space[multiline ? "2" : "1"]} ${theme.space["2"]} 0 0`, ";background:", ({
104
- theme
105
- }) => theme.colors.neutral.backgroundWeak, ";border-radius:", ({
106
- theme
107
- }) => theme.radii.default, ";border:2px solid transparent;", ({
108
- multiline,
109
- theme
110
- }) => !multiline ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}` : "", ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AA8F2B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport { useTheme } from '@ultraviolet/themes'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n  white-space: pre;\n\n  &:not([data-multiline]):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  &[data-multiline=\"true\"]:nth-child(-n+2):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan data-multiline=\"true\" key={child} prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
111
- const ShowMoreContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
112
- shouldForwardProp: (prop) => !["showMore"].includes(prop),
113
- target: "e1q0gj903"
114
- } : {
115
- shouldForwardProp: (prop) => !["showMore"].includes(prop),
116
- target: "e1q0gj903",
117
- label: "ShowMoreContainer"
118
- })("width:100%;box-shadow:", ({
119
- theme,
120
- showMore
121
- }) => !showMore ? `0px -22px 19px -6px
122
- ${theme.colors.neutral.backgroundWeak}` : "none", ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AA+G0B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport { useTheme } from '@ultraviolet/themes'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n  white-space: pre;\n\n  &:not([data-multiline]):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  &[data-multiline=\"true\"]:nth-child(-n+2):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan data-multiline=\"true\" key={child} prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
123
- const StyledButton = /* @__PURE__ */ _styled__default.default("button", process.env.NODE_ENV === "production" ? {
124
- target: "e1q0gj902"
125
- } : {
126
- target: "e1q0gj902",
127
- label: "StyledButton"
128
- })("width:100%;background:none;border:none;padding:", ({
129
- theme
130
- }) => theme.space["2"], ";padding-top:", ({
131
- theme
132
- }) => theme.space["1"], ";cursor:pointer;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AAwHkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport { useTheme } from '@ultraviolet/themes'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n  white-space: pre;\n\n  &:not([data-multiline]):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  &[data-multiline=\"true\"]:nth-child(-n+2):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan data-multiline=\"true\" key={child} prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
133
- const AlignCenterText = /* @__PURE__ */ _styled__default.default(index$3.Text, process.env.NODE_ENV === "production" ? {
134
- target: "e1q0gj901"
135
- } : {
136
- target: "e1q0gj901",
137
- label: "AlignCenterText"
138
- })(process.env.NODE_ENV === "production" ? {
139
- name: "1vcob1d",
140
- styles: "display:flex;justify-content:center;align-items:center"
141
- } : {
142
- name: "1vcob1d",
143
- styles: "display:flex;justify-content:center;align-items:center/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AAiIoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport { useTheme } from '@ultraviolet/themes'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n  white-space: pre;\n\n  &:not([data-multiline]):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  &[data-multiline=\"true\"]:nth-child(-n+2):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan data-multiline=\"true\" key={child} prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */",
144
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
145
- });
146
- const AnimatedArrowIcon = /* @__PURE__ */ _styled__default.default(Icon.ArrowDownIcon, process.env.NODE_ENV === "production" ? {
147
- shouldForwardProp: (prop) => !["showMore"].includes(prop),
148
- target: "e1q0gj900"
149
- } : {
150
- shouldForwardProp: (prop) => !["showMore"].includes(prop),
151
- target: "e1q0gj900",
152
- label: "AnimatedArrowIcon"
153
- })("transform:", ({
154
- showMore
155
- }) => showMore ? "rotate(180deg)" : "rotate(0deg)", ";transform-origin:center;transition:transform 300ms ease-in-out;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AAyI0B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport { useTheme } from '@ultraviolet/themes'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n  white-space: pre;\n\n  &:not([data-multiline]):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  &[data-multiline=\"true\"]:nth-child(-n+2):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan data-multiline=\"true\" key={child} prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
156
15
  const CodeContent = ({
157
16
  children,
158
17
  prefix,
@@ -162,7 +21,14 @@ const CodeContent = ({
162
21
  lines,
163
22
  noExpandable,
164
23
  rows
165
- }) => /* @__PURE__ */ jsxRuntime.jsx(PreText, { as: "pre", hasShowMoreButton, noExpandable, rows, showMore, variant: "code", whiteSpace: !multiline ? "nowrap" : void 0, children: multiline ? react.Children.map(lines, (child) => /* @__PURE__ */ jsxRuntime.jsx(StyledSpan, { "data-multiline": "true", prefix, children: child }, child)) : /* @__PURE__ */ jsxRuntime.jsx(StyledSpan, { prefix, children }) });
24
+ }) => /* @__PURE__ */ jsxRuntime.jsx(index$3.Text, { as: "pre", className: styles_css.pretext({
25
+ noExpandable,
26
+ showMore: hasShowMoreButton && !showMore
27
+ }), style: dynamic.assignInlineVars({
28
+ [styles_css.rowsVar]: rows.toString()
29
+ }), variant: "code", whiteSpace: !multiline ? "nowrap" : void 0, children: multiline ? react.Children.map(lines, (child) => /* @__PURE__ */ jsxRuntime.jsx("span", { className: `${styles_css.line({
30
+ multiline: true
31
+ })} ${prefix ? styles_css.prefix[prefix] : ""}`, children: child }, child)) : /* @__PURE__ */ jsxRuntime.jsx("span", { className: `${styles_css.line()} ${prefix ? styles_css.prefix[prefix] : ""}`, children }) });
166
32
  const Snippet = ({
167
33
  children,
168
34
  copyText,
@@ -177,20 +43,20 @@ const Snippet = ({
177
43
  noExpandable = false,
178
44
  onCopy
179
45
  }) => {
180
- const theme = themes.useTheme();
46
+ const theme = ThemeProvider.useTheme();
181
47
  const [showMore, setShowMore] = react.useReducer((value) => !value, initiallyExpanded ?? false);
182
48
  const lines = children.split(LINES_BREAK_REGEX);
183
49
  const numberOfLines = lines.length;
184
50
  const multiline = numberOfLines > 1;
185
51
  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable;
186
52
  const minHeight = rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 + Number.parseFloat(theme.space[4]) * 16;
187
- return /* @__PURE__ */ jsxRuntime.jsx(Container, { className, "data-testid": dataTestId, multiline, children: /* @__PURE__ */ jsxRuntime.jsxs(StyledStack, { children: [
188
- hasShowMoreButton ? /* @__PURE__ */ jsxRuntime.jsx(index.Expandable, { minHeight, opened: showMore, children: /* @__PURE__ */ jsxRuntime.jsx(CodeContent, { lines, multiline, noExpandable, prefix, rows, children }) }) : /* @__PURE__ */ jsxRuntime.jsx(CodeContent, { lines, multiline, noExpandable, prefix, rows, children }),
189
- /* @__PURE__ */ jsxRuntime.jsx(ButtonContainer, { multiline: multiline && numberOfLines > 1, children: /* @__PURE__ */ jsxRuntime.jsx(index$1.CopyButton, { copiedText, copyText, onCopy, sentiment: "neutral", value: children }) }),
190
- hasShowMoreButton ? /* @__PURE__ */ jsxRuntime.jsx(ShowMoreContainer, { showMore, children: /* @__PURE__ */ jsxRuntime.jsx(StyledButton, { "aria-expanded": showMore, onClick: setShowMore, type: "button", children: /* @__PURE__ */ jsxRuntime.jsxs(AlignCenterText, { as: "span", sentiment: "neutral", variant: "bodySmallStrong", children: [
53
+ return /* @__PURE__ */ jsxRuntime.jsx("div", { className: `${className ? `${className} ` : ""}${styles_css.snippetContainer[multiline ? "multiline" : "oneLine"]}`, "data-testid": dataTestId, children: /* @__PURE__ */ jsxRuntime.jsxs(index.Stack, { className: styles_css.stackStyle, children: [
54
+ hasShowMoreButton ? /* @__PURE__ */ jsxRuntime.jsx(index$1.Expandable, { minHeight, opened: showMore, children: /* @__PURE__ */ jsxRuntime.jsx(CodeContent, { lines, multiline, noExpandable, prefix, rows, children }) }) : /* @__PURE__ */ jsxRuntime.jsx(CodeContent, { lines, multiline, noExpandable, prefix, rows, children }),
55
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles_css.buttonContainer[multiline && numberOfLines > 1 ? "multiline" : "oneLine"], children: /* @__PURE__ */ jsxRuntime.jsx(index$2.CopyButton, { copiedText, copyText, onCopy, sentiment: "neutral", value: children }) }),
56
+ hasShowMoreButton ? /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles_css.showMoreContainer[showMore ? "true" : "false"], children: /* @__PURE__ */ jsxRuntime.jsx("button", { "aria-expanded": showMore, className: styles_css.showMoreButton, onClick: setShowMore, type: "button", children: /* @__PURE__ */ jsxRuntime.jsxs(index$3.Text, { as: "span", className: styles_css.centeredText, sentiment: "neutral", variant: "bodySmallStrong", children: [
191
57
  showMore ? hideText : showText,
192
58
  " ",
193
- /* @__PURE__ */ jsxRuntime.jsx(AnimatedArrowIcon, { showMore })
59
+ /* @__PURE__ */ jsxRuntime.jsx(Icon.ArrowDownIcon, { className: styles_css.animatedArrowIcon[showMore ? "true" : "false"] })
194
60
  ] }) }) }) : null
195
61
  ] }) });
196
62
  };