@ndlib/component-library 1.0.20 → 1.0.22

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 (259) hide show
  1. package/README.md +26 -8
  2. package/dist/assets/index-3cfb730f.js +1 -0
  3. package/dist/components/composites/Card/Card.stories.js +2 -0
  4. package/dist/components/composites/Card/index.js +4 -3
  5. package/dist/components/composites/CardV2/CardV2.module.css +74 -0
  6. package/dist/components/composites/CardV2/CardV2.stories.d.ts +19 -0
  7. package/dist/components/composites/CardV2/CardV2.stories.js +187 -0
  8. package/dist/components/composites/CardV2/CardV2.test.js +67 -0
  9. package/dist/components/composites/CardV2/index.d.ts +42 -0
  10. package/dist/components/composites/CardV2/index.js +97 -0
  11. package/dist/components/composites/DragDropList/DragDropList.stories.js +3 -1
  12. package/dist/components/composites/DropdownLinks/DropdownLinks.stories.js +2 -0
  13. package/dist/components/composites/DropdownLinks/index.d.ts +1 -1
  14. package/dist/components/composites/EmptyState/EmptyState.stories.js +2 -0
  15. package/dist/components/composites/EmptyState/index.js +1 -1
  16. package/dist/components/composites/Modal/Modal.stories.js +5 -2
  17. package/dist/components/composites/Modal/index.js +3 -2
  18. package/dist/components/composites/ModalV2/ModalV2.stories.d.ts +6 -0
  19. package/dist/components/composites/ModalV2/ModalV2.stories.js +41 -0
  20. package/dist/components/composites/ModalV2/ModalV2.test.js +37 -0
  21. package/dist/components/composites/ModalV2/index.d.ts +20 -0
  22. package/dist/components/composites/ModalV2/index.js +65 -0
  23. package/dist/components/composites/NavMenu/NavMenu.stories.js +2 -0
  24. package/dist/components/composites/NavMenu/index.js +1 -1
  25. package/dist/components/composites/Seo/seo.stories.js +2 -0
  26. package/dist/components/composites/SnackBar/SnackBar.stories.js +2 -0
  27. package/dist/components/composites/StructuredData/StructuredData.stories.js +2 -0
  28. package/dist/components/elements/Alerts/Alert.stories.js +2 -0
  29. package/dist/components/elements/Alerts/Alerts.stories.js +2 -0
  30. package/dist/components/elements/Alerts/index.js +2 -1
  31. package/dist/components/elements/ArrowLink/ArrowLink.stories.js +2 -0
  32. package/dist/components/elements/{Fields/AutoComplete → AutoComplete}/AutoComplete.stories.js +6 -4
  33. package/dist/components/elements/{Fields/AutoComplete → AutoComplete}/AutoComplete.test.js +1 -1
  34. package/dist/components/elements/{Fields/AutoComplete → AutoComplete}/index.js +3 -3
  35. package/dist/components/elements/BrandingBar/BrandingBar.stories.js +2 -0
  36. package/dist/components/elements/Button/Button.stories.js +4 -2
  37. package/dist/components/elements/ButtonV2/ButtonV2.module.css +25 -0
  38. package/dist/components/elements/ButtonV2/ButtonV2.stories.d.ts +15 -0
  39. package/dist/components/elements/ButtonV2/ButtonV2.stories.js +90 -0
  40. package/dist/components/elements/ButtonV2/ButtonV2.test.js +45 -0
  41. package/dist/components/elements/ButtonV2/index.d.ts +49 -0
  42. package/dist/components/elements/ButtonV2/index.js +136 -0
  43. package/dist/components/elements/{Fields/Checkbox → Checkbox}/Checkbox.stories.js +3 -1
  44. package/dist/components/elements/{Fields/Checkbox → Checkbox}/Checkbox.test.js +1 -1
  45. package/dist/components/elements/{Fields/Checkbox → Checkbox}/index.d.ts +1 -1
  46. package/dist/components/elements/{Fields/Checkbox → Checkbox}/index.js +2 -2
  47. package/dist/components/elements/{Fields/CheckboxGroup → CheckboxGroup}/CheckboxGroup.stories.js +3 -1
  48. package/dist/components/elements/{Fields/CheckboxGroup → CheckboxGroup}/CheckboxGroup.test.js +1 -1
  49. package/dist/components/elements/{Fields/CheckboxGroup → CheckboxGroup}/index.d.ts +1 -1
  50. package/dist/components/elements/{Fields/CheckboxGroup → CheckboxGroup}/index.js +7 -7
  51. package/dist/components/elements/CheckboxGroupV2/CheckboxGroupV2.stories.d.ts +8 -0
  52. package/dist/components/elements/CheckboxGroupV2/CheckboxGroupV2.stories.js +31 -0
  53. package/dist/components/elements/CheckboxGroupV2/CheckboxGroupV2.test.js +34 -0
  54. package/dist/components/elements/CheckboxGroupV2/index.d.ts +17 -0
  55. package/dist/components/elements/CheckboxGroupV2/index.js +50 -0
  56. package/dist/components/elements/CheckboxV2/CheckboxV2.module.css +5 -0
  57. package/dist/components/elements/CheckboxV2/CheckboxV2.stories.d.ts +6 -0
  58. package/dist/components/elements/CheckboxV2/CheckboxV2.stories.js +19 -0
  59. package/dist/components/elements/CheckboxV2/CheckboxV2.test.js +35 -0
  60. package/dist/components/elements/CheckboxV2/index.d.ts +9 -0
  61. package/dist/components/elements/CheckboxV2/index.js +22 -0
  62. package/dist/components/elements/{Fields/DatePicker → DatePicker}/DatePicker.stories.js +3 -1
  63. package/dist/components/elements/{Fields/DatePicker → DatePicker}/DatePicker.test.js +1 -1
  64. package/dist/components/elements/{Fields/DatePicker → DatePicker}/index.d.ts +1 -1
  65. package/dist/components/elements/{Fields/DatePicker → DatePicker}/index.js +2 -2
  66. package/dist/components/elements/Dropdown/Dropdown.stories.js +3 -1
  67. package/dist/components/elements/Dropdown/index.js +1 -1
  68. package/dist/components/elements/GroupV2/index.d.ts +22 -0
  69. package/dist/components/elements/GroupV2/index.js +71 -0
  70. package/dist/components/elements/{text/Heading → Heading}/Heading.stories.js +5 -3
  71. package/dist/components/elements/{text/Heading → Heading}/Heading.test.js +3 -3
  72. package/dist/components/elements/{text/Heading → Heading}/index.d.ts +3 -3
  73. package/dist/components/elements/{text/Heading → Heading}/index.js +10 -9
  74. package/dist/components/elements/HeadingV2/HeadingV2.module.css +8 -0
  75. package/dist/components/elements/HeadingV2/HeadingV2.stories.d.ts +8 -0
  76. package/dist/components/elements/HeadingV2/HeadingV2.stories.js +37 -0
  77. package/dist/components/elements/HeadingV2/HeadingV2.test.js +51 -0
  78. package/dist/components/elements/HeadingV2/index.d.ts +22 -0
  79. package/dist/components/elements/HeadingV2/index.js +100 -0
  80. package/dist/components/elements/Icon/Icon.stories.js +3 -1
  81. package/dist/components/elements/IconV2/IconV2.module.css +10 -0
  82. package/dist/components/elements/IconV2/IconV2.stories.d.ts +7 -0
  83. package/dist/components/elements/IconV2/IconV2.stories.js +31 -0
  84. package/dist/components/elements/IconV2/IconV2.test.js +62 -0
  85. package/dist/components/elements/IconV2/index.d.ts +10 -0
  86. package/dist/components/elements/IconV2/index.js +33 -0
  87. package/dist/components/elements/{text/Inline → Inline}/Inline.stories.js +2 -0
  88. package/dist/components/elements/{text/Inline → Inline}/index.d.ts +1 -1
  89. package/dist/components/elements/{text/Inline → Inline}/index.js +1 -1
  90. package/dist/components/elements/{text/Label → Label}/Label.stories.js +4 -2
  91. package/dist/components/elements/Label/Label.test.d.ts +1 -0
  92. package/dist/components/elements/{text/Label → Label}/Label.test.js +3 -3
  93. package/dist/components/elements/{text/Label → Label}/index.d.ts +2 -2
  94. package/dist/components/elements/{text/Label → Label}/index.js +3 -3
  95. package/dist/components/elements/LabelV2/LabelV2.stories.d.ts +6 -0
  96. package/dist/components/elements/LabelV2/LabelV2.stories.js +22 -0
  97. package/dist/components/elements/LabelV2/LabelV2.test.d.ts +1 -0
  98. package/dist/components/elements/LabelV2/LabelV2.test.js +56 -0
  99. package/dist/components/elements/LabelV2/index.d.ts +20 -0
  100. package/dist/components/elements/LabelV2/index.js +41 -0
  101. package/dist/components/elements/Link/Link.stories.js +3 -1
  102. package/dist/components/elements/List/List.stories.js +3 -1
  103. package/dist/components/elements/List/index.js +1 -1
  104. package/dist/components/elements/ListBox/Listbox.stories.js +2 -0
  105. package/dist/components/elements/ListBox/index.d.ts +1 -1
  106. package/dist/components/elements/ListBox/index.js +1 -1
  107. package/dist/components/elements/ListBoxV2/ListBoxV2.module.css +33 -0
  108. package/dist/components/elements/ListBoxV2/ListBoxV2.stories.d.ts +6 -0
  109. package/dist/components/elements/ListBoxV2/ListBoxV2.stories.js +19 -0
  110. package/dist/components/elements/ListBoxV2/index.d.ts +33 -0
  111. package/dist/components/elements/ListBoxV2/index.js +35 -0
  112. package/dist/components/elements/Markdown/Markdown.stories.js +2 -0
  113. package/dist/components/elements/Markdown/index.js +4 -4
  114. package/dist/components/elements/{Fields/MonthPicker → MonthPicker}/MonthPicker.stories.js +3 -1
  115. package/dist/components/elements/MonthPicker/MonthPicker.test.d.ts +1 -0
  116. package/dist/components/elements/{Fields/MonthPicker → MonthPicker}/MonthPicker.test.js +1 -1
  117. package/dist/components/elements/{Fields/MonthPicker → MonthPicker}/index.d.ts +1 -1
  118. package/dist/components/elements/{Fields/MonthPicker → MonthPicker}/index.js +2 -2
  119. package/dist/components/elements/{text/Paragraph → Paragraph}/Paragraph.stories.js +5 -3
  120. package/dist/components/elements/Paragraph/Paragraph.test.d.ts +1 -0
  121. package/dist/components/elements/{text/Paragraph → Paragraph}/Paragraph.test.js +1 -1
  122. package/dist/components/elements/{text/Paragraph → Paragraph}/index.d.ts +2 -2
  123. package/dist/components/elements/{text/Paragraph → Paragraph}/index.js +6 -5
  124. package/dist/components/elements/ParagraphV2/ParagraphV2.stories.d.ts +7 -0
  125. package/dist/components/elements/ParagraphV2/ParagraphV2.stories.js +33 -0
  126. package/dist/components/elements/ParagraphV2/ParagraphV2.test.d.ts +1 -0
  127. package/dist/components/elements/ParagraphV2/ParagraphV2.test.js +9 -0
  128. package/dist/components/elements/ParagraphV2/index.d.ts +15 -0
  129. package/dist/components/elements/ParagraphV2/index.js +39 -0
  130. package/dist/components/elements/Pill/Pill.stories.js +3 -1
  131. package/dist/components/elements/Pill/index.js +2 -1
  132. package/dist/components/elements/{Fields/Radio → Radio}/Radio.stories.js +3 -1
  133. package/dist/components/elements/Radio/Radio.test.d.ts +1 -0
  134. package/dist/components/elements/{Fields/Radio → Radio}/Radio.test.js +3 -3
  135. package/dist/components/elements/{Fields/Radio → Radio}/index.d.ts +1 -1
  136. package/dist/components/elements/{Fields/Radio → Radio}/index.js +1 -1
  137. package/dist/components/elements/{Fields/RadioGroup → RadioGroup}/RadioGroup.stories.js +3 -1
  138. package/dist/components/elements/{Fields/RadioGroup → RadioGroup}/RadioGroup.test.js +1 -1
  139. package/dist/components/elements/{Fields/RadioGroup → RadioGroup}/index.d.ts +1 -1
  140. package/dist/components/elements/{Fields/RadioGroup → RadioGroup}/index.js +6 -6
  141. package/dist/components/elements/{text/ReadMore → ReadMore}/ReadMore.stories.js +5 -3
  142. package/dist/components/elements/ReadMore/ReadMore.test.d.ts +1 -0
  143. package/dist/components/elements/{text/ReadMore → ReadMore}/ReadMore.test.js +4 -9
  144. package/dist/components/elements/{text/ReadMore → ReadMore}/index.d.ts +2 -2
  145. package/dist/components/elements/{text/ReadMore → ReadMore}/index.js +10 -9
  146. package/dist/components/elements/ReadMoreV2/ReadMoreV2.module.css +19 -0
  147. package/dist/components/elements/ReadMoreV2/ReadMoreV2.stories.d.ts +8 -0
  148. package/dist/components/elements/ReadMoreV2/ReadMoreV2.stories.js +28 -0
  149. package/dist/components/elements/ReadMoreV2/ReadMoreV2.test.d.ts +1 -0
  150. package/dist/components/elements/ReadMoreV2/ReadMoreV2.test.js +30 -0
  151. package/dist/components/elements/ReadMoreV2/index.d.ts +12 -0
  152. package/dist/components/elements/ReadMoreV2/index.js +81 -0
  153. package/dist/components/elements/{Fields/Select → Select}/Select.stories.js +6 -4
  154. package/dist/components/elements/Select/Select.test.d.ts +1 -0
  155. package/dist/components/elements/{Fields/Select → Select}/Select.test.js +1 -1
  156. package/dist/components/elements/{Fields/Select → Select}/index.d.ts +1 -1
  157. package/dist/components/elements/{Fields/Select → Select}/index.js +9 -9
  158. package/dist/components/elements/SelectV2/SelectV2.module.css +27 -0
  159. package/dist/components/elements/SelectV2/SelectV2.stories.d.ts +8 -0
  160. package/dist/components/elements/SelectV2/SelectV2.stories.js +41 -0
  161. package/dist/components/elements/SelectV2/SelectV2.test.d.ts +1 -0
  162. package/dist/components/elements/SelectV2/SelectV2.test.js +52 -0
  163. package/dist/components/elements/SelectV2/index.d.ts +18 -0
  164. package/dist/components/elements/SelectV2/index.js +164 -0
  165. package/dist/components/elements/Spinner/Spinner.stories.js +2 -0
  166. package/dist/components/elements/Spinner/index.js +1 -1
  167. package/dist/components/elements/SpinnerV2/SpinnerV2.module.css +12 -0
  168. package/dist/components/elements/SpinnerV2/SpinnerV2.stories.d.ts +7 -0
  169. package/dist/components/elements/SpinnerV2/SpinnerV2.stories.js +29 -0
  170. package/dist/components/elements/SpinnerV2/SpinnerV2.test.d.ts +1 -0
  171. package/dist/components/elements/SpinnerV2/SpinnerV2.test.js +9 -0
  172. package/dist/components/elements/SpinnerV2/index.d.ts +14 -0
  173. package/dist/components/elements/SpinnerV2/index.js +35 -0
  174. package/dist/components/elements/TabList/TabList.stories.js +2 -0
  175. package/dist/components/elements/Table/Table.stories.js +2 -0
  176. package/dist/components/elements/{Fields/TextInput → TextInput}/TextInput.stories.js +6 -4
  177. package/dist/components/elements/TextInput/TextInput.test.d.ts +1 -0
  178. package/dist/components/elements/{Fields/TextInput → TextInput}/TextInput.test.js +2 -2
  179. package/dist/components/elements/{Fields/TextInput → TextInput}/index.d.ts +3 -3
  180. package/dist/components/elements/{Fields/TextInput → TextInput}/index.js +9 -8
  181. package/dist/components/elements/TextInputV2/TextInputV2.module.css +71 -0
  182. package/dist/components/elements/TextInputV2/TextInputV2.stories.d.ts +9 -0
  183. package/dist/components/elements/TextInputV2/TextInputV2.stories.js +37 -0
  184. package/dist/components/elements/TextInputV2/TextInputV2.test.d.ts +1 -0
  185. package/dist/components/elements/TextInputV2/TextInputV2.test.js +59 -0
  186. package/dist/components/elements/TextInputV2/index.d.ts +45 -0
  187. package/dist/components/elements/TextInputV2/index.js +97 -0
  188. package/dist/components/elements/layout/Box.stories.js +2 -0
  189. package/dist/components/elements/layout/Flex.stories.js +3 -1
  190. package/dist/components/elements/layoutV2/BoxV2.d.ts +9 -0
  191. package/dist/components/elements/layoutV2/BoxV2.js +19 -0
  192. package/dist/components/elements/layoutV2/BoxV2.stories.d.ts +6 -0
  193. package/dist/components/elements/layoutV2/BoxV2.stories.js +14 -0
  194. package/dist/components/elements/layoutV2/ColumnV2.d.ts +8 -0
  195. package/dist/components/elements/layoutV2/ColumnV2.js +21 -0
  196. package/dist/components/elements/layoutV2/RowV2.d.ts +19 -0
  197. package/dist/components/elements/layoutV2/RowV2.js +54 -0
  198. package/dist/components/providers/alerts.js +5 -4
  199. package/dist/components/providers/alerts.test.d.ts +1 -0
  200. package/dist/components/providers/alerts.test.js +115 -0
  201. package/dist/components/providers/componentConfigV2.d.ts +25 -0
  202. package/dist/components/providers/componentConfigV2.js +37 -0
  203. package/dist/components/providers/media.js +1 -1
  204. package/dist/components/providers/mediaV2.d.ts +11 -0
  205. package/dist/components/providers/mediaV2.js +48 -0
  206. package/dist/components/providers/uiV2.d.ts +20 -0
  207. package/dist/components/providers/uiV2.js +16 -0
  208. package/dist/index.d.ts +34 -14
  209. package/dist/index.html +14 -0
  210. package/dist/index.js +33 -13
  211. package/dist/theme/Color.stories.js +3 -1
  212. package/dist/theme/GlobalStylesV2.d.ts +2 -0
  213. package/dist/theme/GlobalStylesV2.js +212 -0
  214. package/dist/theme/Typography.stories.js +3 -1
  215. package/dist/theme/css-variables.css +57 -0
  216. package/dist/theme/index.d.ts +127 -1
  217. package/dist/theme/index.js +14 -0
  218. package/dist/theme/typography.js +2 -2
  219. package/dist/utils/decorators/UIVersion1.d.ts +2 -0
  220. package/dist/utils/decorators/UIVersion1.js +7 -0
  221. package/dist/utils/decorators/UIVersion2.d.ts +2 -0
  222. package/dist/utils/decorators/UIVersion2.js +7 -0
  223. package/dist/utils/hooks/useFocus.d.ts +7 -0
  224. package/dist/utils/hooks/useFocus.js +12 -0
  225. package/dist/utils/processSx.d.ts +3 -0
  226. package/dist/utils/processSx.js +135 -0
  227. package/package.json +7 -4
  228. /package/dist/components/{elements/Fields/Checkbox/Checkbox.test.d.ts → composites/CardV2/CardV2.test.d.ts} +0 -0
  229. /package/dist/components/{elements/Fields/CheckboxGroup/CheckboxGroup.test.d.ts → composites/ModalV2/ModalV2.test.d.ts} +0 -0
  230. /package/dist/components/elements/{Fields/AutoComplete → AutoComplete}/AutoComplete.stories.d.ts +0 -0
  231. /package/dist/components/elements/{Fields/AutoComplete → AutoComplete}/AutoComplete.test.d.ts +0 -0
  232. /package/dist/components/elements/{Fields/AutoComplete → AutoComplete}/index.d.ts +0 -0
  233. /package/dist/components/elements/{Fields/DatePicker/DatePicker.test.d.ts → ButtonV2/ButtonV2.test.d.ts} +0 -0
  234. /package/dist/components/elements/{text/Caption → Caption}/index.d.ts +0 -0
  235. /package/dist/components/elements/{text/Caption → Caption}/index.js +0 -0
  236. /package/dist/components/elements/{Fields/Checkbox → Checkbox}/Checkbox.stories.d.ts +0 -0
  237. /package/dist/components/elements/{Fields/MonthPicker/MonthPicker.test.d.ts → Checkbox/Checkbox.test.d.ts} +0 -0
  238. /package/dist/components/elements/{Fields/CheckboxGroup → CheckboxGroup}/CheckboxGroup.stories.d.ts +0 -0
  239. /package/dist/components/elements/{Fields/Radio/Radio.test.d.ts → CheckboxGroup/CheckboxGroup.test.d.ts} +0 -0
  240. /package/dist/components/elements/{Fields/Select/Select.test.d.ts → CheckboxGroupV2/CheckboxGroupV2.test.d.ts} +0 -0
  241. /package/dist/components/elements/{text/Heading/Heading.test.d.ts → CheckboxV2/CheckboxV2.test.d.ts} +0 -0
  242. /package/dist/components/elements/{Fields/DatePicker → DatePicker}/DatePicker.stories.d.ts +0 -0
  243. /package/dist/components/elements/{text/Label/Label.test.d.ts → DatePicker/DatePicker.test.d.ts} +0 -0
  244. /package/dist/components/elements/{text/Heading → Heading}/Heading.stories.d.ts +0 -0
  245. /package/dist/components/elements/{text/Paragraph/Paragraph.test.d.ts → Heading/Heading.test.d.ts} +0 -0
  246. /package/dist/components/elements/{text/ReadMore/ReadMore.test.d.ts → HeadingV2/HeadingV2.test.d.ts} +0 -0
  247. /package/dist/components/elements/{Fields/RadioGroup/RadioGroup.test.d.ts → IconV2/IconV2.test.d.ts} +0 -0
  248. /package/dist/components/elements/{text/Inline → Inline}/Inline.stories.d.ts +0 -0
  249. /package/dist/components/elements/{text/Label → Label}/Label.stories.d.ts +0 -0
  250. /package/dist/components/elements/{Fields/MonthPicker → MonthPicker}/MonthPicker.stories.d.ts +0 -0
  251. /package/dist/components/elements/{text/Paragraph → Paragraph}/Paragraph.stories.d.ts +0 -0
  252. /package/dist/components/elements/{Fields/Radio → Radio}/Radio.stories.d.ts +0 -0
  253. /package/dist/components/elements/{Fields/RadioGroup → RadioGroup}/RadioGroup.stories.d.ts +0 -0
  254. /package/dist/components/elements/{Fields/TextInput/TextInput.test.d.ts → RadioGroup/RadioGroup.test.d.ts} +0 -0
  255. /package/dist/components/elements/{text/ReadMore → ReadMore}/ReadMore.stories.d.ts +0 -0
  256. /package/dist/components/elements/{Fields/Select → Select}/Select.stories.d.ts +0 -0
  257. /package/dist/components/elements/{Fields/TextInput → TextInput}/TextInput.stories.d.ts +0 -0
  258. /package/dist/components/elements/{Fields/option.d.ts → option.d.ts} +0 -0
  259. /package/dist/components/elements/{Fields/option.js → option.js} +0 -0
@@ -3,12 +3,14 @@ import ArrowDropDownIcon from '@mui/icons-material/ArrowDropDown';
3
3
  import { Button } from '../../elements/Button';
4
4
  import { Box } from '../../elements/layout/Box';
5
5
  import { Dropdown } from '.';
6
- import { Paragraph } from '../text/Paragraph';
6
+ import { Paragraph } from '../Paragraph';
7
7
  import { Column } from '../layout/Column';
8
+ import { UIVersion1 } from '../../../utils/decorators/UIVersion1';
8
9
  const meta = {
9
10
  title: 'Elements/Dropdown',
10
11
  component: Dropdown,
11
12
  tags: ['autodocs'],
13
+ decorators: [UIVersion1],
12
14
  };
13
15
  export default meta;
14
16
  const lorem = `Lorem ipsum dolor sit amet, consectetur adipiscing elit.
@@ -50,7 +50,7 @@ export const Dropdown = (_a) => {
50
50
  }),
51
51
  ],
52
52
  });
53
- const dropdownBoxStyles = Object.assign(Object.assign({}, floatingStyles), { minWidth: dropdownMinWidth, maxWidth: dropdownMaxWidth, zIndex: Z_INDEX.DIALOG, backgroundColor: COLOR.WHITE, boxShadow: boxShadow.NORMAL });
53
+ const dropdownBoxStyles = Object.assign(Object.assign({}, floatingStyles), { minWidth: dropdownMinWidth, maxWidth: dropdownMaxWidth, zIndex: Z_INDEX.DIALOG, backgroundColor: COLOR.WHITE, boxShadow: boxShadow === null || boxShadow === void 0 ? void 0 : boxShadow.NORMAL });
54
54
  const onClick = useCallback(() => {
55
55
  setIsOpen(!isOpen);
56
56
  }, [isOpen]);
@@ -0,0 +1,22 @@
1
+ import React from 'react';
2
+ import { StyledElementPropsV2 } from '../../../theme';
3
+ type GroupV2ContextType = {
4
+ level: number;
5
+ labelId: string;
6
+ trackHeadingRendered: () => void;
7
+ labelTargetId: string;
8
+ type?: GROUPV2_TYPE;
9
+ };
10
+ export declare enum GROUPV2_TYPE {
11
+ REGION = "region",
12
+ GROUP = "group",
13
+ RAW = "raw"
14
+ }
15
+ export declare const useGroupV2: () => GroupV2ContextType;
16
+ type GroupV2Props = Omit<StyledElementPropsV2<HTMLDivElement, {
17
+ type?: GROUPV2_TYPE;
18
+ }>, 'children'> & {
19
+ children: React.ReactNode | ((context: GroupV2ContextType) => React.ReactNode);
20
+ };
21
+ export declare const GroupV2: React.FC<GroupV2Props>;
22
+ export {};
@@ -0,0 +1,71 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import { jsx as _jsx } from "react/jsx-runtime";
13
+ import React, { useEffect, useId, useRef } from 'react';
14
+ import { useEnvironment } from '../../providers/env';
15
+ import { processSx } from '../../../utils/processSx';
16
+ export var GROUPV2_TYPE;
17
+ (function (GROUPV2_TYPE) {
18
+ GROUPV2_TYPE["REGION"] = "region";
19
+ GROUPV2_TYPE["GROUP"] = "group";
20
+ GROUPV2_TYPE["RAW"] = "raw";
21
+ })(GROUPV2_TYPE || (GROUPV2_TYPE = {}));
22
+ const GROUPV2_TYPE_ROLE_MAP = {
23
+ [GROUPV2_TYPE.REGION]: 'region',
24
+ [GROUPV2_TYPE.GROUP]: 'group',
25
+ [GROUPV2_TYPE.RAW]: 'group',
26
+ };
27
+ const GroupV2Context = React.createContext({
28
+ level: 0,
29
+ labelId: '',
30
+ labelTargetId: '',
31
+ trackHeadingRendered: () => { },
32
+ });
33
+ export const useGroupV2 = () => React.useContext(GroupV2Context);
34
+ export const GroupV2 = (_a) => {
35
+ var { type: typeProp, children, sx } = _a, rest = __rest(_a, ["type", "children", "sx"]);
36
+ const processedStyles = processSx(sx);
37
+ const { level: parentLevel } = useGroupV2();
38
+ const { flagInDevelopment } = useEnvironment();
39
+ const type = typeProp || GROUPV2_TYPE.REGION;
40
+ const uniqueId = useId();
41
+ const labelId = `group-label-${uniqueId}`;
42
+ const labelTargetId = `labeled-${uniqueId}`;
43
+ const headingRenderTracker = useRef({
44
+ hasHeadingRendered: false,
45
+ });
46
+ const trackHeadingRendered = () => {
47
+ headingRenderTracker.current.hasHeadingRendered = true;
48
+ };
49
+ useEffect(() => {
50
+ if (type === GROUPV2_TYPE.REGION) {
51
+ setTimeout(() => {
52
+ if (!headingRenderTracker.current.hasHeadingRendered) {
53
+ flagInDevelopment('Every <GroupV2> component of type "region" must render a <Heading> component within it');
54
+ }
55
+ }, 500);
56
+ }
57
+ }, [flagInDevelopment, type]);
58
+ const level = Math.min(parentLevel + (type === GROUPV2_TYPE.REGION ? 1 : 0), 5);
59
+ const contextValue = {
60
+ level,
61
+ type,
62
+ trackHeadingRendered,
63
+ labelId,
64
+ labelTargetId,
65
+ };
66
+ const Main = (_jsx(GroupV2Context.Provider, Object.assign({ value: contextValue }, { children: typeof children === 'function' ? children(contextValue) : children })));
67
+ if (type === GROUPV2_TYPE.RAW) {
68
+ return Main;
69
+ }
70
+ return (_jsx("div", Object.assign({ role: GROUPV2_TYPE_ROLE_MAP[type], "aria-labelledby": labelId, style: Object.assign({ marginTop: '0.5rem', marginBottom: '0.5rem' }, processedStyles) }, rest, { children: Main })));
71
+ };
@@ -1,12 +1,14 @@
1
1
  import { jsx as _jsx } from "react/jsx-runtime";
2
- import { GROUP_TYPE, Group } from '../../Group';
2
+ import { GROUP_TYPE, Group } from '../Group';
3
3
  import { HEADING_SIZE, Heading } from '.';
4
- import { Column } from '../../layout/Column';
5
- import { COLOR } from '../../../../theme/colors';
4
+ import { Column } from '../layout/Column';
5
+ import { COLOR } from '../../../theme/colors';
6
+ import { UIVersion1 } from '../../../utils/decorators/UIVersion1';
6
7
  const meta = {
7
8
  title: 'Elements/Heading',
8
9
  component: Heading,
9
10
  tags: ['autodocs'],
11
+ decorators: [UIVersion1],
10
12
  };
11
13
  export default meta;
12
14
  const sizes = [
@@ -9,10 +9,10 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
9
9
  };
10
10
  import { jsx as _jsx } from "react/jsx-runtime";
11
11
  import { vi } from 'vitest';
12
- import { render as _render } from '../../../../utils/test';
12
+ import { render as _render } from '../../../utils/test';
13
13
  import { Heading } from '.';
14
- import { GROUP_TYPE, Group } from '../../Group';
15
- import { ENVIRONMENT } from '../../../providers/env';
14
+ import { GROUP_TYPE, Group } from '../Group';
15
+ import { ENVIRONMENT } from '../../providers/env';
16
16
  const render = (component) => {
17
17
  return _render(component, { env: ENVIRONMENT.DEV });
18
18
  };
@@ -1,7 +1,7 @@
1
1
  import React from 'react';
2
- import { TYPOGRAPHY_TYPE } from '../../../../theme/typography';
3
- import { StyledElementProps } from '../../../../theme';
4
- import { COLOR } from '../../../../theme/colors';
2
+ import { TYPOGRAPHY_TYPE } from '../../../theme/typography';
3
+ import { StyledElementProps } from '../../../theme';
4
+ import { COLOR } from '../../../theme/colors';
5
5
  type HeaderProps = StyledElementProps<HTMLSpanElement, {
6
6
  size?: HEADING_SIZE;
7
7
  standalone?: boolean;
@@ -11,12 +11,12 @@ var __rest = (this && this.__rest) || function (s, e) {
11
11
  };
12
12
  import { jsx as _jsx } from "theme-ui/jsx-runtime";
13
13
  import { useEffect } from 'react';
14
- import { getTypographyStyles, TYPOGRAPHY_TYPE, } from '../../../../theme/typography';
15
- import { useTheme } from '../../../../theme';
16
- import { GROUP_TYPE, useGroup } from '../../Group';
17
- import { COLOR } from '../../../../theme/colors';
18
- import { useEnvironment } from '../../../providers/env';
19
- import { multiplyRemSize } from '../../../../utils/misc';
14
+ import { getTypographyStyles, TYPOGRAPHY_TYPE } from '../../../theme/typography';
15
+ import { useTheme } from '../../../theme';
16
+ import { GROUP_TYPE, useGroup } from '../Group';
17
+ import { COLOR } from '../../../theme/colors';
18
+ import { useEnvironment } from '../../providers/env';
19
+ import { multiplyRemSize } from '../../../utils/misc';
20
20
  export var HEADING_SIZE;
21
21
  (function (HEADING_SIZE) {
22
22
  HEADING_SIZE["SM"] = "sm";
@@ -39,7 +39,8 @@ const LEVEL_TYPOGRAPHY_MAP = {
39
39
  6: TYPOGRAPHY_TYPE.HEADING_SMALL,
40
40
  };
41
41
  export const Heading = (_a) => {
42
- var { sx, size, standalone, id, underline, underlineColor, headlineStyles, typography: typographyProp, level: levelParam } = _a, rest = __rest(_a, ["sx", "size", "standalone", "id", "underline", "underlineColor", "headlineStyles", "typography", "level"]);
42
+ var _b, _c;
43
+ var { sx, size, standalone, id, underline, underlineColor, typography: typographyProp, level: levelParam } = _a, rest = __rest(_a, ["sx", "size", "standalone", "id", "underline", "underlineColor", "typography", "level"]);
43
44
  const { level: groupLevel, type, trackHeadingRendered } = useGroup();
44
45
  const { flagInDevelopment } = useEnvironment();
45
46
  const theme = useTheme();
@@ -68,9 +69,9 @@ export const Heading = (_a) => {
68
69
  }
69
70
  return 0.55;
70
71
  };
71
- const marginHeightMultiple = theme.lineHeights[typographyStyles.lineHeight] *
72
+ const marginHeightMultiple = (((_b = theme.lineHeights) === null || _b === void 0 ? void 0 : _b[typographyStyles.lineHeight]) || 1.625) *
72
73
  getMarginHeightMultiple(level);
73
- const fontSize = theme.fontSizes[typographyStyles.fontSize];
74
+ const fontSize = ((_c = theme.fontSizes) === null || _c === void 0 ? void 0 : _c[typographyStyles.fontSize]) || '1rem';
74
75
  const topMargin = multiplyRemSize({
75
76
  size: fontSize,
76
77
  multiple: marginHeightMultiple,
@@ -0,0 +1,8 @@
1
+ .heading {
2
+ padding-top: 0;
3
+ padding-bottom: 0;
4
+ border: 0;
5
+ border-style: solid;
6
+ border-bottom-color: var(--secondary);
7
+ color: var(--primary);
8
+ }
@@ -0,0 +1,8 @@
1
+ import type { Meta, StoryObj } from '@storybook/react';
2
+ import { HeadingV2 } from '.';
3
+ declare const meta: Meta<typeof HeadingV2>;
4
+ export default meta;
5
+ type Story = StoryObj<typeof HeadingV2>;
6
+ export declare const Default: Story;
7
+ export declare const Color: Story;
8
+ export declare const Underline: Story;
@@ -0,0 +1,37 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { GROUPV2_TYPE, GroupV2 } from '../GroupV2';
3
+ import { HEADINGV2_SIZE, HeadingV2 } from '.';
4
+ import { ColumnV2 } from '../layoutV2/ColumnV2';
5
+ import { COLOR } from '../../../theme/colors';
6
+ import { UIVersion2 } from '../../../utils/decorators/UIVersion2';
7
+ const meta = {
8
+ title: 'Elements/HeadingV2',
9
+ component: HeadingV2,
10
+ tags: ['autodocs'],
11
+ decorators: [UIVersion2],
12
+ };
13
+ export default meta;
14
+ const sizes = [
15
+ { size: HEADINGV2_SIZE.XL, label: 'Extra Large (Default Level 1)' },
16
+ { size: HEADINGV2_SIZE.LG, label: 'Large (Default Level 2)' },
17
+ { size: HEADINGV2_SIZE.MD, label: 'Medium (Default Level 3)' },
18
+ { size: HEADINGV2_SIZE.SM, label: 'Small (Default Level 4-6)' },
19
+ ];
20
+ export const Default = {
21
+ render: () => (_jsx(ColumnV2, { children: sizes.map((size) => (_jsx(GroupV2, Object.assign({ type: GROUPV2_TYPE.REGION }, { children: _jsx(HeadingV2, Object.assign({ size: size.size }, { children: size.label })) })))) })),
22
+ args: {
23
+ children: 'Heading V2',
24
+ },
25
+ };
26
+ export const Color = {
27
+ render: () => (_jsx(ColumnV2, { children: sizes.map((size) => (_jsx(GroupV2, Object.assign({ type: GROUPV2_TYPE.REGION }, { children: _jsx(HeadingV2, Object.assign({ size: size.size, sx: { color: COLOR.TEXT } }, { children: size.label })) })))) })),
28
+ args: {
29
+ children: 'Heading V2',
30
+ },
31
+ };
32
+ export const Underline = {
33
+ render: () => (_jsx(ColumnV2, { children: sizes.map((size) => (_jsx(GroupV2, Object.assign({ type: GROUPV2_TYPE.REGION }, { children: _jsx(HeadingV2, Object.assign({ size: size.size, underline: true }, { children: size.label })) })))) })),
34
+ args: {
35
+ children: 'Heading V2',
36
+ },
37
+ };
@@ -0,0 +1,51 @@
1
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
+ return new (P || (P = Promise))(function (resolve, reject) {
4
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
8
+ });
9
+ };
10
+ import { jsx as _jsx } from "react/jsx-runtime";
11
+ import { vi } from 'vitest';
12
+ import { render as _render } from '../../../utils/test';
13
+ import { HeadingV2 } from '.';
14
+ import { GROUPV2_TYPE, GroupV2 } from '../GroupV2';
15
+ import { ENVIRONMENT } from '../../providers/env';
16
+ const render = (component) => {
17
+ return _render(component, { env: ENVIRONMENT.DEV });
18
+ };
19
+ describe('HeadingV2', () => {
20
+ const originalError = console.error;
21
+ beforeEach(() => {
22
+ console.error = vi.fn();
23
+ });
24
+ afterEach(() => {
25
+ console.error = originalError;
26
+ vi.useRealTimers();
27
+ });
28
+ it('renders without an error if passed standalone prop', () => {
29
+ const { getByText } = render(_jsx(HeadingV2, Object.assign({ standalone: true }, { children: "Foo" })));
30
+ expect(getByText('Foo')).toBeInTheDocument();
31
+ });
32
+ it('renders without an error if used within region Group component', () => {
33
+ const { getByText } = render(_jsx(GroupV2, { children: _jsx(HeadingV2, { children: "Foo" }) }));
34
+ expect(getByText('Foo')).toBeInTheDocument();
35
+ });
36
+ it('throws if used outside a Group component', () => __awaiter(void 0, void 0, void 0, function* () {
37
+ expect(() => render(_jsx(HeadingV2, { children: "Foo" }))).toThrow();
38
+ }));
39
+ it('throws if used within non-region Group component', () => __awaiter(void 0, void 0, void 0, function* () {
40
+ expect(() => render(_jsx(GroupV2, Object.assign({ type: GROUPV2_TYPE.GROUP }, { children: _jsx(HeadingV2, { children: "Foo" }) })))).toThrow();
41
+ }));
42
+ it('labels group target automatically', () => {
43
+ const { getByText } = render(_jsx(GroupV2, { children: _jsx(HeadingV2, { children: "Foo" }) }));
44
+ expect(getByText('Foo')).toBeDefined();
45
+ });
46
+ it('is required to render region Group component', () => __awaiter(void 0, void 0, void 0, function* () {
47
+ vi.useFakeTimers();
48
+ render(_jsx(GroupV2, { children: "Foo" }));
49
+ expect(() => vi.runAllTimers()).toThrow();
50
+ }));
51
+ });
@@ -0,0 +1,22 @@
1
+ import React from 'react';
2
+ import { TYPOGRAPHY_TYPE } from '../../../theme/typography';
3
+ import { StyledElementPropsV2 } from '../../../theme';
4
+ import { COLOR } from '../../../theme/colors';
5
+ type HeaderV2Props = StyledElementPropsV2<HTMLSpanElement, {
6
+ size?: HEADINGV2_SIZE;
7
+ standalone?: boolean;
8
+ id?: string;
9
+ underline?: boolean;
10
+ underlineColor?: COLOR;
11
+ typography?: TYPOGRAPHY_TYPE;
12
+ headlineStyles?: any;
13
+ level?: number;
14
+ }>;
15
+ export declare enum HEADINGV2_SIZE {
16
+ SM = "sm",
17
+ MD = "md",
18
+ LG = "lg",
19
+ XL = "xl"
20
+ }
21
+ export declare const HeadingV2: React.FC<HeaderV2Props>;
22
+ export {};
@@ -0,0 +1,100 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import { jsx as _jsx } from "react/jsx-runtime";
13
+ import { useEffect } from 'react';
14
+ import { fontStyles, getTypographyStyles, TYPOGRAPHY_TYPE, } from '../../../theme/typography';
15
+ import { GROUPV2_TYPE, useGroupV2 } from '../GroupV2';
16
+ import { useEnvironment } from '../../providers/env';
17
+ import { multiplyRemSize } from '../../../utils/misc';
18
+ import { processSx } from '../../../utils/processSx';
19
+ import * as styles from './HeadingV2.module.css';
20
+ export var HEADINGV2_SIZE;
21
+ (function (HEADINGV2_SIZE) {
22
+ HEADINGV2_SIZE["SM"] = "sm";
23
+ HEADINGV2_SIZE["MD"] = "md";
24
+ HEADINGV2_SIZE["LG"] = "lg";
25
+ HEADINGV2_SIZE["XL"] = "xl";
26
+ })(HEADINGV2_SIZE || (HEADINGV2_SIZE = {}));
27
+ const SIZE_TYPOGRAPHY_MAP = {
28
+ [HEADINGV2_SIZE.SM]: TYPOGRAPHY_TYPE.HEADING_SMALL,
29
+ [HEADINGV2_SIZE.MD]: TYPOGRAPHY_TYPE.HEADING_MEDIUM,
30
+ [HEADINGV2_SIZE.LG]: TYPOGRAPHY_TYPE.HEADING_LARGE,
31
+ [HEADINGV2_SIZE.XL]: TYPOGRAPHY_TYPE.HEADING_XLARGE,
32
+ };
33
+ const LEVEL_TYPOGRAPHY_MAP = {
34
+ 1: TYPOGRAPHY_TYPE.HEADING_XLARGE,
35
+ 2: TYPOGRAPHY_TYPE.HEADING_LARGE,
36
+ 3: TYPOGRAPHY_TYPE.HEADING_MEDIUM,
37
+ 4: TYPOGRAPHY_TYPE.HEADING_SMALL,
38
+ 5: TYPOGRAPHY_TYPE.HEADING_SMALL,
39
+ 6: TYPOGRAPHY_TYPE.HEADING_SMALL,
40
+ };
41
+ export const HeadingV2 = (_a) => {
42
+ var { sx, size, standalone, id, underline, underlineColor, typography: typographyProp, level: levelParam } = _a, rest = __rest(_a, ["sx", "size", "standalone", "id", "underline", "underlineColor", "typography", "level"]);
43
+ const { level: groupLevel, type, trackHeadingRendered } = useGroupV2();
44
+ const { flagInDevelopment } = useEnvironment();
45
+ const level = levelParam || groupLevel;
46
+ useEffect(() => {
47
+ trackHeadingRendered();
48
+ });
49
+ let typography = TYPOGRAPHY_TYPE.HEADING_MEDIUM;
50
+ if (typographyProp) {
51
+ typography = typographyProp;
52
+ }
53
+ else if (size) {
54
+ typography = SIZE_TYPOGRAPHY_MAP[size];
55
+ }
56
+ else if (level) {
57
+ typography =
58
+ LEVEL_TYPOGRAPHY_MAP[level];
59
+ }
60
+ const typographyStyles = getTypographyStyles(typography);
61
+ const typeSafeStyles = styles;
62
+ const getMarginHeightMultiple = (level) => {
63
+ if (level > 4) {
64
+ return 0.75;
65
+ }
66
+ if (level === 1 || level === 2) {
67
+ return 0.375;
68
+ }
69
+ return 0.55;
70
+ };
71
+ const marginHeightMultiple = fontStyles.lineHeights[typographyStyles.lineHeight] *
72
+ getMarginHeightMultiple(level);
73
+ const fontSize = fontStyles.fontSizes[typographyStyles.fontSize];
74
+ const topMargin = multiplyRemSize({
75
+ size: fontSize,
76
+ multiple: marginHeightMultiple,
77
+ });
78
+ if (type !== GROUPV2_TYPE.REGION && !standalone) {
79
+ flagInDevelopment('Heading component should be used within a Group component with property type={GROUP_TYPE.REGION} or given the standalone flag');
80
+ }
81
+ const processedStyles = processSx(sx);
82
+ const processedTypography = processSx(getTypographyStyles(typography));
83
+ const headerProps = Object.assign({ id: id, role: 'heading', 'aria-level': level, style: Object.assign(Object.assign({ borderBottomWidth: underline ? '2px' : 0, borderBottomColor: underlineColor ? underlineColor : '', marginTop: topMargin }, processedTypography), processedStyles) }, rest);
84
+ switch (level) {
85
+ case 1:
86
+ return _jsx("h1", Object.assign({ className: typeSafeStyles.heading }, headerProps));
87
+ case 2:
88
+ return _jsx("h2", Object.assign({ className: typeSafeStyles.heading }, headerProps));
89
+ case 3:
90
+ return _jsx("h3", Object.assign({ className: typeSafeStyles.heading }, headerProps));
91
+ case 4:
92
+ return _jsx("h4", Object.assign({ className: typeSafeStyles.heading }, headerProps));
93
+ case 5:
94
+ return _jsx("h5", Object.assign({ className: typeSafeStyles.heading }, headerProps));
95
+ case 6:
96
+ return _jsx("h6", Object.assign({ className: typeSafeStyles.heading }, headerProps));
97
+ default:
98
+ return _jsx("h6", Object.assign({ className: typeSafeStyles.heading }, headerProps));
99
+ }
100
+ };
@@ -1,14 +1,16 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import { GROUP_TYPE, Group } from '../Group';
3
- import { HEADING_SIZE, Heading } from '../text/Heading';
3
+ import { HEADING_SIZE, Heading } from '../Heading';
4
4
  import { Column } from '../layout/Column';
5
5
  import { Icon } from './';
6
6
  import AccessAlarmIcon from '@mui/icons-material/AccessAlarm';
7
7
  import { COLOR } from '../../../theme/colors';
8
8
  import { FONT_SIZE } from '../../../theme/typography';
9
+ import { UIVersion1 } from '../../../utils/decorators/UIVersion1';
9
10
  const meta = {
10
11
  title: 'Elements/Icon',
11
12
  component: Icon,
13
+ decorators: [UIVersion1],
12
14
  };
13
15
  export default meta;
14
16
  const sizes = [
@@ -0,0 +1,10 @@
1
+ .iconWrapper {
2
+ display: flex;
3
+ align-items: center;
4
+ justify-content: center;
5
+
6
+ &:hover {
7
+ cursor: pointer;
8
+ transform: scale(1.05);
9
+ }
10
+ }
@@ -0,0 +1,7 @@
1
+ import type { Meta, StoryObj } from '@storybook/react';
2
+ import { IconV2 } from '.';
3
+ declare const meta: Meta<typeof IconV2>;
4
+ export default meta;
5
+ type Story = StoryObj<typeof IconV2>;
6
+ export declare const Default: Story;
7
+ export declare const CustomColor: Story;
@@ -0,0 +1,31 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { GROUPV2_TYPE, GroupV2 } from '../GroupV2';
3
+ import { HEADINGV2_SIZE, HeadingV2 } from '../HeadingV2';
4
+ import { ColumnV2 } from '../layoutV2/ColumnV2';
5
+ import { IconV2 } from '.';
6
+ import AccessAlarmIcon from '@mui/icons-material/AccessAlarm';
7
+ import { COLOR } from '../../../theme/colors';
8
+ import { FONT_SIZE } from '../../../theme/typography';
9
+ import { UIVersion2 } from '../../../utils/decorators/UIVersion2';
10
+ const meta = {
11
+ title: 'Elements/IconV2',
12
+ component: IconV2,
13
+ decorators: [UIVersion2],
14
+ };
15
+ export default meta;
16
+ const sizes = [
17
+ { size: FONT_SIZE.XXL, label: 'XX Large' },
18
+ { size: FONT_SIZE.XL, label: 'X Large' },
19
+ { size: FONT_SIZE.LG, label: 'Large' },
20
+ { size: FONT_SIZE.ML, label: 'Medium Large' },
21
+ { size: FONT_SIZE.MD, label: 'Medium' },
22
+ { size: FONT_SIZE.MS, label: 'Medium Small' },
23
+ { size: FONT_SIZE.SM, label: 'Small' },
24
+ { size: FONT_SIZE.XS, label: 'X Small' },
25
+ ];
26
+ export const Default = {
27
+ render: () => (_jsx(ColumnV2, { children: sizes.map((size) => (_jsxs(GroupV2, Object.assign({ type: GROUPV2_TYPE.REGION }, { children: [_jsx(HeadingV2, Object.assign({ size: HEADINGV2_SIZE.MD }, { children: size.label })), _jsx(IconV2, { icon: AccessAlarmIcon, size: size.size })] })))) })),
28
+ };
29
+ export const CustomColor = {
30
+ render: () => (_jsx(IconV2, { icon: AccessAlarmIcon, color: COLOR.SECONDARY, size: FONT_SIZE.LG })),
31
+ };
@@ -0,0 +1,62 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { render, screen, fireEvent } from '@testing-library/react';
3
+ import '@testing-library/jest-dom';
4
+ import { vi, describe, it, beforeEach, afterEach, expect } from 'vitest';
5
+ import { IconV2 } from '.';
6
+ import { COLOR } from '../../../theme/colors';
7
+ import { FONT_SIZE } from '../../../theme/typography';
8
+ import { useEnvironment } from '../../providers/env';
9
+ vi.mock('../../providers/env', () => ({
10
+ useEnvironment: vi.fn(),
11
+ }));
12
+ describe('IconV2 Component', () => {
13
+ const MockIcon = () => _jsx("svg", { "data-testid": "mock-icon" });
14
+ const mockFlagInDevelopment = vi.fn();
15
+ beforeEach(() => {
16
+ ;
17
+ useEnvironment.mockReturnValue({
18
+ flagInDevelopment: mockFlagInDevelopment,
19
+ });
20
+ });
21
+ afterEach(() => {
22
+ vi.clearAllMocks();
23
+ });
24
+ it('renders the icon component', () => {
25
+ render(_jsx(IconV2, { icon: MockIcon }));
26
+ expect(screen.getByTestId('mock-icon')).toBeInTheDocument();
27
+ });
28
+ it('applies the correct size and color', () => {
29
+ render(_jsx(IconV2, { icon: MockIcon, size: FONT_SIZE.LG, color: COLOR.SECONDARY }));
30
+ const iconElement = screen.getByTestId('mock-icon');
31
+ expect(iconElement).toHaveStyle({
32
+ fontSize: 'inherit',
33
+ color: 'color: rgb(211, 159, 16)',
34
+ });
35
+ });
36
+ it('calls flagInDevelopment if onClick is provided without aria-label', () => {
37
+ render(_jsx(IconV2, { icon: MockIcon, onClick: vi.fn() }));
38
+ expect(mockFlagInDevelopment).toHaveBeenCalledWith('Icon component with onClick should have an aria-label and tabIndex={0}');
39
+ });
40
+ it('does not call flagInDevelopment if onClick is provided with aria-label', () => {
41
+ render(_jsx(IconV2, { icon: MockIcon, onClick: vi.fn(), "aria-label": "icon" }));
42
+ expect(mockFlagInDevelopment).not.toHaveBeenCalled();
43
+ });
44
+ it('renders with tabIndex and role when onClick is provided', () => {
45
+ render(_jsx(IconV2, { icon: MockIcon, onClick: vi.fn(), "aria-label": "icon" }));
46
+ const divElement = screen.getByRole('button');
47
+ expect(divElement).toHaveAttribute('tabIndex', '0');
48
+ });
49
+ it('does not render with tabIndex and role when onClick is not provided', () => {
50
+ render(_jsx(IconV2, { icon: MockIcon }));
51
+ const divElement = screen.getByTestId('mock-icon').parentElement;
52
+ expect(divElement).not.toHaveAttribute('tabIndex');
53
+ expect(divElement).not.toHaveAttribute('role', 'button');
54
+ });
55
+ it('handles onClick event', () => {
56
+ const handleClick = vi.fn();
57
+ render(_jsx(IconV2, { icon: MockIcon, onClick: handleClick, "aria-label": "icon" }));
58
+ const divElement = screen.getByRole('button');
59
+ fireEvent.click(divElement);
60
+ expect(handleClick).toHaveBeenCalledTimes(1);
61
+ });
62
+ });
@@ -0,0 +1,10 @@
1
+ import React from 'react';
2
+ import { COLOR } from '../../../theme/colors';
3
+ import { StyledElementPropsV2 } from '../../../theme';
4
+ import { FONT_SIZE } from '../../../theme/typography';
5
+ export type IconV2Props = StyledElementPropsV2<HTMLDivElement, {
6
+ icon: React.FC<any>;
7
+ size?: FONT_SIZE;
8
+ color?: COLOR;
9
+ }>;
10
+ export declare const IconV2: React.FC<IconV2Props>;
@@ -0,0 +1,33 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import { jsx as _jsx } from "react/jsx-runtime";
13
+ import React from 'react';
14
+ import { COLOR, colors } from '../../../theme/colors';
15
+ import { useEnvironment } from '../../providers/env';
16
+ import { processSx } from '../../../utils/processSx';
17
+ import * as styles from './IconV2.module.css';
18
+ const typeSafeStyles = styles;
19
+ export const IconV2 = (_a) => {
20
+ var { icon, size, color, sx, onClick } = _a, rest = __rest(_a, ["icon", "size", "color", "sx", "onClick"]);
21
+ const InnerComponent = icon;
22
+ const processedStyles = processSx(Object.assign({ fontSize: size }, sx));
23
+ const { flagInDevelopment } = useEnvironment();
24
+ if (onClick && !rest['aria-label']) {
25
+ flagInDevelopment('Icon component with onClick should have an aria-label and tabIndex={0}');
26
+ }
27
+ return (_jsx("div", Object.assign({ tabIndex: onClick ? 0 : undefined, role: onClick ? 'button' : 'none', onClick: onClick, className: typeSafeStyles.iconWrapper, style: processedStyles }, rest, { children: React.createElement(InnerComponent, {
28
+ style: {
29
+ fontSize: 'inherit',
30
+ color: colors[color || COLOR.PRIMARY],
31
+ },
32
+ }) })));
33
+ };
@@ -1,10 +1,12 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import { Bold, Italic } from '.';
3
3
  import { Paragraph } from '../Paragraph';
4
+ import { UIVersion1 } from '../../../utils/decorators/UIVersion1';
4
5
  const meta = {
5
6
  title: 'Elements/Inline',
6
7
  component: Bold,
7
8
  tags: ['autodocs'],
9
+ decorators: [UIVersion1],
8
10
  };
9
11
  export default meta;
10
12
  export const Default = {
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
- import { StyledElementProps } from '../../../../theme';
2
+ import { StyledElementProps } from '../../../theme';
3
3
  type InlineProps = StyledElementProps<HTMLSpanElement>;
4
4
  export declare const Bold: React.FC<InlineProps>;
5
5
  export declare const Italic: React.FC<InlineProps>;