@envive-ai/react-toolkit 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/packages/components/src/atoms/search/types.d.ts +5 -0
- package/dist/packages/components/src/atoms/search/types.js +1 -0
- package/dist/packages/components/src/components/common/ButtonBase/ButtonBase.d.ts +2 -0
- package/dist/packages/components/src/components/common/ButtonBase/ButtonBase.js +41 -0
- package/dist/packages/components/src/components/common/ButtonBase/types.d.ts +24 -0
- package/dist/packages/components/src/components/common/ButtonBase/types.js +6 -0
- package/dist/packages/components/src/components/common/Headline/Headline.d.ts +10 -0
- package/dist/packages/components/src/components/common/Headline/Headline.js +34 -0
- package/dist/packages/components/src/components/common/ImageWithFallback/ImageWithFallback.d.ts +12 -0
- package/dist/packages/components/src/components/common/ImageWithFallback/ImageWithFallback.js +26 -0
- package/dist/packages/components/src/components/common/ProductCard/ProductCard.d.ts +39 -0
- package/dist/packages/components/src/components/common/ProductCard/ProductCard.js +83 -0
- package/dist/packages/components/src/components/common/ProductCard/ProductCardSkeleton.d.ts +9 -0
- package/dist/packages/components/src/components/common/ProductCard/ProductCardSkeleton.js +15 -0
- package/dist/packages/components/src/components/common/ProductCard/productCardVariants.d.ts +8 -0
- package/dist/packages/components/src/components/common/ProductCard/productCardVariants.js +50 -0
- package/dist/packages/components/src/components/common/ProductCard/types.d.ts +39 -0
- package/dist/packages/components/src/components/common/ProductCard/types.js +10 -0
- package/dist/packages/components/src/components/common/ProductGrid/ProductGrid.d.ts +14 -0
- package/dist/packages/components/src/components/common/ProductGrid/ProductGrid.js +13 -0
- package/dist/packages/components/src/components/common/ProductGrid/productGridVariants.d.ts +10 -0
- package/dist/packages/components/src/components/common/ProductGrid/productGridVariants.js +16 -0
- package/dist/packages/components/src/components/common/SparkleAnimation/SparkleAnimation.d.ts +7 -0
- package/dist/packages/components/src/components/common/SparkleAnimation/SparkleAnimation.js +40 -0
- package/dist/packages/components/src/components/common/SparkleAnimation/types.d.ts +6 -0
- package/dist/packages/components/src/components/common/SparkleAnimation/types.js +7 -0
- package/dist/packages/components/src/components/common/Spinner/Spinner.d.ts +5 -0
- package/dist/packages/components/src/components/common/Spinner/Spinner.js +16 -0
- package/dist/packages/components/src/components/common/SuggestionButton/SuggestionButton.d.ts +18 -0
- package/dist/packages/components/src/components/common/SuggestionButton/SuggestionButton.js +210 -0
- package/dist/packages/components/src/components/common/SuggestionButton/types.d.ts +1 -0
- package/dist/packages/components/src/components/common/SuggestionButton/types.js +1 -0
- package/dist/packages/components/src/components/common/Text/Text.d.ts +12 -0
- package/dist/packages/components/src/components/common/Text/Text.js +26 -0
- package/dist/packages/components/src/components/common/Text/textVariantClasses.d.ts +171 -0
- package/dist/packages/components/src/components/common/Text/textVariantClasses.js +103 -0
- package/dist/packages/components/src/components/common/Text/types.d.ts +16 -0
- package/dist/packages/components/src/components/common/Text/types.js +6 -0
- package/dist/packages/components/src/components/common/TextInput/TextInput.d.ts +8 -0
- package/dist/packages/components/src/components/common/TextInput/TextInput.js +25 -0
- package/dist/packages/components/src/components/models/colorsConfig.d.ts +26 -0
- package/dist/packages/components/src/components/models/colorsConfig.js +23 -0
- package/dist/packages/components/src/components/search/FilterScrollbar/AppliedFiltersScrollbar.d.ts +11 -0
- package/dist/packages/components/src/components/search/FilterScrollbar/AppliedFiltersScrollbar.js +18 -0
- package/dist/packages/components/src/components/search/FilterScrollbar/DynamicFiltersScrollbar.d.ts +15 -0
- package/dist/packages/components/src/components/search/FilterScrollbar/DynamicFiltersScrollbar.js +15 -0
- package/dist/packages/components/src/components/search/SearchFilter/SearchFilter.d.ts +2 -0
- package/dist/packages/components/src/components/search/SearchFilter/SearchFilter.js +24 -0
- package/dist/packages/components/src/components/search/SearchFilter/SearchFilterHeader.d.ts +2 -0
- package/dist/packages/components/src/components/search/SearchFilter/SearchFilterHeader.js +9 -0
- package/dist/packages/components/src/components/search/SearchFilter/SearchFilterItem.d.ts +2 -0
- package/dist/packages/components/src/components/search/SearchFilter/SearchFilterItem.js +13 -0
- package/dist/packages/components/src/components/search/SearchFilter/types.d.ts +42 -0
- package/dist/packages/components/src/components/search/SearchFilter/types.js +1 -0
- package/dist/packages/components/src/components/search/SearchInput/SearchInput.d.ts +16 -0
- package/dist/packages/components/src/components/search/SearchInput/SearchInput.js +38 -0
- package/dist/packages/components/src/components/search/SearchInput/searchInputVariants.d.ts +13 -0
- package/dist/packages/components/src/components/search/SearchInput/searchInputVariants.js +12 -0
- package/dist/packages/components/src/components/search/SearchInputAutocomplete/SearchAutocomplete.d.ts +10 -0
- package/dist/packages/components/src/components/search/SearchInputAutocomplete/SearchAutocomplete.js +14 -0
- package/dist/packages/components/src/components/search/SearchInputForm/SearchInputForm.d.ts +16 -0
- package/dist/packages/components/src/components/search/SearchInputForm/SearchInputForm.js +13 -0
- package/dist/packages/components/src/components/search/SearchInputForm/types.d.ts +1 -0
- package/dist/packages/components/src/components/search/SearchInputForm/types.js +1 -0
- package/dist/packages/components/src/components/search/SearchResultsFilterSidebar/SearchResultsFilter.d.ts +14 -0
- package/dist/packages/components/src/components/search/SearchResultsFilterSidebar/SearchResultsFilter.js +15 -0
- package/dist/packages/components/src/components/search/SearchResultsFilterSidebar/searchFilterSidebarVariants.d.ts +16 -0
- package/dist/packages/components/src/components/search/SearchResultsFilterSidebar/searchFilterSidebarVariants.js +29 -0
- package/dist/packages/components/src/components/search/SearchResultsFilterSidebar/types.d.ts +2 -0
- package/dist/packages/components/src/components/search/SearchResultsFilterSidebar/types.js +1 -0
- package/dist/packages/components/src/components/search/SearchResultsStates/NoSearchResultsFound.d.ts +8 -0
- package/dist/packages/components/src/components/search/SearchResultsStates/NoSearchResultsFound.js +10 -0
- package/dist/packages/components/src/components/search/SearchResultsStates/SearchResultsGrid.d.ts +24 -0
- package/dist/packages/components/src/components/search/SearchResultsStates/SearchResultsGrid.js +19 -0
- package/dist/packages/components/src/components/search/SearchResultsStates/SearchResultsLoadingGrid.d.ts +6 -0
- package/dist/packages/components/src/components/search/SearchResultsStates/SearchResultsLoadingGrid.js +10 -0
- package/dist/packages/components/src/components/search/types.d.ts +5 -0
- package/dist/packages/components/src/components/search/types.js +6 -0
- package/dist/packages/components/src/components/test/types.d.ts +3 -0
- package/dist/packages/components/src/components/test/types.js +1 -0
- package/dist/packages/components/src/config/chatElementDisplayLocation.d.ts +21 -0
- package/dist/packages/components/src/config/chatElementDisplayLocation.js +23 -0
- package/dist/packages/components/src/index.d.ts +45 -0
- package/dist/packages/components/src/index.js +49 -0
- package/dist/packages/components/src/logging/logger.d.ts +7 -0
- package/dist/packages/components/src/logging/logger.js +16 -0
- package/dist/packages/components/src/types/external.d.ts +21 -0
- package/dist/packages/components/src/types/external.js +5 -0
- package/dist/packages/components/src/util/camelCase.d.ts +65 -0
- package/dist/packages/components/src/util/camelCase.js +2 -0
- package/dist/packages/components/src/util/camelCasedPropertiesDeep.d.ts +53 -0
- package/dist/packages/components/src/util/camelCasedPropertiesDeep.js +1 -0
- package/dist/packages/components/src/util/formatPrice.d.ts +1 -0
- package/dist/packages/components/src/util/formatPrice.js +11 -0
- package/dist/packages/components/src/util/internal.d.ts +27 -0
- package/dist/packages/components/src/util/internal.js +4 -0
- package/dist/packages/components/src/util/primitive.d.ts +6 -0
- package/dist/packages/components/src/util/primitive.js +2 -0
- package/dist/packages/components/src/util/splitWords.d.ts +55 -0
- package/dist/packages/components/src/util/splitWords.js +2 -0
- package/dist/packages/components/src/util/trim.d.ts +24 -0
- package/dist/packages/components/src/util/trim.js +2 -0
- package/dist/packages/components/src/util/unknownArray.d.ts +25 -0
- package/dist/packages/components/src/util/unknownArray.js +1 -0
- package/dist/src/atoms/search/types.d.ts +5 -0
- package/dist/src/atoms/search/types.js +1 -0
- package/dist/src/components/common/ButtonBase/ButtonBase.d.ts +2 -0
- package/dist/src/components/common/ButtonBase/ButtonBase.js +41 -0
- package/dist/src/components/common/ButtonBase/types.d.ts +24 -0
- package/dist/src/components/common/ButtonBase/types.js +6 -0
- package/dist/src/components/common/Headline/Headline.d.ts +10 -0
- package/dist/src/components/common/Headline/Headline.js +34 -0
- package/dist/src/components/common/ImageWithFallback/ImageWithFallback.d.ts +12 -0
- package/dist/src/components/common/ImageWithFallback/ImageWithFallback.js +26 -0
- package/dist/src/components/common/ProductCard/ProductCard.d.ts +39 -0
- package/dist/src/components/common/ProductCard/ProductCard.js +84 -0
- package/dist/src/components/common/ProductCard/ProductCardSkeleton.d.ts +9 -0
- package/dist/src/components/common/ProductCard/ProductCardSkeleton.js +15 -0
- package/dist/src/components/common/ProductCard/productCardVariants.d.ts +8 -0
- package/dist/src/components/common/ProductCard/productCardVariants.js +50 -0
- package/dist/src/components/common/ProductCard/types.d.ts +39 -0
- package/dist/src/components/common/ProductCard/types.js +10 -0
- package/dist/src/components/common/ProductGrid/ProductGrid.d.ts +14 -0
- package/dist/src/components/common/ProductGrid/ProductGrid.js +13 -0
- package/dist/src/components/common/ProductGrid/productGridVariants.d.ts +10 -0
- package/dist/src/components/common/ProductGrid/productGridVariants.js +16 -0
- package/dist/src/components/common/SparkleAnimation/SparkleAnimation.d.ts +7 -0
- package/dist/src/components/common/SparkleAnimation/SparkleAnimation.js +40 -0
- package/dist/src/components/common/SparkleAnimation/types.d.ts +6 -0
- package/dist/src/components/common/SparkleAnimation/types.js +7 -0
- package/dist/src/components/common/Spinner/Spinner.d.ts +5 -0
- package/dist/src/components/common/Spinner/Spinner.js +16 -0
- package/dist/src/components/common/SuggestionButton/SuggestionButton.d.ts +18 -0
- package/dist/src/components/common/SuggestionButton/SuggestionButton.js +210 -0
- package/dist/src/components/common/SuggestionButton/types.d.ts +1 -0
- package/dist/src/components/common/SuggestionButton/types.js +1 -0
- package/dist/src/components/common/Text/Text.d.ts +12 -0
- package/dist/src/components/common/Text/Text.js +26 -0
- package/dist/src/components/common/Text/textVariantClasses.d.ts +171 -0
- package/dist/src/components/common/Text/textVariantClasses.js +103 -0
- package/dist/src/components/common/Text/types.d.ts +16 -0
- package/dist/src/components/common/Text/types.js +6 -0
- package/dist/src/components/common/TextInput/TextInput.d.ts +8 -0
- package/dist/src/components/common/TextInput/TextInput.js +25 -0
- package/dist/src/components/models/colorsConfig.d.ts +26 -0
- package/dist/src/components/models/colorsConfig.js +23 -0
- package/dist/src/components/search/FilterScrollbar/AppliedFiltersScrollbar.d.ts +11 -0
- package/dist/src/components/search/FilterScrollbar/AppliedFiltersScrollbar.js +18 -0
- package/dist/src/components/search/FilterScrollbar/DynamicFiltersScrollbar.d.ts +15 -0
- package/dist/src/components/search/FilterScrollbar/DynamicFiltersScrollbar.js +15 -0
- package/dist/src/components/search/SearchFilter/SearchFilter.d.ts +2 -0
- package/dist/src/components/search/SearchFilter/SearchFilter.js +24 -0
- package/dist/src/components/search/SearchFilter/SearchFilterHeader.d.ts +2 -0
- package/dist/src/components/search/SearchFilter/SearchFilterHeader.js +9 -0
- package/dist/src/components/search/SearchFilter/SearchFilterItem.d.ts +2 -0
- package/dist/src/components/search/SearchFilter/SearchFilterItem.js +13 -0
- package/dist/src/components/search/SearchFilter/types.d.ts +42 -0
- package/dist/src/components/search/SearchFilter/types.js +1 -0
- package/dist/src/components/search/SearchInput/SearchInput.d.ts +16 -0
- package/dist/src/components/search/SearchInput/SearchInput.js +38 -0
- package/dist/src/components/search/SearchInput/searchInputVariants.d.ts +13 -0
- package/dist/src/components/search/SearchInput/searchInputVariants.js +12 -0
- package/dist/src/components/search/SearchInputAutocomplete/SearchAutocomplete.d.ts +10 -0
- package/dist/src/components/search/SearchInputAutocomplete/SearchAutocomplete.js +14 -0
- package/dist/src/components/search/SearchInputForm/SearchInputForm.d.ts +16 -0
- package/dist/src/components/search/SearchInputForm/SearchInputForm.js +13 -0
- package/dist/src/components/search/SearchInputForm/types.d.ts +1 -0
- package/dist/src/components/search/SearchInputForm/types.js +1 -0
- package/dist/src/components/search/SearchResultsFilterSidebar/SearchResultsFilter.d.ts +14 -0
- package/dist/src/components/search/SearchResultsFilterSidebar/SearchResultsFilter.js +15 -0
- package/dist/src/components/search/SearchResultsFilterSidebar/searchFilterSidebarVariants.d.ts +16 -0
- package/dist/src/components/search/SearchResultsFilterSidebar/searchFilterSidebarVariants.js +29 -0
- package/dist/src/components/search/SearchResultsFilterSidebar/types.d.ts +2 -0
- package/dist/src/components/search/SearchResultsFilterSidebar/types.js +1 -0
- package/dist/src/components/search/SearchResultsStates/NoSearchResultsFound.d.ts +8 -0
- package/dist/src/components/search/SearchResultsStates/NoSearchResultsFound.js +10 -0
- package/dist/src/components/search/SearchResultsStates/SearchResultsGrid.d.ts +24 -0
- package/dist/src/components/search/SearchResultsStates/SearchResultsGrid.js +19 -0
- package/dist/src/components/search/SearchResultsStates/SearchResultsLoadingGrid.d.ts +6 -0
- package/dist/src/components/search/SearchResultsStates/SearchResultsLoadingGrid.js +10 -0
- package/dist/src/components/search/types.d.ts +5 -0
- package/dist/src/components/search/types.js +6 -0
- package/dist/src/components/test/types.d.ts +3 -0
- package/dist/src/components/test/types.js +1 -0
- package/dist/src/config/chatElementDisplayLocation.d.ts +21 -0
- package/dist/src/config/chatElementDisplayLocation.js +23 -0
- package/dist/src/index.d.ts +45 -0
- package/dist/src/index.js +49 -0
- package/dist/src/logging/logger.d.ts +7 -0
- package/dist/src/logging/logger.js +16 -0
- package/dist/src/types/external.d.ts +21 -0
- package/dist/src/types/external.js +5 -0
- package/dist/src/util/camelCase.d.ts +65 -0
- package/dist/src/util/camelCase.js +2 -0
- package/dist/src/util/camelCasedPropertiesDeep.d.ts +53 -0
- package/dist/src/util/camelCasedPropertiesDeep.js +1 -0
- package/dist/src/util/formatPrice.d.ts +1 -0
- package/dist/src/util/formatPrice.js +11 -0
- package/dist/src/util/internal.d.ts +27 -0
- package/dist/src/util/internal.js +4 -0
- package/dist/src/util/primitive.d.ts +6 -0
- package/dist/src/util/primitive.js +2 -0
- package/dist/src/util/splitWords.d.ts +55 -0
- package/dist/src/util/splitWords.js +2 -0
- package/dist/src/util/trim.d.ts +24 -0
- package/dist/src/util/trim.js +2 -0
- package/dist/src/util/unknownArray.d.ts +25 -0
- package/dist/src/util/unknownArray.js +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +41 -0
|
@@ -0,0 +1,210 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import classNames from 'classnames';
|
|
3
|
+
import OutlinedStar from '@envive/icons/src/OutlinedStar';
|
|
4
|
+
import FourPointStar from '@envive/icons/src/FourPointStar';
|
|
5
|
+
import { ButtonBase } from '../ButtonBase/ButtonBase';
|
|
6
|
+
export const SPIFFY_SUGGESTION_BUTTON_QUESTION_CLASS = 'spiffy-suggestion-button-question-class';
|
|
7
|
+
export const SPIFFY_SUGGESTION_BUTTON_ANSWER_CLASS = 'spiffy-suggestion-button-answer-class';
|
|
8
|
+
export const SPIFFY_SUGGESTION_BUTTON_TEXT_CLASS = 'spiffy-suggestion-button-text-class';
|
|
9
|
+
// Add a comment that includes the hover prefix so that tailwind will pickup and generate the right css
|
|
10
|
+
// Common class patterns to avoid duplication
|
|
11
|
+
const BORDER_CLASS = 'spiffy-tw-border'; // hover:spiffy-tw-border
|
|
12
|
+
const TEXT_LINK_CLASSES = [
|
|
13
|
+
'spiffy-tw-text-[--spiffy-colors-text-link]', // hover:spiffy-tw-text-[--spiffy-colors-text-link]
|
|
14
|
+
'spiffy-tw-fill-[--spiffy-colors-text-link]', // hover:spiffy-tw-fill-[--spiffy-colors-text-link]
|
|
15
|
+
'spiffy-tw-stroke-[--spiffy-colors-text-link]', // hover:spiffy-tw-stroke-[--spiffy-colors-text-link]
|
|
16
|
+
];
|
|
17
|
+
const TEXT_LIGHT_CLASSES = [
|
|
18
|
+
'spiffy-tw-text-[--spiffy-colors-text-light]', // hover:spiffy-tw-text-[--spiffy-colors-text-light]
|
|
19
|
+
'spiffy-tw-fill-[--spiffy-colors-text-light]', // hover:spiffy-tw-fill-[--spiffy-colors-text-light]
|
|
20
|
+
'spiffy-tw-stroke-[--spiffy-colors-text-light]', // hover:spiffy-tw-stroke-[--spiffy-colors-text-light]
|
|
21
|
+
];
|
|
22
|
+
const TEXT_PRIMARY_CLASSES = [
|
|
23
|
+
'spiffy-tw-text-[--spiffy-colors-text-primary]', // hover:spiffy-tw-text-[--spiffy-colors-text-primary]
|
|
24
|
+
'spiffy-tw-fill-[--spiffy-colors-text-primary]', // hover:spiffy-tw-fill-[--spiffy-colors-text-primary]
|
|
25
|
+
'spiffy-tw-stroke-[--spiffy-colors-text-primary]', // hover:spiffy-tw-stroke-[--spiffy-colors-text-primary]
|
|
26
|
+
];
|
|
27
|
+
const ACCENT_PRIMARY_CLASSES = [
|
|
28
|
+
'spiffy-tw-fill-[--spiffy-colors-accent-primary]', // hover:spiffy-tw-fill-[--spiffy-colors-accent-primary]
|
|
29
|
+
'spiffy-tw-stroke-[--spiffy-colors-accent-primary]', // hover:spiffy-tw-stroke-[--spiffy-colors-accent-primary]
|
|
30
|
+
];
|
|
31
|
+
const DARK_BACKGROUND_CLASSES = [
|
|
32
|
+
'spiffy-tw-bg-[--spiffy-colors-background-dark]', // hover:spiffy-tw-bg-[--spiffy-colors-background-dark]
|
|
33
|
+
'spiffy-tw-border-[--spiffy-colors-background-dark]', // hover:spiffy-tw-border-[--spiffy-colors-background-secondary]
|
|
34
|
+
];
|
|
35
|
+
const SECONDARY_DARK_BACKGROUND_CLASSES = [
|
|
36
|
+
'spiffy-tw-bg-[--spiffy-colors-background-secondary-dark]', // hover:spiffy-tw-bg-[--spiffy-colors-background-secondary-dark]
|
|
37
|
+
'spiffy-tw-border-[--spiffy-colors-background-secondary-dark]', // hover:spiffy-tw-border-[--spiffy-colors-background-secondary-dark]
|
|
38
|
+
];
|
|
39
|
+
const variantClassMap = new Map([
|
|
40
|
+
[
|
|
41
|
+
'outlined',
|
|
42
|
+
[
|
|
43
|
+
'spiffy-tw-border-[--spiffy-colors-border-outline]', // hover:spiffy-tw-border-[--spiffy-colors-border-outline]
|
|
44
|
+
...TEXT_LINK_CLASSES,
|
|
45
|
+
],
|
|
46
|
+
],
|
|
47
|
+
[
|
|
48
|
+
'outlinedLight',
|
|
49
|
+
[
|
|
50
|
+
'spiffy-tw-border-[--spiffy-colors-border-outline]', // hover:spiffy-tw-border-[--spiffy-colors-border-outline]
|
|
51
|
+
'spiffy-tw-bg-[--spiffy-colors-background-light]', // hover:spiffy-tw-bg-[--spiffy-colors-background-light]
|
|
52
|
+
...TEXT_LINK_CLASSES,
|
|
53
|
+
BORDER_CLASS,
|
|
54
|
+
],
|
|
55
|
+
],
|
|
56
|
+
[
|
|
57
|
+
'primary',
|
|
58
|
+
[
|
|
59
|
+
'spiffy-tw-bg-[--spiffy-colors-background-primary]', // hover:spiffy-tw-bg-[--spiffy-colors-background-primary]
|
|
60
|
+
'spiffy-tw-border-[--spiffy-colors-background-primary]', // hover:spiffy-tw-border-[--spiffy-colors-background-secondary]
|
|
61
|
+
...TEXT_LIGHT_CLASSES,
|
|
62
|
+
BORDER_CLASS,
|
|
63
|
+
],
|
|
64
|
+
],
|
|
65
|
+
[
|
|
66
|
+
'secondary',
|
|
67
|
+
[
|
|
68
|
+
'spiffy-tw-bg-[--spiffy-colors-background-secondary]', // hover:spiffy-tw-bg-[--spiffy-colors-background-secondary]
|
|
69
|
+
'spiffy-tw-text-[--spiffy-colors-text-link]', // hover:spiffy-tw-text-[--spiffy-colors-text-link]
|
|
70
|
+
'spiffy-tw-border-[--spiffy-colors-background-secondary]', // hover:spiffy-tw-border-[--spiffy-colors-background-secondary]
|
|
71
|
+
...ACCENT_PRIMARY_CLASSES,
|
|
72
|
+
BORDER_CLASS,
|
|
73
|
+
],
|
|
74
|
+
],
|
|
75
|
+
[
|
|
76
|
+
'tertiary',
|
|
77
|
+
[
|
|
78
|
+
'spiffy-tw-bg-[--spiffy-colors-background-tertiary]', // hover:spiffy-tw-bg-[--spiffy-colors-background-tertiary]
|
|
79
|
+
'spiffy-tw-border-[--spiffy-colors-background-tertiary]', // hover:spiffy-tw-border-[--spiffy-colors-background-secondary]
|
|
80
|
+
...TEXT_LINK_CLASSES,
|
|
81
|
+
BORDER_CLASS,
|
|
82
|
+
],
|
|
83
|
+
],
|
|
84
|
+
['dark', [...DARK_BACKGROUND_CLASSES, ...TEXT_LIGHT_CLASSES, BORDER_CLASS]],
|
|
85
|
+
[
|
|
86
|
+
'darkPrimary',
|
|
87
|
+
[
|
|
88
|
+
...DARK_BACKGROUND_CLASSES,
|
|
89
|
+
'spiffy-tw-text-[--spiffy-colors-text-light]', // hover:spiffy-tw-text-[--spiffy-colors-text-light]
|
|
90
|
+
...ACCENT_PRIMARY_CLASSES,
|
|
91
|
+
BORDER_CLASS,
|
|
92
|
+
],
|
|
93
|
+
],
|
|
94
|
+
[
|
|
95
|
+
'darkAccent',
|
|
96
|
+
[
|
|
97
|
+
...DARK_BACKGROUND_CLASSES,
|
|
98
|
+
'spiffy-tw-text-[--spiffy-colors-text-light]', // hover:spiffy-tw-text-[--spiffy-colors-text-light]
|
|
99
|
+
'spiffy-tw-fill-[--spiffy-colors-text-accent]', // hover:spiffy-tw-fill-[--spiffy-colors-text-accent]
|
|
100
|
+
'spiffy-tw-stroke-[--spiffy-colors-text-accent]', // hover:spiffy-tw-stroke-[--spiffy-colors-text-accent]
|
|
101
|
+
BORDER_CLASS,
|
|
102
|
+
],
|
|
103
|
+
],
|
|
104
|
+
[
|
|
105
|
+
'transparent',
|
|
106
|
+
[
|
|
107
|
+
'spiffy-tw-bg-transparent', // hover:spiffy-tw-bg-transparent
|
|
108
|
+
'spiffy-tw-border-[--spiffy-colors-background-light]', // hover:spiffy-tw-border-[--spiffy-colors-background-light]
|
|
109
|
+
'spiffy-tw-text-[--spiffy-colors-text-light]', // hover:spiffy-tw-text-[--spiffy-colors-text-light]
|
|
110
|
+
'spiffy-tw-fill-transparent', // hover:spiffy-tw-fill-transparent
|
|
111
|
+
'spiffy-tw-stroke-[--spiffy-colors-text-light]', // hover:spiffy-tw-stroke-[--spiffy-colors-text-light]
|
|
112
|
+
BORDER_CLASS,
|
|
113
|
+
],
|
|
114
|
+
],
|
|
115
|
+
[
|
|
116
|
+
'transparentDark',
|
|
117
|
+
[
|
|
118
|
+
'spiffy-tw-bg-transparent', // hover:spiffy-tw-bg-transparent
|
|
119
|
+
'spiffy-tw-border-[--spiffy-colors-border-light]', // hover:spiffy-tw-border-[--spiffy-colors-border-light]
|
|
120
|
+
'spiffy-tw-text-[--spiffy-colors-text-primary]', // hover:spiffy-tw-text-[--spiffy-colors-text-primary]
|
|
121
|
+
'spiffy-tw-fill-transparent', // hover:spiffy-tw-fill-transparent
|
|
122
|
+
'spiffy-tw-stroke-[--spiffy-colors-text-primary]', // hover:spiffy-tw-stroke-[--spiffy-colors-text-primary]
|
|
123
|
+
BORDER_CLASS,
|
|
124
|
+
],
|
|
125
|
+
],
|
|
126
|
+
// This is used as the hover state for transparent
|
|
127
|
+
['secondaryDark', [...SECONDARY_DARK_BACKGROUND_CLASSES, ...TEXT_LINK_CLASSES, BORDER_CLASS]],
|
|
128
|
+
[
|
|
129
|
+
'secondaryAccent',
|
|
130
|
+
[
|
|
131
|
+
...SECONDARY_DARK_BACKGROUND_CLASSES,
|
|
132
|
+
'spiffy-tw-text-[--spiffy-colors-text-link]', // hover:spiffy-tw-text-[--spiffy-colors-text-link]
|
|
133
|
+
...ACCENT_PRIMARY_CLASSES,
|
|
134
|
+
BORDER_CLASS,
|
|
135
|
+
],
|
|
136
|
+
],
|
|
137
|
+
[
|
|
138
|
+
'lightDark',
|
|
139
|
+
[
|
|
140
|
+
'spiffy-tw-bg-[--spiffy-colors-background-light]', // hover:spiffy-tw-bg-[--spiffy-colors-background-light]
|
|
141
|
+
'spiffy-tw-border-[--spiffy-colors-background-dark]', // hover:spiffy-tw-border-[--spiffy-colors-background-dark]
|
|
142
|
+
...TEXT_PRIMARY_CLASSES,
|
|
143
|
+
BORDER_CLASS,
|
|
144
|
+
],
|
|
145
|
+
],
|
|
146
|
+
]);
|
|
147
|
+
const borderedVariants = [
|
|
148
|
+
'outlined',
|
|
149
|
+
'outlinedLight',
|
|
150
|
+
'primary',
|
|
151
|
+
'secondary',
|
|
152
|
+
'tertiary',
|
|
153
|
+
'dark',
|
|
154
|
+
'darkAccent',
|
|
155
|
+
'darkPrimary',
|
|
156
|
+
'transparent',
|
|
157
|
+
'transparentDark',
|
|
158
|
+
'secondaryDark',
|
|
159
|
+
'secondaryAccent',
|
|
160
|
+
'lightDark',
|
|
161
|
+
];
|
|
162
|
+
const hoverTransform = (variantClass) => variantClass?.map((className) => `hover:${className}`);
|
|
163
|
+
export const SuggestionButton = ({ variant, hoverVariant, isDisabled, content, boldText, borderRadius = 'lg', isAnswer = false, dataAttributes, dataTestId, onClick, }) => {
|
|
164
|
+
const buttonClassName = classNames({
|
|
165
|
+
[SPIFFY_SUGGESTION_BUTTON_QUESTION_CLASS]: !isAnswer,
|
|
166
|
+
[SPIFFY_SUGGESTION_BUTTON_ANSWER_CLASS]: isAnswer,
|
|
167
|
+
'!spiffy-tw-rounded-[20px]': borderRadius === 'lg',
|
|
168
|
+
'!spiffy-tw-rounded-[8px]': borderRadius === 'md',
|
|
169
|
+
'!spiffy-tw-rounded-[0px]': borderRadius === 'sm',
|
|
170
|
+
'spiffy-tw-border-[1px]': borderedVariants.includes(variant),
|
|
171
|
+
'spiffy-tw-border-solid': borderedVariants.includes(variant),
|
|
172
|
+
});
|
|
173
|
+
const textClassName = classNames({
|
|
174
|
+
'spiffy-tw-text-[14px]': true,
|
|
175
|
+
'spiffy-tw-leading-[100%]': true,
|
|
176
|
+
'!spiffy-tw-font-bold': boldText,
|
|
177
|
+
});
|
|
178
|
+
const iconClass = classNames({
|
|
179
|
+
'spiffy-tw-w-[11px]': true,
|
|
180
|
+
'spiffy-tw-h-[11px]': true,
|
|
181
|
+
'spiffy-tw-stroke-inherit': true,
|
|
182
|
+
'spiffy-tw-fill-inherit': true,
|
|
183
|
+
});
|
|
184
|
+
const baseClasses = variantClassMap.get(variant) ?? [];
|
|
185
|
+
const hoverClasses = variantClassMap.get(hoverVariant) ?? [];
|
|
186
|
+
// Separate border classes for proper cascading
|
|
187
|
+
const baseBorderClasses = baseClasses.filter((cls) => cls.includes('border'));
|
|
188
|
+
const baseNonBorderClasses = baseClasses.filter((cls) => !cls.includes('border'));
|
|
189
|
+
const hoverBorderClasses = hoverClasses.filter((cls) => cls.includes('border'));
|
|
190
|
+
const hoverNonBorderClasses = hoverClasses.filter((cls) => !cls.includes('border'));
|
|
191
|
+
const variantClasses = [
|
|
192
|
+
...baseNonBorderClasses,
|
|
193
|
+
...hoverTransform(hoverNonBorderClasses),
|
|
194
|
+
...baseBorderClasses,
|
|
195
|
+
...hoverTransform(hoverBorderClasses),
|
|
196
|
+
];
|
|
197
|
+
const buttonClass = `${buttonClassName} ${variantClasses.join(' ')}`;
|
|
198
|
+
// Choose icon based on variant to match legacy exactly
|
|
199
|
+
const getIcon = () => {
|
|
200
|
+
if (isAnswer)
|
|
201
|
+
return undefined;
|
|
202
|
+
if (variant === 'transparentDark') {
|
|
203
|
+
return OutlinedStar;
|
|
204
|
+
}
|
|
205
|
+
return FourPointStar;
|
|
206
|
+
};
|
|
207
|
+
return (_jsx(ButtonBase, { text: content, dataAttributes: dataAttributes, dataTestId: dataTestId, isDisabled: isDisabled,
|
|
208
|
+
// we may want to support custom icons in the future
|
|
209
|
+
icon: getIcon(), iconClass: isAnswer ? undefined : iconClass, textClass: `${SPIFFY_SUGGESTION_BUTTON_TEXT_CLASS} ${textClassName}`, buttonClass: buttonClass, onClick: onClick }));
|
|
210
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export type SuggestionButtonVariant = 'outlined' | 'outlinedLight' | 'primary' | 'secondary' | 'tertiary' | 'dark' | 'darkAccent' | 'darkPrimary' | 'secondaryDark' | 'secondaryAccent' | 'transparent' | 'transparentDark' | 'lightDark';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { type TextType, type TextVariant } from './types';
|
|
2
|
+
type TextProps = {
|
|
3
|
+
children: React.ReactNode;
|
|
4
|
+
noOfLines?: number;
|
|
5
|
+
className?: string;
|
|
6
|
+
style?: React.CSSProperties;
|
|
7
|
+
variant?: TextVariant;
|
|
8
|
+
type?: TextType;
|
|
9
|
+
testId?: string;
|
|
10
|
+
};
|
|
11
|
+
export declare const Text: ({ children, className, style, noOfLines, testId, type, variant, }: TextProps) => import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
export {};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import classNames from 'classnames';
|
|
3
|
+
import { TextVariantMap } from './textVariantClasses';
|
|
4
|
+
export const Text = ({ children, className, style, noOfLines, testId, type = 'span', variant = 'body3', }) => {
|
|
5
|
+
const variantClassNames = variant ? TextVariantMap[variant] : {};
|
|
6
|
+
const textClassNames = classNames(className, variantClassNames, {
|
|
7
|
+
'spiffy-tw-font-["Inter Variable,sans-serif"]': true,
|
|
8
|
+
'spiffy-tw-line-clamp-1': noOfLines === 1,
|
|
9
|
+
'spiffy-tw-line-clamp-2': noOfLines === 2,
|
|
10
|
+
'spiffy-tw-line-clamp-3': noOfLines === 3,
|
|
11
|
+
'spiffy-tw-line-clamp-4': noOfLines === 4,
|
|
12
|
+
'spiffy-tw-line-clamp-5': noOfLines === 5,
|
|
13
|
+
'spiffy-tw-line-clamp-6': noOfLines === 6,
|
|
14
|
+
'spiffy-tw-line-clamp-7': noOfLines === 7,
|
|
15
|
+
});
|
|
16
|
+
switch (type) {
|
|
17
|
+
case 'p':
|
|
18
|
+
return (_jsx("p", { "data-testid": testId, className: textClassNames, style: style, children: children }));
|
|
19
|
+
case 'span':
|
|
20
|
+
return (_jsx("span", { "data-testid": testId, className: textClassNames, style: style, children: children }));
|
|
21
|
+
case 'sub':
|
|
22
|
+
return (_jsx("sub", { "data-testid": testId, className: textClassNames, style: style, children: children }));
|
|
23
|
+
default:
|
|
24
|
+
throw new Error(`Invalid text type: ${type}`);
|
|
25
|
+
}
|
|
26
|
+
};
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
export declare const HeadlineVariantMap: {
|
|
2
|
+
t1: {
|
|
3
|
+
'spiffy-headline': boolean;
|
|
4
|
+
'spiffy-headline-1': boolean;
|
|
5
|
+
'spiffy-tw-text-[32px]': boolean;
|
|
6
|
+
'spiffy-tw-font-medium': boolean;
|
|
7
|
+
'spiffy-tw-leading-[124%]': boolean;
|
|
8
|
+
};
|
|
9
|
+
t2: {
|
|
10
|
+
'spiffy-headline': boolean;
|
|
11
|
+
'spiffy-headline-1': boolean;
|
|
12
|
+
'spiffy-tw-text-[16px]': boolean;
|
|
13
|
+
'spiffy-tw-font-medium': boolean;
|
|
14
|
+
'spiffy-tw-leading-[124%]': boolean;
|
|
15
|
+
};
|
|
16
|
+
t3: {
|
|
17
|
+
'spiffy-headline': boolean;
|
|
18
|
+
'spiffy-headline-1': boolean;
|
|
19
|
+
'spiffy-tw-text-[24px]': boolean;
|
|
20
|
+
'spiffy-tw-leading-[120%]': boolean;
|
|
21
|
+
};
|
|
22
|
+
h1: {
|
|
23
|
+
'spiffy-headline': boolean;
|
|
24
|
+
'spiffy-headline-1': boolean;
|
|
25
|
+
'spiffy-tw-text-[20px]': boolean;
|
|
26
|
+
'spiffy-tw-font-normal': boolean;
|
|
27
|
+
'spiffy-tw-leading-[120%]': boolean;
|
|
28
|
+
};
|
|
29
|
+
h2: {
|
|
30
|
+
'spiffy-headline': boolean;
|
|
31
|
+
'spiffy-headline-2': boolean;
|
|
32
|
+
'spiffy-tw-text-[16px]': boolean;
|
|
33
|
+
'spiffy-tw-font-normal': boolean;
|
|
34
|
+
'spiffy-tw-leading-[124%]': boolean;
|
|
35
|
+
};
|
|
36
|
+
h3: {
|
|
37
|
+
'spiffy-headline': boolean;
|
|
38
|
+
'spiffy-headline-3': boolean;
|
|
39
|
+
'spiffy-tw-text-[15px]': boolean;
|
|
40
|
+
'spiffy-tw-font-medium': boolean;
|
|
41
|
+
'spiffy-tw-leading-[124%]': boolean;
|
|
42
|
+
};
|
|
43
|
+
h4: {
|
|
44
|
+
'spiffy-headline': boolean;
|
|
45
|
+
'spiffy-headline-4': boolean;
|
|
46
|
+
'spiffy-tw-text-[14px]': boolean;
|
|
47
|
+
'spiffy-tw-font-medium': boolean;
|
|
48
|
+
'spiffy-tw-leading-[124%]': boolean;
|
|
49
|
+
};
|
|
50
|
+
};
|
|
51
|
+
export declare const TextVariantMap: {
|
|
52
|
+
body1: {
|
|
53
|
+
'spiffy-body-text': boolean;
|
|
54
|
+
'spiffy-body-1': boolean;
|
|
55
|
+
'spiffy-tw-text-[20px]': boolean;
|
|
56
|
+
'spiffy-tw-font-normal': boolean;
|
|
57
|
+
'spiffy-tw-line-height-[120%]': boolean;
|
|
58
|
+
};
|
|
59
|
+
body2: {
|
|
60
|
+
'spiffy-body-text': boolean;
|
|
61
|
+
'spiffy-body-2': boolean;
|
|
62
|
+
'spiffy-tw-text-[16px]': boolean;
|
|
63
|
+
'spiffy-tw-font-normal': boolean;
|
|
64
|
+
'spiffy-tw-line-height-[148%]': boolean;
|
|
65
|
+
};
|
|
66
|
+
body3: {
|
|
67
|
+
'spiffy-body-text': boolean;
|
|
68
|
+
'spiffy-body-3': boolean;
|
|
69
|
+
'spiffy-tw-text-sm': boolean;
|
|
70
|
+
'spiffy-tw-font-normal': boolean;
|
|
71
|
+
'spiffy-tw-leading-[140%]': boolean;
|
|
72
|
+
};
|
|
73
|
+
body4: {
|
|
74
|
+
'spiffy-body-text': boolean;
|
|
75
|
+
'spiffy-body-4': boolean;
|
|
76
|
+
'spiffy-tw-text-xs': boolean;
|
|
77
|
+
'spiffy-tw-font-medium': boolean;
|
|
78
|
+
'spiffy-tw-leading-[130%]': boolean;
|
|
79
|
+
};
|
|
80
|
+
body5: {
|
|
81
|
+
'spiffy-body-text': boolean;
|
|
82
|
+
'spiffy-body-5': boolean;
|
|
83
|
+
'spiffy-tw-text-[10px]': boolean;
|
|
84
|
+
'spiffy-tw-font-normal': boolean;
|
|
85
|
+
};
|
|
86
|
+
};
|
|
87
|
+
export declare const TextStyleVariantMap: {
|
|
88
|
+
t1: {
|
|
89
|
+
'spiffy-headline': boolean;
|
|
90
|
+
'spiffy-headline-1': boolean;
|
|
91
|
+
'spiffy-tw-text-[32px]': boolean;
|
|
92
|
+
'spiffy-tw-font-medium': boolean;
|
|
93
|
+
'spiffy-tw-leading-[124%]': boolean;
|
|
94
|
+
};
|
|
95
|
+
t2: {
|
|
96
|
+
'spiffy-headline': boolean;
|
|
97
|
+
'spiffy-headline-1': boolean;
|
|
98
|
+
'spiffy-tw-text-[16px]': boolean;
|
|
99
|
+
'spiffy-tw-font-medium': boolean;
|
|
100
|
+
'spiffy-tw-leading-[124%]': boolean;
|
|
101
|
+
};
|
|
102
|
+
t3: {
|
|
103
|
+
'spiffy-headline': boolean;
|
|
104
|
+
'spiffy-headline-1': boolean;
|
|
105
|
+
'spiffy-tw-text-[24px]': boolean;
|
|
106
|
+
'spiffy-tw-leading-[120%]': boolean;
|
|
107
|
+
};
|
|
108
|
+
h1: {
|
|
109
|
+
'spiffy-headline': boolean;
|
|
110
|
+
'spiffy-headline-1': boolean;
|
|
111
|
+
'spiffy-tw-text-[20px]': boolean;
|
|
112
|
+
'spiffy-tw-font-normal': boolean;
|
|
113
|
+
'spiffy-tw-leading-[120%]': boolean;
|
|
114
|
+
};
|
|
115
|
+
h2: {
|
|
116
|
+
'spiffy-headline': boolean;
|
|
117
|
+
'spiffy-headline-2': boolean;
|
|
118
|
+
'spiffy-tw-text-[16px]': boolean;
|
|
119
|
+
'spiffy-tw-font-normal': boolean;
|
|
120
|
+
'spiffy-tw-leading-[124%]': boolean;
|
|
121
|
+
};
|
|
122
|
+
h3: {
|
|
123
|
+
'spiffy-headline': boolean;
|
|
124
|
+
'spiffy-headline-3': boolean;
|
|
125
|
+
'spiffy-tw-text-[15px]': boolean;
|
|
126
|
+
'spiffy-tw-font-medium': boolean;
|
|
127
|
+
'spiffy-tw-leading-[124%]': boolean;
|
|
128
|
+
};
|
|
129
|
+
h4: {
|
|
130
|
+
'spiffy-headline': boolean;
|
|
131
|
+
'spiffy-headline-4': boolean;
|
|
132
|
+
'spiffy-tw-text-[14px]': boolean;
|
|
133
|
+
'spiffy-tw-font-medium': boolean;
|
|
134
|
+
'spiffy-tw-leading-[124%]': boolean;
|
|
135
|
+
};
|
|
136
|
+
body1: {
|
|
137
|
+
'spiffy-body-text': boolean;
|
|
138
|
+
'spiffy-body-1': boolean;
|
|
139
|
+
'spiffy-tw-text-[20px]': boolean;
|
|
140
|
+
'spiffy-tw-font-normal': boolean;
|
|
141
|
+
'spiffy-tw-line-height-[120%]': boolean;
|
|
142
|
+
};
|
|
143
|
+
body2: {
|
|
144
|
+
'spiffy-body-text': boolean;
|
|
145
|
+
'spiffy-body-2': boolean;
|
|
146
|
+
'spiffy-tw-text-[16px]': boolean;
|
|
147
|
+
'spiffy-tw-font-normal': boolean;
|
|
148
|
+
'spiffy-tw-line-height-[148%]': boolean;
|
|
149
|
+
};
|
|
150
|
+
body3: {
|
|
151
|
+
'spiffy-body-text': boolean;
|
|
152
|
+
'spiffy-body-3': boolean;
|
|
153
|
+
'spiffy-tw-text-sm': boolean;
|
|
154
|
+
'spiffy-tw-font-normal': boolean;
|
|
155
|
+
'spiffy-tw-leading-[140%]': boolean;
|
|
156
|
+
};
|
|
157
|
+
body4: {
|
|
158
|
+
'spiffy-body-text': boolean;
|
|
159
|
+
'spiffy-body-4': boolean;
|
|
160
|
+
'spiffy-tw-text-xs': boolean;
|
|
161
|
+
'spiffy-tw-font-medium': boolean;
|
|
162
|
+
'spiffy-tw-leading-[130%]': boolean;
|
|
163
|
+
};
|
|
164
|
+
body5: {
|
|
165
|
+
'spiffy-body-text': boolean;
|
|
166
|
+
'spiffy-body-5': boolean;
|
|
167
|
+
'spiffy-tw-text-[10px]': boolean;
|
|
168
|
+
'spiffy-tw-font-normal': boolean;
|
|
169
|
+
};
|
|
170
|
+
};
|
|
171
|
+
export declare const getVariantPlaceholderClassNames: (classes: Record<string, boolean>) => Record<string, boolean>;
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
// TODO: add the rest of the variants as needed
|
|
2
|
+
export const HeadlineVariantMap = {
|
|
3
|
+
t1: {
|
|
4
|
+
'spiffy-headline': true,
|
|
5
|
+
'spiffy-headline-1': true,
|
|
6
|
+
'spiffy-tw-text-[32px]': true,
|
|
7
|
+
'spiffy-tw-font-medium': true,
|
|
8
|
+
'spiffy-tw-leading-[124%]': true,
|
|
9
|
+
},
|
|
10
|
+
t2: {
|
|
11
|
+
'spiffy-headline': true,
|
|
12
|
+
'spiffy-headline-1': true,
|
|
13
|
+
'spiffy-tw-text-[16px]': true,
|
|
14
|
+
'spiffy-tw-font-medium': true,
|
|
15
|
+
'spiffy-tw-leading-[124%]': true,
|
|
16
|
+
},
|
|
17
|
+
t3: {
|
|
18
|
+
'spiffy-headline': true,
|
|
19
|
+
'spiffy-headline-1': true,
|
|
20
|
+
'spiffy-tw-text-[24px]': true,
|
|
21
|
+
'spiffy-tw-leading-[120%]': true,
|
|
22
|
+
},
|
|
23
|
+
h1: {
|
|
24
|
+
'spiffy-headline': true,
|
|
25
|
+
'spiffy-headline-1': true,
|
|
26
|
+
'spiffy-tw-text-[20px]': true,
|
|
27
|
+
'spiffy-tw-font-normal': true,
|
|
28
|
+
'spiffy-tw-leading-[120%]': true,
|
|
29
|
+
},
|
|
30
|
+
h2: {
|
|
31
|
+
'spiffy-headline': true,
|
|
32
|
+
'spiffy-headline-2': true,
|
|
33
|
+
'spiffy-tw-text-[16px]': true,
|
|
34
|
+
'spiffy-tw-font-normal': true,
|
|
35
|
+
'spiffy-tw-leading-[124%]': true,
|
|
36
|
+
},
|
|
37
|
+
h3: {
|
|
38
|
+
'spiffy-headline': true,
|
|
39
|
+
'spiffy-headline-3': true,
|
|
40
|
+
'spiffy-tw-text-[15px]': true,
|
|
41
|
+
'spiffy-tw-font-medium': true,
|
|
42
|
+
'spiffy-tw-leading-[124%]': true,
|
|
43
|
+
},
|
|
44
|
+
h4: {
|
|
45
|
+
'spiffy-headline': true,
|
|
46
|
+
'spiffy-headline-4': true,
|
|
47
|
+
'spiffy-tw-text-[14px]': true,
|
|
48
|
+
'spiffy-tw-font-medium': true,
|
|
49
|
+
'spiffy-tw-leading-[124%]': true,
|
|
50
|
+
},
|
|
51
|
+
};
|
|
52
|
+
// TODO: add the rest of the variants as needed
|
|
53
|
+
export const TextVariantMap = {
|
|
54
|
+
body1: {
|
|
55
|
+
'spiffy-body-text': true,
|
|
56
|
+
'spiffy-body-1': true,
|
|
57
|
+
'spiffy-tw-text-[20px]': true,
|
|
58
|
+
'spiffy-tw-font-normal': true,
|
|
59
|
+
'spiffy-tw-line-height-[120%]': true,
|
|
60
|
+
},
|
|
61
|
+
body2: {
|
|
62
|
+
'spiffy-body-text': true,
|
|
63
|
+
'spiffy-body-2': true,
|
|
64
|
+
'spiffy-tw-text-[16px]': true,
|
|
65
|
+
'spiffy-tw-font-normal': true,
|
|
66
|
+
'spiffy-tw-line-height-[148%]': true,
|
|
67
|
+
},
|
|
68
|
+
body3: {
|
|
69
|
+
'spiffy-body-text': true,
|
|
70
|
+
'spiffy-body-3': true,
|
|
71
|
+
'spiffy-tw-text-sm': true,
|
|
72
|
+
'spiffy-tw-font-normal': true,
|
|
73
|
+
'spiffy-tw-leading-[140%]': true,
|
|
74
|
+
},
|
|
75
|
+
body4: {
|
|
76
|
+
'spiffy-body-text': true,
|
|
77
|
+
'spiffy-body-4': true,
|
|
78
|
+
'spiffy-tw-text-xs': true,
|
|
79
|
+
'spiffy-tw-font-medium': true,
|
|
80
|
+
'spiffy-tw-leading-[130%]': true,
|
|
81
|
+
},
|
|
82
|
+
body5: {
|
|
83
|
+
'spiffy-body-text': true,
|
|
84
|
+
'spiffy-body-5': true,
|
|
85
|
+
'spiffy-tw-text-[10px]': true,
|
|
86
|
+
'spiffy-tw-font-normal': true,
|
|
87
|
+
},
|
|
88
|
+
};
|
|
89
|
+
export const TextStyleVariantMap = {
|
|
90
|
+
...TextVariantMap,
|
|
91
|
+
...HeadlineVariantMap,
|
|
92
|
+
};
|
|
93
|
+
export const getVariantPlaceholderClassNames = (classes) => {
|
|
94
|
+
return Object.keys(classes).reduce((acc, key) => {
|
|
95
|
+
if (key.includes('spiffy-tw')) {
|
|
96
|
+
acc[`placeholder:${key}`] = classes[key];
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
acc[`${key}-placeholder`] = classes[key];
|
|
100
|
+
}
|
|
101
|
+
return acc;
|
|
102
|
+
}, {});
|
|
103
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export declare enum ExpandableTextOverrides {
|
|
2
|
+
EXPANDABLE_TEXT_CONTAINER = "spiffy-expandable-text-container",
|
|
3
|
+
EXPANDABLE_TEXT = "spiffy-expandable-text",
|
|
4
|
+
EXPANDABLE_BUTTON = "spiffy-expandable-button"
|
|
5
|
+
}
|
|
6
|
+
export type TextVariant = 'body1' | 'body2' | 'body3' | 'body4' | 'body5';
|
|
7
|
+
export type TextType = 'p' | 'span' | 'sub';
|
|
8
|
+
export type HeadlineProps = {
|
|
9
|
+
children: React.ReactNode;
|
|
10
|
+
className?: string;
|
|
11
|
+
style?: React.CSSProperties;
|
|
12
|
+
variant?: HeadlineVariant;
|
|
13
|
+
testId?: string;
|
|
14
|
+
id?: string;
|
|
15
|
+
};
|
|
16
|
+
export type HeadlineVariant = 't1' | 't2' | 't3' | 'h1' | 'h2' | 'h3' | 'h4';
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export var ExpandableTextOverrides;
|
|
2
|
+
(function (ExpandableTextOverrides) {
|
|
3
|
+
ExpandableTextOverrides["EXPANDABLE_TEXT_CONTAINER"] = "spiffy-expandable-text-container";
|
|
4
|
+
ExpandableTextOverrides["EXPANDABLE_TEXT"] = "spiffy-expandable-text";
|
|
5
|
+
ExpandableTextOverrides["EXPANDABLE_BUTTON"] = "spiffy-expandable-button";
|
|
6
|
+
})(ExpandableTextOverrides || (ExpandableTextOverrides = {}));
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { TextStyleVariantMap } from '../Text/textVariantClasses';
|
|
3
|
+
export interface TextInputProps extends React.InputHTMLAttributes<HTMLInputElement> {
|
|
4
|
+
borderRadius: 'sm' | 'md' | 'lg' | 'xl';
|
|
5
|
+
borderColorClass?: string;
|
|
6
|
+
placeholderVariant?: keyof typeof TextStyleVariantMap;
|
|
7
|
+
}
|
|
8
|
+
export declare const TextInput: React.ForwardRefExoticComponent<TextInputProps & React.RefAttributes<HTMLInputElement>>;
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
// Disabling this prevents an otherwise simple wrapper around input
|
|
3
|
+
// from becoming needlessly verbose while maintaining flexibility.
|
|
4
|
+
// Keeping it enabled requires listing every possible prop.
|
|
5
|
+
import React from 'react';
|
|
6
|
+
import classNames from 'classnames';
|
|
7
|
+
import { getVariantPlaceholderClassNames, TextStyleVariantMap } from '../Text/textVariantClasses';
|
|
8
|
+
export const TextInput = React.forwardRef(({ className, borderRadius, borderColorClass, placeholderVariant, ...rest }, ref) => {
|
|
9
|
+
const variantClassNames = placeholderVariant ? TextStyleVariantMap[placeholderVariant] : {};
|
|
10
|
+
const placeholderVariantClassNames = getVariantPlaceholderClassNames(variantClassNames);
|
|
11
|
+
const inputClasses = classNames([
|
|
12
|
+
{
|
|
13
|
+
'spiffy-text-input': true,
|
|
14
|
+
'spiffy-tw-outline-none': true,
|
|
15
|
+
'spiffy-tw-rounded-[64px]': borderRadius === 'xl',
|
|
16
|
+
'spiffy-tw-rounded-[20px]': borderRadius === 'lg',
|
|
17
|
+
'spiffy-tw-rounded-[8px]': borderRadius === 'md',
|
|
18
|
+
'spiffy-tw-rounded-[0px]': borderRadius === 'sm',
|
|
19
|
+
...placeholderVariantClassNames,
|
|
20
|
+
},
|
|
21
|
+
borderColorClass,
|
|
22
|
+
className,
|
|
23
|
+
]);
|
|
24
|
+
return _jsx("input", { ref: ref, ...rest, className: inputClasses });
|
|
25
|
+
});
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
declare enum ColorNames {
|
|
2
|
+
TextPrimary = "text-primary",
|
|
3
|
+
TextSecondary = "text-secondary",
|
|
4
|
+
TextAccent = "text-accent",
|
|
5
|
+
TextLink = "text-link",
|
|
6
|
+
TextLight = "text-light",
|
|
7
|
+
BackgroundPrimary = "background-primary",
|
|
8
|
+
BackgroundSecondary = "background-secondary",
|
|
9
|
+
BackgroundSecondaryDark = "background-secondary-dark",
|
|
10
|
+
BackgroundTertiary = "background-tertiary",
|
|
11
|
+
BackgroundDark = "background-dark",
|
|
12
|
+
BackgroundLight = "background-light",
|
|
13
|
+
BackgroundSaturated = "background-saturated",
|
|
14
|
+
BorderLight = "border-light",
|
|
15
|
+
BorderMedium = "border-medium",
|
|
16
|
+
BorderDark = "border-dark",
|
|
17
|
+
BorderOutline = "border-outline",
|
|
18
|
+
AccentPrimary = "accent-primary",
|
|
19
|
+
AccentSecondary = "accent-secondary"
|
|
20
|
+
}
|
|
21
|
+
type ColorMapping = {
|
|
22
|
+
[key in ColorNames]: string;
|
|
23
|
+
};
|
|
24
|
+
declare const colorVar: (color: ColorNames) => string;
|
|
25
|
+
export { ColorNames, colorVar };
|
|
26
|
+
export type { ColorMapping };
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
var ColorNames;
|
|
2
|
+
(function (ColorNames) {
|
|
3
|
+
ColorNames["TextPrimary"] = "text-primary";
|
|
4
|
+
ColorNames["TextSecondary"] = "text-secondary";
|
|
5
|
+
ColorNames["TextAccent"] = "text-accent";
|
|
6
|
+
ColorNames["TextLink"] = "text-link";
|
|
7
|
+
ColorNames["TextLight"] = "text-light";
|
|
8
|
+
ColorNames["BackgroundPrimary"] = "background-primary";
|
|
9
|
+
ColorNames["BackgroundSecondary"] = "background-secondary";
|
|
10
|
+
ColorNames["BackgroundSecondaryDark"] = "background-secondary-dark";
|
|
11
|
+
ColorNames["BackgroundTertiary"] = "background-tertiary";
|
|
12
|
+
ColorNames["BackgroundDark"] = "background-dark";
|
|
13
|
+
ColorNames["BackgroundLight"] = "background-light";
|
|
14
|
+
ColorNames["BackgroundSaturated"] = "background-saturated";
|
|
15
|
+
ColorNames["BorderLight"] = "border-light";
|
|
16
|
+
ColorNames["BorderMedium"] = "border-medium";
|
|
17
|
+
ColorNames["BorderDark"] = "border-dark";
|
|
18
|
+
ColorNames["BorderOutline"] = "border-outline";
|
|
19
|
+
ColorNames["AccentPrimary"] = "accent-primary";
|
|
20
|
+
ColorNames["AccentSecondary"] = "accent-secondary";
|
|
21
|
+
})(ColorNames || (ColorNames = {}));
|
|
22
|
+
const colorVar = (color) => `var(--spiffy-colors-${color})`;
|
|
23
|
+
export { ColorNames, colorVar };
|
package/dist/packages/components/src/components/search/FilterScrollbar/AppliedFiltersScrollbar.d.ts
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { SelectedFilterOption } from '../../../../../../src/atoms/search/types';
|
|
2
|
+
interface AppliedFiltersScrollbarProps {
|
|
3
|
+
selectedFilterOptions: SelectedFilterOption[];
|
|
4
|
+
filterBarClassNames: string;
|
|
5
|
+
filterDefaultClasses: string;
|
|
6
|
+
filterHoverClasses: string;
|
|
7
|
+
appliedFilterBackgroundClasses: string;
|
|
8
|
+
onRemoveFilter: (filter: SelectedFilterOption) => void;
|
|
9
|
+
}
|
|
10
|
+
export declare const AppliedFiltersScrollbar: ({ selectedFilterOptions, filterBarClassNames, filterDefaultClasses, filterHoverClasses, appliedFilterBackgroundClasses, onRemoveFilter, }: AppliedFiltersScrollbarProps) => import("react/jsx-runtime").JSX.Element;
|
|
11
|
+
export {};
|