@envive-ai/react-toolkit 0.2.2 → 0.2.4

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 (158) hide show
  1. package/dist/Accordion/index.cjs +4 -0
  2. package/dist/Accordion/index.d.cts +13 -0
  3. package/dist/Accordion/index.d.ts +13 -0
  4. package/dist/Accordion/index.js +4 -0
  5. package/dist/Accordion-DxtXK__u.js +77 -0
  6. package/dist/Accordion-RpyCFs2a.cjs +88 -0
  7. package/dist/AnimatedChevron/index.cjs +3 -0
  8. package/dist/AnimatedChevron/index.d.cts +14 -0
  9. package/dist/AnimatedChevron/index.d.ts +14 -0
  10. package/dist/AnimatedChevron/index.js +3 -0
  11. package/dist/AnimatedChevron-Bik7GMSe.js +29 -0
  12. package/dist/AnimatedChevron-Q96FneFy.cjs +37 -0
  13. package/dist/AppliedFiltersScrollbar/index.cjs +46 -0
  14. package/dist/AppliedFiltersScrollbar/index.d.cts +22 -0
  15. package/dist/AppliedFiltersScrollbar/index.d.ts +22 -0
  16. package/dist/AppliedFiltersScrollbar/index.js +42 -0
  17. package/dist/ButtonBase/index.cjs +6 -0
  18. package/dist/ButtonBase/index.d.cts +42 -0
  19. package/dist/ButtonBase/index.d.ts +42 -0
  20. package/dist/ButtonBase/index.js +5 -0
  21. package/dist/ButtonBase-6wjsZ1tU.js +60 -0
  22. package/dist/ButtonBase-AU23oGQr.cjs +75 -0
  23. package/dist/ButtonBase-C_uKnl48.js +1 -0
  24. package/dist/ButtonBase-DbWQ25n-.cjs +0 -0
  25. package/dist/DynamicFiltersScrollbar/index.cjs +34 -0
  26. package/dist/DynamicFiltersScrollbar/index.d.cts +28 -0
  27. package/dist/DynamicFiltersScrollbar/index.d.ts +28 -0
  28. package/dist/DynamicFiltersScrollbar/index.js +30 -0
  29. package/dist/DynamicFiltersScrollbar-50i_InZz.cjs +81 -0
  30. package/dist/DynamicFiltersScrollbar-AhyHehrB.js +66 -0
  31. package/dist/FilterScrollbar/index.cjs +5 -0
  32. package/dist/FilterScrollbar/index.d.cts +47 -0
  33. package/dist/FilterScrollbar/index.d.ts +47 -0
  34. package/dist/FilterScrollbar/index.js +4 -0
  35. package/dist/ImageWithFallback/index.cjs +3 -0
  36. package/dist/ImageWithFallback/index.d.cts +26 -0
  37. package/dist/ImageWithFallback/index.d.ts +26 -0
  38. package/dist/ImageWithFallback/index.js +3 -0
  39. package/dist/ImageWithFallback-1LqhQK1q.cjs +51 -0
  40. package/dist/ImageWithFallback-Ckwsmd8P.js +42 -0
  41. package/dist/ModalSheet/index.cjs +4 -0
  42. package/dist/ModalSheet/index.d.cts +38 -0
  43. package/dist/ModalSheet/index.d.ts +38 -0
  44. package/dist/ModalSheet/index.js +4 -0
  45. package/dist/ModalSheet-BSj_g9JF.js +302 -0
  46. package/dist/ModalSheet-CcthFeMD.cjs +313 -0
  47. package/dist/ProductCard/index.cjs +15 -0
  48. package/dist/ProductCard/index.d.cts +2 -0
  49. package/dist/ProductCard/index.d.ts +2 -0
  50. package/dist/ProductCard/index.js +6 -0
  51. package/dist/ProductCard-BIlnM2nV.js +254 -0
  52. package/dist/ProductCard-CByKIsUN.cjs +318 -0
  53. package/dist/ProductGrid/index.cjs +8 -0
  54. package/dist/ProductGrid/index.d.cts +33 -0
  55. package/dist/ProductGrid/index.d.ts +33 -0
  56. package/dist/ProductGrid/index.js +7 -0
  57. package/dist/ProductGrid-BeFeluHo.cjs +74 -0
  58. package/dist/ProductGrid-Cgkb4vNf.js +60 -0
  59. package/dist/RadioButton/index.cjs +4 -0
  60. package/dist/RadioButton/index.d.cts +32 -0
  61. package/dist/RadioButton/index.d.ts +32 -0
  62. package/dist/RadioButton/index.js +4 -0
  63. package/dist/RadioButton-C_soBi7w.js +75 -0
  64. package/dist/RadioButton-DG0PgZbz.cjs +84 -0
  65. package/dist/RadioButtonGroup/index.cjs +6 -0
  66. package/dist/RadioButtonGroup/index.d.cts +36 -0
  67. package/dist/RadioButtonGroup/index.d.ts +36 -0
  68. package/dist/RadioButtonGroup/index.js +5 -0
  69. package/dist/RadioButtonGroup-3t2kqSFA.cjs +52 -0
  70. package/dist/RadioButtonGroup-DMbVgPQH.js +38 -0
  71. package/dist/SearchAutocomplete/index.cjs +3 -0
  72. package/dist/SearchAutocomplete/index.d.cts +13 -0
  73. package/dist/SearchAutocomplete/index.d.ts +13 -0
  74. package/dist/SearchAutocomplete/index.js +3 -0
  75. package/dist/SearchAutocomplete-TX8UTczp.cjs +62 -0
  76. package/dist/SearchAutocomplete-obO19yzL.js +51 -0
  77. package/dist/SearchFilter/index.cjs +17 -0
  78. package/dist/SearchFilter/index.d.cts +91 -0
  79. package/dist/SearchFilter/index.d.ts +91 -0
  80. package/dist/SearchFilter/index.js +12 -0
  81. package/dist/SearchFilter-BQW4o3Xf.js +268 -0
  82. package/dist/SearchFilter-t9or-lnj.cjs +307 -0
  83. package/dist/SearchInput/index.cjs +8 -0
  84. package/dist/SearchInput/index.d.cts +34 -0
  85. package/dist/SearchInput/index.d.ts +34 -0
  86. package/dist/SearchInput/index.js +7 -0
  87. package/dist/SearchInput-BaiWd0_O.js +108 -0
  88. package/dist/SearchInput-CO1poiit.cjs +124 -0
  89. package/dist/SearchInputForm/index.cjs +40 -0
  90. package/dist/SearchInputForm/index.d.cts +34 -0
  91. package/dist/SearchInputForm/index.d.ts +34 -0
  92. package/dist/SearchInputForm/index.js +38 -0
  93. package/dist/SearchResultsContent/index.cjs +44 -0
  94. package/dist/SearchResultsContent/index.d.cts +48 -0
  95. package/dist/SearchResultsContent/index.d.ts +48 -0
  96. package/dist/SearchResultsContent/index.js +41 -0
  97. package/dist/SearchResultsFilterSidebar/index.cjs +59 -0
  98. package/dist/SearchResultsFilterSidebar/index.d.cts +2 -0
  99. package/dist/SearchResultsFilterSidebar/index.d.ts +2 -0
  100. package/dist/SearchResultsFilterSidebar/index.js +55 -0
  101. package/dist/SearchResultsStates/index.cjs +14 -0
  102. package/dist/SearchResultsStates/index.d.cts +69 -0
  103. package/dist/SearchResultsStates/index.d.ts +69 -0
  104. package/dist/SearchResultsStates/index.js +12 -0
  105. package/dist/SearchResultsStates-Bv5NyxPn.cjs +132 -0
  106. package/dist/SearchResultsStates-DUG-117h.js +110 -0
  107. package/dist/SettingsVariant-BsBbdjV5.cjs +63 -0
  108. package/dist/SettingsVariant-CUSFlJEu.js +55 -0
  109. package/dist/SparkleAnimation/index.cjs +4 -0
  110. package/dist/SparkleAnimation/index.d.cts +23 -0
  111. package/dist/SparkleAnimation/index.d.ts +23 -0
  112. package/dist/SparkleAnimation/index.js +3 -0
  113. package/dist/SparkleAnimation-Bm3fk2FJ.cjs +101 -0
  114. package/dist/SparkleAnimation-D1QjYho_.js +84 -0
  115. package/dist/Spinner/index.cjs +3 -0
  116. package/dist/Spinner/index.d.cts +11 -0
  117. package/dist/Spinner/index.d.ts +11 -0
  118. package/dist/Spinner/index.js +3 -0
  119. package/dist/Spinner-BqTt55uu.js +38 -0
  120. package/dist/Spinner-DjK8ts9E.cjs +46 -0
  121. package/dist/SuggestionButton/index.cjs +187 -0
  122. package/dist/SuggestionButton/index.d.cts +35 -0
  123. package/dist/SuggestionButton/index.d.ts +35 -0
  124. package/dist/SuggestionButton/index.js +179 -0
  125. package/dist/TextInput/index.cjs +4 -0
  126. package/dist/TextInput/index.d.cts +13 -0
  127. package/dist/TextInput/index.d.ts +13 -0
  128. package/dist/TextInput/index.js +4 -0
  129. package/dist/TextInput-B_4Bu2vf.js +31 -0
  130. package/dist/TextInput-iAKCKHwT.cjs +40 -0
  131. package/dist/ToggleButton/index.cjs +4 -0
  132. package/dist/ToggleButton/index.d.cts +30 -0
  133. package/dist/ToggleButton/index.d.ts +30 -0
  134. package/dist/ToggleButton/index.js +4 -0
  135. package/dist/ToggleButton-Br6MgjiG.js +60 -0
  136. package/dist/ToggleButton-CJ74eu-N.cjs +68 -0
  137. package/dist/Typography/index.cjs +6 -0
  138. package/dist/Typography/index.d.cts +3 -0
  139. package/dist/Typography/index.d.ts +3 -0
  140. package/dist/Typography/index.js +3 -0
  141. package/dist/Typography-CFNWgbM5.cjs +176 -0
  142. package/dist/Typography-D3vDkBMS.js +150 -0
  143. package/dist/chunk-CUT6urMc.cjs +30 -0
  144. package/dist/colorsConfig-D-MZuBvt.cjs +38 -0
  145. package/dist/colorsConfig-DEfiLHH0.js +26 -0
  146. package/dist/index-B5p2z61Y.d.ts +325 -0
  147. package/dist/index-BH-QK27q.d.ts +31 -0
  148. package/dist/index-BMHF0IWd.d.cts +31 -0
  149. package/dist/index-BcvJf9Sr.d.ts +46 -0
  150. package/dist/index-DDp-fLgm.d.cts +325 -0
  151. package/dist/index-Dfe_lkL2.d.cts +46 -0
  152. package/dist/searchFilterSidebarVariants-BD4SYugF.js +34 -0
  153. package/dist/searchFilterSidebarVariants-DXabOauB.cjs +39 -0
  154. package/dist/types-BhGjnuWx.d.cts +4 -0
  155. package/dist/types-CGRog8XL.d.ts +4 -0
  156. package/dist/typographyVariantClasses-COmQXqcN.d.ts +119 -0
  157. package/dist/typographyVariantClasses-DTSltxPN.d.cts +119 -0
  158. package/package.json +3 -3
@@ -0,0 +1,75 @@
1
+ const require_chunk = require('./chunk-CUT6urMc.cjs');
2
+ const require_Typography = require('./Typography-CFNWgbM5.cjs');
3
+ let react = require("react");
4
+ react = require_chunk.__toESM(react);
5
+ let classnames = require("classnames");
6
+ classnames = require_chunk.__toESM(classnames);
7
+ let react_jsx_runtime = require("react/jsx-runtime");
8
+ react_jsx_runtime = require_chunk.__toESM(react_jsx_runtime);
9
+
10
+ //#region src/components/ButtonBase/types.ts
11
+ let ButtonBaseOverrides = /* @__PURE__ */ function(ButtonBaseOverrides$1) {
12
+ ButtonBaseOverrides$1["BUTTON"] = "spiffy-button-base-button";
13
+ ButtonBaseOverrides$1["BUTTON_TEXT"] = "spiffy-button-base-button-text";
14
+ ButtonBaseOverrides$1["BUTTON_ICON"] = "spiffy-button-base-button-icon";
15
+ return ButtonBaseOverrides$1;
16
+ }({});
17
+
18
+ //#endregion
19
+ //#region src/components/ButtonBase/ButtonBase.tsx
20
+ const ButtonBase = ({ isDisabled = false, dataAttributes, buttonClass, text, textClass, icon, iconClass = "spiffy-tw-w-[21px] spiffy-tw-h-[21px]", dataTestId, onClick, disablePadding = false }) => {
21
+ const buttonRef = (0, react.useRef)(null);
22
+ const buttonClassName = (0, classnames.default)({
23
+ [ButtonBaseOverrides.BUTTON]: true,
24
+ "spiffy-tw-flex": true,
25
+ "spiffy-tw-min-h-[36px]": true,
26
+ "spiffy-tw-cursor-pointer": true,
27
+ "spiffy-tw-items-center": true,
28
+ "spiffy-tw-gap-2": true,
29
+ "spiffy-tw-px-4": !disablePadding,
30
+ "spiffy-tw-transition-colors": true,
31
+ "spiffy-tw-opacity-40": isDisabled,
32
+ "spiffy-tw-cursor-not-allowed": isDisabled,
33
+ [`${buttonClass}`]: buttonClass != null
34
+ });
35
+ const textClassName = (0, classnames.default)({
36
+ [ButtonBaseOverrides.BUTTON_TEXT]: true,
37
+ "spiffy-tw-whitespace-nowrap": true,
38
+ [`${textClass}`]: textClass != null
39
+ });
40
+ const iconClassName = (0, classnames.default)({
41
+ [ButtonBaseOverrides.BUTTON_ICON]: true,
42
+ [`${iconClass}`]: iconClass != null
43
+ });
44
+ (0, react.useEffect)(() => {
45
+ if (dataAttributes && buttonRef.current) Object.entries(dataAttributes).forEach(([key, value]) => {
46
+ buttonRef.current?.setAttribute(key, value);
47
+ });
48
+ }, [dataAttributes]);
49
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("button", {
50
+ type: "button",
51
+ ref: buttonRef,
52
+ className: buttonClassName,
53
+ disabled: isDisabled,
54
+ "data-testid": dataTestId,
55
+ onClick,
56
+ children: [icon && (0, react.createElement)(icon, { className: iconClassName }), /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_Typography.Typography, {
57
+ className: textClassName,
58
+ children: text
59
+ })]
60
+ });
61
+ };
62
+
63
+ //#endregion
64
+ Object.defineProperty(exports, 'ButtonBase', {
65
+ enumerable: true,
66
+ get: function () {
67
+ return ButtonBase;
68
+ }
69
+ });
70
+ Object.defineProperty(exports, 'ButtonBaseOverrides', {
71
+ enumerable: true,
72
+ get: function () {
73
+ return ButtonBaseOverrides;
74
+ }
75
+ });
@@ -0,0 +1 @@
1
+ export { };
File without changes
@@ -0,0 +1,34 @@
1
+ const require_chunk = require('../chunk-CUT6urMc.cjs');
2
+ const require_Typography = require('../Typography-CFNWgbM5.cjs');
3
+ let classnames = require("classnames");
4
+ classnames = require_chunk.__toESM(classnames);
5
+ let react_jsx_runtime = require("react/jsx-runtime");
6
+ react_jsx_runtime = require_chunk.__toESM(react_jsx_runtime);
7
+ let react_indiana_drag_scroll = require("react-indiana-drag-scroll");
8
+ react_indiana_drag_scroll = require_chunk.__toESM(react_indiana_drag_scroll);
9
+
10
+ //#region src/components/DynamicFiltersScrollbar/DynamicFiltersScrollbar.tsx
11
+ const DynamicFiltersScrollbar = ({ availableDynamicFilters, filterBarClassNames, filterDefaultClasses, filterHoverClasses, onToggleDynamicFilter }) => /* @__PURE__ */ (0, react_jsx_runtime.jsx)(react_indiana_drag_scroll.default, {
12
+ className: filterBarClassNames,
13
+ hideScrollbars: true,
14
+ children: availableDynamicFilters.map(({ name, displayName }) => {
15
+ const buttonClasses = (0, classnames.default)("spiffy-tw-px-[12px] spiffy-tw-py-2 spiffy-tw-rounded-full spiffy-tw-border spiffy-tw-whitespace-nowrap ", filterHoverClasses, filterDefaultClasses);
16
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)("button", {
17
+ type: "button",
18
+ className: buttonClasses,
19
+ onClick: () => {
20
+ onToggleDynamicFilter({
21
+ filter: name,
22
+ dynamicFilterDisplayName: displayName
23
+ });
24
+ },
25
+ children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_Typography.Typography, {
26
+ variant: "body3",
27
+ children: displayName
28
+ })
29
+ }, name);
30
+ })
31
+ });
32
+
33
+ //#endregion
34
+ exports.DynamicFiltersScrollbar = DynamicFiltersScrollbar;
@@ -0,0 +1,28 @@
1
+ import * as react_jsx_runtime0 from "react/jsx-runtime";
2
+
3
+ //#region src/components/DynamicFiltersScrollbar/DynamicFiltersScrollbar.d.ts
4
+ interface DynamicFiltersScrollbarProps {
5
+ availableDynamicFilters: {
6
+ name: string;
7
+ displayName: string;
8
+ }[];
9
+ filterBarClassNames: string;
10
+ filterDefaultClasses: string;
11
+ filterHoverClasses: string;
12
+ onToggleDynamicFilter: ({
13
+ filter,
14
+ dynamicFilterDisplayName
15
+ }: {
16
+ filter: string;
17
+ dynamicFilterDisplayName: string;
18
+ }) => void;
19
+ }
20
+ declare const DynamicFiltersScrollbar: ({
21
+ availableDynamicFilters,
22
+ filterBarClassNames,
23
+ filterDefaultClasses,
24
+ filterHoverClasses,
25
+ onToggleDynamicFilter
26
+ }: DynamicFiltersScrollbarProps) => react_jsx_runtime0.JSX.Element;
27
+ //#endregion
28
+ export { DynamicFiltersScrollbar };
@@ -0,0 +1,28 @@
1
+ import * as react_jsx_runtime17 from "react/jsx-runtime";
2
+
3
+ //#region src/components/DynamicFiltersScrollbar/DynamicFiltersScrollbar.d.ts
4
+ interface DynamicFiltersScrollbarProps {
5
+ availableDynamicFilters: {
6
+ name: string;
7
+ displayName: string;
8
+ }[];
9
+ filterBarClassNames: string;
10
+ filterDefaultClasses: string;
11
+ filterHoverClasses: string;
12
+ onToggleDynamicFilter: ({
13
+ filter,
14
+ dynamicFilterDisplayName
15
+ }: {
16
+ filter: string;
17
+ dynamicFilterDisplayName: string;
18
+ }) => void;
19
+ }
20
+ declare const DynamicFiltersScrollbar: ({
21
+ availableDynamicFilters,
22
+ filterBarClassNames,
23
+ filterDefaultClasses,
24
+ filterHoverClasses,
25
+ onToggleDynamicFilter
26
+ }: DynamicFiltersScrollbarProps) => react_jsx_runtime17.JSX.Element;
27
+ //#endregion
28
+ export { DynamicFiltersScrollbar };
@@ -0,0 +1,30 @@
1
+ import { Typography } from "../Typography-D3vDkBMS.js";
2
+ import classNames from "classnames";
3
+ import { jsx } from "react/jsx-runtime";
4
+ import ScrollContainer from "react-indiana-drag-scroll";
5
+
6
+ //#region src/components/DynamicFiltersScrollbar/DynamicFiltersScrollbar.tsx
7
+ const DynamicFiltersScrollbar = ({ availableDynamicFilters, filterBarClassNames, filterDefaultClasses, filterHoverClasses, onToggleDynamicFilter }) => /* @__PURE__ */ jsx(ScrollContainer, {
8
+ className: filterBarClassNames,
9
+ hideScrollbars: true,
10
+ children: availableDynamicFilters.map(({ name, displayName }) => {
11
+ const buttonClasses = classNames("spiffy-tw-px-[12px] spiffy-tw-py-2 spiffy-tw-rounded-full spiffy-tw-border spiffy-tw-whitespace-nowrap ", filterHoverClasses, filterDefaultClasses);
12
+ return /* @__PURE__ */ jsx("button", {
13
+ type: "button",
14
+ className: buttonClasses,
15
+ onClick: () => {
16
+ onToggleDynamicFilter({
17
+ filter: name,
18
+ dynamicFilterDisplayName: displayName
19
+ });
20
+ },
21
+ children: /* @__PURE__ */ jsx(Typography, {
22
+ variant: "body3",
23
+ children: displayName
24
+ })
25
+ }, name);
26
+ })
27
+ });
28
+
29
+ //#endregion
30
+ export { DynamicFiltersScrollbar };
@@ -0,0 +1,81 @@
1
+ const require_chunk = require('./chunk-CUT6urMc.cjs');
2
+ const require_Typography = require('./Typography-CFNWgbM5.cjs');
3
+ let classnames = require("classnames");
4
+ classnames = require_chunk.__toESM(classnames);
5
+ let react_jsx_runtime = require("react/jsx-runtime");
6
+ react_jsx_runtime = require_chunk.__toESM(react_jsx_runtime);
7
+ let react_indiana_drag_scroll = require("react-indiana-drag-scroll");
8
+ react_indiana_drag_scroll = require_chunk.__toESM(react_indiana_drag_scroll);
9
+
10
+ //#region src/components/FilterScrollbar/AppliedFiltersScrollbar.tsx
11
+ const AppliedFiltersScrollbar = ({ selectedFilterOptions, filterBarClassNames, filterDefaultClasses, filterHoverClasses, appliedFilterBackgroundClasses, onRemoveFilter }) => {
12
+ if (selectedFilterOptions.length === 0) return null;
13
+ const filterDefaultWithoutBg = filterDefaultClasses.replace(/spiffy-tw-bg-\[--spiffy-colors-[^\]]+\]/g, "").trim();
14
+ const buttonClasses = (0, classnames.default)(" spiffy-tw-flex spiffy-tw-items-center spiffy-tw-rounded-full spiffy-tw-px-[8px] spiffy-tw-py-[4px] spiffy-tw-whitespace-nowrap", filterHoverClasses, filterDefaultWithoutBg, appliedFilterBackgroundClasses);
15
+ const iconColor = "currentColor";
16
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(react_indiana_drag_scroll.default, {
17
+ className: filterBarClassNames,
18
+ hideScrollbars: true,
19
+ children: selectedFilterOptions.map((filter) => /* @__PURE__ */ (0, react_jsx_runtime.jsx)("button", {
20
+ className: buttonClasses,
21
+ type: "button",
22
+ onClick: () => onRemoveFilter(filter),
23
+ "aria-label": `Remove filter: ${filter.displayName}`,
24
+ children: /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
25
+ className: "spiffy-tw-flex spiffy-tw-items-center spiffy-tw-gap-[8px]",
26
+ children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_Typography.Typography, {
27
+ variant: "body3",
28
+ children: filter.displayName
29
+ }), /* @__PURE__ */ (0, react_jsx_runtime.jsx)("svg", {
30
+ xmlns: "http://www.w3.org/2000/svg",
31
+ width: "10",
32
+ height: "10",
33
+ viewBox: "0 0 10 10",
34
+ fill: "none",
35
+ children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)("path", {
36
+ d: "M4.59766 4.29297L8.48535 0.405273L9.19238 1.1123L5.30469 5L9.19238 8.8877L8.48535 9.59473L4.59766 5.70703L0.707031 9.59766L0 8.89062L3.89062 5L0 1.10938L0.707031 0.402344L4.59766 4.29297Z",
37
+ fill: iconColor
38
+ })
39
+ })]
40
+ })
41
+ }, filter.id))
42
+ });
43
+ };
44
+
45
+ //#endregion
46
+ //#region src/components/FilterScrollbar/DynamicFiltersScrollbar.tsx
47
+ const DynamicFiltersScrollbar = ({ availableDynamicFilters, filterBarClassNames, filterDefaultClasses, filterHoverClasses, onToggleDynamicFilter }) => /* @__PURE__ */ (0, react_jsx_runtime.jsx)(react_indiana_drag_scroll.default, {
48
+ className: filterBarClassNames,
49
+ hideScrollbars: true,
50
+ children: availableDynamicFilters.map(({ name, displayName }) => {
51
+ const buttonClasses = (0, classnames.default)("spiffy-tw-px-[12px] spiffy-tw-py-2 spiffy-tw-rounded-full spiffy-tw-border spiffy-tw-whitespace-nowrap ", filterHoverClasses, filterDefaultClasses);
52
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)("button", {
53
+ type: "button",
54
+ className: buttonClasses,
55
+ onClick: () => {
56
+ onToggleDynamicFilter({
57
+ filter: name,
58
+ dynamicFilterDisplayName: displayName
59
+ });
60
+ },
61
+ children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_Typography.Typography, {
62
+ variant: "body3",
63
+ children: displayName
64
+ })
65
+ }, name);
66
+ })
67
+ });
68
+
69
+ //#endregion
70
+ Object.defineProperty(exports, 'AppliedFiltersScrollbar', {
71
+ enumerable: true,
72
+ get: function () {
73
+ return AppliedFiltersScrollbar;
74
+ }
75
+ });
76
+ Object.defineProperty(exports, 'DynamicFiltersScrollbar', {
77
+ enumerable: true,
78
+ get: function () {
79
+ return DynamicFiltersScrollbar;
80
+ }
81
+ });
@@ -0,0 +1,66 @@
1
+ import { Typography } from "./Typography-D3vDkBMS.js";
2
+ import classNames from "classnames";
3
+ import { jsx, jsxs } from "react/jsx-runtime";
4
+ import ScrollContainer from "react-indiana-drag-scroll";
5
+
6
+ //#region src/components/FilterScrollbar/AppliedFiltersScrollbar.tsx
7
+ const AppliedFiltersScrollbar = ({ selectedFilterOptions, filterBarClassNames, filterDefaultClasses, filterHoverClasses, appliedFilterBackgroundClasses, onRemoveFilter }) => {
8
+ if (selectedFilterOptions.length === 0) return null;
9
+ const filterDefaultWithoutBg = filterDefaultClasses.replace(/spiffy-tw-bg-\[--spiffy-colors-[^\]]+\]/g, "").trim();
10
+ const buttonClasses = classNames(" spiffy-tw-flex spiffy-tw-items-center spiffy-tw-rounded-full spiffy-tw-px-[8px] spiffy-tw-py-[4px] spiffy-tw-whitespace-nowrap", filterHoverClasses, filterDefaultWithoutBg, appliedFilterBackgroundClasses);
11
+ const iconColor = "currentColor";
12
+ return /* @__PURE__ */ jsx(ScrollContainer, {
13
+ className: filterBarClassNames,
14
+ hideScrollbars: true,
15
+ children: selectedFilterOptions.map((filter) => /* @__PURE__ */ jsx("button", {
16
+ className: buttonClasses,
17
+ type: "button",
18
+ onClick: () => onRemoveFilter(filter),
19
+ "aria-label": `Remove filter: ${filter.displayName}`,
20
+ children: /* @__PURE__ */ jsxs("div", {
21
+ className: "spiffy-tw-flex spiffy-tw-items-center spiffy-tw-gap-[8px]",
22
+ children: [/* @__PURE__ */ jsx(Typography, {
23
+ variant: "body3",
24
+ children: filter.displayName
25
+ }), /* @__PURE__ */ jsx("svg", {
26
+ xmlns: "http://www.w3.org/2000/svg",
27
+ width: "10",
28
+ height: "10",
29
+ viewBox: "0 0 10 10",
30
+ fill: "none",
31
+ children: /* @__PURE__ */ jsx("path", {
32
+ d: "M4.59766 4.29297L8.48535 0.405273L9.19238 1.1123L5.30469 5L9.19238 8.8877L8.48535 9.59473L4.59766 5.70703L0.707031 9.59766L0 8.89062L3.89062 5L0 1.10938L0.707031 0.402344L4.59766 4.29297Z",
33
+ fill: iconColor
34
+ })
35
+ })]
36
+ })
37
+ }, filter.id))
38
+ });
39
+ };
40
+
41
+ //#endregion
42
+ //#region src/components/FilterScrollbar/DynamicFiltersScrollbar.tsx
43
+ const DynamicFiltersScrollbar = ({ availableDynamicFilters, filterBarClassNames, filterDefaultClasses, filterHoverClasses, onToggleDynamicFilter }) => /* @__PURE__ */ jsx(ScrollContainer, {
44
+ className: filterBarClassNames,
45
+ hideScrollbars: true,
46
+ children: availableDynamicFilters.map(({ name, displayName }) => {
47
+ const buttonClasses = classNames("spiffy-tw-px-[12px] spiffy-tw-py-2 spiffy-tw-rounded-full spiffy-tw-border spiffy-tw-whitespace-nowrap ", filterHoverClasses, filterDefaultClasses);
48
+ return /* @__PURE__ */ jsx("button", {
49
+ type: "button",
50
+ className: buttonClasses,
51
+ onClick: () => {
52
+ onToggleDynamicFilter({
53
+ filter: name,
54
+ dynamicFilterDisplayName: displayName
55
+ });
56
+ },
57
+ children: /* @__PURE__ */ jsx(Typography, {
58
+ variant: "body3",
59
+ children: displayName
60
+ })
61
+ }, name);
62
+ })
63
+ });
64
+
65
+ //#endregion
66
+ export { AppliedFiltersScrollbar, DynamicFiltersScrollbar };
@@ -0,0 +1,5 @@
1
+ require('../Typography-CFNWgbM5.cjs');
2
+ const require_DynamicFiltersScrollbar = require('../DynamicFiltersScrollbar-50i_InZz.cjs');
3
+
4
+ exports.AppliedFiltersScrollbar = require_DynamicFiltersScrollbar.AppliedFiltersScrollbar;
5
+ exports.DynamicFiltersScrollbar = require_DynamicFiltersScrollbar.DynamicFiltersScrollbar;
@@ -0,0 +1,47 @@
1
+ import * as react_jsx_runtime23 from "react/jsx-runtime";
2
+ import { SelectedFilterOption } from "@envive-ai/react-hooks/atoms/search";
3
+
4
+ //#region src/components/FilterScrollbar/AppliedFiltersScrollbar.d.ts
5
+ interface AppliedFiltersScrollbarProps {
6
+ selectedFilterOptions: SelectedFilterOption[];
7
+ filterBarClassNames: string;
8
+ filterDefaultClasses: string;
9
+ filterHoverClasses: string;
10
+ appliedFilterBackgroundClasses: string;
11
+ onRemoveFilter: (filter: SelectedFilterOption) => void;
12
+ }
13
+ declare const AppliedFiltersScrollbar: ({
14
+ selectedFilterOptions,
15
+ filterBarClassNames,
16
+ filterDefaultClasses,
17
+ filterHoverClasses,
18
+ appliedFilterBackgroundClasses,
19
+ onRemoveFilter
20
+ }: AppliedFiltersScrollbarProps) => react_jsx_runtime23.JSX.Element;
21
+ //#endregion
22
+ //#region src/components/FilterScrollbar/DynamicFiltersScrollbar.d.ts
23
+ interface DynamicFiltersScrollbarProps {
24
+ availableDynamicFilters: {
25
+ name: string;
26
+ displayName: string;
27
+ }[];
28
+ filterBarClassNames: string;
29
+ filterDefaultClasses: string;
30
+ filterHoverClasses: string;
31
+ onToggleDynamicFilter: ({
32
+ filter,
33
+ dynamicFilterDisplayName
34
+ }: {
35
+ filter: string;
36
+ dynamicFilterDisplayName: string;
37
+ }) => void;
38
+ }
39
+ declare const DynamicFiltersScrollbar: ({
40
+ availableDynamicFilters,
41
+ filterBarClassNames,
42
+ filterDefaultClasses,
43
+ filterHoverClasses,
44
+ onToggleDynamicFilter
45
+ }: DynamicFiltersScrollbarProps) => react_jsx_runtime23.JSX.Element;
46
+ //#endregion
47
+ export { AppliedFiltersScrollbar, DynamicFiltersScrollbar };
@@ -0,0 +1,47 @@
1
+ import * as react_jsx_runtime26 from "react/jsx-runtime";
2
+ import { SelectedFilterOption } from "@envive-ai/react-hooks/atoms/search";
3
+
4
+ //#region src/components/FilterScrollbar/AppliedFiltersScrollbar.d.ts
5
+ interface AppliedFiltersScrollbarProps {
6
+ selectedFilterOptions: SelectedFilterOption[];
7
+ filterBarClassNames: string;
8
+ filterDefaultClasses: string;
9
+ filterHoverClasses: string;
10
+ appliedFilterBackgroundClasses: string;
11
+ onRemoveFilter: (filter: SelectedFilterOption) => void;
12
+ }
13
+ declare const AppliedFiltersScrollbar: ({
14
+ selectedFilterOptions,
15
+ filterBarClassNames,
16
+ filterDefaultClasses,
17
+ filterHoverClasses,
18
+ appliedFilterBackgroundClasses,
19
+ onRemoveFilter
20
+ }: AppliedFiltersScrollbarProps) => react_jsx_runtime26.JSX.Element;
21
+ //#endregion
22
+ //#region src/components/FilterScrollbar/DynamicFiltersScrollbar.d.ts
23
+ interface DynamicFiltersScrollbarProps {
24
+ availableDynamicFilters: {
25
+ name: string;
26
+ displayName: string;
27
+ }[];
28
+ filterBarClassNames: string;
29
+ filterDefaultClasses: string;
30
+ filterHoverClasses: string;
31
+ onToggleDynamicFilter: ({
32
+ filter,
33
+ dynamicFilterDisplayName
34
+ }: {
35
+ filter: string;
36
+ dynamicFilterDisplayName: string;
37
+ }) => void;
38
+ }
39
+ declare const DynamicFiltersScrollbar: ({
40
+ availableDynamicFilters,
41
+ filterBarClassNames,
42
+ filterDefaultClasses,
43
+ filterHoverClasses,
44
+ onToggleDynamicFilter
45
+ }: DynamicFiltersScrollbarProps) => react_jsx_runtime26.JSX.Element;
46
+ //#endregion
47
+ export { AppliedFiltersScrollbar, DynamicFiltersScrollbar };
@@ -0,0 +1,4 @@
1
+ import "../Typography-D3vDkBMS.js";
2
+ import { AppliedFiltersScrollbar, DynamicFiltersScrollbar } from "../DynamicFiltersScrollbar-AhyHehrB.js";
3
+
4
+ export { AppliedFiltersScrollbar, DynamicFiltersScrollbar };
@@ -0,0 +1,3 @@
1
+ const require_ImageWithFallback = require('../ImageWithFallback-1LqhQK1q.cjs');
2
+
3
+ exports.ImageWithFallback = require_ImageWithFallback.ImageWithFallback;
@@ -0,0 +1,26 @@
1
+ import * as react_jsx_runtime9 from "react/jsx-runtime";
2
+ import React from "react";
3
+
4
+ //#region src/components/ImageWithFallback/ImageWithFallback.d.ts
5
+ interface ImageWithFallbackProps {
6
+ src: string | undefined;
7
+ alt: string;
8
+ fallbackClassnames?: string;
9
+ fallback: React.ReactNode;
10
+ dataTestId?: string;
11
+ imageClassnames: string;
12
+ onLoad?: () => void;
13
+ onError?: () => void;
14
+ }
15
+ declare const ImageWithFallback: ({
16
+ src,
17
+ alt,
18
+ dataTestId,
19
+ fallbackClassnames,
20
+ fallback,
21
+ imageClassnames,
22
+ onLoad,
23
+ onError
24
+ }: ImageWithFallbackProps) => react_jsx_runtime9.JSX.Element;
25
+ //#endregion
26
+ export { ImageWithFallback, ImageWithFallbackProps };
@@ -0,0 +1,26 @@
1
+ import React from "react";
2
+ import * as react_jsx_runtime20 from "react/jsx-runtime";
3
+
4
+ //#region src/components/ImageWithFallback/ImageWithFallback.d.ts
5
+ interface ImageWithFallbackProps {
6
+ src: string | undefined;
7
+ alt: string;
8
+ fallbackClassnames?: string;
9
+ fallback: React.ReactNode;
10
+ dataTestId?: string;
11
+ imageClassnames: string;
12
+ onLoad?: () => void;
13
+ onError?: () => void;
14
+ }
15
+ declare const ImageWithFallback: ({
16
+ src,
17
+ alt,
18
+ dataTestId,
19
+ fallbackClassnames,
20
+ fallback,
21
+ imageClassnames,
22
+ onLoad,
23
+ onError
24
+ }: ImageWithFallbackProps) => react_jsx_runtime20.JSX.Element;
25
+ //#endregion
26
+ export { ImageWithFallback, ImageWithFallbackProps };
@@ -0,0 +1,3 @@
1
+ import { ImageWithFallback } from "../ImageWithFallback-Ckwsmd8P.js";
2
+
3
+ export { ImageWithFallback };
@@ -0,0 +1,51 @@
1
+ const require_chunk = require('./chunk-CUT6urMc.cjs');
2
+ let react = require("react");
3
+ react = require_chunk.__toESM(react);
4
+ let classnames = require("classnames");
5
+ classnames = require_chunk.__toESM(classnames);
6
+ let react_jsx_runtime = require("react/jsx-runtime");
7
+ react_jsx_runtime = require_chunk.__toESM(react_jsx_runtime);
8
+
9
+ //#region src/components/ImageWithFallback/ImageWithFallback.tsx
10
+ const ImageWithFallback = ({ src, alt, dataTestId, fallbackClassnames, fallback, imageClassnames, onLoad, onError }) => {
11
+ const [isLoaded, setIsLoaded] = (0, react.useState)(false);
12
+ const [isError, setIsError] = (0, react.useState)(false);
13
+ const imageExtraClassnames = (0, classnames.default)(imageClassnames, {
14
+ "spiffy-tw-block": isLoaded,
15
+ "spiffy-tw-hidden": !isLoaded
16
+ });
17
+ const fallbackMergedClassNames = (0, classnames.default)({
18
+ "spiffy-tw-flex": true,
19
+ "spiffy-tw-flex-col": true,
20
+ "spiffy-tw-items-center": true
21
+ }, fallbackClassnames);
22
+ if (isError) return /* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", {
23
+ className: fallbackMergedClassNames,
24
+ children: fallback
25
+ });
26
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)(react_jsx_runtime.Fragment, { children: [!isLoaded && /* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", {
27
+ className: fallbackMergedClassNames,
28
+ children: fallback
29
+ }), /* @__PURE__ */ (0, react_jsx_runtime.jsx)("img", {
30
+ src,
31
+ className: imageExtraClassnames,
32
+ "data-testid": dataTestId,
33
+ alt,
34
+ onLoad: () => {
35
+ setIsLoaded(true);
36
+ onLoad?.();
37
+ },
38
+ onError: () => {
39
+ setIsError(true);
40
+ onError?.();
41
+ }
42
+ })] });
43
+ };
44
+
45
+ //#endregion
46
+ Object.defineProperty(exports, 'ImageWithFallback', {
47
+ enumerable: true,
48
+ get: function () {
49
+ return ImageWithFallback;
50
+ }
51
+ });
@@ -0,0 +1,42 @@
1
+ import React, { useState } from "react";
2
+ import classNames from "classnames";
3
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
4
+
5
+ //#region src/components/ImageWithFallback/ImageWithFallback.tsx
6
+ const ImageWithFallback = ({ src, alt, dataTestId, fallbackClassnames, fallback, imageClassnames, onLoad, onError }) => {
7
+ const [isLoaded, setIsLoaded] = useState(false);
8
+ const [isError, setIsError] = useState(false);
9
+ const imageExtraClassnames = classNames(imageClassnames, {
10
+ "spiffy-tw-block": isLoaded,
11
+ "spiffy-tw-hidden": !isLoaded
12
+ });
13
+ const fallbackMergedClassNames = classNames({
14
+ "spiffy-tw-flex": true,
15
+ "spiffy-tw-flex-col": true,
16
+ "spiffy-tw-items-center": true
17
+ }, fallbackClassnames);
18
+ if (isError) return /* @__PURE__ */ jsx("div", {
19
+ className: fallbackMergedClassNames,
20
+ children: fallback
21
+ });
22
+ return /* @__PURE__ */ jsxs(Fragment, { children: [!isLoaded && /* @__PURE__ */ jsx("div", {
23
+ className: fallbackMergedClassNames,
24
+ children: fallback
25
+ }), /* @__PURE__ */ jsx("img", {
26
+ src,
27
+ className: imageExtraClassnames,
28
+ "data-testid": dataTestId,
29
+ alt,
30
+ onLoad: () => {
31
+ setIsLoaded(true);
32
+ onLoad?.();
33
+ },
34
+ onError: () => {
35
+ setIsError(true);
36
+ onError?.();
37
+ }
38
+ })] });
39
+ };
40
+
41
+ //#endregion
42
+ export { ImageWithFallback };
@@ -0,0 +1,4 @@
1
+ require('../AnimatedChevron-Q96FneFy.cjs');
2
+ const require_ModalSheet = require('../ModalSheet-CcthFeMD.cjs');
3
+
4
+ exports.ModalSheet = require_ModalSheet.ModalSheet;
@@ -0,0 +1,38 @@
1
+ import * as react_jsx_runtime17 from "react/jsx-runtime";
2
+
3
+ //#region src/components/ModalSheet/types.d.ts
4
+ type ModalSheetProps = {
5
+ children: React.ReactNode;
6
+ isOpen: boolean;
7
+ closeModal: () => void;
8
+ desktopWidth?: number;
9
+ mobileFullHeight?: number;
10
+ animationDuration?: number;
11
+ headerProps: ModalSheetHeaderProps;
12
+ footerProps?: ModalSheetFooterProps;
13
+ showOverlay?: boolean;
14
+ };
15
+ type ModalSheetHeaderProps = {
16
+ headerVariant?: ModalSheetHeaderVariant;
17
+ headerContent: React.ReactNode;
18
+ handleHeaderClick?: () => void;
19
+ chevronColor: string;
20
+ };
21
+ type ModalSheetFooterProps = {
22
+ footerContent: React.ReactNode;
23
+ footerClassName?: string;
24
+ };
25
+ type ModalSheetHeaderVariant = 'primary';
26
+ //#endregion
27
+ //#region src/components/ModalSheet/ModalSheet.d.ts
28
+ declare const ModalSheet: ({
29
+ children,
30
+ isOpen,
31
+ closeModal,
32
+ animationDuration,
33
+ desktopWidth,
34
+ headerProps,
35
+ footerProps
36
+ }: ModalSheetProps) => react_jsx_runtime17.JSX.Element;
37
+ //#endregion
38
+ export { ModalSheet };