@times-components/ts-components 1.150.0 → 1.151.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (54) hide show
  1. package/CHANGELOG.md +11 -0
  2. package/dist/components/clarkson-says/ClarksonSays.stories.d.ts +1 -0
  3. package/dist/components/clarkson-says/ClarksonSays.stories.js +5 -0
  4. package/dist/components/clarkson-says/assets/ChatIcon.d.ts +1 -0
  5. package/dist/components/clarkson-says/assets/ChatIcon.js +8 -0
  6. package/dist/components/clarkson-says/assets/ChevronDown.d.ts +1 -0
  7. package/dist/components/clarkson-says/assets/ChevronDown.js +7 -0
  8. package/dist/components/clarkson-says/assets/OpenAIIcon.d.ts +1 -0
  9. package/dist/components/clarkson-says/assets/OpenAIIcon.js +8 -0
  10. package/dist/components/clarkson-says/components/CardHero.d.ts +3 -0
  11. package/dist/components/clarkson-says/components/CardHero.js +12 -0
  12. package/dist/components/clarkson-says/components/CategoriesRows.d.ts +6 -0
  13. package/dist/components/clarkson-says/components/CategoriesRows.js +41 -0
  14. package/dist/components/clarkson-says/components/ErrorView.d.ts +6 -0
  15. package/dist/components/clarkson-says/components/ErrorView.js +32 -0
  16. package/dist/components/clarkson-says/components/GradientOverlay.d.ts +1 -0
  17. package/dist/components/clarkson-says/components/GradientOverlay.js +73 -0
  18. package/dist/components/clarkson-says/components/LoadingView.d.ts +7 -0
  19. package/dist/components/clarkson-says/components/LoadingView.js +42 -0
  20. package/dist/components/clarkson-says/components/ProductBetaBadge.d.ts +7 -0
  21. package/dist/components/clarkson-says/components/ProductBetaBadge.js +208 -0
  22. package/dist/components/clarkson-says/components/ResponseCard.d.ts +9 -0
  23. package/dist/components/clarkson-says/components/ResponseCard.js +45 -0
  24. package/dist/components/clarkson-says/components/styles.d.ts +102 -0
  25. package/dist/components/clarkson-says/components/styles.js +379 -0
  26. package/dist/components/clarkson-says/data/clarkson-responses.json +1788 -0
  27. package/dist/components/clarkson-says/index.d.ts +4 -0
  28. package/dist/components/clarkson-says/index.js +84 -0
  29. package/dist/components/clarkson-says/types.d.ts +22 -0
  30. package/dist/components/clarkson-says/types.js +2 -0
  31. package/dist/components/clarkson-says/utils.d.ts +3 -0
  32. package/dist/components/clarkson-says/utils.js +32 -0
  33. package/dist/index.d.ts +1 -0
  34. package/dist/index.js +2 -1
  35. package/jest.config.js +4 -2
  36. package/package.json +13 -13
  37. package/rnw.js +1 -1
  38. package/src/components/clarkson-says/ClarksonSays.stories.tsx +7 -0
  39. package/src/components/clarkson-says/assets/ChatIcon.tsx +33 -0
  40. package/src/components/clarkson-says/assets/ChevronDown.tsx +28 -0
  41. package/src/components/clarkson-says/assets/OpenAIIcon.tsx +34 -0
  42. package/src/components/clarkson-says/components/CardHero.tsx +20 -0
  43. package/src/components/clarkson-says/components/CategoriesRows.tsx +90 -0
  44. package/src/components/clarkson-says/components/ErrorView.tsx +53 -0
  45. package/src/components/clarkson-says/components/GradientOverlay.tsx +83 -0
  46. package/src/components/clarkson-says/components/LoadingView.tsx +70 -0
  47. package/src/components/clarkson-says/components/ProductBetaBadge.tsx +294 -0
  48. package/src/components/clarkson-says/components/ResponseCard.tsx +144 -0
  49. package/src/components/clarkson-says/components/styles.ts +434 -0
  50. package/src/components/clarkson-says/data/clarkson-responses.json +1788 -0
  51. package/src/components/clarkson-says/index.tsx +133 -0
  52. package/src/components/clarkson-says/types.ts +23 -0
  53. package/src/components/clarkson-says/utils.ts +35 -0
  54. package/src/index.ts +1 -0
package/CHANGELOG.md CHANGED
@@ -3,6 +3,17 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ # [1.151.0](https://github.com/newsuk/times-components/compare/@times-components/ts-components@1.150.0...@times-components/ts-components@1.151.0) (2026-02-02)
7
+
8
+
9
+ ### Features
10
+
11
+ * **TLAB-7:** Clarkson says POC ([#4266](https://github.com/newsuk/times-components/issues/4266)) ([3a919a2](https://github.com/newsuk/times-components/commit/3a919a2f77dcd290a0c83ceb90e5b8d6c5bc10e1))
12
+
13
+
14
+
15
+
16
+
6
17
  # [1.150.0](https://github.com/newsuk/times-components/compare/@times-components/ts-components@1.149.0...@times-components/ts-components@1.150.0) (2026-02-02)
7
18
 
8
19
 
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+ import { ClarksonSays } from './index';
3
+ import { storiesOf } from '@storybook/react';
4
+ storiesOf('Typescript Component/Clarkson Says', module).add('Default', () => (React.createElement(ClarksonSays, null)));
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2xhcmtzb25TYXlzLnN0b3JpZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy9jbGFya3Nvbi1zYXlzL0NsYXJrc29uU2F5cy5zdG9yaWVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssTUFBTSxPQUFPLENBQUM7QUFDMUIsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUN2QyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFN0MsU0FBUyxDQUFDLG9DQUFvQyxFQUFFLE1BQU0sQ0FBQyxDQUFDLEdBQUcsQ0FBQyxTQUFTLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FDM0Usb0JBQUMsWUFBWSxPQUFHLENBQ2pCLENBQUMsQ0FBQyJ9
@@ -0,0 +1 @@
1
+ export declare const ChatIcon: () => JSX.Element;
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ export const ChatIcon = () => (React.createElement("svg", { width: "40", height: "40", viewBox: "0 0 40 40", fill: "none", xmlns: "http://www.w3.org/2000/svg", xmlnsXlink: "http://www.w3.org/1999/xlink" },
3
+ React.createElement("rect", { width: "40", height: "40", fill: "url(#pattern0_8547_143321)" }),
4
+ React.createElement("defs", null,
5
+ React.createElement("pattern", { id: "pattern0_8547_143321", patternContentUnits: "objectBoundingBox", width: "1", height: "1" },
6
+ React.createElement("use", { xlinkHref: "#image0_8547_143321", transform: "translate(-0.00516529) scale(0.00206612)" })),
7
+ React.createElement("image", { id: "image0_8547_143321", width: "489", height: "484", preserveAspectRatio: "none", xlinkHref: "" }))));
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2hhdEljb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9jbGFya3Nvbi1zYXlzL2Fzc2V0cy9DaGF0SWNvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE1BQU0sT0FBTyxDQUFDO0FBQzFCLE1BQU0sQ0FBQyxNQUFNLFFBQVEsR0FBRyxHQUFHLEVBQUUsQ0FBQyxDQUM1Qiw2QkFDRSxLQUFLLEVBQUMsSUFBSSxFQUNWLE1BQU0sRUFBQyxJQUFJLEVBQ1gsT0FBTyxFQUFDLFdBQVcsRUFDbkIsSUFBSSxFQUFDLE1BQU0sRUFDWCxLQUFLLEVBQUMsNEJBQTRCLEVBQ2xDLFVBQVUsRUFBQyw4QkFBOEI7SUFFekMsOEJBQU0sS0FBSyxFQUFDLElBQUksRUFBQyxNQUFNLEVBQUMsSUFBSSxFQUFDLElBQUksRUFBQyw0QkFBNEIsR0FBRztJQUNqRTtRQUNFLGlDQUNFLEVBQUUsRUFBQyxzQkFBc0IsRUFDekIsbUJBQW1CLEVBQUMsbUJBQW1CLEVBQ3ZDLEtBQUssRUFBQyxHQUFHLEVBQ1QsTUFBTSxFQUFDLEdBQUc7WUFFViw2QkFDRSxTQUFTLEVBQUMscUJBQXFCLEVBQy9CLFNBQVMsRUFBQywwQ0FBMEMsR0FDcEQsQ0FDTTtRQUNWLCtCQUNFLEVBQUUsRUFBQyxvQkFBb0IsRUFDdkIsS0FBSyxFQUFDLEtBQUssRUFDWCxNQUFNLEVBQUMsS0FBSyxFQUNaLG1CQUFtQixFQUFDLE1BQU0sRUFDMUIsU0FBUyxFQUFDLDRtNEJBQTRtNEIsR0FDdG40QixDQUNHLENBQ0gsQ0FDUCxDQUFDIn0=
@@ -0,0 +1 @@
1
+ export declare const ChevronDown: () => JSX.Element;
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+ export const ChevronDown = () => (React.createElement("svg", { width: "16", height: "16", viewBox: "0 0 16 16", fill: "none", xmlns: "http://www.w3.org/2000/svg" },
3
+ React.createElement("mask", { id: "mask0_8576_2", style: { maskType: 'alpha' }, maskUnits: "userSpaceOnUse", x: "0", y: "0", width: "16", height: "16" },
4
+ React.createElement("path", { d: "M11.06 5.72656L8 8.7799L4.94 5.72656L4 6.66656L8 10.6666L12 6.66656L11.06 5.72656Z", fill: "#0A0A0A" })),
5
+ React.createElement("g", { mask: "url(#mask0_8576_2)" },
6
+ React.createElement("rect", { width: "16", height: "16", fill: "#005C8A" }))));
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2hldnJvbkRvd24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9jbGFya3Nvbi1zYXlzL2Fzc2V0cy9DaGV2cm9uRG93bi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE1BQU0sT0FBTyxDQUFDO0FBQzFCLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyxHQUFHLEVBQUUsQ0FBQyxDQUMvQiw2QkFDRSxLQUFLLEVBQUMsSUFBSSxFQUNWLE1BQU0sRUFBQyxJQUFJLEVBQ1gsT0FBTyxFQUFDLFdBQVcsRUFDbkIsSUFBSSxFQUFDLE1BQU0sRUFDWCxLQUFLLEVBQUMsNEJBQTRCO0lBRWxDLDhCQUNFLEVBQUUsRUFBQyxjQUFjLEVBQ2pCLEtBQUssRUFBRSxFQUFFLFFBQVEsRUFBRSxPQUFPLEVBQUUsRUFDNUIsU0FBUyxFQUFDLGdCQUFnQixFQUMxQixDQUFDLEVBQUMsR0FBRyxFQUNMLENBQUMsRUFBQyxHQUFHLEVBQ0wsS0FBSyxFQUFDLElBQUksRUFDVixNQUFNLEVBQUMsSUFBSTtRQUVYLDhCQUNFLENBQUMsRUFBQyxvRkFBb0YsRUFDdEYsSUFBSSxFQUFDLFNBQVMsR0FDZCxDQUNHO0lBQ1AsMkJBQUcsSUFBSSxFQUFDLG9CQUFvQjtRQUMxQiw4QkFBTSxLQUFLLEVBQUMsSUFBSSxFQUFDLE1BQU0sRUFBQyxJQUFJLEVBQUMsSUFBSSxFQUFDLFNBQVMsR0FBRyxDQUM1QyxDQUNBLENBQ1AsQ0FBQyJ9
@@ -0,0 +1 @@
1
+ export declare const OpenAIIcon: () => JSX.Element;
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ export const OpenAIIcon = () => (React.createElement("svg", { width: "59", height: "16", viewBox: "0 0 59 16", fill: "none", xmlns: "http://www.w3.org/2000/svg", xmlnsXlink: "http://www.w3.org/1999/xlink" },
3
+ React.createElement("rect", { width: "59", height: "16", fill: "url(#pattern0_8547_147345)" }),
4
+ React.createElement("defs", null,
5
+ React.createElement("pattern", { id: "pattern0_8547_147345", patternContentUnits: "objectBoundingBox", width: "1", height: "1" },
6
+ React.createElement("use", { xlinkHref: "#image0_8547_147345", transform: "matrix(0.00104167 0 0 0.00384115 0 -0.00126953)" })),
7
+ React.createElement("image", { id: "image0_8547_147345", width: "960", height: "261", preserveAspectRatio: "none", xlinkHref: "" }))));
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiT3BlbkFJSWNvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL2NsYXJrc29uLXNheXMvYXNzZXRzL09wZW5BSUljb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxNQUFNLE9BQU8sQ0FBQztBQUUxQixNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUcsR0FBRyxFQUFFLENBQUMsQ0FDOUIsNkJBQ0UsS0FBSyxFQUFDLElBQUksRUFDVixNQUFNLEVBQUMsSUFBSSxFQUNYLE9BQU8sRUFBQyxXQUFXLEVBQ25CLElBQUksRUFBQyxNQUFNLEVBQ1gsS0FBSyxFQUFDLDRCQUE0QixFQUNsQyxVQUFVLEVBQUMsOEJBQThCO0lBRXpDLDhCQUFNLEtBQUssRUFBQyxJQUFJLEVBQUMsTUFBTSxFQUFDLElBQUksRUFBQyxJQUFJLEVBQUMsNEJBQTRCLEdBQUc7SUFDakU7UUFDRSxpQ0FDRSxFQUFFLEVBQUMsc0JBQXNCLEVBQ3pCLG1CQUFtQixFQUFDLG1CQUFtQixFQUN2QyxLQUFLLEVBQUMsR0FBRyxFQUNULE1BQU0sRUFBQyxHQUFHO1lBRVYsNkJBQ0UsU0FBUyxFQUFDLHFCQUFxQixFQUMvQixTQUFTLEVBQUMsaURBQWlELEdBQzNELENBQ007UUFDViwrQkFDRSxFQUFFLEVBQUMsb0JBQW9CLEVBQ3ZCLEtBQUssRUFBQyxLQUFLLEVBQ1gsTUFBTSxFQUFDLEtBQUssRUFDWixtQkFBbUIsRUFBQyxNQUFNLEVBQzFCLFNBQVMsRUFBQyw0MXNDQUE0MXNDLEdBQ3Qyc0MsQ0FDRyxDQUNILENBQ1AsQ0FBQyJ9
@@ -0,0 +1,3 @@
1
+ export declare function CardHero({ isApp }: {
2
+ isApp?: boolean;
3
+ }): JSX.Element;
@@ -0,0 +1,12 @@
1
+ import React from 'react';
2
+ import { HeroRow, TitleGroup, H1, H2, TitleContainer } from './styles';
3
+ import { ChatIcon } from '../assets/ChatIcon';
4
+ export function CardHero({ isApp }) {
5
+ return (React.createElement(HeroRow, null,
6
+ React.createElement(TitleGroup, null,
7
+ React.createElement(TitleContainer, null,
8
+ React.createElement(H1, null, "Clarkson Says"),
9
+ React.createElement(ChatIcon, null)),
10
+ React.createElement(H2, { isApp: isApp }, "Curious what Jeremy Clarkson really thinks? Explore his views on the topics below."))));
11
+ }
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2FyZEhlcm8uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9jbGFya3Nvbi1zYXlzL2NvbXBvbmVudHMvQ2FyZEhlcm8udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxNQUFNLE9BQU8sQ0FBQztBQUMxQixPQUFPLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLGNBQWMsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUN2RSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFOUMsTUFBTSxVQUFVLFFBQVEsQ0FBQyxFQUFFLEtBQUssRUFBdUI7SUFDckQsT0FBTyxDQUNMLG9CQUFDLE9BQU87UUFDTixvQkFBQyxVQUFVO1lBQ1Qsb0JBQUMsY0FBYztnQkFDYixvQkFBQyxFQUFFLHdCQUFtQjtnQkFDdEIsb0JBQUMsUUFBUSxPQUFHLENBQ0c7WUFDakIsb0JBQUMsRUFBRSxJQUFDLEtBQUssRUFBRSxLQUFLLHlGQUdYLENBQ00sQ0FDTCxDQUNYLENBQUM7QUFDSixDQUFDIn0=
@@ -0,0 +1,6 @@
1
+ import { ClarksonResponse } from '../types';
2
+ export declare function CategoriesRows({ topics, handleTopicClick }: {
3
+ topics: ClarksonResponse[];
4
+ handleTopicClick: (topic: ClarksonResponse) => void;
5
+ isLoading?: boolean;
6
+ }): JSX.Element;
@@ -0,0 +1,41 @@
1
+ import React, { useMemo, useState } from 'react';
2
+ import { TopicsWrap, CategoryTopicButton, CategoryRowContainer, ShowMoreButton, TopicCount, CategorySubheading, CategoryHeader, ShowMoreButtonContainer } from './styles';
3
+ import clarksonResponses from '../data/clarkson-responses.json';
4
+ import { ChevronDown } from '../assets/ChevronDown';
5
+ export function CategoriesRows({ topics, handleTopicClick }) {
6
+ const categories = clarksonResponses.categories || [];
7
+ const topicByTitle = useMemo(() => {
8
+ const map = new Map();
9
+ topics.forEach(t => map.set(t.title, t));
10
+ return map;
11
+ }, [topics]);
12
+ const [expanded, setExpanded] = useState({});
13
+ const toggleExpanded = (id) => {
14
+ setExpanded(prev => ({ ...prev, [id]: !prev[id] }));
15
+ };
16
+ return (React.createElement("div", null, categories.map(cat => {
17
+ const items = cat.topics
18
+ .map(name => topicByTitle.get(name))
19
+ .filter(Boolean);
20
+ if (items.length === 0) {
21
+ return null;
22
+ }
23
+ const isExpanded = !!expanded[cat.id];
24
+ const initialCount = 4;
25
+ const visibleItems = isExpanded ? items : items.slice(0, initialCount);
26
+ const remaining = Math.max(items.length - initialCount, 0);
27
+ return (React.createElement(CategoryRowContainer, { key: cat.id },
28
+ React.createElement(CategoryHeader, null,
29
+ React.createElement(CategorySubheading, null, cat.title),
30
+ React.createElement(TopicCount, null,
31
+ items.length,
32
+ " topics")),
33
+ React.createElement(TopicsWrap, null, visibleItems.map(topic => (React.createElement(CategoryTopicButton, { key: topic.title, onClick: () => handleTopicClick(topic) }, topic.title)))),
34
+ remaining > 0 && (React.createElement(ShowMoreButtonContainer, { "aria-expanded": isExpanded },
35
+ React.createElement(ShowMoreButton, { onClick: () => toggleExpanded(cat.id), "aria-expanded": isExpanded }, isExpanded
36
+ ? 'Hide additional topics'
37
+ : `Show ${remaining} more topics`),
38
+ React.createElement(ChevronDown, null)))));
39
+ })));
40
+ }
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2F0ZWdvcmllc1Jvd3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9jbGFya3Nvbi1zYXlzL2NvbXBvbmVudHMvQ2F0ZWdvcmllc1Jvd3MudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxFQUFFLEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLE9BQU8sQ0FBQztBQUVqRCxPQUFPLEVBQ0wsVUFBVSxFQUNWLG1CQUFtQixFQUNuQixvQkFBb0IsRUFDcEIsY0FBYyxFQUNkLFVBQVUsRUFDVixrQkFBa0IsRUFDbEIsY0FBYyxFQUNkLHVCQUF1QixFQUN4QixNQUFNLFVBQVUsQ0FBQztBQUNsQixPQUFPLGlCQUFpQixNQUFNLGlDQUFpQyxDQUFDO0FBQ2hFLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUVwRCxNQUFNLFVBQVUsY0FBYyxDQUFDLEVBQzdCLE1BQU0sRUFDTixnQkFBZ0IsRUFLakI7SUFDQyxNQUFNLFVBQVUsR0FBZ0IsaUJBQXlCLENBQUMsVUFBVSxJQUFJLEVBQUUsQ0FBQztJQUUzRSxNQUFNLFlBQVksR0FBRyxPQUFPLENBQzFCLEdBQUcsRUFBRTtRQUNILE1BQU0sR0FBRyxHQUFHLElBQUksR0FBRyxFQUE0QixDQUFDO1FBQ2hELE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN6QyxPQUFPLEdBQUcsQ0FBQztJQUNiLENBQUMsRUFDRCxDQUFDLE1BQU0sQ0FBQyxDQUNULENBQUM7SUFFRixNQUFNLENBQUMsUUFBUSxFQUFFLFdBQVcsQ0FBQyxHQUFHLFFBQVEsQ0FBMEIsRUFBRSxDQUFDLENBQUM7SUFFdEUsTUFBTSxjQUFjLEdBQUcsQ0FBQyxFQUFVLEVBQUUsRUFBRTtRQUNwQyxXQUFXLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLEVBQUUsR0FBRyxJQUFJLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUN0RCxDQUFDLENBQUM7SUFFRixPQUFPLENBQ0wsaUNBQ0csVUFBVSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsRUFBRTtRQUNwQixNQUFNLEtBQUssR0FBRyxHQUFHLENBQUMsTUFBTTthQUNyQixHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO2FBQ25DLE1BQU0sQ0FBQyxPQUFPLENBQXVCLENBQUM7UUFDekMsSUFBSSxLQUFLLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtZQUN0QixPQUFPLElBQUksQ0FBQztTQUNiO1FBRUQsTUFBTSxVQUFVLEdBQUcsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDdEMsTUFBTSxZQUFZLEdBQUcsQ0FBQyxDQUFDO1FBQ3ZCLE1BQU0sWUFBWSxHQUFHLFVBQVUsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxZQUFZLENBQUMsQ0FBQztRQUN2RSxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsWUFBWSxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBRTNELE9BQU8sQ0FDTCxvQkFBQyxvQkFBb0IsSUFBQyxHQUFHLEVBQUUsR0FBRyxDQUFDLEVBQUU7WUFDL0Isb0JBQUMsY0FBYztnQkFDYixvQkFBQyxrQkFBa0IsUUFBRSxHQUFHLENBQUMsS0FBSyxDQUFzQjtnQkFDcEQsb0JBQUMsVUFBVTtvQkFBRSxLQUFLLENBQUMsTUFBTTs4QkFBcUIsQ0FDL0I7WUFDakIsb0JBQUMsVUFBVSxRQUNSLFlBQVksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUN6QixvQkFBQyxtQkFBbUIsSUFDbEIsR0FBRyxFQUFFLEtBQUssQ0FBQyxLQUFLLEVBQ2hCLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsSUFFckMsS0FBSyxDQUFDLEtBQUssQ0FDUSxDQUN2QixDQUFDLENBQ1M7WUFDWixTQUFTLEdBQUcsQ0FBQyxJQUFJLENBQ2hCLG9CQUFDLHVCQUF1QixxQkFBZ0IsVUFBVTtnQkFDaEQsb0JBQUMsY0FBYyxJQUNiLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxtQkFDdEIsVUFBVSxJQUV4QixVQUFVO29CQUNULENBQUMsQ0FBQyx3QkFBd0I7b0JBQzFCLENBQUMsQ0FBQyxRQUFRLFNBQVMsY0FBYyxDQUNwQjtnQkFDakIsb0JBQUMsV0FBVyxPQUFHLENBQ1MsQ0FDM0IsQ0FDb0IsQ0FDeEIsQ0FBQztJQUNKLENBQUMsQ0FBQyxDQUNFLENBQ1AsQ0FBQztBQUNKLENBQUMifQ==
@@ -0,0 +1,6 @@
1
+ interface ErrorViewProps {
2
+ isApp?: boolean;
3
+ resetResponse: () => void;
4
+ }
5
+ export declare function ErrorView({ isApp, resetResponse }: ErrorViewProps): JSX.Element;
6
+ export {};
@@ -0,0 +1,32 @@
1
+ import React from 'react';
2
+ import { BackButton, Overlay, TopBar } from './styles';
3
+ export function ErrorView({ isApp, resetResponse }) {
4
+ return (React.createElement(Overlay, { isApp: isApp },
5
+ React.createElement(TopBar, { isApp: isApp }),
6
+ React.createElement("div", { style: {
7
+ display: 'flex',
8
+ flexDirection: 'column',
9
+ justifyContent: 'center',
10
+ alignItems: 'center',
11
+ padding: 32,
12
+ height: '100%',
13
+ width: '100%'
14
+ } },
15
+ React.createElement("p", { style: {
16
+ color: isApp ? '#fca5a5' : '#ef4444',
17
+ fontSize: 18,
18
+ fontWeight: 600,
19
+ textAlign: 'center'
20
+ } },
21
+ "Something went wrong.",
22
+ React.createElement("br", null),
23
+ " If the problem persists, please try again later."),
24
+ React.createElement(BackButton, { isApp: isApp, onClick: resetResponse },
25
+ React.createElement("span", { style: {
26
+ fontWeight: 700,
27
+ fontSize: 20,
28
+ lineHeight: 1
29
+ } }, "\u2190"),
30
+ React.createElement("span", null, "Go back")))));
31
+ }
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRXJyb3JWaWV3LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvY2xhcmtzb24tc2F5cy9jb21wb25lbnRzL0Vycm9yVmlldy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE1BQU0sT0FBTyxDQUFDO0FBQzFCLE9BQU8sRUFBRSxVQUFVLEVBQUUsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLFVBQVUsQ0FBQztBQU92RCxNQUFNLFVBQVUsU0FBUyxDQUFDLEVBQ3hCLEtBQUssRUFDTCxhQUFhLEVBQ0U7SUFDZixPQUFPLENBQ0wsb0JBQUMsT0FBTyxJQUFDLEtBQUssRUFBRSxLQUFLO1FBQ25CLG9CQUFDLE1BQU0sSUFBQyxLQUFLLEVBQUUsS0FBSyxHQUFJO1FBQ3hCLDZCQUNFLEtBQUssRUFBRTtnQkFDTCxPQUFPLEVBQUUsTUFBTTtnQkFDZixhQUFhLEVBQUUsUUFBUTtnQkFDdkIsY0FBYyxFQUFFLFFBQVE7Z0JBQ3hCLFVBQVUsRUFBRSxRQUFRO2dCQUNwQixPQUFPLEVBQUUsRUFBRTtnQkFDWCxNQUFNLEVBQUUsTUFBTTtnQkFDZCxLQUFLLEVBQUUsTUFBTTthQUNkO1lBRUQsMkJBQ0UsS0FBSyxFQUFFO29CQUNMLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsU0FBUztvQkFDcEMsUUFBUSxFQUFFLEVBQUU7b0JBQ1osVUFBVSxFQUFFLEdBQUc7b0JBQ2YsU0FBUyxFQUFFLFFBQVE7aUJBQ3BCOztnQkFHRCwrQkFBTTtvRUFDSjtZQUNKLG9CQUFDLFVBQVUsSUFBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxhQUFhO2dCQUM5Qyw4QkFDRSxLQUFLLEVBQUU7d0JBQ0wsVUFBVSxFQUFFLEdBQUc7d0JBQ2YsUUFBUSxFQUFFLEVBQUU7d0JBQ1osVUFBVSxFQUFFLENBQUM7cUJBQ2QsYUFHSTtnQkFDUCw0Q0FBb0IsQ0FDVCxDQUNULENBQ0UsQ0FDWCxDQUFDO0FBQ0osQ0FBQyJ9
@@ -0,0 +1 @@
1
+ export declare function GradientOverlay(): JSX.Element;
@@ -0,0 +1,73 @@
1
+ import React from 'react';
2
+ import styled from 'styled-components';
3
+ const Wrapper = styled.div({
4
+ position: 'absolute',
5
+ top: '-20px',
6
+ left: '50%',
7
+ transform: 'translateX(-50%)',
8
+ width: '100%',
9
+ maxWidth: '1045px',
10
+ height: '432px',
11
+ overflow: 'hidden',
12
+ pointerEvents: 'none'
13
+ });
14
+ const Inner = styled.div({
15
+ position: 'relative',
16
+ width: '100%',
17
+ maxWidth: '1015px',
18
+ height: '264px',
19
+ transform: 'rotate(9.714deg)',
20
+ margin: '2rem auto 0',
21
+ opacity: 0.3
22
+ });
23
+ const sharedBlobStyles = {
24
+ position: 'absolute',
25
+ borderRadius: '9999px',
26
+ filter: 'blur(57px)'
27
+ };
28
+ const Blob1 = styled.div({
29
+ ...sharedBlobStyles,
30
+ width: '251px',
31
+ height: '83px',
32
+ background: '#00E5FF',
33
+ top: '154px',
34
+ left: '564px',
35
+ transform: 'matrix(0.988304, -0.152496, 0.400202, 0.916427, 0, 0)'
36
+ });
37
+ const Blob2 = styled.div({
38
+ ...sharedBlobStyles,
39
+ width: '254px',
40
+ height: '99px',
41
+ background: '#CCB2F7',
42
+ top: '187px',
43
+ left: '269px',
44
+ transform: 'matrix(0.985307, -0.170793, 0.440438, 0.897783, 0, 0)'
45
+ });
46
+ const Blob3 = styled.div({
47
+ ...sharedBlobStyles,
48
+ width: '68px',
49
+ height: '96px',
50
+ background: '#FF007E',
51
+ opacity: 0.6,
52
+ top: '207px',
53
+ left: '130px',
54
+ transform: 'matrix(0.746322, 0.665585, -0.786773, 0.617243, 0, 0)'
55
+ });
56
+ const Blob4 = styled.div({
57
+ ...sharedBlobStyles,
58
+ width: '136px',
59
+ height: '128px',
60
+ background: '#97B6FF',
61
+ top: '123px',
62
+ left: '862px',
63
+ transform: 'matrix(0.831079, -0.556154, 0.730325, 0.6831, 0, 0)'
64
+ });
65
+ export function GradientOverlay() {
66
+ return (React.createElement(Wrapper, null,
67
+ React.createElement(Inner, null,
68
+ React.createElement(Blob1, null),
69
+ React.createElement(Blob2, null),
70
+ React.createElement(Blob3, null),
71
+ React.createElement(Blob4, null))));
72
+ }
73
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiR3JhZGllbnRPdmVybGF5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvY2xhcmtzb24tc2F5cy9jb21wb25lbnRzL0dyYWRpZW50T3ZlcmxheS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE1BQU0sT0FBTyxDQUFDO0FBQzFCLE9BQU8sTUFBTSxNQUFNLG1CQUFtQixDQUFDO0FBQ3ZDLE1BQU0sT0FBTyxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUM7SUFDekIsUUFBUSxFQUFFLFVBQVU7SUFDcEIsR0FBRyxFQUFFLE9BQU87SUFDWixJQUFJLEVBQUUsS0FBSztJQUNYLFNBQVMsRUFBRSxrQkFBa0I7SUFDN0IsS0FBSyxFQUFFLE1BQU07SUFDYixRQUFRLEVBQUUsUUFBUTtJQUNsQixNQUFNLEVBQUUsT0FBTztJQUNmLFFBQVEsRUFBRSxRQUFRO0lBQ2xCLGFBQWEsRUFBRSxNQUFNO0NBQ3RCLENBQUMsQ0FBQztBQUVILE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUM7SUFDdkIsUUFBUSxFQUFFLFVBQVU7SUFDcEIsS0FBSyxFQUFFLE1BQU07SUFDYixRQUFRLEVBQUUsUUFBUTtJQUNsQixNQUFNLEVBQUUsT0FBTztJQUNmLFNBQVMsRUFBRSxrQkFBa0I7SUFDN0IsTUFBTSxFQUFFLGFBQWE7SUFDckIsT0FBTyxFQUFFLEdBQUc7Q0FDYixDQUFDLENBQUM7QUFFSCxNQUFNLGdCQUFnQixHQUFHO0lBQ3ZCLFFBQVEsRUFBRSxVQUFtQjtJQUM3QixZQUFZLEVBQUUsUUFBUTtJQUN0QixNQUFNLEVBQUUsWUFBWTtDQUNyQixDQUFDO0FBRUYsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQztJQUN2QixHQUFHLGdCQUFnQjtJQUNuQixLQUFLLEVBQUUsT0FBTztJQUNkLE1BQU0sRUFBRSxNQUFNO0lBQ2QsVUFBVSxFQUFFLFNBQVM7SUFDckIsR0FBRyxFQUFFLE9BQU87SUFDWixJQUFJLEVBQUUsT0FBTztJQUNiLFNBQVMsRUFBRSx1REFBdUQ7Q0FDbkUsQ0FBQyxDQUFDO0FBRUgsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQztJQUN2QixHQUFHLGdCQUFnQjtJQUNuQixLQUFLLEVBQUUsT0FBTztJQUNkLE1BQU0sRUFBRSxNQUFNO0lBQ2QsVUFBVSxFQUFFLFNBQVM7SUFDckIsR0FBRyxFQUFFLE9BQU87SUFDWixJQUFJLEVBQUUsT0FBTztJQUNiLFNBQVMsRUFBRSx1REFBdUQ7Q0FDbkUsQ0FBQyxDQUFDO0FBRUgsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQztJQUN2QixHQUFHLGdCQUFnQjtJQUNuQixLQUFLLEVBQUUsTUFBTTtJQUNiLE1BQU0sRUFBRSxNQUFNO0lBQ2QsVUFBVSxFQUFFLFNBQVM7SUFDckIsT0FBTyxFQUFFLEdBQUc7SUFDWixHQUFHLEVBQUUsT0FBTztJQUNaLElBQUksRUFBRSxPQUFPO0lBQ2IsU0FBUyxFQUFFLHVEQUF1RDtDQUNuRSxDQUFDLENBQUM7QUFFSCxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDO0lBQ3ZCLEdBQUcsZ0JBQWdCO0lBQ25CLEtBQUssRUFBRSxPQUFPO0lBQ2QsTUFBTSxFQUFFLE9BQU87SUFDZixVQUFVLEVBQUUsU0FBUztJQUNyQixHQUFHLEVBQUUsT0FBTztJQUNaLElBQUksRUFBRSxPQUFPO0lBQ2IsU0FBUyxFQUFFLHFEQUFxRDtDQUNqRSxDQUFDLENBQUM7QUFFSCxNQUFNLFVBQVUsZUFBZTtJQUM3QixPQUFPLENBQ0wsb0JBQUMsT0FBTztRQUNOLG9CQUFDLEtBQUs7WUFDSixvQkFBQyxLQUFLLE9BQUc7WUFDVCxvQkFBQyxLQUFLLE9BQUc7WUFDVCxvQkFBQyxLQUFLLE9BQUc7WUFDVCxvQkFBQyxLQUFLLE9BQUcsQ0FDSCxDQUNBLENBQ1gsQ0FBQztBQUNKLENBQUMifQ==
@@ -0,0 +1,7 @@
1
+ interface LoadingViewProps {
2
+ isApp?: boolean;
3
+ progress?: number;
4
+ selectedTopic?: string;
5
+ }
6
+ export declare function LoadingView({ isApp, progress, selectedTopic }: LoadingViewProps): JSX.Element;
7
+ export {};
@@ -0,0 +1,42 @@
1
+ import React, { useEffect, useState } from 'react';
2
+ import { loadingMessages } from '../utils';
3
+ import { Overlay, ProgressBarShell, Spinner } from './styles';
4
+ import { GradientOverlay } from './GradientOverlay';
5
+ const INTERVAL = 2000;
6
+ export function LoadingView({ isApp, progress, selectedTopic }) {
7
+ // Loading message carousel
8
+ const [loadingIndex, setLoadingIndex] = useState(0);
9
+ useEffect(() => {
10
+ const interval = setInterval(() => {
11
+ setLoadingIndex(prev => (prev + 1) % loadingMessages.length);
12
+ }, INTERVAL);
13
+ return () => clearInterval(interval);
14
+ }, []);
15
+ return (React.createElement(Overlay, { isApp: isApp },
16
+ React.createElement(GradientOverlay, null),
17
+ React.createElement(ProgressBarShell, { isApp: isApp, width: progress }),
18
+ React.createElement("div", { style: {
19
+ height: '100%',
20
+ display: 'flex',
21
+ flexDirection: 'column',
22
+ justifyContent: 'flex-start',
23
+ alignItems: 'center',
24
+ padding: '48px 16px 16px'
25
+ } },
26
+ React.createElement(Spinner, { isApp: isApp }),
27
+ selectedTopic && (React.createElement("p", { style: {
28
+ fontSize: 32,
29
+ marginBlockEnd: 24,
30
+ fontWeight: 600,
31
+ fontFamily: 'Times Modern, serif',
32
+ color: isApp ? '#fff' : '#1a1a1a'
33
+ } }, selectedTopic[0].toUpperCase() + selectedTopic.slice(1))),
34
+ React.createElement("p", { style: {
35
+ color: isApp ? '#9ca3af' : '#727272',
36
+ fontFamily: 'Roboto, sans-serif',
37
+ fontSize: 16,
38
+ textAlign: 'center',
39
+ maxWidth: 300
40
+ } }, loadingMessages[loadingIndex]))));
41
+ }
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTG9hZGluZ1ZpZXcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9jbGFya3Nvbi1zYXlzL2NvbXBvbmVudHMvTG9hZGluZ1ZpZXcudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxFQUFFLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxNQUFNLE9BQU8sQ0FBQztBQUNuRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsT0FBTyxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQzlELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUVwRCxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUM7QUFRdEIsTUFBTSxVQUFVLFdBQVcsQ0FBQyxFQUMxQixLQUFLLEVBQ0wsUUFBUSxFQUNSLGFBQWEsRUFDSTtJQUNqQiwyQkFBMkI7SUFDM0IsTUFBTSxDQUFDLFlBQVksRUFBRSxlQUFlLENBQUMsR0FBRyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDcEQsU0FBUyxDQUFDLEdBQUcsRUFBRTtRQUNiLE1BQU0sUUFBUSxHQUFHLFdBQVcsQ0FBQyxHQUFHLEVBQUU7WUFDaEMsZUFBZSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLEdBQUcsZUFBZSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQy9ELENBQUMsRUFBRSxRQUFRLENBQUMsQ0FBQztRQUNiLE9BQU8sR0FBRyxFQUFFLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3ZDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUVQLE9BQU8sQ0FDTCxvQkFBQyxPQUFPLElBQUMsS0FBSyxFQUFFLEtBQUs7UUFDbkIsb0JBQUMsZUFBZSxPQUFHO1FBQ25CLG9CQUFDLGdCQUFnQixJQUFDLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLFFBQVEsR0FBSTtRQUNuRCw2QkFDRSxLQUFLLEVBQUU7Z0JBQ0wsTUFBTSxFQUFFLE1BQU07Z0JBQ2QsT0FBTyxFQUFFLE1BQU07Z0JBQ2YsYUFBYSxFQUFFLFFBQVE7Z0JBQ3ZCLGNBQWMsRUFBRSxZQUFZO2dCQUM1QixVQUFVLEVBQUUsUUFBUTtnQkFDcEIsT0FBTyxFQUFFLGdCQUFnQjthQUMxQjtZQUVELG9CQUFDLE9BQU8sSUFBQyxLQUFLLEVBQUUsS0FBSyxHQUFJO1lBQ3hCLGFBQWEsSUFBSSxDQUNoQiwyQkFDRSxLQUFLLEVBQUU7b0JBQ0wsUUFBUSxFQUFFLEVBQUU7b0JBQ1osY0FBYyxFQUFFLEVBQUU7b0JBQ2xCLFVBQVUsRUFBRSxHQUFHO29CQUNmLFVBQVUsRUFBRSxxQkFBcUI7b0JBQ2pDLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsU0FBUztpQkFDbEMsSUFFQSxhQUFhLENBQUMsQ0FBQyxDQUFDLENBQUMsV0FBVyxFQUFFLEdBQUcsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FDdEQsQ0FDTDtZQUNELDJCQUNFLEtBQUssRUFBRTtvQkFDTCxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFNBQVM7b0JBQ3BDLFVBQVUsRUFBRSxvQkFBb0I7b0JBQ2hDLFFBQVEsRUFBRSxFQUFFO29CQUNaLFNBQVMsRUFBRSxRQUFRO29CQUNuQixRQUFRLEVBQUUsR0FBRztpQkFDZCxJQUVBLGVBQWUsQ0FBQyxZQUFZLENBQUMsQ0FDNUIsQ0FDQSxDQUNFLENBQ1gsQ0FBQztBQUNKLENBQUMifQ==
@@ -0,0 +1,7 @@
1
+ export declare type BadgeVariant = 'pill' | 'rectangular';
2
+ interface ProductBetaBadgeProps {
3
+ variant?: BadgeVariant;
4
+ className?: string;
5
+ }
6
+ export declare function ProductBetaBadge({ variant, className }: ProductBetaBadgeProps): JSX.Element;
7
+ export {};