@danielcruzcode/ui-core 0.1.6 → 0.1.8

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 (117) hide show
  1. package/dist/JumboProvider/JumboProvider.d.ts +6 -0
  2. package/dist/JumboProvider/JumboProvider.d.ts.map +1 -0
  3. package/dist/JumboProvider/JumboProvider.js +37 -0
  4. package/dist/JumboProvider/JumboProvider.js.map +1 -0
  5. package/dist/JumboProvider/index.d.ts +3 -0
  6. package/dist/JumboProvider/index.d.ts.map +1 -0
  7. package/dist/JumboProvider/index.js +2 -0
  8. package/dist/JumboProvider/index.js.map +1 -0
  9. package/dist/commerce/ProductCard/ProductCard.d.ts +4 -5
  10. package/dist/commerce/ProductCard/ProductCard.d.ts.map +1 -1
  11. package/dist/commerce/ProductCard/ProductCard.js +42 -0
  12. package/dist/commerce/ProductCard/ProductCard.js.map +1 -0
  13. package/dist/commerce/ProductCard/ProductCard.styles.d.ts +106 -0
  14. package/dist/commerce/ProductCard/ProductCard.styles.d.ts.map +1 -0
  15. package/dist/commerce/ProductCard/ProductCard.styles.js +212 -0
  16. package/dist/commerce/ProductCard/ProductCard.styles.js.map +1 -0
  17. package/dist/commerce/ProductCard/index.js +2 -0
  18. package/dist/commerce/ProductCard/index.js.map +1 -0
  19. package/dist/commerce/ProductShelf/ProductShelf.d.ts +6 -3
  20. package/dist/commerce/ProductShelf/ProductShelf.d.ts.map +1 -1
  21. package/dist/commerce/ProductShelf/ProductShelf.js +20 -0
  22. package/dist/commerce/ProductShelf/ProductShelf.js.map +1 -0
  23. package/dist/commerce/ProductShelf/index.js +2 -0
  24. package/dist/commerce/ProductShelf/index.js.map +1 -0
  25. package/dist/components/Card/Card.d.ts +1 -1
  26. package/dist/components/Card/Card.d.ts.map +1 -1
  27. package/dist/components/Card/Card.js +33 -0
  28. package/dist/components/Card/Card.js.map +1 -0
  29. package/dist/components/Carousel/Carousel.d.ts +7 -3
  30. package/dist/components/Carousel/Carousel.d.ts.map +1 -1
  31. package/dist/components/Carousel/Carousel.js +24 -9
  32. package/dist/components/Carousel/Carousel.js.map +1 -1
  33. package/dist/components/Carousel/index.js +2 -0
  34. package/dist/components/Carousel/index.js.map +1 -0
  35. package/dist/index.cjs.js +1 -1
  36. package/dist/index.cjs10.js +1 -1
  37. package/dist/index.cjs11.js +1 -1
  38. package/dist/index.cjs12.js +1 -5
  39. package/dist/index.cjs13.js +1 -6
  40. package/dist/index.cjs14.js +1 -1
  41. package/dist/index.cjs15.js +1 -1
  42. package/dist/index.cjs16.js +1 -1
  43. package/dist/index.cjs17.js +26 -1
  44. package/dist/index.cjs18.js +1 -1
  45. package/dist/index.cjs19.js +1 -0
  46. package/dist/index.cjs2.js +1 -19
  47. package/dist/index.cjs20.js +1 -0
  48. package/dist/index.cjs21.js +1 -0
  49. package/dist/index.cjs22.js +1 -0
  50. package/dist/index.cjs23.js +1 -0
  51. package/dist/index.cjs24.js +1 -0
  52. package/dist/index.cjs25.js +1 -0
  53. package/dist/index.cjs26.js +1 -0
  54. package/dist/index.cjs27.js +1 -0
  55. package/dist/index.cjs28.js +1 -0
  56. package/dist/index.cjs29.js +1 -0
  57. package/dist/index.cjs3.js +1 -12
  58. package/dist/index.cjs4.js +1 -17
  59. package/dist/index.cjs5.js +1 -17
  60. package/dist/index.cjs6.js +1 -8
  61. package/dist/index.cjs7.js +1 -12
  62. package/dist/index.cjs8.js +1 -8
  63. package/dist/index.cjs9.js +1 -18
  64. package/dist/index.d.ts +2 -0
  65. package/dist/index.d.ts.map +1 -1
  66. package/dist/index.esm.js +18 -16
  67. package/dist/index.esm10.js +101 -61
  68. package/dist/index.esm11.js +57 -24
  69. package/dist/index.esm12.js +11 -11
  70. package/dist/index.esm13.js +27 -12
  71. package/dist/index.esm14.js +26 -45
  72. package/dist/index.esm15.js +75 -22
  73. package/dist/index.esm16.js +45 -33
  74. package/dist/index.esm17.js +167 -1202
  75. package/dist/index.esm18.js +22 -50
  76. package/dist/index.esm19.js +12 -0
  77. package/dist/index.esm2.js +47 -37
  78. package/dist/index.esm20.js +130 -0
  79. package/dist/index.esm21.js +7 -0
  80. package/dist/index.esm22.js +34 -0
  81. package/dist/index.esm23.js +10 -0
  82. package/dist/index.esm24.js +22 -0
  83. package/dist/index.esm25.js +53 -0
  84. package/dist/index.esm26.js +9 -0
  85. package/dist/index.esm27.js +52 -0
  86. package/dist/index.esm28.js +35 -0
  87. package/dist/index.esm29.js +1204 -0
  88. package/dist/index.esm3.js +31 -26
  89. package/dist/index.esm4.js +27 -27
  90. package/dist/index.esm5.js +84 -34
  91. package/dist/index.esm6.js +72 -23
  92. package/dist/index.esm7.js +62 -27
  93. package/dist/index.esm8.js +68 -34
  94. package/dist/index.esm9.js +114 -84
  95. package/dist/index.js +19 -0
  96. package/dist/index.js.map +1 -0
  97. package/dist/layout/Container/Container.js +14 -0
  98. package/dist/layout/Container/Container.js.map +1 -0
  99. package/dist/layout/Stack/Stack.js +13 -0
  100. package/dist/layout/Stack/Stack.js.map +1 -0
  101. package/dist/primitives/Badge/Badge.d.ts +3 -2
  102. package/dist/primitives/Badge/Badge.d.ts.map +1 -1
  103. package/dist/primitives/Badge/Badge.js +31 -0
  104. package/dist/primitives/Badge/Badge.js.map +1 -0
  105. package/dist/primitives/Badge/index.js +2 -0
  106. package/dist/primitives/Badge/index.js.map +1 -0
  107. package/dist/primitives/Button/Button.js +37 -0
  108. package/dist/primitives/Button/Button.js.map +1 -0
  109. package/dist/primitives/Checkbox/Checkbox.js +28 -0
  110. package/dist/primitives/Checkbox/Checkbox.js.map +1 -0
  111. package/dist/primitives/Input/Input.js +36 -0
  112. package/dist/primitives/Input/Input.js.map +1 -0
  113. package/dist/primitives/Select/Select.js +24 -0
  114. package/dist/primitives/Select/Select.js.map +1 -0
  115. package/dist/primitives/Tag/Tag.js +29 -0
  116. package/dist/primitives/Tag/Tag.js.map +1 -0
  117. package/package.json +2 -1
@@ -1,32 +1,67 @@
1
- import { jsxs as f, jsx as e } from "react/jsx-runtime";
2
- import i from "@emotion/styled";
3
- import { tokens as t } from "./index.esm14.js";
4
- import { useId as x, useRef as b, useEffect as k } from "react";
5
- const g = i.label`
6
- display: inline-flex; align-items: center; gap: ${t.space.sm};
7
- cursor: ${({ disabled: o }) => o ? "not-allowed" : "pointer"};
8
- opacity: ${({ disabled: o }) => o ? 0.5 : 1};
9
- font-family: ${t.font.body}; user-select: none;
10
- `, m = i.input`position:absolute;opacity:0;width:0;height:0;margin:0;`, $ = i.span`
11
- width: 18px; height: 18px; border-radius: ${t.radius.sm};
12
- border: 1.5px solid ${({ active: o }) => o ? t.color.brand : t.color.border};
13
- background-color: ${({ active: o }) => o ? t.color.brand : t.color.background};
14
- display: flex; align-items: center; justify-content: center; flex-shrink: 0;
15
- transition: background-color ${t.transition.fast}, border-color ${t.transition.fast};
16
- `, w = i.span`font-size: 15px; color: ${t.color.text};`;
17
- function B({ checked: o = !1, onChange: n, label: l, disabled: a = !1, indeterminate: r = !1, name: h, id: s }) {
18
- const p = x(), d = s != null ? s : p, c = b(null);
19
- return k(() => {
20
- c.current && (c.current.indeterminate = r);
21
- }, [r]), /* @__PURE__ */ f(g, { htmlFor: d, disabled: a, children: [
22
- /* @__PURE__ */ e(m, { ref: c, id: d, name: h, type: "checkbox", checked: o, disabled: a, onChange: (u) => n == null ? void 0 : n(u.target.checked), "aria-checked": r ? "mixed" : o }),
23
- /* @__PURE__ */ f($, { active: o || r, "aria-hidden": "true", children: [
24
- r && /* @__PURE__ */ e("svg", { width: "10", height: "2", viewBox: "0 0 10 2", fill: "none", children: /* @__PURE__ */ e("path", { d: "M1 1h8", stroke: "white", strokeWidth: "2", strokeLinecap: "round" }) }),
25
- o && !r && /* @__PURE__ */ e("svg", { width: "10", height: "8", viewBox: "0 0 10 8", fill: "none", children: /* @__PURE__ */ e("path", { d: "M1 4l3 3 5-6", stroke: "white", strokeWidth: "1.8", strokeLinecap: "round", strokeLinejoin: "round" }) })
1
+ import { jsxs as i, jsx as b } from "react/jsx-runtime";
2
+ import c from "./index.esm15.js";
3
+ import { tokens as Z } from "./index.esm16.js";
4
+ import { useId as C, useRef as Y, useEffect as t } from "react";
5
+ function B() {
6
+ 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).";
7
+ }
8
+ const o = /* @__PURE__ */ c("label", process.env.NODE_ENV === "production" ? {
9
+ target: "enlaae73"
10
+ } : {
11
+ target: "enlaae73",
12
+ label: "Wrapper"
13
+ })("display:inline-flex;align-items:center;gap:", Z.space.sm, ";cursor:", ({
14
+ disabled: I
15
+ }) => I ? "not-allowed" : "pointer", ";opacity:", ({
16
+ disabled: I
17
+ }) => I ? 0.5 : 1, ";font-family:", Z.font.body, ";user-select:none;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy9tYWNib29rL0RvY3VtZW50cy9jZW5jb3N1ZC9qdW1iby9saWIvcGFja2FnZXMvdWktY29yZS9zcmMvcHJpbWl0aXZlcy9DaGVja2JveC9DaGVja2JveC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBY21EIiwiZmlsZSI6Ii9Vc2Vycy9tYWNib29rL0RvY3VtZW50cy9jZW5jb3N1ZC9qdW1iby9saWIvcGFja2FnZXMvdWktY29yZS9zcmMvcHJpbWl0aXZlcy9DaGVja2JveC9DaGVja2JveC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IHRva2VucyB9IGZyb20gJ0BkYW5pZWxjcnV6Y29kZS9kZXNpZ24tdG9rZW5zJ1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VJZCwgdXNlUmVmIH0gZnJvbSAncmVhY3QnXG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2hlY2tib3hQcm9wcyB7XG4gIGNoZWNrZWQ/OiBib29sZWFuXG4gIG9uQ2hhbmdlPzogKGNoZWNrZWQ6IGJvb2xlYW4pID0+IHZvaWRcbiAgbGFiZWw/OiBzdHJpbmdcbiAgZGlzYWJsZWQ/OiBib29sZWFuXG4gIGluZGV0ZXJtaW5hdGU/OiBib29sZWFuXG4gIG5hbWU/OiBzdHJpbmdcbiAgaWQ/OiBzdHJpbmdcbn1cblxuY29uc3QgV3JhcHBlciA9IHN0eWxlZC5sYWJlbDx7IGRpc2FibGVkOiBib29sZWFuIH0+YFxuICBkaXNwbGF5OiBpbmxpbmUtZmxleDsgYWxpZ24taXRlbXM6IGNlbnRlcjsgZ2FwOiAke3Rva2Vucy5zcGFjZS5zbX07XG4gIGN1cnNvcjogJHsoeyBkaXNhYmxlZCB9KSA9PiAoZGlzYWJsZWQgPyAnbm90LWFsbG93ZWQnIDogJ3BvaW50ZXInKX07XG4gIG9wYWNpdHk6ICR7KHsgZGlzYWJsZWQgfSkgPT4gKGRpc2FibGVkID8gMC41IDogMSl9O1xuICBmb250LWZhbWlseTogJHt0b2tlbnMuZm9udC5ib2R5fTsgdXNlci1zZWxlY3Q6IG5vbmU7XG5gXG5jb25zdCBIaWRkZW5JbnB1dCA9IHN0eWxlZC5pbnB1dGBwb3NpdGlvbjphYnNvbHV0ZTtvcGFjaXR5OjA7d2lkdGg6MDtoZWlnaHQ6MDttYXJnaW46MDtgXG5jb25zdCBCb3ggPSBzdHlsZWQuc3Bhbjx7IGFjdGl2ZTogYm9vbGVhbiB9PmBcbiAgd2lkdGg6IDE4cHg7IGhlaWdodDogMThweDsgYm9yZGVyLXJhZGl1czogJHt0b2tlbnMucmFkaXVzLnNtfTtcbiAgYm9yZGVyOiAxLjVweCBzb2xpZCAkeyh7IGFjdGl2ZSB9KSA9PiAoYWN0aXZlID8gdG9rZW5zLmNvbG9yLmJyYW5kIDogdG9rZW5zLmNvbG9yLmJvcmRlcil9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IGFjdGl2ZSB9KSA9PiAoYWN0aXZlID8gdG9rZW5zLmNvbG9yLmJyYW5kIDogdG9rZW5zLmNvbG9yLmJhY2tncm91bmQpfTtcbiAgZGlzcGxheTogZmxleDsgYWxpZ24taXRlbXM6IGNlbnRlcjsganVzdGlmeS1jb250ZW50OiBjZW50ZXI7IGZsZXgtc2hyaW5rOiAwO1xuICB0cmFuc2l0aW9uOiBiYWNrZ3JvdW5kLWNvbG9yICR7dG9rZW5zLnRyYW5zaXRpb24uZmFzdH0sIGJvcmRlci1jb2xvciAke3Rva2Vucy50cmFuc2l0aW9uLmZhc3R9O1xuYFxuY29uc3QgTGFiZWxUZXh0ID0gc3R5bGVkLnNwYW5gZm9udC1zaXplOiAxNXB4OyBjb2xvcjogJHt0b2tlbnMuY29sb3IudGV4dH07YFxuXG5leHBvcnQgZnVuY3Rpb24gQ2hlY2tib3goeyBjaGVja2VkID0gZmFsc2UsIG9uQ2hhbmdlLCBsYWJlbCwgZGlzYWJsZWQgPSBmYWxzZSwgaW5kZXRlcm1pbmF0ZSA9IGZhbHNlLCBuYW1lLCBpZDogaWRQcm9wIH06IENoZWNrYm94UHJvcHMpIHtcbiAgY29uc3QgZ2VuZXJhdGVkSWQgPSB1c2VJZCgpXG4gIGNvbnN0IGlkID0gaWRQcm9wID8/IGdlbmVyYXRlZElkXG4gIGNvbnN0IGlucHV0UmVmID0gdXNlUmVmPEhUTUxJbnB1dEVsZW1lbnQ+KG51bGwpXG4gIHVzZUVmZmVjdCgoKSA9PiB7IGlmIChpbnB1dFJlZi5jdXJyZW50KSBpbnB1dFJlZi5jdXJyZW50LmluZGV0ZXJtaW5hdGUgPSBpbmRldGVybWluYXRlIH0sIFtpbmRldGVybWluYXRlXSlcbiAgcmV0dXJuIChcbiAgICA8V3JhcHBlciBodG1sRm9yPXtpZH0gZGlzYWJsZWQ9e2Rpc2FibGVkfT5cbiAgICAgIDxIaWRkZW5JbnB1dCByZWY9e2lucHV0UmVmfSBpZD17aWR9IG5hbWU9e25hbWV9IHR5cGU9XCJjaGVja2JveFwiIGNoZWNrZWQ9e2NoZWNrZWR9IGRpc2FibGVkPXtkaXNhYmxlZH0gb25DaGFuZ2U9eyhlKSA9PiBvbkNoYW5nZT8uKGUudGFyZ2V0LmNoZWNrZWQpfSBhcmlhLWNoZWNrZWQ9e2luZGV0ZXJtaW5hdGUgPyAnbWl4ZWQnIDogY2hlY2tlZH0gLz5cbiAgICAgIDxCb3ggYWN0aXZlPXtjaGVja2VkIHx8IGluZGV0ZXJtaW5hdGV9IGFyaWEtaGlkZGVuPVwidHJ1ZVwiPlxuICAgICAgICB7aW5kZXRlcm1pbmF0ZSAmJiA8c3ZnIHdpZHRoPVwiMTBcIiBoZWlnaHQ9XCIyXCIgdmlld0JveD1cIjAgMCAxMCAyXCIgZmlsbD1cIm5vbmVcIj48cGF0aCBkPVwiTTEgMWg4XCIgc3Ryb2tlPVwid2hpdGVcIiBzdHJva2VXaWR0aD1cIjJcIiBzdHJva2VMaW5lY2FwPVwicm91bmRcIiAvPjwvc3ZnPn1cbiAgICAgICAge2NoZWNrZWQgJiYgIWluZGV0ZXJtaW5hdGUgJiYgPHN2ZyB3aWR0aD1cIjEwXCIgaGVpZ2h0PVwiOFwiIHZpZXdCb3g9XCIwIDAgMTAgOFwiIGZpbGw9XCJub25lXCI+PHBhdGggZD1cIk0xIDRsMyAzIDUtNlwiIHN0cm9rZT1cIndoaXRlXCIgc3Ryb2tlV2lkdGg9XCIxLjhcIiBzdHJva2VMaW5lY2FwPVwicm91bmRcIiBzdHJva2VMaW5lam9pbj1cInJvdW5kXCIgLz48L3N2Zz59XG4gICAgICA8L0JveD5cbiAgICAgIHtsYWJlbCAmJiA8TGFiZWxUZXh0PntsYWJlbH08L0xhYmVsVGV4dD59XG4gICAgPC9XcmFwcGVyPlxuICApXG59XG4iXX0= */")), n = /* @__PURE__ */ c("input", process.env.NODE_ENV === "production" ? {
18
+ target: "enlaae72"
19
+ } : {
20
+ target: "enlaae72",
21
+ label: "HiddenInput"
22
+ })(process.env.NODE_ENV === "production" ? {
23
+ name: "1k9qwvf",
24
+ styles: "position:absolute;opacity:0;width:0;height:0;margin:0"
25
+ } : {
26
+ name: "1k9qwvf",
27
+ styles: "position:absolute;opacity:0;width:0;height:0;margin:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy9tYWNib29rL0RvY3VtZW50cy9jZW5jb3N1ZC9qdW1iby9saWIvcGFja2FnZXMvdWktY29yZS9zcmMvcHJpbWl0aXZlcy9DaGVja2JveC9DaGVja2JveC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0JnQyIsImZpbGUiOiIvVXNlcnMvbWFjYm9vay9Eb2N1bWVudHMvY2VuY29zdWQvanVtYm8vbGliL3BhY2thZ2VzL3VpLWNvcmUvc3JjL3ByaW1pdGl2ZXMvQ2hlY2tib3gvQ2hlY2tib3gudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyB0b2tlbnMgfSBmcm9tICdAZGFuaWVsY3J1emNvZGUvZGVzaWduLXRva2VucydcbmltcG9ydCB7IHVzZUVmZmVjdCwgdXNlSWQsIHVzZVJlZiB9IGZyb20gJ3JlYWN0J1xuXG5leHBvcnQgaW50ZXJmYWNlIENoZWNrYm94UHJvcHMge1xuICBjaGVja2VkPzogYm9vbGVhblxuICBvbkNoYW5nZT86IChjaGVja2VkOiBib29sZWFuKSA9PiB2b2lkXG4gIGxhYmVsPzogc3RyaW5nXG4gIGRpc2FibGVkPzogYm9vbGVhblxuICBpbmRldGVybWluYXRlPzogYm9vbGVhblxuICBuYW1lPzogc3RyaW5nXG4gIGlkPzogc3RyaW5nXG59XG5cbmNvbnN0IFdyYXBwZXIgPSBzdHlsZWQubGFiZWw8eyBkaXNhYmxlZDogYm9vbGVhbiB9PmBcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7IGFsaWduLWl0ZW1zOiBjZW50ZXI7IGdhcDogJHt0b2tlbnMuc3BhY2Uuc219O1xuICBjdXJzb3I6ICR7KHsgZGlzYWJsZWQgfSkgPT4gKGRpc2FibGVkID8gJ25vdC1hbGxvd2VkJyA6ICdwb2ludGVyJyl9O1xuICBvcGFjaXR5OiAkeyh7IGRpc2FibGVkIH0pID0+IChkaXNhYmxlZCA/IDAuNSA6IDEpfTtcbiAgZm9udC1mYW1pbHk6ICR7dG9rZW5zLmZvbnQuYm9keX07IHVzZXItc2VsZWN0OiBub25lO1xuYFxuY29uc3QgSGlkZGVuSW5wdXQgPSBzdHlsZWQuaW5wdXRgcG9zaXRpb246YWJzb2x1dGU7b3BhY2l0eTowO3dpZHRoOjA7aGVpZ2h0OjA7bWFyZ2luOjA7YFxuY29uc3QgQm94ID0gc3R5bGVkLnNwYW48eyBhY3RpdmU6IGJvb2xlYW4gfT5gXG4gIHdpZHRoOiAxOHB4OyBoZWlnaHQ6IDE4cHg7IGJvcmRlci1yYWRpdXM6ICR7dG9rZW5zLnJhZGl1cy5zbX07XG4gIGJvcmRlcjogMS41cHggc29saWQgJHsoeyBhY3RpdmUgfSkgPT4gKGFjdGl2ZSA/IHRva2Vucy5jb2xvci5icmFuZCA6IHRva2Vucy5jb2xvci5ib3JkZXIpfTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyBhY3RpdmUgfSkgPT4gKGFjdGl2ZSA/IHRva2Vucy5jb2xvci5icmFuZCA6IHRva2Vucy5jb2xvci5iYWNrZ3JvdW5kKX07XG4gIGRpc3BsYXk6IGZsZXg7IGFsaWduLWl0ZW1zOiBjZW50ZXI7IGp1c3RpZnktY29udGVudDogY2VudGVyOyBmbGV4LXNocmluazogMDtcbiAgdHJhbnNpdGlvbjogYmFja2dyb3VuZC1jb2xvciAke3Rva2Vucy50cmFuc2l0aW9uLmZhc3R9LCBib3JkZXItY29sb3IgJHt0b2tlbnMudHJhbnNpdGlvbi5mYXN0fTtcbmBcbmNvbnN0IExhYmVsVGV4dCA9IHN0eWxlZC5zcGFuYGZvbnQtc2l6ZTogMTVweDsgY29sb3I6ICR7dG9rZW5zLmNvbG9yLnRleHR9O2BcblxuZXhwb3J0IGZ1bmN0aW9uIENoZWNrYm94KHsgY2hlY2tlZCA9IGZhbHNlLCBvbkNoYW5nZSwgbGFiZWwsIGRpc2FibGVkID0gZmFsc2UsIGluZGV0ZXJtaW5hdGUgPSBmYWxzZSwgbmFtZSwgaWQ6IGlkUHJvcCB9OiBDaGVja2JveFByb3BzKSB7XG4gIGNvbnN0IGdlbmVyYXRlZElkID0gdXNlSWQoKVxuICBjb25zdCBpZCA9IGlkUHJvcCA/PyBnZW5lcmF0ZWRJZFxuICBjb25zdCBpbnB1dFJlZiA9IHVzZVJlZjxIVE1MSW5wdXRFbGVtZW50PihudWxsKVxuICB1c2VFZmZlY3QoKCkgPT4geyBpZiAoaW5wdXRSZWYuY3VycmVudCkgaW5wdXRSZWYuY3VycmVudC5pbmRldGVybWluYXRlID0gaW5kZXRlcm1pbmF0ZSB9LCBbaW5kZXRlcm1pbmF0ZV0pXG4gIHJldHVybiAoXG4gICAgPFdyYXBwZXIgaHRtbEZvcj17aWR9IGRpc2FibGVkPXtkaXNhYmxlZH0+XG4gICAgICA8SGlkZGVuSW5wdXQgcmVmPXtpbnB1dFJlZn0gaWQ9e2lkfSBuYW1lPXtuYW1lfSB0eXBlPVwiY2hlY2tib3hcIiBjaGVja2VkPXtjaGVja2VkfSBkaXNhYmxlZD17ZGlzYWJsZWR9IG9uQ2hhbmdlPXsoZSkgPT4gb25DaGFuZ2U/LihlLnRhcmdldC5jaGVja2VkKX0gYXJpYS1jaGVja2VkPXtpbmRldGVybWluYXRlID8gJ21peGVkJyA6IGNoZWNrZWR9IC8+XG4gICAgICA8Qm94IGFjdGl2ZT17Y2hlY2tlZCB8fCBpbmRldGVybWluYXRlfSBhcmlhLWhpZGRlbj1cInRydWVcIj5cbiAgICAgICAge2luZGV0ZXJtaW5hdGUgJiYgPHN2ZyB3aWR0aD1cIjEwXCIgaGVpZ2h0PVwiMlwiIHZpZXdCb3g9XCIwIDAgMTAgMlwiIGZpbGw9XCJub25lXCI+PHBhdGggZD1cIk0xIDFoOFwiIHN0cm9rZT1cIndoaXRlXCIgc3Ryb2tlV2lkdGg9XCIyXCIgc3Ryb2tlTGluZWNhcD1cInJvdW5kXCIgLz48L3N2Zz59XG4gICAgICAgIHtjaGVja2VkICYmICFpbmRldGVybWluYXRlICYmIDxzdmcgd2lkdGg9XCIxMFwiIGhlaWdodD1cIjhcIiB2aWV3Qm94PVwiMCAwIDEwIDhcIiBmaWxsPVwibm9uZVwiPjxwYXRoIGQ9XCJNMSA0bDMgMyA1LTZcIiBzdHJva2U9XCJ3aGl0ZVwiIHN0cm9rZVdpZHRoPVwiMS44XCIgc3Ryb2tlTGluZWNhcD1cInJvdW5kXCIgc3Ryb2tlTGluZWpvaW49XCJyb3VuZFwiIC8+PC9zdmc+fVxuICAgICAgPC9Cb3g+XG4gICAgICB7bGFiZWwgJiYgPExhYmVsVGV4dD57bGFiZWx9PC9MYWJlbFRleHQ+fVxuICAgIDwvV3JhcHBlcj5cbiAgKVxufVxuIl19 */",
28
+ toString: B
29
+ }), R = /* @__PURE__ */ c("span", process.env.NODE_ENV === "production" ? {
30
+ target: "enlaae71"
31
+ } : {
32
+ target: "enlaae71",
33
+ label: "Box"
34
+ })("width:18px;height:18px;border-radius:", Z.radius.sm, ";border:1.5px solid ", ({
35
+ active: I
36
+ }) => I ? Z.color.brand : Z.color.border, ";background-color:", ({
37
+ active: I
38
+ }) => I ? Z.color.brand : Z.color.background, ";display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background-color ", Z.transition.fast, ",border-color ", Z.transition.fast, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy9tYWNib29rL0RvY3VtZW50cy9jZW5jb3N1ZC9qdW1iby9saWIvcGFja2FnZXMvdWktY29yZS9zcmMvcHJpbWl0aXZlcy9DaGVja2JveC9DaGVja2JveC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUI0QyIsImZpbGUiOiIvVXNlcnMvbWFjYm9vay9Eb2N1bWVudHMvY2VuY29zdWQvanVtYm8vbGliL3BhY2thZ2VzL3VpLWNvcmUvc3JjL3ByaW1pdGl2ZXMvQ2hlY2tib3gvQ2hlY2tib3gudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyB0b2tlbnMgfSBmcm9tICdAZGFuaWVsY3J1emNvZGUvZGVzaWduLXRva2VucydcbmltcG9ydCB7IHVzZUVmZmVjdCwgdXNlSWQsIHVzZVJlZiB9IGZyb20gJ3JlYWN0J1xuXG5leHBvcnQgaW50ZXJmYWNlIENoZWNrYm94UHJvcHMge1xuICBjaGVja2VkPzogYm9vbGVhblxuICBvbkNoYW5nZT86IChjaGVja2VkOiBib29sZWFuKSA9PiB2b2lkXG4gIGxhYmVsPzogc3RyaW5nXG4gIGRpc2FibGVkPzogYm9vbGVhblxuICBpbmRldGVybWluYXRlPzogYm9vbGVhblxuICBuYW1lPzogc3RyaW5nXG4gIGlkPzogc3RyaW5nXG59XG5cbmNvbnN0IFdyYXBwZXIgPSBzdHlsZWQubGFiZWw8eyBkaXNhYmxlZDogYm9vbGVhbiB9PmBcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7IGFsaWduLWl0ZW1zOiBjZW50ZXI7IGdhcDogJHt0b2tlbnMuc3BhY2Uuc219O1xuICBjdXJzb3I6ICR7KHsgZGlzYWJsZWQgfSkgPT4gKGRpc2FibGVkID8gJ25vdC1hbGxvd2VkJyA6ICdwb2ludGVyJyl9O1xuICBvcGFjaXR5OiAkeyh7IGRpc2FibGVkIH0pID0+IChkaXNhYmxlZCA/IDAuNSA6IDEpfTtcbiAgZm9udC1mYW1pbHk6ICR7dG9rZW5zLmZvbnQuYm9keX07IHVzZXItc2VsZWN0OiBub25lO1xuYFxuY29uc3QgSGlkZGVuSW5wdXQgPSBzdHlsZWQuaW5wdXRgcG9zaXRpb246YWJzb2x1dGU7b3BhY2l0eTowO3dpZHRoOjA7aGVpZ2h0OjA7bWFyZ2luOjA7YFxuY29uc3QgQm94ID0gc3R5bGVkLnNwYW48eyBhY3RpdmU6IGJvb2xlYW4gfT5gXG4gIHdpZHRoOiAxOHB4OyBoZWlnaHQ6IDE4cHg7IGJvcmRlci1yYWRpdXM6ICR7dG9rZW5zLnJhZGl1cy5zbX07XG4gIGJvcmRlcjogMS41cHggc29saWQgJHsoeyBhY3RpdmUgfSkgPT4gKGFjdGl2ZSA/IHRva2Vucy5jb2xvci5icmFuZCA6IHRva2Vucy5jb2xvci5ib3JkZXIpfTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyBhY3RpdmUgfSkgPT4gKGFjdGl2ZSA/IHRva2Vucy5jb2xvci5icmFuZCA6IHRva2Vucy5jb2xvci5iYWNrZ3JvdW5kKX07XG4gIGRpc3BsYXk6IGZsZXg7IGFsaWduLWl0ZW1zOiBjZW50ZXI7IGp1c3RpZnktY29udGVudDogY2VudGVyOyBmbGV4LXNocmluazogMDtcbiAgdHJhbnNpdGlvbjogYmFja2dyb3VuZC1jb2xvciAke3Rva2Vucy50cmFuc2l0aW9uLmZhc3R9LCBib3JkZXItY29sb3IgJHt0b2tlbnMudHJhbnNpdGlvbi5mYXN0fTtcbmBcbmNvbnN0IExhYmVsVGV4dCA9IHN0eWxlZC5zcGFuYGZvbnQtc2l6ZTogMTVweDsgY29sb3I6ICR7dG9rZW5zLmNvbG9yLnRleHR9O2BcblxuZXhwb3J0IGZ1bmN0aW9uIENoZWNrYm94KHsgY2hlY2tlZCA9IGZhbHNlLCBvbkNoYW5nZSwgbGFiZWwsIGRpc2FibGVkID0gZmFsc2UsIGluZGV0ZXJtaW5hdGUgPSBmYWxzZSwgbmFtZSwgaWQ6IGlkUHJvcCB9OiBDaGVja2JveFByb3BzKSB7XG4gIGNvbnN0IGdlbmVyYXRlZElkID0gdXNlSWQoKVxuICBjb25zdCBpZCA9IGlkUHJvcCA/PyBnZW5lcmF0ZWRJZFxuICBjb25zdCBpbnB1dFJlZiA9IHVzZVJlZjxIVE1MSW5wdXRFbGVtZW50PihudWxsKVxuICB1c2VFZmZlY3QoKCkgPT4geyBpZiAoaW5wdXRSZWYuY3VycmVudCkgaW5wdXRSZWYuY3VycmVudC5pbmRldGVybWluYXRlID0gaW5kZXRlcm1pbmF0ZSB9LCBbaW5kZXRlcm1pbmF0ZV0pXG4gIHJldHVybiAoXG4gICAgPFdyYXBwZXIgaHRtbEZvcj17aWR9IGRpc2FibGVkPXtkaXNhYmxlZH0+XG4gICAgICA8SGlkZGVuSW5wdXQgcmVmPXtpbnB1dFJlZn0gaWQ9e2lkfSBuYW1lPXtuYW1lfSB0eXBlPVwiY2hlY2tib3hcIiBjaGVja2VkPXtjaGVja2VkfSBkaXNhYmxlZD17ZGlzYWJsZWR9IG9uQ2hhbmdlPXsoZSkgPT4gb25DaGFuZ2U/LihlLnRhcmdldC5jaGVja2VkKX0gYXJpYS1jaGVja2VkPXtpbmRldGVybWluYXRlID8gJ21peGVkJyA6IGNoZWNrZWR9IC8+XG4gICAgICA8Qm94IGFjdGl2ZT17Y2hlY2tlZCB8fCBpbmRldGVybWluYXRlfSBhcmlhLWhpZGRlbj1cInRydWVcIj5cbiAgICAgICAge2luZGV0ZXJtaW5hdGUgJiYgPHN2ZyB3aWR0aD1cIjEwXCIgaGVpZ2h0PVwiMlwiIHZpZXdCb3g9XCIwIDAgMTAgMlwiIGZpbGw9XCJub25lXCI+PHBhdGggZD1cIk0xIDFoOFwiIHN0cm9rZT1cIndoaXRlXCIgc3Ryb2tlV2lkdGg9XCIyXCIgc3Ryb2tlTGluZWNhcD1cInJvdW5kXCIgLz48L3N2Zz59XG4gICAgICAgIHtjaGVja2VkICYmICFpbmRldGVybWluYXRlICYmIDxzdmcgd2lkdGg9XCIxMFwiIGhlaWdodD1cIjhcIiB2aWV3Qm94PVwiMCAwIDEwIDhcIiBmaWxsPVwibm9uZVwiPjxwYXRoIGQ9XCJNMSA0bDMgMyA1LTZcIiBzdHJva2U9XCJ3aGl0ZVwiIHN0cm9rZVdpZHRoPVwiMS44XCIgc3Ryb2tlTGluZWNhcD1cInJvdW5kXCIgc3Ryb2tlTGluZWpvaW49XCJyb3VuZFwiIC8+PC9zdmc+fVxuICAgICAgPC9Cb3g+XG4gICAgICB7bGFiZWwgJiYgPExhYmVsVGV4dD57bGFiZWx9PC9MYWJlbFRleHQ+fVxuICAgIDwvV3JhcHBlcj5cbiAgKVxufVxuIl19 */")), y = /* @__PURE__ */ c("span", process.env.NODE_ENV === "production" ? {
39
+ target: "enlaae70"
40
+ } : {
41
+ target: "enlaae70",
42
+ label: "LabelText"
43
+ })("font-size:15px;color:", Z.color.text, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy9tYWNib29rL0RvY3VtZW50cy9jZW5jb3N1ZC9qdW1iby9saWIvcGFja2FnZXMvdWktY29yZS9zcmMvcHJpbWl0aXZlcy9DaGVja2JveC9DaGVja2JveC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEI2QiIsImZpbGUiOiIvVXNlcnMvbWFjYm9vay9Eb2N1bWVudHMvY2VuY29zdWQvanVtYm8vbGliL3BhY2thZ2VzL3VpLWNvcmUvc3JjL3ByaW1pdGl2ZXMvQ2hlY2tib3gvQ2hlY2tib3gudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyB0b2tlbnMgfSBmcm9tICdAZGFuaWVsY3J1emNvZGUvZGVzaWduLXRva2VucydcbmltcG9ydCB7IHVzZUVmZmVjdCwgdXNlSWQsIHVzZVJlZiB9IGZyb20gJ3JlYWN0J1xuXG5leHBvcnQgaW50ZXJmYWNlIENoZWNrYm94UHJvcHMge1xuICBjaGVja2VkPzogYm9vbGVhblxuICBvbkNoYW5nZT86IChjaGVja2VkOiBib29sZWFuKSA9PiB2b2lkXG4gIGxhYmVsPzogc3RyaW5nXG4gIGRpc2FibGVkPzogYm9vbGVhblxuICBpbmRldGVybWluYXRlPzogYm9vbGVhblxuICBuYW1lPzogc3RyaW5nXG4gIGlkPzogc3RyaW5nXG59XG5cbmNvbnN0IFdyYXBwZXIgPSBzdHlsZWQubGFiZWw8eyBkaXNhYmxlZDogYm9vbGVhbiB9PmBcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7IGFsaWduLWl0ZW1zOiBjZW50ZXI7IGdhcDogJHt0b2tlbnMuc3BhY2Uuc219O1xuICBjdXJzb3I6ICR7KHsgZGlzYWJsZWQgfSkgPT4gKGRpc2FibGVkID8gJ25vdC1hbGxvd2VkJyA6ICdwb2ludGVyJyl9O1xuICBvcGFjaXR5OiAkeyh7IGRpc2FibGVkIH0pID0+IChkaXNhYmxlZCA/IDAuNSA6IDEpfTtcbiAgZm9udC1mYW1pbHk6ICR7dG9rZW5zLmZvbnQuYm9keX07IHVzZXItc2VsZWN0OiBub25lO1xuYFxuY29uc3QgSGlkZGVuSW5wdXQgPSBzdHlsZWQuaW5wdXRgcG9zaXRpb246YWJzb2x1dGU7b3BhY2l0eTowO3dpZHRoOjA7aGVpZ2h0OjA7bWFyZ2luOjA7YFxuY29uc3QgQm94ID0gc3R5bGVkLnNwYW48eyBhY3RpdmU6IGJvb2xlYW4gfT5gXG4gIHdpZHRoOiAxOHB4OyBoZWlnaHQ6IDE4cHg7IGJvcmRlci1yYWRpdXM6ICR7dG9rZW5zLnJhZGl1cy5zbX07XG4gIGJvcmRlcjogMS41cHggc29saWQgJHsoeyBhY3RpdmUgfSkgPT4gKGFjdGl2ZSA/IHRva2Vucy5jb2xvci5icmFuZCA6IHRva2Vucy5jb2xvci5ib3JkZXIpfTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyBhY3RpdmUgfSkgPT4gKGFjdGl2ZSA/IHRva2Vucy5jb2xvci5icmFuZCA6IHRva2Vucy5jb2xvci5iYWNrZ3JvdW5kKX07XG4gIGRpc3BsYXk6IGZsZXg7IGFsaWduLWl0ZW1zOiBjZW50ZXI7IGp1c3RpZnktY29udGVudDogY2VudGVyOyBmbGV4LXNocmluazogMDtcbiAgdHJhbnNpdGlvbjogYmFja2dyb3VuZC1jb2xvciAke3Rva2Vucy50cmFuc2l0aW9uLmZhc3R9LCBib3JkZXItY29sb3IgJHt0b2tlbnMudHJhbnNpdGlvbi5mYXN0fTtcbmBcbmNvbnN0IExhYmVsVGV4dCA9IHN0eWxlZC5zcGFuYGZvbnQtc2l6ZTogMTVweDsgY29sb3I6ICR7dG9rZW5zLmNvbG9yLnRleHR9O2BcblxuZXhwb3J0IGZ1bmN0aW9uIENoZWNrYm94KHsgY2hlY2tlZCA9IGZhbHNlLCBvbkNoYW5nZSwgbGFiZWwsIGRpc2FibGVkID0gZmFsc2UsIGluZGV0ZXJtaW5hdGUgPSBmYWxzZSwgbmFtZSwgaWQ6IGlkUHJvcCB9OiBDaGVja2JveFByb3BzKSB7XG4gIGNvbnN0IGdlbmVyYXRlZElkID0gdXNlSWQoKVxuICBjb25zdCBpZCA9IGlkUHJvcCA/PyBnZW5lcmF0ZWRJZFxuICBjb25zdCBpbnB1dFJlZiA9IHVzZVJlZjxIVE1MSW5wdXRFbGVtZW50PihudWxsKVxuICB1c2VFZmZlY3QoKCkgPT4geyBpZiAoaW5wdXRSZWYuY3VycmVudCkgaW5wdXRSZWYuY3VycmVudC5pbmRldGVybWluYXRlID0gaW5kZXRlcm1pbmF0ZSB9LCBbaW5kZXRlcm1pbmF0ZV0pXG4gIHJldHVybiAoXG4gICAgPFdyYXBwZXIgaHRtbEZvcj17aWR9IGRpc2FibGVkPXtkaXNhYmxlZH0+XG4gICAgICA8SGlkZGVuSW5wdXQgcmVmPXtpbnB1dFJlZn0gaWQ9e2lkfSBuYW1lPXtuYW1lfSB0eXBlPVwiY2hlY2tib3hcIiBjaGVja2VkPXtjaGVja2VkfSBkaXNhYmxlZD17ZGlzYWJsZWR9IG9uQ2hhbmdlPXsoZSkgPT4gb25DaGFuZ2U/LihlLnRhcmdldC5jaGVja2VkKX0gYXJpYS1jaGVja2VkPXtpbmRldGVybWluYXRlID8gJ21peGVkJyA6IGNoZWNrZWR9IC8+XG4gICAgICA8Qm94IGFjdGl2ZT17Y2hlY2tlZCB8fCBpbmRldGVybWluYXRlfSBhcmlhLWhpZGRlbj1cInRydWVcIj5cbiAgICAgICAge2luZGV0ZXJtaW5hdGUgJiYgPHN2ZyB3aWR0aD1cIjEwXCIgaGVpZ2h0PVwiMlwiIHZpZXdCb3g9XCIwIDAgMTAgMlwiIGZpbGw9XCJub25lXCI+PHBhdGggZD1cIk0xIDFoOFwiIHN0cm9rZT1cIndoaXRlXCIgc3Ryb2tlV2lkdGg9XCIyXCIgc3Ryb2tlTGluZWNhcD1cInJvdW5kXCIgLz48L3N2Zz59XG4gICAgICAgIHtjaGVja2VkICYmICFpbmRldGVybWluYXRlICYmIDxzdmcgd2lkdGg9XCIxMFwiIGhlaWdodD1cIjhcIiB2aWV3Qm94PVwiMCAwIDEwIDhcIiBmaWxsPVwibm9uZVwiPjxwYXRoIGQ9XCJNMSA0bDMgMyA1LTZcIiBzdHJva2U9XCJ3aGl0ZVwiIHN0cm9rZVdpZHRoPVwiMS44XCIgc3Ryb2tlTGluZWNhcD1cInJvdW5kXCIgc3Ryb2tlTGluZWpvaW49XCJyb3VuZFwiIC8+PC9zdmc+fVxuICAgICAgPC9Cb3g+XG4gICAgICB7bGFiZWwgJiYgPExhYmVsVGV4dD57bGFiZWx9PC9MYWJlbFRleHQ+fVxuICAgIDwvV3JhcHBlcj5cbiAgKVxufVxuIl19 */"));
44
+ function h({
45
+ checked: I = !1,
46
+ onChange: G,
47
+ label: V,
48
+ disabled: a = !1,
49
+ indeterminate: l = !1,
50
+ name: X,
51
+ id: g
52
+ }) {
53
+ const m = C(), d = g != null ? g : m, W = Y(null);
54
+ return t(() => {
55
+ W.current && (W.current.indeterminate = l);
56
+ }, [l]), /* @__PURE__ */ i(o, { htmlFor: d, disabled: a, children: [
57
+ /* @__PURE__ */ b(n, { ref: W, id: d, name: X, type: "checkbox", checked: I, disabled: a, onChange: (u) => G == null ? void 0 : G(u.target.checked), "aria-checked": l ? "mixed" : I }),
58
+ /* @__PURE__ */ i(R, { active: I || l, "aria-hidden": "true", children: [
59
+ l && /* @__PURE__ */ b("svg", { width: "10", height: "2", viewBox: "0 0 10 2", fill: "none", children: /* @__PURE__ */ b("path", { d: "M1 1h8", stroke: "white", strokeWidth: "2", strokeLinecap: "round" }) }),
60
+ I && !l && /* @__PURE__ */ b("svg", { width: "10", height: "8", viewBox: "0 0 10 8", fill: "none", children: /* @__PURE__ */ b("path", { d: "M1 4l3 3 5-6", stroke: "white", strokeWidth: "1.8", strokeLinecap: "round", strokeLinejoin: "round" }) })
26
61
  ] }),
27
- l && /* @__PURE__ */ e(w, { children: l })
62
+ V && /* @__PURE__ */ b(y, { children: V })
28
63
  ] });
29
64
  }
30
65
  export {
31
- B as Checkbox
66
+ h as Checkbox
32
67
  };
@@ -1,37 +1,71 @@
1
- import { jsxs as h, jsx as a } from "react/jsx-runtime";
2
- import e from "@emotion/styled";
3
- import { tokens as o } from "./index.esm14.js";
4
- const v = { none: "0", sm: o.space.sm, md: o.space.md, lg: o.space.lg }, f = e.article`
5
- display:flex;flex-direction:column;background-color:${o.color.background};
6
- border-radius:${o.radius.md};border:1px solid ${o.color.border};
7
- overflow:hidden;position:relative;
8
- transition:box-shadow ${o.transition.normal},transform ${o.transition.normal};
9
- max-width:15rem;height:27rem;padding:${({ padding: r }) => v[r]};
10
- ${({ hoverable: r }) => r && `cursor:pointer;&:hover{box-shadow:${o.shadow.sm};transform:translateY(-2px);}`}
11
- `, x = e.div`width:100%;overflow:hidden;`, $ = e.div`padding:${o.space.sm} ${o.space.md};`, b = e.div`padding:0 ${o.space.md};flex:1;`, g = e.div`padding:${o.space.md};border-top:1px solid ${o.color.border};margin-top:auto;`;
12
- function j({ media: r, header: i, body: s, footer: l, onClick: d, hoverable: c = !1, className: p, padding: m = "none" }) {
13
- const n = !!d;
14
- return /* @__PURE__ */ h(
15
- f,
16
- {
17
- hoverable: c || n,
18
- padding: m,
19
- className: p,
20
- onClick: d,
21
- role: n ? "button" : void 0,
22
- tabIndex: n ? 0 : void 0,
23
- onKeyDown: n ? (t) => {
24
- (t.key === "Enter" || t.key === " ") && (t.preventDefault(), d == null || d());
25
- } : void 0,
26
- children: [
27
- r && /* @__PURE__ */ a(x, { children: r }),
28
- i && /* @__PURE__ */ a($, { children: i }),
29
- s && /* @__PURE__ */ a(b, { children: s }),
30
- l && /* @__PURE__ */ a(g, { children: l })
31
- ]
32
- }
33
- );
1
+ import { jsxs as t, jsx as G } from "react/jsx-runtime";
2
+ import g from "./index.esm15.js";
3
+ import { tokens as b } from "./index.esm16.js";
4
+ function d() {
5
+ 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).";
6
+ }
7
+ const X = {
8
+ none: "0",
9
+ sm: b.space.sm,
10
+ md: b.space.md,
11
+ lg: b.space.lg
12
+ }, R = /* @__PURE__ */ g("article", process.env.NODE_ENV === "production" ? {
13
+ target: "e1qo70ov4"
14
+ } : {
15
+ target: "e1qo70ov4",
16
+ label: "StyledArticle"
17
+ })("display:flex;flex-direction:column;background-color:", b.color.background, ";border-radius:", b.radius.md, ";overflow:hidden;position:relative;transition:box-shadow ", b.transition.normal, ",transform ", b.transition.normal, ";max-width:15rem;height:528px;padding:", ({
18
+ padding: I
19
+ }) => X[I], ";", ({
20
+ hoverable: I
21
+ }) => I && `cursor:pointer;&:hover{box-shadow:${b.shadow.sm};transform:translateY(-2px);}`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy9tYWNib29rL0RvY3VtZW50cy9jZW5jb3N1ZC9qdW1iby9saWIvcGFja2FnZXMvdWktY29yZS9zcmMvY29tcG9uZW50cy9DYXJkL0NhcmQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9CRSIsImZpbGUiOiIvVXNlcnMvbWFjYm9vay9Eb2N1bWVudHMvY2VuY29zdWQvanVtYm8vbGliL3BhY2thZ2VzL3VpLWNvcmUvc3JjL2NvbXBvbmVudHMvQ2FyZC9DYXJkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHRva2VucyB9IGZyb20gJ0BkYW5pZWxjcnV6Y29kZS9kZXNpZ24tdG9rZW5zJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB0eXBlIFJlYWN0IGZyb20gJ3JlYWN0JztcblxuZXhwb3J0IGludGVyZmFjZSBDYXJkUHJvcHMge1xuICBtZWRpYT86IFJlYWN0LlJlYWN0Tm9kZTtcbiAgaGVhZGVyPzogUmVhY3QuUmVhY3ROb2RlO1xuICBib2R5PzogUmVhY3QuUmVhY3ROb2RlO1xuICBmb290ZXI/OiBSZWFjdC5SZWFjdE5vZGU7XG4gIG9uQ2xpY2s/OiAoKSA9PiB2b2lkO1xuICBob3ZlcmFibGU/OiBib29sZWFuO1xuICBjbGFzc05hbWU/OiBzdHJpbmc7XG4gIHBhZGRpbmc/OiAnbm9uZScgfCAnc20nIHwgJ21kJyB8ICdsZyc7XG59XG5cbmNvbnN0IHBhZGRpbmdNYXAgPSB7IG5vbmU6ICcwJywgc206IHRva2Vucy5zcGFjZS5zbSwgbWQ6IHRva2Vucy5zcGFjZS5tZCwgbGc6IHRva2Vucy5zcGFjZS5sZyB9O1xuXG5jb25zdCBTdHlsZWRBcnRpY2xlID0gc3R5bGVkLmFydGljbGU8e1xuICBob3ZlcmFibGU6IGJvb2xlYW47XG4gIHBhZGRpbmc6IE5vbk51bGxhYmxlPENhcmRQcm9wc1sncGFkZGluZyddPjtcbn0+YFxuICBkaXNwbGF5OmZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOmNvbHVtbjtcbiAgYmFja2dyb3VuZC1jb2xvcjoke3Rva2Vucy5jb2xvci5iYWNrZ3JvdW5kfTtcbiAgYm9yZGVyLXJhZGl1czoke3Rva2Vucy5yYWRpdXMubWR9O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICBwb3NpdGlvbjpyZWxhdGl2ZTtcbiAgdHJhbnNpdGlvbjpib3gtc2hhZG93ICR7dG9rZW5zLnRyYW5zaXRpb24ubm9ybWFsfSx0cmFuc2Zvcm0gJHt0b2tlbnMudHJhbnNpdGlvbi5ub3JtYWx9O1xuICBtYXgtd2lkdGg6MTVyZW07XG4gIGhlaWdodDo1MjhweDtcbiAgcGFkZGluZzokeyh7IHBhZGRpbmcgfSkgPT4gcGFkZGluZ01hcFtwYWRkaW5nXX07XG4gICR7KHsgaG92ZXJhYmxlIH0pID0+IGhvdmVyYWJsZSAmJiBgY3Vyc29yOnBvaW50ZXI7Jjpob3Zlcntib3gtc2hhZG93OiR7dG9rZW5zLnNoYWRvdy5zbX07dHJhbnNmb3JtOnRyYW5zbGF0ZVkoLTJweCk7fWB9XG5gO1xuY29uc3QgQ2FyZE1lZGlhID0gc3R5bGVkLmRpdmB3aWR0aDoxMDAlO292ZXJmbG93OmhpZGRlbjtgO1xuY29uc3QgQ2FyZEhlYWRlciA9IHN0eWxlZC5kaXZgcGFkZGluZzoke3Rva2Vucy5zcGFjZS5zbX0gJHt0b2tlbnMuc3BhY2UubWR9O2A7XG5jb25zdCBDYXJkQm9keSA9IHN0eWxlZC5kaXZgcGFkZGluZzowICR7dG9rZW5zLnNwYWNlLnNtfTtmbGV4OjE7YDtcbmNvbnN0IENhcmRGb290ZXIgPSBzdHlsZWQuZGl2YHBhZGRpbmc6JHt0b2tlbnMuc3BhY2Uuc219O21hcmdpbi10b3A6YXV0bztgO1xuXG5leHBvcnQgZnVuY3Rpb24gQ2FyZCh7XG4gIG1lZGlhLFxuICBoZWFkZXIsXG4gIGJvZHksXG4gIGZvb3RlcixcbiAgb25DbGljayxcbiAgaG92ZXJhYmxlID0gZmFsc2UsXG4gIGNsYXNzTmFtZSxcbiAgcGFkZGluZyA9ICdub25lJyxcbn06IENhcmRQcm9wcykge1xuICBjb25zdCBpc0ludGVyYWN0aXZlID0gQm9vbGVhbihvbkNsaWNrKTtcbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkQXJ0aWNsZVxuICAgICAgaG92ZXJhYmxlPXtob3ZlcmFibGUgfHwgaXNJbnRlcmFjdGl2ZX1cbiAgICAgIHBhZGRpbmc9e3BhZGRpbmd9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgICByb2xlPXtpc0ludGVyYWN0aXZlID8gJ2J1dHRvbicgOiB1bmRlZmluZWR9XG4gICAgICB0YWJJbmRleD17aXNJbnRlcmFjdGl2ZSA/IDAgOiB1bmRlZmluZWR9XG4gICAgICBvbktleURvd249e1xuICAgICAgICBpc0ludGVyYWN0aXZlXG4gICAgICAgICAgPyAoZSkgPT4ge1xuICAgICAgICAgICAgICBpZiAoZS5rZXkgPT09ICdFbnRlcicgfHwgZS5rZXkgPT09ICcgJykge1xuICAgICAgICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICAgICAgICBvbkNsaWNrPy4oKTtcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIDogdW5kZWZpbmVkXG4gICAgICB9XG4gICAgPlxuICAgICAge21lZGlhICYmIDxDYXJkTWVkaWE+e21lZGlhfTwvQ2FyZE1lZGlhPn1cbiAgICAgIHtoZWFkZXIgJiYgPENhcmRIZWFkZXI+e2hlYWRlcn08L0NhcmRIZWFkZXI+fVxuICAgICAge2JvZHkgJiYgPENhcmRCb2R5Pntib2R5fTwvQ2FyZEJvZHk+fVxuICAgICAge2Zvb3RlciAmJiA8Q2FyZEZvb3Rlcj57Zm9vdGVyfTwvQ2FyZEZvb3Rlcj59XG4gICAgPC9TdHlsZWRBcnRpY2xlPlxuICApO1xufVxuIl19 */")), a = /* @__PURE__ */ g("div", process.env.NODE_ENV === "production" ? {
22
+ target: "e1qo70ov3"
23
+ } : {
24
+ target: "e1qo70ov3",
25
+ label: "CardMedia"
26
+ })(process.env.NODE_ENV === "production" ? {
27
+ name: "1cwloic",
28
+ styles: "width:100%;overflow:hidden"
29
+ } : {
30
+ name: "1cwloic",
31
+ styles: "width:100%;overflow:hidden/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy9tYWNib29rL0RvY3VtZW50cy9jZW5jb3N1ZC9qdW1iby9saWIvcGFja2FnZXMvdWktY29yZS9zcmMvY29tcG9uZW50cy9DYXJkL0NhcmQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlDNEIiLCJmaWxlIjoiL1VzZXJzL21hY2Jvb2svRG9jdW1lbnRzL2NlbmNvc3VkL2p1bWJvL2xpYi9wYWNrYWdlcy91aS1jb3JlL3NyYy9jb21wb25lbnRzL0NhcmQvQ2FyZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB0b2tlbnMgfSBmcm9tICdAZGFuaWVsY3J1emNvZGUvZGVzaWduLXRva2Vucyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgdHlwZSBSZWFjdCBmcm9tICdyZWFjdCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2FyZFByb3BzIHtcbiAgbWVkaWE/OiBSZWFjdC5SZWFjdE5vZGU7XG4gIGhlYWRlcj86IFJlYWN0LlJlYWN0Tm9kZTtcbiAgYm9keT86IFJlYWN0LlJlYWN0Tm9kZTtcbiAgZm9vdGVyPzogUmVhY3QuUmVhY3ROb2RlO1xuICBvbkNsaWNrPzogKCkgPT4gdm9pZDtcbiAgaG92ZXJhYmxlPzogYm9vbGVhbjtcbiAgY2xhc3NOYW1lPzogc3RyaW5nO1xuICBwYWRkaW5nPzogJ25vbmUnIHwgJ3NtJyB8ICdtZCcgfCAnbGcnO1xufVxuXG5jb25zdCBwYWRkaW5nTWFwID0geyBub25lOiAnMCcsIHNtOiB0b2tlbnMuc3BhY2Uuc20sIG1kOiB0b2tlbnMuc3BhY2UubWQsIGxnOiB0b2tlbnMuc3BhY2UubGcgfTtcblxuY29uc3QgU3R5bGVkQXJ0aWNsZSA9IHN0eWxlZC5hcnRpY2xlPHtcbiAgaG92ZXJhYmxlOiBib29sZWFuO1xuICBwYWRkaW5nOiBOb25OdWxsYWJsZTxDYXJkUHJvcHNbJ3BhZGRpbmcnXT47XG59PmBcbiAgZGlzcGxheTpmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjpjb2x1bW47XG4gIGJhY2tncm91bmQtY29sb3I6JHt0b2tlbnMuY29sb3IuYmFja2dyb3VuZH07XG4gIGJvcmRlci1yYWRpdXM6JHt0b2tlbnMucmFkaXVzLm1kfTtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgcG9zaXRpb246cmVsYXRpdmU7XG4gIHRyYW5zaXRpb246Ym94LXNoYWRvdyAke3Rva2Vucy50cmFuc2l0aW9uLm5vcm1hbH0sdHJhbnNmb3JtICR7dG9rZW5zLnRyYW5zaXRpb24ubm9ybWFsfTtcbiAgbWF4LXdpZHRoOjE1cmVtO1xuICBoZWlnaHQ6NTI4cHg7XG4gIHBhZGRpbmc6JHsoeyBwYWRkaW5nIH0pID0+IHBhZGRpbmdNYXBbcGFkZGluZ119O1xuICAkeyh7IGhvdmVyYWJsZSB9KSA9PiBob3ZlcmFibGUgJiYgYGN1cnNvcjpwb2ludGVyOyY6aG92ZXJ7Ym94LXNoYWRvdzoke3Rva2Vucy5zaGFkb3cuc219O3RyYW5zZm9ybTp0cmFuc2xhdGVZKC0ycHgpO31gfVxuYDtcbmNvbnN0IENhcmRNZWRpYSA9IHN0eWxlZC5kaXZgd2lkdGg6MTAwJTtvdmVyZmxvdzpoaWRkZW47YDtcbmNvbnN0IENhcmRIZWFkZXIgPSBzdHlsZWQuZGl2YHBhZGRpbmc6JHt0b2tlbnMuc3BhY2Uuc219ICR7dG9rZW5zLnNwYWNlLm1kfTtgO1xuY29uc3QgQ2FyZEJvZHkgPSBzdHlsZWQuZGl2YHBhZGRpbmc6MCAke3Rva2Vucy5zcGFjZS5zbX07ZmxleDoxO2A7XG5jb25zdCBDYXJkRm9vdGVyID0gc3R5bGVkLmRpdmBwYWRkaW5nOiR7dG9rZW5zLnNwYWNlLnNtfTttYXJnaW4tdG9wOmF1dG87YDtcblxuZXhwb3J0IGZ1bmN0aW9uIENhcmQoe1xuICBtZWRpYSxcbiAgaGVhZGVyLFxuICBib2R5LFxuICBmb290ZXIsXG4gIG9uQ2xpY2ssXG4gIGhvdmVyYWJsZSA9IGZhbHNlLFxuICBjbGFzc05hbWUsXG4gIHBhZGRpbmcgPSAnbm9uZScsXG59OiBDYXJkUHJvcHMpIHtcbiAgY29uc3QgaXNJbnRlcmFjdGl2ZSA9IEJvb2xlYW4ob25DbGljayk7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEFydGljbGVcbiAgICAgIGhvdmVyYWJsZT17aG92ZXJhYmxlIHx8IGlzSW50ZXJhY3RpdmV9XG4gICAgICBwYWRkaW5nPXtwYWRkaW5nfVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgcm9sZT17aXNJbnRlcmFjdGl2ZSA/ICdidXR0b24nIDogdW5kZWZpbmVkfVxuICAgICAgdGFiSW5kZXg9e2lzSW50ZXJhY3RpdmUgPyAwIDogdW5kZWZpbmVkfVxuICAgICAgb25LZXlEb3duPXtcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgICAgID8gKGUpID0+IHtcbiAgICAgICAgICAgICAgaWYgKGUua2V5ID09PSAnRW50ZXInIHx8IGUua2V5ID09PSAnICcpIHtcbiAgICAgICAgICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgb25DbGljaz8uKCk7XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICA6IHVuZGVmaW5lZFxuICAgICAgfVxuICAgID5cbiAgICAgIHttZWRpYSAmJiA8Q2FyZE1lZGlhPnttZWRpYX08L0NhcmRNZWRpYT59XG4gICAgICB7aGVhZGVyICYmIDxDYXJkSGVhZGVyPntoZWFkZXJ9PC9DYXJkSGVhZGVyPn1cbiAgICAgIHtib2R5ICYmIDxDYXJkQm9keT57Ym9keX08L0NhcmRCb2R5Pn1cbiAgICAgIHtmb290ZXIgJiYgPENhcmRGb290ZXI+e2Zvb3Rlcn08L0NhcmRGb290ZXI+fVxuICAgIDwvU3R5bGVkQXJ0aWNsZT5cbiAgKTtcbn1cbiJdfQ== */",
32
+ toString: d
33
+ }), n = /* @__PURE__ */ g("div", process.env.NODE_ENV === "production" ? {
34
+ target: "e1qo70ov2"
35
+ } : {
36
+ target: "e1qo70ov2",
37
+ label: "CardHeader"
38
+ })("padding:", b.space.sm, " ", b.space.md, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy9tYWNib29rL0RvY3VtZW50cy9jZW5jb3N1ZC9qdW1iby9saWIvcGFja2FnZXMvdWktY29yZS9zcmMvY29tcG9uZW50cy9DYXJkL0NhcmQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtDNkIiLCJmaWxlIjoiL1VzZXJzL21hY2Jvb2svRG9jdW1lbnRzL2NlbmNvc3VkL2p1bWJvL2xpYi9wYWNrYWdlcy91aS1jb3JlL3NyYy9jb21wb25lbnRzL0NhcmQvQ2FyZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB0b2tlbnMgfSBmcm9tICdAZGFuaWVsY3J1emNvZGUvZGVzaWduLXRva2Vucyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgdHlwZSBSZWFjdCBmcm9tICdyZWFjdCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2FyZFByb3BzIHtcbiAgbWVkaWE/OiBSZWFjdC5SZWFjdE5vZGU7XG4gIGhlYWRlcj86IFJlYWN0LlJlYWN0Tm9kZTtcbiAgYm9keT86IFJlYWN0LlJlYWN0Tm9kZTtcbiAgZm9vdGVyPzogUmVhY3QuUmVhY3ROb2RlO1xuICBvbkNsaWNrPzogKCkgPT4gdm9pZDtcbiAgaG92ZXJhYmxlPzogYm9vbGVhbjtcbiAgY2xhc3NOYW1lPzogc3RyaW5nO1xuICBwYWRkaW5nPzogJ25vbmUnIHwgJ3NtJyB8ICdtZCcgfCAnbGcnO1xufVxuXG5jb25zdCBwYWRkaW5nTWFwID0geyBub25lOiAnMCcsIHNtOiB0b2tlbnMuc3BhY2Uuc20sIG1kOiB0b2tlbnMuc3BhY2UubWQsIGxnOiB0b2tlbnMuc3BhY2UubGcgfTtcblxuY29uc3QgU3R5bGVkQXJ0aWNsZSA9IHN0eWxlZC5hcnRpY2xlPHtcbiAgaG92ZXJhYmxlOiBib29sZWFuO1xuICBwYWRkaW5nOiBOb25OdWxsYWJsZTxDYXJkUHJvcHNbJ3BhZGRpbmcnXT47XG59PmBcbiAgZGlzcGxheTpmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjpjb2x1bW47XG4gIGJhY2tncm91bmQtY29sb3I6JHt0b2tlbnMuY29sb3IuYmFja2dyb3VuZH07XG4gIGJvcmRlci1yYWRpdXM6JHt0b2tlbnMucmFkaXVzLm1kfTtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgcG9zaXRpb246cmVsYXRpdmU7XG4gIHRyYW5zaXRpb246Ym94LXNoYWRvdyAke3Rva2Vucy50cmFuc2l0aW9uLm5vcm1hbH0sdHJhbnNmb3JtICR7dG9rZW5zLnRyYW5zaXRpb24ubm9ybWFsfTtcbiAgbWF4LXdpZHRoOjE1cmVtO1xuICBoZWlnaHQ6NTI4cHg7XG4gIHBhZGRpbmc6JHsoeyBwYWRkaW5nIH0pID0+IHBhZGRpbmdNYXBbcGFkZGluZ119O1xuICAkeyh7IGhvdmVyYWJsZSB9KSA9PiBob3ZlcmFibGUgJiYgYGN1cnNvcjpwb2ludGVyOyY6aG92ZXJ7Ym94LXNoYWRvdzoke3Rva2Vucy5zaGFkb3cuc219O3RyYW5zZm9ybTp0cmFuc2xhdGVZKC0ycHgpO31gfVxuYDtcbmNvbnN0IENhcmRNZWRpYSA9IHN0eWxlZC5kaXZgd2lkdGg6MTAwJTtvdmVyZmxvdzpoaWRkZW47YDtcbmNvbnN0IENhcmRIZWFkZXIgPSBzdHlsZWQuZGl2YHBhZGRpbmc6JHt0b2tlbnMuc3BhY2Uuc219ICR7dG9rZW5zLnNwYWNlLm1kfTtgO1xuY29uc3QgQ2FyZEJvZHkgPSBzdHlsZWQuZGl2YHBhZGRpbmc6MCAke3Rva2Vucy5zcGFjZS5zbX07ZmxleDoxO2A7XG5jb25zdCBDYXJkRm9vdGVyID0gc3R5bGVkLmRpdmBwYWRkaW5nOiR7dG9rZW5zLnNwYWNlLnNtfTttYXJnaW4tdG9wOmF1dG87YDtcblxuZXhwb3J0IGZ1bmN0aW9uIENhcmQoe1xuICBtZWRpYSxcbiAgaGVhZGVyLFxuICBib2R5LFxuICBmb290ZXIsXG4gIG9uQ2xpY2ssXG4gIGhvdmVyYWJsZSA9IGZhbHNlLFxuICBjbGFzc05hbWUsXG4gIHBhZGRpbmcgPSAnbm9uZScsXG59OiBDYXJkUHJvcHMpIHtcbiAgY29uc3QgaXNJbnRlcmFjdGl2ZSA9IEJvb2xlYW4ob25DbGljayk7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEFydGljbGVcbiAgICAgIGhvdmVyYWJsZT17aG92ZXJhYmxlIHx8IGlzSW50ZXJhY3RpdmV9XG4gICAgICBwYWRkaW5nPXtwYWRkaW5nfVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgcm9sZT17aXNJbnRlcmFjdGl2ZSA/ICdidXR0b24nIDogdW5kZWZpbmVkfVxuICAgICAgdGFiSW5kZXg9e2lzSW50ZXJhY3RpdmUgPyAwIDogdW5kZWZpbmVkfVxuICAgICAgb25LZXlEb3duPXtcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgICAgID8gKGUpID0+IHtcbiAgICAgICAgICAgICAgaWYgKGUua2V5ID09PSAnRW50ZXInIHx8IGUua2V5ID09PSAnICcpIHtcbiAgICAgICAgICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgb25DbGljaz8uKCk7XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICA6IHVuZGVmaW5lZFxuICAgICAgfVxuICAgID5cbiAgICAgIHttZWRpYSAmJiA8Q2FyZE1lZGlhPnttZWRpYX08L0NhcmRNZWRpYT59XG4gICAgICB7aGVhZGVyICYmIDxDYXJkSGVhZGVyPntoZWFkZXJ9PC9DYXJkSGVhZGVyPn1cbiAgICAgIHtib2R5ICYmIDxDYXJkQm9keT57Ym9keX08L0NhcmRCb2R5Pn1cbiAgICAgIHtmb290ZXIgJiYgPENhcmRGb290ZXI+e2Zvb3Rlcn08L0NhcmRGb290ZXI+fVxuICAgIDwvU3R5bGVkQXJ0aWNsZT5cbiAgKTtcbn1cbiJdfQ== */")), i = /* @__PURE__ */ g("div", process.env.NODE_ENV === "production" ? {
39
+ target: "e1qo70ov1"
40
+ } : {
41
+ target: "e1qo70ov1",
42
+ label: "CardBody"
43
+ })("padding:0 ", b.space.sm, ";flex:1;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy9tYWNib29rL0RvY3VtZW50cy9jZW5jb3N1ZC9qdW1iby9saWIvcGFja2FnZXMvdWktY29yZS9zcmMvY29tcG9uZW50cy9DYXJkL0NhcmQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1DMkIiLCJmaWxlIjoiL1VzZXJzL21hY2Jvb2svRG9jdW1lbnRzL2NlbmNvc3VkL2p1bWJvL2xpYi9wYWNrYWdlcy91aS1jb3JlL3NyYy9jb21wb25lbnRzL0NhcmQvQ2FyZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB0b2tlbnMgfSBmcm9tICdAZGFuaWVsY3J1emNvZGUvZGVzaWduLXRva2Vucyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgdHlwZSBSZWFjdCBmcm9tICdyZWFjdCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2FyZFByb3BzIHtcbiAgbWVkaWE/OiBSZWFjdC5SZWFjdE5vZGU7XG4gIGhlYWRlcj86IFJlYWN0LlJlYWN0Tm9kZTtcbiAgYm9keT86IFJlYWN0LlJlYWN0Tm9kZTtcbiAgZm9vdGVyPzogUmVhY3QuUmVhY3ROb2RlO1xuICBvbkNsaWNrPzogKCkgPT4gdm9pZDtcbiAgaG92ZXJhYmxlPzogYm9vbGVhbjtcbiAgY2xhc3NOYW1lPzogc3RyaW5nO1xuICBwYWRkaW5nPzogJ25vbmUnIHwgJ3NtJyB8ICdtZCcgfCAnbGcnO1xufVxuXG5jb25zdCBwYWRkaW5nTWFwID0geyBub25lOiAnMCcsIHNtOiB0b2tlbnMuc3BhY2Uuc20sIG1kOiB0b2tlbnMuc3BhY2UubWQsIGxnOiB0b2tlbnMuc3BhY2UubGcgfTtcblxuY29uc3QgU3R5bGVkQXJ0aWNsZSA9IHN0eWxlZC5hcnRpY2xlPHtcbiAgaG92ZXJhYmxlOiBib29sZWFuO1xuICBwYWRkaW5nOiBOb25OdWxsYWJsZTxDYXJkUHJvcHNbJ3BhZGRpbmcnXT47XG59PmBcbiAgZGlzcGxheTpmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjpjb2x1bW47XG4gIGJhY2tncm91bmQtY29sb3I6JHt0b2tlbnMuY29sb3IuYmFja2dyb3VuZH07XG4gIGJvcmRlci1yYWRpdXM6JHt0b2tlbnMucmFkaXVzLm1kfTtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgcG9zaXRpb246cmVsYXRpdmU7XG4gIHRyYW5zaXRpb246Ym94LXNoYWRvdyAke3Rva2Vucy50cmFuc2l0aW9uLm5vcm1hbH0sdHJhbnNmb3JtICR7dG9rZW5zLnRyYW5zaXRpb24ubm9ybWFsfTtcbiAgbWF4LXdpZHRoOjE1cmVtO1xuICBoZWlnaHQ6NTI4cHg7XG4gIHBhZGRpbmc6JHsoeyBwYWRkaW5nIH0pID0+IHBhZGRpbmdNYXBbcGFkZGluZ119O1xuICAkeyh7IGhvdmVyYWJsZSB9KSA9PiBob3ZlcmFibGUgJiYgYGN1cnNvcjpwb2ludGVyOyY6aG92ZXJ7Ym94LXNoYWRvdzoke3Rva2Vucy5zaGFkb3cuc219O3RyYW5zZm9ybTp0cmFuc2xhdGVZKC0ycHgpO31gfVxuYDtcbmNvbnN0IENhcmRNZWRpYSA9IHN0eWxlZC5kaXZgd2lkdGg6MTAwJTtvdmVyZmxvdzpoaWRkZW47YDtcbmNvbnN0IENhcmRIZWFkZXIgPSBzdHlsZWQuZGl2YHBhZGRpbmc6JHt0b2tlbnMuc3BhY2Uuc219ICR7dG9rZW5zLnNwYWNlLm1kfTtgO1xuY29uc3QgQ2FyZEJvZHkgPSBzdHlsZWQuZGl2YHBhZGRpbmc6MCAke3Rva2Vucy5zcGFjZS5zbX07ZmxleDoxO2A7XG5jb25zdCBDYXJkRm9vdGVyID0gc3R5bGVkLmRpdmBwYWRkaW5nOiR7dG9rZW5zLnNwYWNlLnNtfTttYXJnaW4tdG9wOmF1dG87YDtcblxuZXhwb3J0IGZ1bmN0aW9uIENhcmQoe1xuICBtZWRpYSxcbiAgaGVhZGVyLFxuICBib2R5LFxuICBmb290ZXIsXG4gIG9uQ2xpY2ssXG4gIGhvdmVyYWJsZSA9IGZhbHNlLFxuICBjbGFzc05hbWUsXG4gIHBhZGRpbmcgPSAnbm9uZScsXG59OiBDYXJkUHJvcHMpIHtcbiAgY29uc3QgaXNJbnRlcmFjdGl2ZSA9IEJvb2xlYW4ob25DbGljayk7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEFydGljbGVcbiAgICAgIGhvdmVyYWJsZT17aG92ZXJhYmxlIHx8IGlzSW50ZXJhY3RpdmV9XG4gICAgICBwYWRkaW5nPXtwYWRkaW5nfVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgcm9sZT17aXNJbnRlcmFjdGl2ZSA/ICdidXR0b24nIDogdW5kZWZpbmVkfVxuICAgICAgdGFiSW5kZXg9e2lzSW50ZXJhY3RpdmUgPyAwIDogdW5kZWZpbmVkfVxuICAgICAgb25LZXlEb3duPXtcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgICAgID8gKGUpID0+IHtcbiAgICAgICAgICAgICAgaWYgKGUua2V5ID09PSAnRW50ZXInIHx8IGUua2V5ID09PSAnICcpIHtcbiAgICAgICAgICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgb25DbGljaz8uKCk7XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICA6IHVuZGVmaW5lZFxuICAgICAgfVxuICAgID5cbiAgICAgIHttZWRpYSAmJiA8Q2FyZE1lZGlhPnttZWRpYX08L0NhcmRNZWRpYT59XG4gICAgICB7aGVhZGVyICYmIDxDYXJkSGVhZGVyPntoZWFkZXJ9PC9DYXJkSGVhZGVyPn1cbiAgICAgIHtib2R5ICYmIDxDYXJkQm9keT57Ym9keX08L0NhcmRCb2R5Pn1cbiAgICAgIHtmb290ZXIgJiYgPENhcmRGb290ZXI+e2Zvb3Rlcn08L0NhcmRGb290ZXI+fVxuICAgIDwvU3R5bGVkQXJ0aWNsZT5cbiAgKTtcbn1cbiJdfQ== */")), V = /* @__PURE__ */ g("div", process.env.NODE_ENV === "production" ? {
44
+ target: "e1qo70ov0"
45
+ } : {
46
+ target: "e1qo70ov0",
47
+ label: "CardFooter"
48
+ })("padding:", b.space.sm, ";margin-top:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy9tYWNib29rL0RvY3VtZW50cy9jZW5jb3N1ZC9qdW1iby9saWIvcGFja2FnZXMvdWktY29yZS9zcmMvY29tcG9uZW50cy9DYXJkL0NhcmQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9DNkIiLCJmaWxlIjoiL1VzZXJzL21hY2Jvb2svRG9jdW1lbnRzL2NlbmNvc3VkL2p1bWJvL2xpYi9wYWNrYWdlcy91aS1jb3JlL3NyYy9jb21wb25lbnRzL0NhcmQvQ2FyZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB0b2tlbnMgfSBmcm9tICdAZGFuaWVsY3J1emNvZGUvZGVzaWduLXRva2Vucyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgdHlwZSBSZWFjdCBmcm9tICdyZWFjdCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2FyZFByb3BzIHtcbiAgbWVkaWE/OiBSZWFjdC5SZWFjdE5vZGU7XG4gIGhlYWRlcj86IFJlYWN0LlJlYWN0Tm9kZTtcbiAgYm9keT86IFJlYWN0LlJlYWN0Tm9kZTtcbiAgZm9vdGVyPzogUmVhY3QuUmVhY3ROb2RlO1xuICBvbkNsaWNrPzogKCkgPT4gdm9pZDtcbiAgaG92ZXJhYmxlPzogYm9vbGVhbjtcbiAgY2xhc3NOYW1lPzogc3RyaW5nO1xuICBwYWRkaW5nPzogJ25vbmUnIHwgJ3NtJyB8ICdtZCcgfCAnbGcnO1xufVxuXG5jb25zdCBwYWRkaW5nTWFwID0geyBub25lOiAnMCcsIHNtOiB0b2tlbnMuc3BhY2Uuc20sIG1kOiB0b2tlbnMuc3BhY2UubWQsIGxnOiB0b2tlbnMuc3BhY2UubGcgfTtcblxuY29uc3QgU3R5bGVkQXJ0aWNsZSA9IHN0eWxlZC5hcnRpY2xlPHtcbiAgaG92ZXJhYmxlOiBib29sZWFuO1xuICBwYWRkaW5nOiBOb25OdWxsYWJsZTxDYXJkUHJvcHNbJ3BhZGRpbmcnXT47XG59PmBcbiAgZGlzcGxheTpmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjpjb2x1bW47XG4gIGJhY2tncm91bmQtY29sb3I6JHt0b2tlbnMuY29sb3IuYmFja2dyb3VuZH07XG4gIGJvcmRlci1yYWRpdXM6JHt0b2tlbnMucmFkaXVzLm1kfTtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgcG9zaXRpb246cmVsYXRpdmU7XG4gIHRyYW5zaXRpb246Ym94LXNoYWRvdyAke3Rva2Vucy50cmFuc2l0aW9uLm5vcm1hbH0sdHJhbnNmb3JtICR7dG9rZW5zLnRyYW5zaXRpb24ubm9ybWFsfTtcbiAgbWF4LXdpZHRoOjE1cmVtO1xuICBoZWlnaHQ6NTI4cHg7XG4gIHBhZGRpbmc6JHsoeyBwYWRkaW5nIH0pID0+IHBhZGRpbmdNYXBbcGFkZGluZ119O1xuICAkeyh7IGhvdmVyYWJsZSB9KSA9PiBob3ZlcmFibGUgJiYgYGN1cnNvcjpwb2ludGVyOyY6aG92ZXJ7Ym94LXNoYWRvdzoke3Rva2Vucy5zaGFkb3cuc219O3RyYW5zZm9ybTp0cmFuc2xhdGVZKC0ycHgpO31gfVxuYDtcbmNvbnN0IENhcmRNZWRpYSA9IHN0eWxlZC5kaXZgd2lkdGg6MTAwJTtvdmVyZmxvdzpoaWRkZW47YDtcbmNvbnN0IENhcmRIZWFkZXIgPSBzdHlsZWQuZGl2YHBhZGRpbmc6JHt0b2tlbnMuc3BhY2Uuc219ICR7dG9rZW5zLnNwYWNlLm1kfTtgO1xuY29uc3QgQ2FyZEJvZHkgPSBzdHlsZWQuZGl2YHBhZGRpbmc6MCAke3Rva2Vucy5zcGFjZS5zbX07ZmxleDoxO2A7XG5jb25zdCBDYXJkRm9vdGVyID0gc3R5bGVkLmRpdmBwYWRkaW5nOiR7dG9rZW5zLnNwYWNlLnNtfTttYXJnaW4tdG9wOmF1dG87YDtcblxuZXhwb3J0IGZ1bmN0aW9uIENhcmQoe1xuICBtZWRpYSxcbiAgaGVhZGVyLFxuICBib2R5LFxuICBmb290ZXIsXG4gIG9uQ2xpY2ssXG4gIGhvdmVyYWJsZSA9IGZhbHNlLFxuICBjbGFzc05hbWUsXG4gIHBhZGRpbmcgPSAnbm9uZScsXG59OiBDYXJkUHJvcHMpIHtcbiAgY29uc3QgaXNJbnRlcmFjdGl2ZSA9IEJvb2xlYW4ob25DbGljayk7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEFydGljbGVcbiAgICAgIGhvdmVyYWJsZT17aG92ZXJhYmxlIHx8IGlzSW50ZXJhY3RpdmV9XG4gICAgICBwYWRkaW5nPXtwYWRkaW5nfVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgcm9sZT17aXNJbnRlcmFjdGl2ZSA/ICdidXR0b24nIDogdW5kZWZpbmVkfVxuICAgICAgdGFiSW5kZXg9e2lzSW50ZXJhY3RpdmUgPyAwIDogdW5kZWZpbmVkfVxuICAgICAgb25LZXlEb3duPXtcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgICAgID8gKGUpID0+IHtcbiAgICAgICAgICAgICAgaWYgKGUua2V5ID09PSAnRW50ZXInIHx8IGUua2V5ID09PSAnICcpIHtcbiAgICAgICAgICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgb25DbGljaz8uKCk7XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICA6IHVuZGVmaW5lZFxuICAgICAgfVxuICAgID5cbiAgICAgIHttZWRpYSAmJiA8Q2FyZE1lZGlhPnttZWRpYX08L0NhcmRNZWRpYT59XG4gICAgICB7aGVhZGVyICYmIDxDYXJkSGVhZGVyPntoZWFkZXJ9PC9DYXJkSGVhZGVyPn1cbiAgICAgIHtib2R5ICYmIDxDYXJkQm9keT57Ym9keX08L0NhcmRCb2R5Pn1cbiAgICAgIHtmb290ZXIgJiYgPENhcmRGb290ZXI+e2Zvb3Rlcn08L0NhcmRGb290ZXI+fVxuICAgIDwvU3R5bGVkQXJ0aWNsZT5cbiAgKTtcbn1cbiJdfQ== */"));
49
+ function h({
50
+ media: I,
51
+ header: C,
52
+ body: m,
53
+ footer: l,
54
+ onClick: c,
55
+ hoverable: A = !1,
56
+ className: Y,
57
+ padding: u = "none"
58
+ }) {
59
+ const Z = !!c;
60
+ return /* @__PURE__ */ t(R, { hoverable: A || Z, padding: u, className: Y, onClick: c, role: Z ? "button" : void 0, tabIndex: Z ? 0 : void 0, onKeyDown: Z ? (W) => {
61
+ (W.key === "Enter" || W.key === " ") && (W.preventDefault(), c == null || c());
62
+ } : void 0, children: [
63
+ I && /* @__PURE__ */ G(a, { children: I }),
64
+ C && /* @__PURE__ */ G(n, { children: C }),
65
+ m && /* @__PURE__ */ G(i, { children: m }),
66
+ l && /* @__PURE__ */ G(V, { children: l })
67
+ ] });
34
68
  }
35
69
  export {
36
- j as Card
70
+ h as Card
37
71
  };
@@ -1,92 +1,122 @@
1
- import { jsxs as y, jsx as o, Fragment as _ } from "react/jsx-runtime";
2
- import c from "@emotion/styled";
3
- import { tokens as e } from "./index.esm14.js";
4
- import G from "./index.esm15.js";
5
- import { useState as a, useRef as S, useEffect as u, useCallback as P } from "react";
6
- const X = { sm: 8, md: 16, lg: 24, xl: 32 };
7
- function Y(r, i) {
8
- return typeof r == "number" ? r : i >= 1024 ? r.desktop : i >= 640 ? r.tablet : r.mobile;
1
+ import { jsxs as a, jsx as b, Fragment as S } from "react/jsx-runtime";
2
+ import V from "./index.esm15.js";
3
+ import { tokens as C } from "./index.esm16.js";
4
+ import O from "./index.esm18.js";
5
+ import { useState as u, useRef as x, useEffect as B, useCallback as T } from "react";
6
+ const D = {
7
+ sm: 8,
8
+ md: 16,
9
+ lg: 24,
10
+ xl: 32
11
+ };
12
+ function P(g, G, l) {
13
+ if (typeof g == "number") return g;
14
+ if ("min" in g) {
15
+ const X = Math.floor((G + l) / (g.min + l)), W = Math.max(1, X);
16
+ return g.max !== void 0 ? Math.min(W, g.max) : W;
17
+ }
18
+ return G >= 1024 ? g.desktop : G >= 900 && g.wide !== void 0 ? g.wide : G >= 640 ? g.tablet : g.mobile;
9
19
  }
10
- const I = c.button`
11
- position:absolute;top:50%;transform:translateY(-50%);z-index:10;
12
- display:flex;align-items:center;justify-content:center;
13
- width:36px;height:36px;border-radius:${e.radius.full};
14
- border:1px solid ${e.color.border};background-color:${e.color.background};
15
- color:${e.color.text};cursor:pointer;box-shadow:${e.shadow.sm};
16
- transition:box-shadow ${e.transition.fast};
17
- &:hover{box-shadow:${e.shadow.md};}
18
- &:focus-visible{outline:2px solid ${e.color.borderFocus};outline-offset:2px;}
19
- &:disabled{opacity:0.4;cursor:not-allowed;}
20
- `, q = c(I)`left:${e.space.sm};`, H = c(I)`right:${e.space.sm};`, J = c.button`
21
- width:${({ active: r }) => r ? "20px" : "8px"};height:8px;
22
- border-radius:${e.radius.full};
23
- background-color:${({ active: r }) => r ? e.color.brand : e.color.border};
24
- border:none;cursor:pointer;padding:0;
25
- transition:background-color ${e.transition.fast},width ${e.transition.fast};
26
- &:focus-visible{outline:2px solid ${e.color.borderFocus};outline-offset:2px;}
27
- `, K = c.div`display:flex;justify-content:center;gap:${e.space.sm};margin-top:${e.space.sm};`;
28
- function V({
29
- children: r,
30
- autoplay: i = !1,
31
- autoplayMs: p = 4e3,
32
- pauseOnHover: h = !0,
33
- showArrows: L = !0,
34
- showDots: j = !0,
35
- loop: R = !1,
36
- slidesPerView: x = 1,
37
- slidesPerGroup: W = 1,
38
- gap: b,
39
- onSlideChange: d
20
+ const H = /* @__PURE__ */ V("button", process.env.NODE_ENV === "production" ? {
21
+ target: "e4oxflb4"
22
+ } : {
23
+ target: "e4oxflb4",
24
+ label: "ArrowBtn"
25
+ })("position:absolute;top:50%;transform:translateY(-50%);z-index:10;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:", C.radius.full, ";border:1px solid ", C.color.border, ";background-color:", C.color.background, ";color:", C.color.text, ";cursor:pointer;box-shadow:", C.shadow.sm, ";transition:box-shadow ", C.transition.fast, ";&:hover{box-shadow:", C.shadow.md, ";}&:focus-visible{outline:2px solid ", C.color.borderFocus, ";outline-offset:2px;}&:disabled{opacity:0.4;cursor:not-allowed;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/Users/macbook/Documents/cencosud/jumbo/lib/packages/ui-core/src/components/Carousel/Carousel.tsx"],"names":[],"mappings":"AAwC8B","file":"/Users/macbook/Documents/cencosud/jumbo/lib/packages/ui-core/src/components/Carousel/Carousel.tsx","sourcesContent":["import { tokens } from '@danielcruzcode/design-tokens';\nimport styled from '@emotion/styled';\nimport useEmblaCarousel from 'embla-carousel-react';\nimport type React from 'react';\nimport { useCallback, useEffect, useRef, useState } from 'react';\n\ntype SlidesPerView =\n  | number\n  | { mobile: number; tablet: number; wide?: number; desktop: number }\n  | { min: number; max?: number };\n\nexport interface CarouselProps {\n  children: React.ReactNode[];\n  autoplay?: boolean;\n  autoplayMs?: number;\n  pauseOnHover?: boolean;\n  showArrows?: boolean;\n  showDots?: boolean;\n  loop?: boolean;\n  slidesPerView?: SlidesPerView;\n  slidesPerGroup?: number;\n  gap?: keyof typeof tokens.space;\n  onSlideChange?: (index: number) => void;\n}\n\nconst GAP_PX: Record<string, number> = { sm: 8, md: 16, lg: 24, xl: 32 };\n\nfunction getSpv(slidesPerView: SlidesPerView, width: number, gapPx: number): number {\n  if (typeof slidesPerView === 'number') return slidesPerView;\n  if ('min' in slidesPerView) {\n    const count = Math.floor((width + gapPx) / (slidesPerView.min + gapPx));\n    const clamped = Math.max(1, count);\n    return slidesPerView.max !== undefined ? Math.min(clamped, slidesPerView.max) : clamped;\n  }\n  if (width >= 1024) return slidesPerView.desktop;\n  if (width >= 900 && slidesPerView.wide !== undefined) return slidesPerView.wide;\n  if (width >= 640) return slidesPerView.tablet;\n  return slidesPerView.mobile;\n}\n\nconst ArrowBtn = styled.button`\n  position:absolute;top:50%;transform:translateY(-50%);z-index:10;\n  display:flex;align-items:center;justify-content:center;\n  width:36px;height:36px;border-radius:${tokens.radius.full};\n  border:1px solid ${tokens.color.border};background-color:${tokens.color.background};\n  color:${tokens.color.text};cursor:pointer;box-shadow:${tokens.shadow.sm};\n  transition:box-shadow ${tokens.transition.fast};\n  &:hover{box-shadow:${tokens.shadow.md};}\n  &:focus-visible{outline:2px solid ${tokens.color.borderFocus};outline-offset:2px;}\n  &:disabled{opacity:0.4;cursor:not-allowed;}\n`;\nconst ArrowPrev = styled(ArrowBtn)`left:${tokens.space.sm};`;\nconst ArrowNext = styled(ArrowBtn)`right:${tokens.space.sm};`;\n\nconst Dot = styled.button<{ active: boolean }>`\n  width:${({ active }) => (active ? '20px' : '8px')};height:8px;\n  border-radius:${tokens.radius.full};\n  background-color:${({ active }) => (active ? tokens.color.brand : tokens.color.border)};\n  border:none;cursor:pointer;padding:0;\n  transition:background-color ${tokens.transition.fast},width ${tokens.transition.fast};\n  &:focus-visible{outline:2px solid ${tokens.color.borderFocus};outline-offset:2px;}\n`;\nconst Dots = styled.div`display:flex;justify-content:center;gap:${tokens.space.sm};margin-top:${tokens.space.sm};`;\n\nexport function Carousel({\n  children,\n  autoplay = false,\n  autoplayMs = 4000,\n  pauseOnHover = true,\n  showArrows = true,\n  showDots = true,\n  loop = false,\n  slidesPerView = 1,\n  gap,\n  onSlideChange,\n}: CarouselProps) {\n  const gapPx = gap ? (GAP_PX[gap as string] ?? 0) : 0;\n  const [spv, setSpv] = useState(1);\n  const [emblaRef, emblaApi] = useEmblaCarousel({ loop, slidesToScroll: spv, align: 'start' });\n  const [selectedIndex, setSelectedIndex] = useState(0);\n  const [scrollSnaps, setScrollSnaps] = useState<number[]>([]);\n  const [hovered, setHovered] = useState(false);\n\n  const slidesPerViewRef = useRef(slidesPerView);\n  slidesPerViewRef.current = slidesPerView;\n  const gapPxRef = useRef(gapPx);\n  gapPxRef.current = gapPx;\n\n  const containerRef = useRef<HTMLDivElement>(null);\n\n  // Use ResizeObserver on the container — reliable in iframes and custom viewports\n  useEffect(() => {\n    const el = containerRef.current;\n    if (!el) return;\n    const ro = new ResizeObserver(([entry]) => {\n      const width = entry.contentRect.width;\n      setSpv(getSpv(slidesPerViewRef.current, width, gapPxRef.current));\n    });\n    ro.observe(el);\n    return () => ro.disconnect();\n  }, []);\n\n  const onSelect = useCallback(() => {\n    if (!emblaApi) return;\n    const index = emblaApi.selectedScrollSnap();\n    setSelectedIndex(index);\n    onSlideChange?.(index);\n  }, [emblaApi, onSlideChange]);\n\n  useEffect(() => {\n    if (!emblaApi) return;\n    setScrollSnaps(emblaApi.scrollSnapList());\n    emblaApi.on('select', onSelect);\n    emblaApi.on('reInit', onSelect);\n    return () => {\n      emblaApi.off('select', onSelect);\n      emblaApi.off('reInit', onSelect);\n    };\n  }, [emblaApi, onSelect]);\n\n  useEffect(() => {\n    emblaApi?.reInit();\n  }, [emblaApi, spv]);\n\n  useEffect(() => {\n    if (!autoplay || !emblaApi) return;\n    if (pauseOnHover && hovered) return;\n    const id = setInterval(() => emblaApi.scrollNext(), autoplayMs);\n    return () => clearInterval(id);\n  }, [autoplay, autoplayMs, emblaApi, pauseOnHover, hovered]);\n\n  const slideWidth = `calc((100% - ${gapPx * (spv - 1)}px) / ${spv})`;\n  const centered = children.length < spv;\n\n  return (\n    <div\n      ref={containerRef}\n      style={{ position: 'relative', width: '100%' }}\n      onMouseEnter={() => setHovered(true)}\n      onMouseLeave={() => setHovered(false)}\n    >\n      <div ref={emblaRef} style={{ overflow: 'hidden' }}>\n        <div style={{ display: 'flex', gap: gapPx, justifyContent: centered ? 'center' : 'flex-start' }}>\n          {children.map((child, i) => (\n            <div key={i} style={{ flex: `0 0 ${slideWidth}`, minWidth: 0 }}>\n              {child}\n            </div>\n          ))}\n        </div>\n      </div>\n      {showArrows && (\n        <>\n          <ArrowPrev\n            type=\"button\"\n            aria-label=\"Slide anterior\"\n            onClick={() => emblaApi?.scrollPrev()}\n          >\n            <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" aria-hidden=\"true\">\n              <path\n                d=\"M10 12L6 8l4-4\"\n                stroke=\"currentColor\"\n                strokeWidth=\"1.5\"\n                strokeLinecap=\"round\"\n                strokeLinejoin=\"round\"\n              />\n            </svg>\n          </ArrowPrev>\n          <ArrowNext\n            type=\"button\"\n            aria-label=\"Slide siguiente\"\n            onClick={() => emblaApi?.scrollNext()}\n          >\n            <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" aria-hidden=\"true\">\n              <path\n                d=\"M6 4l4 4-4 4\"\n                stroke=\"currentColor\"\n                strokeWidth=\"1.5\"\n                strokeLinecap=\"round\"\n                strokeLinejoin=\"round\"\n              />\n            </svg>\n          </ArrowNext>\n        </>\n      )}\n      {showDots && (\n        <Dots>\n          {scrollSnaps.map((_, i) => (\n            <Dot\n              key={i}\n              active={i === selectedIndex}\n              type=\"button\"\n              onClick={() => emblaApi?.scrollTo(i)}\n              aria-label={`Ir al slide ${i + 1}`}\n            />\n          ))}\n        </Dots>\n      )}\n    </div>\n  );\n}\n"]} */")), L = /* @__PURE__ */ V(H, process.env.NODE_ENV === "production" ? {
26
+ target: "e4oxflb3"
27
+ } : {
28
+ target: "e4oxflb3",
29
+ label: "ArrowPrev"
30
+ })("left:", C.space.sm, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/Users/macbook/Documents/cencosud/jumbo/lib/packages/ui-core/src/components/Carousel/Carousel.tsx"],"names":[],"mappings":"AAmDkC","file":"/Users/macbook/Documents/cencosud/jumbo/lib/packages/ui-core/src/components/Carousel/Carousel.tsx","sourcesContent":["import { tokens } from '@danielcruzcode/design-tokens';\nimport styled from '@emotion/styled';\nimport useEmblaCarousel from 'embla-carousel-react';\nimport type React from 'react';\nimport { useCallback, useEffect, useRef, useState } from 'react';\n\ntype SlidesPerView =\n  | number\n  | { mobile: number; tablet: number; wide?: number; desktop: number }\n  | { min: number; max?: number };\n\nexport interface CarouselProps {\n  children: React.ReactNode[];\n  autoplay?: boolean;\n  autoplayMs?: number;\n  pauseOnHover?: boolean;\n  showArrows?: boolean;\n  showDots?: boolean;\n  loop?: boolean;\n  slidesPerView?: SlidesPerView;\n  slidesPerGroup?: number;\n  gap?: keyof typeof tokens.space;\n  onSlideChange?: (index: number) => void;\n}\n\nconst GAP_PX: Record<string, number> = { sm: 8, md: 16, lg: 24, xl: 32 };\n\nfunction getSpv(slidesPerView: SlidesPerView, width: number, gapPx: number): number {\n  if (typeof slidesPerView === 'number') return slidesPerView;\n  if ('min' in slidesPerView) {\n    const count = Math.floor((width + gapPx) / (slidesPerView.min + gapPx));\n    const clamped = Math.max(1, count);\n    return slidesPerView.max !== undefined ? Math.min(clamped, slidesPerView.max) : clamped;\n  }\n  if (width >= 1024) return slidesPerView.desktop;\n  if (width >= 900 && slidesPerView.wide !== undefined) return slidesPerView.wide;\n  if (width >= 640) return slidesPerView.tablet;\n  return slidesPerView.mobile;\n}\n\nconst ArrowBtn = styled.button`\n  position:absolute;top:50%;transform:translateY(-50%);z-index:10;\n  display:flex;align-items:center;justify-content:center;\n  width:36px;height:36px;border-radius:${tokens.radius.full};\n  border:1px solid ${tokens.color.border};background-color:${tokens.color.background};\n  color:${tokens.color.text};cursor:pointer;box-shadow:${tokens.shadow.sm};\n  transition:box-shadow ${tokens.transition.fast};\n  &:hover{box-shadow:${tokens.shadow.md};}\n  &:focus-visible{outline:2px solid ${tokens.color.borderFocus};outline-offset:2px;}\n  &:disabled{opacity:0.4;cursor:not-allowed;}\n`;\nconst ArrowPrev = styled(ArrowBtn)`left:${tokens.space.sm};`;\nconst ArrowNext = styled(ArrowBtn)`right:${tokens.space.sm};`;\n\nconst Dot = styled.button<{ active: boolean }>`\n  width:${({ active }) => (active ? '20px' : '8px')};height:8px;\n  border-radius:${tokens.radius.full};\n  background-color:${({ active }) => (active ? tokens.color.brand : tokens.color.border)};\n  border:none;cursor:pointer;padding:0;\n  transition:background-color ${tokens.transition.fast},width ${tokens.transition.fast};\n  &:focus-visible{outline:2px solid ${tokens.color.borderFocus};outline-offset:2px;}\n`;\nconst Dots = styled.div`display:flex;justify-content:center;gap:${tokens.space.sm};margin-top:${tokens.space.sm};`;\n\nexport function Carousel({\n  children,\n  autoplay = false,\n  autoplayMs = 4000,\n  pauseOnHover = true,\n  showArrows = true,\n  showDots = true,\n  loop = false,\n  slidesPerView = 1,\n  gap,\n  onSlideChange,\n}: CarouselProps) {\n  const gapPx = gap ? (GAP_PX[gap as string] ?? 0) : 0;\n  const [spv, setSpv] = useState(1);\n  const [emblaRef, emblaApi] = useEmblaCarousel({ loop, slidesToScroll: spv, align: 'start' });\n  const [selectedIndex, setSelectedIndex] = useState(0);\n  const [scrollSnaps, setScrollSnaps] = useState<number[]>([]);\n  const [hovered, setHovered] = useState(false);\n\n  const slidesPerViewRef = useRef(slidesPerView);\n  slidesPerViewRef.current = slidesPerView;\n  const gapPxRef = useRef(gapPx);\n  gapPxRef.current = gapPx;\n\n  const containerRef = useRef<HTMLDivElement>(null);\n\n  // Use ResizeObserver on the container — reliable in iframes and custom viewports\n  useEffect(() => {\n    const el = containerRef.current;\n    if (!el) return;\n    const ro = new ResizeObserver(([entry]) => {\n      const width = entry.contentRect.width;\n      setSpv(getSpv(slidesPerViewRef.current, width, gapPxRef.current));\n    });\n    ro.observe(el);\n    return () => ro.disconnect();\n  }, []);\n\n  const onSelect = useCallback(() => {\n    if (!emblaApi) return;\n    const index = emblaApi.selectedScrollSnap();\n    setSelectedIndex(index);\n    onSlideChange?.(index);\n  }, [emblaApi, onSlideChange]);\n\n  useEffect(() => {\n    if (!emblaApi) return;\n    setScrollSnaps(emblaApi.scrollSnapList());\n    emblaApi.on('select', onSelect);\n    emblaApi.on('reInit', onSelect);\n    return () => {\n      emblaApi.off('select', onSelect);\n      emblaApi.off('reInit', onSelect);\n    };\n  }, [emblaApi, onSelect]);\n\n  useEffect(() => {\n    emblaApi?.reInit();\n  }, [emblaApi, spv]);\n\n  useEffect(() => {\n    if (!autoplay || !emblaApi) return;\n    if (pauseOnHover && hovered) return;\n    const id = setInterval(() => emblaApi.scrollNext(), autoplayMs);\n    return () => clearInterval(id);\n  }, [autoplay, autoplayMs, emblaApi, pauseOnHover, hovered]);\n\n  const slideWidth = `calc((100% - ${gapPx * (spv - 1)}px) / ${spv})`;\n  const centered = children.length < spv;\n\n  return (\n    <div\n      ref={containerRef}\n      style={{ position: 'relative', width: '100%' }}\n      onMouseEnter={() => setHovered(true)}\n      onMouseLeave={() => setHovered(false)}\n    >\n      <div ref={emblaRef} style={{ overflow: 'hidden' }}>\n        <div style={{ display: 'flex', gap: gapPx, justifyContent: centered ? 'center' : 'flex-start' }}>\n          {children.map((child, i) => (\n            <div key={i} style={{ flex: `0 0 ${slideWidth}`, minWidth: 0 }}>\n              {child}\n            </div>\n          ))}\n        </div>\n      </div>\n      {showArrows && (\n        <>\n          <ArrowPrev\n            type=\"button\"\n            aria-label=\"Slide anterior\"\n            onClick={() => emblaApi?.scrollPrev()}\n          >\n            <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" aria-hidden=\"true\">\n              <path\n                d=\"M10 12L6 8l4-4\"\n                stroke=\"currentColor\"\n                strokeWidth=\"1.5\"\n                strokeLinecap=\"round\"\n                strokeLinejoin=\"round\"\n              />\n            </svg>\n          </ArrowPrev>\n          <ArrowNext\n            type=\"button\"\n            aria-label=\"Slide siguiente\"\n            onClick={() => emblaApi?.scrollNext()}\n          >\n            <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" aria-hidden=\"true\">\n              <path\n                d=\"M6 4l4 4-4 4\"\n                stroke=\"currentColor\"\n                strokeWidth=\"1.5\"\n                strokeLinecap=\"round\"\n                strokeLinejoin=\"round\"\n              />\n            </svg>\n          </ArrowNext>\n        </>\n      )}\n      {showDots && (\n        <Dots>\n          {scrollSnaps.map((_, i) => (\n            <Dot\n              key={i}\n              active={i === selectedIndex}\n              type=\"button\"\n              onClick={() => emblaApi?.scrollTo(i)}\n              aria-label={`Ir al slide ${i + 1}`}\n            />\n          ))}\n        </Dots>\n      )}\n    </div>\n  );\n}\n"]} */")), r = /* @__PURE__ */ V(H, process.env.NODE_ENV === "production" ? {
31
+ target: "e4oxflb2"
32
+ } : {
33
+ target: "e4oxflb2",
34
+ label: "ArrowNext"
35
+ })("right:", C.space.sm, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/Users/macbook/Documents/cencosud/jumbo/lib/packages/ui-core/src/components/Carousel/Carousel.tsx"],"names":[],"mappings":"AAoDkC","file":"/Users/macbook/Documents/cencosud/jumbo/lib/packages/ui-core/src/components/Carousel/Carousel.tsx","sourcesContent":["import { tokens } from '@danielcruzcode/design-tokens';\nimport styled from '@emotion/styled';\nimport useEmblaCarousel from 'embla-carousel-react';\nimport type React from 'react';\nimport { useCallback, useEffect, useRef, useState } from 'react';\n\ntype SlidesPerView =\n  | number\n  | { mobile: number; tablet: number; wide?: number; desktop: number }\n  | { min: number; max?: number };\n\nexport interface CarouselProps {\n  children: React.ReactNode[];\n  autoplay?: boolean;\n  autoplayMs?: number;\n  pauseOnHover?: boolean;\n  showArrows?: boolean;\n  showDots?: boolean;\n  loop?: boolean;\n  slidesPerView?: SlidesPerView;\n  slidesPerGroup?: number;\n  gap?: keyof typeof tokens.space;\n  onSlideChange?: (index: number) => void;\n}\n\nconst GAP_PX: Record<string, number> = { sm: 8, md: 16, lg: 24, xl: 32 };\n\nfunction getSpv(slidesPerView: SlidesPerView, width: number, gapPx: number): number {\n  if (typeof slidesPerView === 'number') return slidesPerView;\n  if ('min' in slidesPerView) {\n    const count = Math.floor((width + gapPx) / (slidesPerView.min + gapPx));\n    const clamped = Math.max(1, count);\n    return slidesPerView.max !== undefined ? Math.min(clamped, slidesPerView.max) : clamped;\n  }\n  if (width >= 1024) return slidesPerView.desktop;\n  if (width >= 900 && slidesPerView.wide !== undefined) return slidesPerView.wide;\n  if (width >= 640) return slidesPerView.tablet;\n  return slidesPerView.mobile;\n}\n\nconst ArrowBtn = styled.button`\n  position:absolute;top:50%;transform:translateY(-50%);z-index:10;\n  display:flex;align-items:center;justify-content:center;\n  width:36px;height:36px;border-radius:${tokens.radius.full};\n  border:1px solid ${tokens.color.border};background-color:${tokens.color.background};\n  color:${tokens.color.text};cursor:pointer;box-shadow:${tokens.shadow.sm};\n  transition:box-shadow ${tokens.transition.fast};\n  &:hover{box-shadow:${tokens.shadow.md};}\n  &:focus-visible{outline:2px solid ${tokens.color.borderFocus};outline-offset:2px;}\n  &:disabled{opacity:0.4;cursor:not-allowed;}\n`;\nconst ArrowPrev = styled(ArrowBtn)`left:${tokens.space.sm};`;\nconst ArrowNext = styled(ArrowBtn)`right:${tokens.space.sm};`;\n\nconst Dot = styled.button<{ active: boolean }>`\n  width:${({ active }) => (active ? '20px' : '8px')};height:8px;\n  border-radius:${tokens.radius.full};\n  background-color:${({ active }) => (active ? tokens.color.brand : tokens.color.border)};\n  border:none;cursor:pointer;padding:0;\n  transition:background-color ${tokens.transition.fast},width ${tokens.transition.fast};\n  &:focus-visible{outline:2px solid ${tokens.color.borderFocus};outline-offset:2px;}\n`;\nconst Dots = styled.div`display:flex;justify-content:center;gap:${tokens.space.sm};margin-top:${tokens.space.sm};`;\n\nexport function Carousel({\n  children,\n  autoplay = false,\n  autoplayMs = 4000,\n  pauseOnHover = true,\n  showArrows = true,\n  showDots = true,\n  loop = false,\n  slidesPerView = 1,\n  gap,\n  onSlideChange,\n}: CarouselProps) {\n  const gapPx = gap ? (GAP_PX[gap as string] ?? 0) : 0;\n  const [spv, setSpv] = useState(1);\n  const [emblaRef, emblaApi] = useEmblaCarousel({ loop, slidesToScroll: spv, align: 'start' });\n  const [selectedIndex, setSelectedIndex] = useState(0);\n  const [scrollSnaps, setScrollSnaps] = useState<number[]>([]);\n  const [hovered, setHovered] = useState(false);\n\n  const slidesPerViewRef = useRef(slidesPerView);\n  slidesPerViewRef.current = slidesPerView;\n  const gapPxRef = useRef(gapPx);\n  gapPxRef.current = gapPx;\n\n  const containerRef = useRef<HTMLDivElement>(null);\n\n  // Use ResizeObserver on the container — reliable in iframes and custom viewports\n  useEffect(() => {\n    const el = containerRef.current;\n    if (!el) return;\n    const ro = new ResizeObserver(([entry]) => {\n      const width = entry.contentRect.width;\n      setSpv(getSpv(slidesPerViewRef.current, width, gapPxRef.current));\n    });\n    ro.observe(el);\n    return () => ro.disconnect();\n  }, []);\n\n  const onSelect = useCallback(() => {\n    if (!emblaApi) return;\n    const index = emblaApi.selectedScrollSnap();\n    setSelectedIndex(index);\n    onSlideChange?.(index);\n  }, [emblaApi, onSlideChange]);\n\n  useEffect(() => {\n    if (!emblaApi) return;\n    setScrollSnaps(emblaApi.scrollSnapList());\n    emblaApi.on('select', onSelect);\n    emblaApi.on('reInit', onSelect);\n    return () => {\n      emblaApi.off('select', onSelect);\n      emblaApi.off('reInit', onSelect);\n    };\n  }, [emblaApi, onSelect]);\n\n  useEffect(() => {\n    emblaApi?.reInit();\n  }, [emblaApi, spv]);\n\n  useEffect(() => {\n    if (!autoplay || !emblaApi) return;\n    if (pauseOnHover && hovered) return;\n    const id = setInterval(() => emblaApi.scrollNext(), autoplayMs);\n    return () => clearInterval(id);\n  }, [autoplay, autoplayMs, emblaApi, pauseOnHover, hovered]);\n\n  const slideWidth = `calc((100% - ${gapPx * (spv - 1)}px) / ${spv})`;\n  const centered = children.length < spv;\n\n  return (\n    <div\n      ref={containerRef}\n      style={{ position: 'relative', width: '100%' }}\n      onMouseEnter={() => setHovered(true)}\n      onMouseLeave={() => setHovered(false)}\n    >\n      <div ref={emblaRef} style={{ overflow: 'hidden' }}>\n        <div style={{ display: 'flex', gap: gapPx, justifyContent: centered ? 'center' : 'flex-start' }}>\n          {children.map((child, i) => (\n            <div key={i} style={{ flex: `0 0 ${slideWidth}`, minWidth: 0 }}>\n              {child}\n            </div>\n          ))}\n        </div>\n      </div>\n      {showArrows && (\n        <>\n          <ArrowPrev\n            type=\"button\"\n            aria-label=\"Slide anterior\"\n            onClick={() => emblaApi?.scrollPrev()}\n          >\n            <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" aria-hidden=\"true\">\n              <path\n                d=\"M10 12L6 8l4-4\"\n                stroke=\"currentColor\"\n                strokeWidth=\"1.5\"\n                strokeLinecap=\"round\"\n                strokeLinejoin=\"round\"\n              />\n            </svg>\n          </ArrowPrev>\n          <ArrowNext\n            type=\"button\"\n            aria-label=\"Slide siguiente\"\n            onClick={() => emblaApi?.scrollNext()}\n          >\n            <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" aria-hidden=\"true\">\n              <path\n                d=\"M6 4l4 4-4 4\"\n                stroke=\"currentColor\"\n                strokeWidth=\"1.5\"\n                strokeLinecap=\"round\"\n                strokeLinejoin=\"round\"\n              />\n            </svg>\n          </ArrowNext>\n        </>\n      )}\n      {showDots && (\n        <Dots>\n          {scrollSnaps.map((_, i) => (\n            <Dot\n              key={i}\n              active={i === selectedIndex}\n              type=\"button\"\n              onClick={() => emblaApi?.scrollTo(i)}\n              aria-label={`Ir al slide ${i + 1}`}\n            />\n          ))}\n        </Dots>\n      )}\n    </div>\n  );\n}\n"]} */")), K = /* @__PURE__ */ V("button", process.env.NODE_ENV === "production" ? {
36
+ target: "e4oxflb1"
37
+ } : {
38
+ target: "e4oxflb1",
39
+ label: "Dot"
40
+ })("width:", ({
41
+ active: g
42
+ }) => g ? "20px" : "8px", ";height:8px;border-radius:", C.radius.full, ";background-color:", ({
43
+ active: g
44
+ }) => g ? C.color.brand : C.color.border, ";border:none;cursor:pointer;padding:0;transition:background-color ", C.transition.fast, ",width ", C.transition.fast, ";&:focus-visible{outline:2px solid ", C.color.borderFocus, ";outline-offset:2px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/Users/macbook/Documents/cencosud/jumbo/lib/packages/ui-core/src/components/Carousel/Carousel.tsx"],"names":[],"mappings":"AAsD8C","file":"/Users/macbook/Documents/cencosud/jumbo/lib/packages/ui-core/src/components/Carousel/Carousel.tsx","sourcesContent":["import { tokens } from '@danielcruzcode/design-tokens';\nimport styled from '@emotion/styled';\nimport useEmblaCarousel from 'embla-carousel-react';\nimport type React from 'react';\nimport { useCallback, useEffect, useRef, useState } from 'react';\n\ntype SlidesPerView =\n  | number\n  | { mobile: number; tablet: number; wide?: number; desktop: number }\n  | { min: number; max?: number };\n\nexport interface CarouselProps {\n  children: React.ReactNode[];\n  autoplay?: boolean;\n  autoplayMs?: number;\n  pauseOnHover?: boolean;\n  showArrows?: boolean;\n  showDots?: boolean;\n  loop?: boolean;\n  slidesPerView?: SlidesPerView;\n  slidesPerGroup?: number;\n  gap?: keyof typeof tokens.space;\n  onSlideChange?: (index: number) => void;\n}\n\nconst GAP_PX: Record<string, number> = { sm: 8, md: 16, lg: 24, xl: 32 };\n\nfunction getSpv(slidesPerView: SlidesPerView, width: number, gapPx: number): number {\n  if (typeof slidesPerView === 'number') return slidesPerView;\n  if ('min' in slidesPerView) {\n    const count = Math.floor((width + gapPx) / (slidesPerView.min + gapPx));\n    const clamped = Math.max(1, count);\n    return slidesPerView.max !== undefined ? Math.min(clamped, slidesPerView.max) : clamped;\n  }\n  if (width >= 1024) return slidesPerView.desktop;\n  if (width >= 900 && slidesPerView.wide !== undefined) return slidesPerView.wide;\n  if (width >= 640) return slidesPerView.tablet;\n  return slidesPerView.mobile;\n}\n\nconst ArrowBtn = styled.button`\n  position:absolute;top:50%;transform:translateY(-50%);z-index:10;\n  display:flex;align-items:center;justify-content:center;\n  width:36px;height:36px;border-radius:${tokens.radius.full};\n  border:1px solid ${tokens.color.border};background-color:${tokens.color.background};\n  color:${tokens.color.text};cursor:pointer;box-shadow:${tokens.shadow.sm};\n  transition:box-shadow ${tokens.transition.fast};\n  &:hover{box-shadow:${tokens.shadow.md};}\n  &:focus-visible{outline:2px solid ${tokens.color.borderFocus};outline-offset:2px;}\n  &:disabled{opacity:0.4;cursor:not-allowed;}\n`;\nconst ArrowPrev = styled(ArrowBtn)`left:${tokens.space.sm};`;\nconst ArrowNext = styled(ArrowBtn)`right:${tokens.space.sm};`;\n\nconst Dot = styled.button<{ active: boolean }>`\n  width:${({ active }) => (active ? '20px' : '8px')};height:8px;\n  border-radius:${tokens.radius.full};\n  background-color:${({ active }) => (active ? tokens.color.brand : tokens.color.border)};\n  border:none;cursor:pointer;padding:0;\n  transition:background-color ${tokens.transition.fast},width ${tokens.transition.fast};\n  &:focus-visible{outline:2px solid ${tokens.color.borderFocus};outline-offset:2px;}\n`;\nconst Dots = styled.div`display:flex;justify-content:center;gap:${tokens.space.sm};margin-top:${tokens.space.sm};`;\n\nexport function Carousel({\n  children,\n  autoplay = false,\n  autoplayMs = 4000,\n  pauseOnHover = true,\n  showArrows = true,\n  showDots = true,\n  loop = false,\n  slidesPerView = 1,\n  gap,\n  onSlideChange,\n}: CarouselProps) {\n  const gapPx = gap ? (GAP_PX[gap as string] ?? 0) : 0;\n  const [spv, setSpv] = useState(1);\n  const [emblaRef, emblaApi] = useEmblaCarousel({ loop, slidesToScroll: spv, align: 'start' });\n  const [selectedIndex, setSelectedIndex] = useState(0);\n  const [scrollSnaps, setScrollSnaps] = useState<number[]>([]);\n  const [hovered, setHovered] = useState(false);\n\n  const slidesPerViewRef = useRef(slidesPerView);\n  slidesPerViewRef.current = slidesPerView;\n  const gapPxRef = useRef(gapPx);\n  gapPxRef.current = gapPx;\n\n  const containerRef = useRef<HTMLDivElement>(null);\n\n  // Use ResizeObserver on the container — reliable in iframes and custom viewports\n  useEffect(() => {\n    const el = containerRef.current;\n    if (!el) return;\n    const ro = new ResizeObserver(([entry]) => {\n      const width = entry.contentRect.width;\n      setSpv(getSpv(slidesPerViewRef.current, width, gapPxRef.current));\n    });\n    ro.observe(el);\n    return () => ro.disconnect();\n  }, []);\n\n  const onSelect = useCallback(() => {\n    if (!emblaApi) return;\n    const index = emblaApi.selectedScrollSnap();\n    setSelectedIndex(index);\n    onSlideChange?.(index);\n  }, [emblaApi, onSlideChange]);\n\n  useEffect(() => {\n    if (!emblaApi) return;\n    setScrollSnaps(emblaApi.scrollSnapList());\n    emblaApi.on('select', onSelect);\n    emblaApi.on('reInit', onSelect);\n    return () => {\n      emblaApi.off('select', onSelect);\n      emblaApi.off('reInit', onSelect);\n    };\n  }, [emblaApi, onSelect]);\n\n  useEffect(() => {\n    emblaApi?.reInit();\n  }, [emblaApi, spv]);\n\n  useEffect(() => {\n    if (!autoplay || !emblaApi) return;\n    if (pauseOnHover && hovered) return;\n    const id = setInterval(() => emblaApi.scrollNext(), autoplayMs);\n    return () => clearInterval(id);\n  }, [autoplay, autoplayMs, emblaApi, pauseOnHover, hovered]);\n\n  const slideWidth = `calc((100% - ${gapPx * (spv - 1)}px) / ${spv})`;\n  const centered = children.length < spv;\n\n  return (\n    <div\n      ref={containerRef}\n      style={{ position: 'relative', width: '100%' }}\n      onMouseEnter={() => setHovered(true)}\n      onMouseLeave={() => setHovered(false)}\n    >\n      <div ref={emblaRef} style={{ overflow: 'hidden' }}>\n        <div style={{ display: 'flex', gap: gapPx, justifyContent: centered ? 'center' : 'flex-start' }}>\n          {children.map((child, i) => (\n            <div key={i} style={{ flex: `0 0 ${slideWidth}`, minWidth: 0 }}>\n              {child}\n            </div>\n          ))}\n        </div>\n      </div>\n      {showArrows && (\n        <>\n          <ArrowPrev\n            type=\"button\"\n            aria-label=\"Slide anterior\"\n            onClick={() => emblaApi?.scrollPrev()}\n          >\n            <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" aria-hidden=\"true\">\n              <path\n                d=\"M10 12L6 8l4-4\"\n                stroke=\"currentColor\"\n                strokeWidth=\"1.5\"\n                strokeLinecap=\"round\"\n                strokeLinejoin=\"round\"\n              />\n            </svg>\n          </ArrowPrev>\n          <ArrowNext\n            type=\"button\"\n            aria-label=\"Slide siguiente\"\n            onClick={() => emblaApi?.scrollNext()}\n          >\n            <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" aria-hidden=\"true\">\n              <path\n                d=\"M6 4l4 4-4 4\"\n                stroke=\"currentColor\"\n                strokeWidth=\"1.5\"\n                strokeLinecap=\"round\"\n                strokeLinejoin=\"round\"\n              />\n            </svg>\n          </ArrowNext>\n        </>\n      )}\n      {showDots && (\n        <Dots>\n          {scrollSnaps.map((_, i) => (\n            <Dot\n              key={i}\n              active={i === selectedIndex}\n              type=\"button\"\n              onClick={() => emblaApi?.scrollTo(i)}\n              aria-label={`Ir al slide ${i + 1}`}\n            />\n          ))}\n        </Dots>\n      )}\n    </div>\n  );\n}\n"]} */")), M = /* @__PURE__ */ V("div", process.env.NODE_ENV === "production" ? {
45
+ target: "e4oxflb0"
46
+ } : {
47
+ target: "e4oxflb0",
48
+ label: "Dots"
49
+ })("display:flex;justify-content:center;gap:", C.space.sm, ";margin-top:", C.space.sm, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/Users/macbook/Documents/cencosud/jumbo/lib/packages/ui-core/src/components/Carousel/Carousel.tsx"],"names":[],"mappings":"AA8DuB","file":"/Users/macbook/Documents/cencosud/jumbo/lib/packages/ui-core/src/components/Carousel/Carousel.tsx","sourcesContent":["import { tokens } from '@danielcruzcode/design-tokens';\nimport styled from '@emotion/styled';\nimport useEmblaCarousel from 'embla-carousel-react';\nimport type React from 'react';\nimport { useCallback, useEffect, useRef, useState } from 'react';\n\ntype SlidesPerView =\n  | number\n  | { mobile: number; tablet: number; wide?: number; desktop: number }\n  | { min: number; max?: number };\n\nexport interface CarouselProps {\n  children: React.ReactNode[];\n  autoplay?: boolean;\n  autoplayMs?: number;\n  pauseOnHover?: boolean;\n  showArrows?: boolean;\n  showDots?: boolean;\n  loop?: boolean;\n  slidesPerView?: SlidesPerView;\n  slidesPerGroup?: number;\n  gap?: keyof typeof tokens.space;\n  onSlideChange?: (index: number) => void;\n}\n\nconst GAP_PX: Record<string, number> = { sm: 8, md: 16, lg: 24, xl: 32 };\n\nfunction getSpv(slidesPerView: SlidesPerView, width: number, gapPx: number): number {\n  if (typeof slidesPerView === 'number') return slidesPerView;\n  if ('min' in slidesPerView) {\n    const count = Math.floor((width + gapPx) / (slidesPerView.min + gapPx));\n    const clamped = Math.max(1, count);\n    return slidesPerView.max !== undefined ? Math.min(clamped, slidesPerView.max) : clamped;\n  }\n  if (width >= 1024) return slidesPerView.desktop;\n  if (width >= 900 && slidesPerView.wide !== undefined) return slidesPerView.wide;\n  if (width >= 640) return slidesPerView.tablet;\n  return slidesPerView.mobile;\n}\n\nconst ArrowBtn = styled.button`\n  position:absolute;top:50%;transform:translateY(-50%);z-index:10;\n  display:flex;align-items:center;justify-content:center;\n  width:36px;height:36px;border-radius:${tokens.radius.full};\n  border:1px solid ${tokens.color.border};background-color:${tokens.color.background};\n  color:${tokens.color.text};cursor:pointer;box-shadow:${tokens.shadow.sm};\n  transition:box-shadow ${tokens.transition.fast};\n  &:hover{box-shadow:${tokens.shadow.md};}\n  &:focus-visible{outline:2px solid ${tokens.color.borderFocus};outline-offset:2px;}\n  &:disabled{opacity:0.4;cursor:not-allowed;}\n`;\nconst ArrowPrev = styled(ArrowBtn)`left:${tokens.space.sm};`;\nconst ArrowNext = styled(ArrowBtn)`right:${tokens.space.sm};`;\n\nconst Dot = styled.button<{ active: boolean }>`\n  width:${({ active }) => (active ? '20px' : '8px')};height:8px;\n  border-radius:${tokens.radius.full};\n  background-color:${({ active }) => (active ? tokens.color.brand : tokens.color.border)};\n  border:none;cursor:pointer;padding:0;\n  transition:background-color ${tokens.transition.fast},width ${tokens.transition.fast};\n  &:focus-visible{outline:2px solid ${tokens.color.borderFocus};outline-offset:2px;}\n`;\nconst Dots = styled.div`display:flex;justify-content:center;gap:${tokens.space.sm};margin-top:${tokens.space.sm};`;\n\nexport function Carousel({\n  children,\n  autoplay = false,\n  autoplayMs = 4000,\n  pauseOnHover = true,\n  showArrows = true,\n  showDots = true,\n  loop = false,\n  slidesPerView = 1,\n  gap,\n  onSlideChange,\n}: CarouselProps) {\n  const gapPx = gap ? (GAP_PX[gap as string] ?? 0) : 0;\n  const [spv, setSpv] = useState(1);\n  const [emblaRef, emblaApi] = useEmblaCarousel({ loop, slidesToScroll: spv, align: 'start' });\n  const [selectedIndex, setSelectedIndex] = useState(0);\n  const [scrollSnaps, setScrollSnaps] = useState<number[]>([]);\n  const [hovered, setHovered] = useState(false);\n\n  const slidesPerViewRef = useRef(slidesPerView);\n  slidesPerViewRef.current = slidesPerView;\n  const gapPxRef = useRef(gapPx);\n  gapPxRef.current = gapPx;\n\n  const containerRef = useRef<HTMLDivElement>(null);\n\n  // Use ResizeObserver on the container — reliable in iframes and custom viewports\n  useEffect(() => {\n    const el = containerRef.current;\n    if (!el) return;\n    const ro = new ResizeObserver(([entry]) => {\n      const width = entry.contentRect.width;\n      setSpv(getSpv(slidesPerViewRef.current, width, gapPxRef.current));\n    });\n    ro.observe(el);\n    return () => ro.disconnect();\n  }, []);\n\n  const onSelect = useCallback(() => {\n    if (!emblaApi) return;\n    const index = emblaApi.selectedScrollSnap();\n    setSelectedIndex(index);\n    onSlideChange?.(index);\n  }, [emblaApi, onSlideChange]);\n\n  useEffect(() => {\n    if (!emblaApi) return;\n    setScrollSnaps(emblaApi.scrollSnapList());\n    emblaApi.on('select', onSelect);\n    emblaApi.on('reInit', onSelect);\n    return () => {\n      emblaApi.off('select', onSelect);\n      emblaApi.off('reInit', onSelect);\n    };\n  }, [emblaApi, onSelect]);\n\n  useEffect(() => {\n    emblaApi?.reInit();\n  }, [emblaApi, spv]);\n\n  useEffect(() => {\n    if (!autoplay || !emblaApi) return;\n    if (pauseOnHover && hovered) return;\n    const id = setInterval(() => emblaApi.scrollNext(), autoplayMs);\n    return () => clearInterval(id);\n  }, [autoplay, autoplayMs, emblaApi, pauseOnHover, hovered]);\n\n  const slideWidth = `calc((100% - ${gapPx * (spv - 1)}px) / ${spv})`;\n  const centered = children.length < spv;\n\n  return (\n    <div\n      ref={containerRef}\n      style={{ position: 'relative', width: '100%' }}\n      onMouseEnter={() => setHovered(true)}\n      onMouseLeave={() => setHovered(false)}\n    >\n      <div ref={emblaRef} style={{ overflow: 'hidden' }}>\n        <div style={{ display: 'flex', gap: gapPx, justifyContent: centered ? 'center' : 'flex-start' }}>\n          {children.map((child, i) => (\n            <div key={i} style={{ flex: `0 0 ${slideWidth}`, minWidth: 0 }}>\n              {child}\n            </div>\n          ))}\n        </div>\n      </div>\n      {showArrows && (\n        <>\n          <ArrowPrev\n            type=\"button\"\n            aria-label=\"Slide anterior\"\n            onClick={() => emblaApi?.scrollPrev()}\n          >\n            <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" aria-hidden=\"true\">\n              <path\n                d=\"M10 12L6 8l4-4\"\n                stroke=\"currentColor\"\n                strokeWidth=\"1.5\"\n                strokeLinecap=\"round\"\n                strokeLinejoin=\"round\"\n              />\n            </svg>\n          </ArrowPrev>\n          <ArrowNext\n            type=\"button\"\n            aria-label=\"Slide siguiente\"\n            onClick={() => emblaApi?.scrollNext()}\n          >\n            <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" aria-hidden=\"true\">\n              <path\n                d=\"M6 4l4 4-4 4\"\n                stroke=\"currentColor\"\n                strokeWidth=\"1.5\"\n                strokeLinecap=\"round\"\n                strokeLinejoin=\"round\"\n              />\n            </svg>\n          </ArrowNext>\n        </>\n      )}\n      {showDots && (\n        <Dots>\n          {scrollSnaps.map((_, i) => (\n            <Dot\n              key={i}\n              active={i === selectedIndex}\n              type=\"button\"\n              onClick={() => emblaApi?.scrollTo(i)}\n              aria-label={`Ir al slide ${i + 1}`}\n            />\n          ))}\n        </Dots>\n      )}\n    </div>\n  );\n}\n"]} */"));
50
+ function II({
51
+ children: g,
52
+ autoplay: G = !1,
53
+ autoplayMs: l = 4e3,
54
+ pauseOnHover: X = !0,
55
+ showArrows: W = !0,
56
+ showDots: s = !0,
57
+ loop: v = !1,
58
+ slidesPerView: Y = 1,
59
+ gap: y,
60
+ onSlideChange: m
40
61
  }) {
41
- var w;
42
- const v = b && (w = X[b]) != null ? w : 0, [B, t] = G({ loop: R, slidesToScroll: W, align: "start" }), [C, E] = a(0), [F, M] = a([]), [m, $] = a(!1), k = S(x);
43
- k.current = x;
44
- const g = S(null), [f, N] = a(1);
45
- u(() => {
46
- const n = g.current;
47
- if (!n) return;
48
- const s = new ResizeObserver(([D]) => {
49
- const T = D.contentRect.width;
50
- N(Y(k.current, T));
62
+ var R;
63
+ const i = y && (R = D[y]) != null ? R : 0, [Z, o] = u(1), [h, I] = O({
64
+ loop: v,
65
+ slidesToScroll: Z,
66
+ align: "start"
67
+ }), [z, k] = u(0), [F, w] = u([]), [t, N] = u(!1), J = x(Y);
68
+ J.current = Y;
69
+ const p = x(i);
70
+ p.current = i;
71
+ const n = x(null);
72
+ B(() => {
73
+ const c = n.current;
74
+ if (!c) return;
75
+ const A = new ResizeObserver(([Q]) => {
76
+ const U = Q.contentRect.width;
77
+ o(P(J.current, U, p.current));
51
78
  });
52
- return s.observe(n), () => s.disconnect();
79
+ return A.observe(c), () => A.disconnect();
53
80
  }, []);
54
- const l = P(() => {
55
- if (!t) return;
56
- const n = t.selectedScrollSnap();
57
- E(n), d == null || d(n);
58
- }, [t, d]);
59
- u(() => {
60
- if (t)
61
- return M(t.scrollSnapList()), t.on("select", l), t.on("reInit", l), () => {
62
- t.off("select", l), t.off("reInit", l);
81
+ const d = T(() => {
82
+ if (!I) return;
83
+ const c = I.selectedScrollSnap();
84
+ k(c), m == null || m(c);
85
+ }, [I, m]);
86
+ B(() => {
87
+ if (I)
88
+ return w(I.scrollSnapList()), I.on("select", d), I.on("reInit", d), () => {
89
+ I.off("select", d), I.off("reInit", d);
63
90
  };
64
- }, [t, l]), u(() => {
65
- t == null || t.reInit();
66
- }, [t, f]), u(() => {
67
- if (!i || !t || h && m) return;
68
- const n = setInterval(() => t.scrollNext(), p);
69
- return () => clearInterval(n);
70
- }, [i, p, t, h, m]);
71
- const z = `calc((100% - ${v * (f - 1)}px) / ${f})`;
72
- return /* @__PURE__ */ y(
73
- "div",
74
- {
75
- ref: g,
76
- style: { position: "relative", width: "100%" },
77
- onMouseEnter: () => $(!0),
78
- onMouseLeave: () => $(!1),
79
- children: [
80
- /* @__PURE__ */ o("div", { ref: B, style: { overflow: "hidden" }, children: /* @__PURE__ */ o("div", { style: { display: "flex", gap: v }, children: r.map((n, s) => /* @__PURE__ */ o("div", { style: { flex: `0 0 ${z}`, minWidth: 0 }, children: n }, s)) }) }),
81
- L && /* @__PURE__ */ y(_, { children: [
82
- /* @__PURE__ */ o(q, { type: "button", "aria-label": "Slide anterior", onClick: () => t == null ? void 0 : t.scrollPrev(), children: /* @__PURE__ */ o("svg", { width: "16", height: "16", viewBox: "0 0 16 16", fill: "none", "aria-hidden": "true", children: /* @__PURE__ */ o("path", { d: "M10 12L6 8l4-4", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round", strokeLinejoin: "round" }) }) }),
83
- /* @__PURE__ */ o(H, { type: "button", "aria-label": "Slide siguiente", onClick: () => t == null ? void 0 : t.scrollNext(), children: /* @__PURE__ */ o("svg", { width: "16", height: "16", viewBox: "0 0 16 16", fill: "none", "aria-hidden": "true", children: /* @__PURE__ */ o("path", { d: "M6 4l4 4-4 4", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round", strokeLinejoin: "round" }) }) })
84
- ] }),
85
- j && /* @__PURE__ */ o(K, { children: F.map((n, s) => /* @__PURE__ */ o(J, { active: s === C, type: "button", onClick: () => t == null ? void 0 : t.scrollTo(s), "aria-label": `Ir al slide ${s + 1}` }, s)) })
86
- ]
87
- }
88
- );
91
+ }, [I, d]), B(() => {
92
+ I == null || I.reInit();
93
+ }, [I, Z]), B(() => {
94
+ if (!G || !I || X && t) return;
95
+ const c = setInterval(() => I.scrollNext(), l);
96
+ return () => clearInterval(c);
97
+ }, [G, l, I, X, t]);
98
+ const e = `calc((100% - ${i * (Z - 1)}px) / ${Z})`, j = g.length < Z;
99
+ return /* @__PURE__ */ a("div", { ref: n, style: {
100
+ position: "relative",
101
+ width: "100%"
102
+ }, onMouseEnter: () => N(!0), onMouseLeave: () => N(!1), children: [
103
+ /* @__PURE__ */ b("div", { ref: h, style: {
104
+ overflow: "hidden"
105
+ }, children: /* @__PURE__ */ b("div", { style: {
106
+ display: "flex",
107
+ gap: i,
108
+ justifyContent: j ? "center" : "flex-start"
109
+ }, children: g.map((c, A) => /* @__PURE__ */ b("div", { style: {
110
+ flex: `0 0 ${e}`,
111
+ minWidth: 0
112
+ }, children: c }, A)) }) }),
113
+ W && /* @__PURE__ */ a(S, { children: [
114
+ /* @__PURE__ */ b(L, { type: "button", "aria-label": "Slide anterior", onClick: () => I == null ? void 0 : I.scrollPrev(), children: /* @__PURE__ */ b("svg", { width: "16", height: "16", viewBox: "0 0 16 16", fill: "none", "aria-hidden": "true", children: /* @__PURE__ */ b("path", { d: "M10 12L6 8l4-4", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round", strokeLinejoin: "round" }) }) }),
115
+ /* @__PURE__ */ b(r, { type: "button", "aria-label": "Slide siguiente", onClick: () => I == null ? void 0 : I.scrollNext(), children: /* @__PURE__ */ b("svg", { width: "16", height: "16", viewBox: "0 0 16 16", fill: "none", "aria-hidden": "true", children: /* @__PURE__ */ b("path", { d: "M6 4l4 4-4 4", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round", strokeLinejoin: "round" }) }) })
116
+ ] }),
117
+ s && /* @__PURE__ */ b(M, { children: F.map((c, A) => /* @__PURE__ */ b(K, { active: A === z, type: "button", onClick: () => I == null ? void 0 : I.scrollTo(A), "aria-label": `Ir al slide ${A + 1}` }, A)) })
118
+ ] });
89
119
  }
90
120
  export {
91
- V as Carousel
121
+ II as Carousel
92
122
  };