@spaced-out/ui-design-system 0.3.38-beta.0 → 0.3.39-beta.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 (307) hide show
  1. package/.cspell/custom-words.txt +4 -0
  2. package/.github/workflows/publish_to_npm.yml +32 -4
  3. package/CHANGELOG.md +16 -0
  4. package/dts-generator/.editorconfig +10 -0
  5. package/dts-generator/.gitattributes +4 -0
  6. package/dts-generator/README.md +63 -0
  7. package/dts-generator/convert.js +101 -0
  8. package/dts-generator/package.json +16 -0
  9. package/gulpfile.js +20 -1
  10. package/lib/components/Avatar/Avatar.d.ts +264 -0
  11. package/lib/components/Avatar/index.d.ts +1 -0
  12. package/lib/components/AvatarGroup/AvatarGroup.d.ts +161 -0
  13. package/lib/components/AvatarGroup/index.d.ts +1 -0
  14. package/lib/components/Badge/Badge.d.ts +138 -0
  15. package/lib/components/Badge/index.d.ts +1 -0
  16. package/lib/components/Banner/Banner.d.ts +52 -0
  17. package/lib/components/Banner/index.d.ts +1 -0
  18. package/lib/components/Breadcrumbs/BreadcrumbLink/BreadcrumbLink.d.ts +50 -0
  19. package/lib/components/Breadcrumbs/BreadcrumbLink/index.d.ts +1 -0
  20. package/lib/components/Breadcrumbs/Breadcrumbs.d.ts +64 -0
  21. package/lib/components/Breadcrumbs/index.d.ts +2 -0
  22. package/lib/components/Button/Button.d.ts +288 -0
  23. package/lib/components/Button/index.d.ts +14 -0
  24. package/lib/components/ButtonDropdown/ButtonDropdown.d.ts +192 -0
  25. package/lib/components/ButtonDropdown/SimpleButtonDropdown.d.ts +148 -0
  26. package/lib/components/ButtonDropdown/index.d.ts +2 -0
  27. package/lib/components/ButtonTabs/ButtonTab/ButtonTab.d.ts +82 -0
  28. package/lib/components/ButtonTabs/ButtonTab/index.d.ts +1 -0
  29. package/lib/components/ButtonTabs/ButtonTabDropdown.d.ts +118 -0
  30. package/lib/components/ButtonTabs/ButtonTabs.d.ts +113 -0
  31. package/lib/components/ButtonTabs/index.d.ts +2 -0
  32. package/lib/components/Card/Card.d.ts +163 -0
  33. package/lib/components/Card/index.d.ts +1 -0
  34. package/lib/components/Charts/ChartTooltip/index.d.ts +10 -0
  35. package/lib/components/Charts/ChartWrapper/ChartWrapper.d.ts +184 -0
  36. package/lib/components/Charts/ChartWrapper/index.d.ts +1 -0
  37. package/lib/components/Charts/ColumnChart/ColumnChart.d.ts +111 -0
  38. package/lib/components/Charts/ColumnChart/index.d.ts +1 -0
  39. package/lib/components/Charts/DonutChart/DonutChart.d.ts +142 -0
  40. package/lib/components/Charts/DonutChart/index.d.ts +1 -0
  41. package/lib/components/Charts/FunnelChart/FunnelChart.d.ts +99 -0
  42. package/lib/components/Charts/FunnelChart/index.d.ts +1 -0
  43. package/lib/components/Charts/LineChart/LineChart.d.ts +97 -0
  44. package/lib/components/Charts/LineChart/index.d.ts +1 -0
  45. package/lib/components/Charts/SpiderChart/SpiderChart.d.ts +95 -0
  46. package/lib/components/Charts/SpiderChart/index.d.ts +1 -0
  47. package/lib/components/Charts/index.d.ts +7 -0
  48. package/lib/components/ChatBubble/ChatBubble.d.ts +203 -0
  49. package/lib/components/ChatBubble/index.d.ts +1 -0
  50. package/lib/components/Checkbox/Checkbox.d.ts +165 -0
  51. package/lib/components/Checkbox/CheckboxGroup.d.ts +113 -0
  52. package/lib/components/Checkbox/index.d.ts +2 -0
  53. package/lib/components/Chip/Chip.d.ts +181 -0
  54. package/lib/components/Chip/index.d.ts +2 -0
  55. package/lib/components/CircularLoader/CircularLoader.d.ts +56 -0
  56. package/lib/components/CircularLoader/index.d.ts +1 -0
  57. package/lib/components/CollapsibleCard/CollapsibleCard.d.ts +134 -0
  58. package/lib/components/CollapsibleCard/index.d.ts +1 -0
  59. package/lib/components/Combobox/Combobox.d.ts +292 -0
  60. package/lib/components/Combobox/helper.d.ts +205 -0
  61. package/lib/components/Combobox/index.d.ts +1 -0
  62. package/lib/components/ConditionalWrapper/ConditionalWrapper.d.ts +12 -0
  63. package/lib/components/ConditionalWrapper/index.d.ts +1 -0
  64. package/lib/components/DateRangePicker/Calendar.d.ts +119 -0
  65. package/lib/components/DateRangePicker/DateRangePicker.d.ts +196 -0
  66. package/lib/components/DateRangePicker/DateRangeWrapper.d.ts +311 -0
  67. package/lib/components/DateRangePicker/Day.d.ts +70 -0
  68. package/lib/components/DateRangePicker/index.d.ts +1 -0
  69. package/lib/components/Dialog/Dialog.d.ts +208 -0
  70. package/lib/components/Dialog/index.d.ts +1 -0
  71. package/lib/components/Disclaimer/Disclaimer.d.ts +32 -0
  72. package/lib/components/Disclaimer/index.d.ts +1 -0
  73. package/lib/components/Dropdown/Dropdown.d.ts +145 -0
  74. package/lib/components/Dropdown/SimpleDropdown.d.ts +142 -0
  75. package/lib/components/Dropdown/index.d.ts +2 -0
  76. package/lib/components/EmptyState/EmptyImages/CalendarEmptyImage.d.ts +108 -0
  77. package/lib/components/EmptyState/EmptyImages/ChartEmptyImage.d.ts +194 -0
  78. package/lib/components/EmptyState/EmptyImages/DataEmptyImage.d.ts +116 -0
  79. package/lib/components/EmptyState/EmptyImages/FileEmptyImage.d.ts +133 -0
  80. package/lib/components/EmptyState/EmptyImages/MessageEmptyImage.d.ts +64 -0
  81. package/lib/components/EmptyState/EmptyImages/UploadEmptyImage.d.ts +67 -0
  82. package/lib/components/EmptyState/EmptyImages/index.d.ts +6 -0
  83. package/lib/components/EmptyState/EmptyState.d.ts +82 -0
  84. package/lib/components/EmptyState/index.d.ts +1 -0
  85. package/lib/components/ErrorMessage/ErrorImages/ForbiddenImage.d.ts +85 -0
  86. package/lib/components/ErrorMessage/ErrorImages/NotFoundImage.d.ts +117 -0
  87. package/lib/components/ErrorMessage/ErrorImages/ServerErrorImage.d.ts +237 -0
  88. package/lib/components/ErrorMessage/ErrorImages/UnauthorizedImage.d.ts +73 -0
  89. package/lib/components/ErrorMessage/ErrorImages/index.d.ts +4 -0
  90. package/lib/components/ErrorMessage/ErrorMessage.d.ts +86 -0
  91. package/lib/components/ErrorMessage/index.d.ts +1 -0
  92. package/lib/components/FileUpload/FileBlock/FileBlock.d.ts +137 -0
  93. package/lib/components/FileUpload/FileBlock/index.d.ts +1 -0
  94. package/lib/components/FileUpload/FileUpload.d.ts +190 -0
  95. package/lib/components/FileUpload/index.d.ts +2 -0
  96. package/lib/components/FocusManager/FocusManager.d.ts +52 -0
  97. package/lib/components/FocusManager/index.d.ts +1 -0
  98. package/lib/components/FocusManagerWithArrowKeyNavigation/FocusManagerWithArrowKeyNavigation.d.ts +137 -0
  99. package/lib/components/FocusManagerWithArrowKeyNavigation/index.d.ts +1 -0
  100. package/lib/components/FormTitleWrapper/FormTitleWrapper.d.ts +62 -0
  101. package/lib/components/FormTitleWrapper/index.d.ts +1 -0
  102. package/lib/components/Grid/Grid.d.ts +104 -0
  103. package/lib/components/Grid/index.d.ts +1 -0
  104. package/lib/components/Icon/ClickableIcon.d.ts +101 -0
  105. package/lib/components/Icon/Icon.d.ts +71 -0
  106. package/lib/components/Icon/Icon.docs.d.ts +138 -0
  107. package/lib/components/Icon/SemanticIcon.d.ts +42 -0
  108. package/lib/components/Icon/index.d.ts +3 -0
  109. package/lib/components/InContextAlert/InContextAlert.d.ts +210 -0
  110. package/lib/components/InContextAlert/index.d.ts +1 -0
  111. package/lib/components/InlineDropdown/InlineDropdown.d.ts +146 -0
  112. package/lib/components/InlineDropdown/SimpleInlineDropdown.d.ts +145 -0
  113. package/lib/components/InlineDropdown/index.d.ts +2 -0
  114. package/lib/components/Input/Input.d.ts +327 -0
  115. package/lib/components/Input/index.d.ts +1 -0
  116. package/lib/components/KPIBox/KPIBox.d.ts +89 -0
  117. package/lib/components/KPIBox/index.d.ts +1 -0
  118. package/lib/components/LinearLoader/LinearLoader.d.ts +44 -0
  119. package/lib/components/LinearLoader/index.d.ts +1 -0
  120. package/lib/components/Link/Link.d.ts +225 -0
  121. package/lib/components/Link/index.d.ts +1 -0
  122. package/lib/components/Menu/Menu.d.ts +379 -0
  123. package/lib/components/Menu/MenuOptionButton.d.ts +199 -0
  124. package/lib/components/Menu/index.d.ts +2 -0
  125. package/lib/components/Modal/Modal.d.ts +354 -0
  126. package/lib/components/Modal/index.d.ts +14 -0
  127. package/lib/components/Notification/Notification.d.ts +147 -0
  128. package/lib/components/Notification/index.d.ts +1 -0
  129. package/lib/components/OptionButton/OptionButton.d.ts +150 -0
  130. package/lib/components/OptionButton/SimpleOptionButton.d.ts +150 -0
  131. package/lib/components/OptionButton/index.d.ts +2 -0
  132. package/lib/components/PageTitle/PageTitle.d.ts +256 -0
  133. package/lib/components/PageTitle/index.d.ts +1 -0
  134. package/lib/components/Pagination/Pagination.d.ts +144 -0
  135. package/lib/components/Pagination/PaginationItem.d.ts +136 -0
  136. package/lib/components/Pagination/index.d.ts +1 -0
  137. package/lib/components/Panel/Panel.d.ts +168 -0
  138. package/lib/components/Panel/index.d.ts +9 -0
  139. package/lib/components/ProgressDonut/ProgressDonut.d.ts +102 -0
  140. package/lib/components/ProgressDonut/index.d.ts +1 -0
  141. package/lib/components/PromptChip/PromptChip.d.ts +167 -0
  142. package/lib/components/PromptChip/index.d.ts +1 -0
  143. package/lib/components/PromptInput/PromptInput.d.ts +189 -0
  144. package/lib/components/PromptInput/index.d.ts +1 -0
  145. package/lib/components/RadioButton/RadioButton.d.ts +132 -0
  146. package/lib/components/RadioButton/RadioGroup.d.ts +88 -0
  147. package/lib/components/RadioButton/index.d.ts +2 -0
  148. package/lib/components/RadioTile/RadioTile.d.ts +109 -0
  149. package/lib/components/RadioTile/index.d.ts +1 -0
  150. package/lib/components/RangeSlider/RangeSlider.d.ts +207 -0
  151. package/lib/components/RangeSlider/index.d.ts +1 -0
  152. package/lib/components/Rating/Rating.d.ts +131 -0
  153. package/lib/components/Rating/index.d.ts +1 -0
  154. package/lib/components/ScoreBar/ScoreBar.d.ts +122 -0
  155. package/lib/components/ScoreBar/index.d.ts +1 -0
  156. package/lib/components/SearchInput/SearchInput.d.ts +79 -0
  157. package/lib/components/SearchInput/index.d.ts +2 -0
  158. package/lib/components/Separator/Separator.d.ts +51 -0
  159. package/lib/components/Separator/index.d.ts +1 -0
  160. package/lib/components/Shimmer/Shimmer.d.ts +131 -0
  161. package/lib/components/Shimmer/index.d.ts +1 -0
  162. package/lib/components/SideMenuLink/SideMenuLink.d.ts +336 -0
  163. package/lib/components/SideMenuLink/index.d.ts +1 -0
  164. package/lib/components/StatusIndicator/StatusIndicator.d.ts +60 -0
  165. package/lib/components/StatusIndicator/index.d.ts +1 -0
  166. package/lib/components/Stepper/Step/Step.d.ts +119 -0
  167. package/lib/components/Stepper/Step/StepContent.d.ts +35 -0
  168. package/lib/components/Stepper/Step/StepLabel.d.ts +35 -0
  169. package/lib/components/Stepper/Step/index.d.ts +3 -0
  170. package/lib/components/Stepper/Stepper.d.ts +60 -0
  171. package/lib/components/Stepper/index.d.ts +2 -0
  172. package/lib/components/StickyBar/StickyBar.d.ts +55 -0
  173. package/lib/components/StickyBar/index.d.ts +1 -0
  174. package/lib/components/SubMenu/SubMenu.d.ts +89 -0
  175. package/lib/components/SubMenu/SubMenuGroup.d.ts +156 -0
  176. package/lib/components/SubMenu/SubMenuItem.d.ts +161 -0
  177. package/lib/components/SubMenu/SubMenuLink.d.ts +81 -0
  178. package/lib/components/SubMenu/index.d.ts +4 -0
  179. package/lib/components/Table/Cell.d.ts +107 -0
  180. package/lib/components/Table/DefaultRow.d.ts +144 -0
  181. package/lib/components/Table/DefaultTableHeader.d.ts +236 -0
  182. package/lib/components/Table/StaticTable.d.ts +198 -0
  183. package/lib/components/Table/Table.d.ts +113 -0
  184. package/lib/components/Table/Table.docs.d.ts +532 -0
  185. package/lib/components/Table/TableActionBar.d.ts +48 -0
  186. package/lib/components/Table/TableBottomBar.d.ts +20 -0
  187. package/lib/components/Table/TableTopBar.d.ts +20 -0
  188. package/lib/components/Table/dummyTableData.d.ts +2189 -0
  189. package/lib/components/Table/hooks.d.ts +98 -0
  190. package/lib/components/Table/index.d.ts +8 -0
  191. package/lib/components/Tabs/Tab/Tab.d.ts +146 -0
  192. package/lib/components/Tabs/Tab/index.d.ts +1 -0
  193. package/lib/components/Tabs/TabList/TabDropdown.d.ts +100 -0
  194. package/lib/components/Tabs/TabList/TabList.d.ts +157 -0
  195. package/lib/components/Tabs/TabList/index.d.ts +1 -0
  196. package/lib/components/Tabs/index.d.ts +2 -0
  197. package/lib/components/Text/Text.d.ts +1021 -0
  198. package/lib/components/Text/index.d.ts +30 -0
  199. package/lib/components/TextTile/TextTile.d.ts +40 -0
  200. package/lib/components/TextTile/index.d.ts +1 -0
  201. package/lib/components/Textarea/Textarea.d.ts +132 -0
  202. package/lib/components/Textarea/index.d.ts +2 -0
  203. package/lib/components/Timeline/Timeline.d.ts +40 -0
  204. package/lib/components/Timeline/TimelineItem/TimelineItem.d.ts +121 -0
  205. package/lib/components/Timeline/TimelineItem/index.d.ts +1 -0
  206. package/lib/components/Timeline/index.d.ts +2 -0
  207. package/lib/components/Toast/Toast.d.ts +248 -0
  208. package/lib/components/Toast/ToastContainer.d.ts +140 -0
  209. package/lib/components/Toast/ToastManager.d.ts +58 -0
  210. package/lib/components/Toast/index.d.ts +10 -0
  211. package/lib/components/Toggle/Toggle.d.ts +111 -0
  212. package/lib/components/Toggle/index.d.ts +1 -0
  213. package/lib/components/TokenListInput/TokenListInput.d.ts +333 -0
  214. package/lib/components/TokenListInput/TokenValueChips.d.ts +64 -0
  215. package/lib/components/TokenListInput/index.d.ts +1 -0
  216. package/lib/components/Tooltip/Tooltip.d.ts +186 -0
  217. package/lib/components/Tooltip/index.d.ts +1 -0
  218. package/lib/components/Truncate/Truncate.d.ts +87 -0
  219. package/lib/components/Truncate/index.d.ts +2 -0
  220. package/lib/components/TruncatedTextWithTooltip/TruncatedTextWithTooltip.d.ts +95 -0
  221. package/lib/components/TruncatedTextWithTooltip/index.d.ts +1 -0
  222. package/lib/components/Typeahead/SimpleTypeahead.d.ts +141 -0
  223. package/lib/components/Typeahead/Typeahead.d.ts +217 -0
  224. package/lib/components/Typeahead/index.d.ts +2 -0
  225. package/lib/components/WeekdayPicker/WeekdayPicker.d.ts +242 -0
  226. package/lib/components/WeekdayPicker/index.d.ts +1 -0
  227. package/lib/components/index.d.ts +71 -0
  228. package/lib/hooks/index.d.ts +12 -0
  229. package/lib/hooks/useArbitraryOptionAddition/index.d.ts +1 -0
  230. package/lib/hooks/useArbitraryOptionAddition/useArbitraryOptionAddition.d.ts +124 -0
  231. package/lib/hooks/useCopyToClipboard/index.d.ts +1 -0
  232. package/lib/hooks/useCopyToClipboard/useCopyToClipboard.d.ts +27 -0
  233. package/lib/hooks/useFileUpload/index.d.ts +1 -0
  234. package/lib/hooks/useFileUpload/useFileUpload.d.ts +342 -0
  235. package/lib/hooks/useFilteredOptions/index.d.ts +1 -0
  236. package/lib/hooks/useFilteredOptions/useFilteredOptions.d.ts +87 -0
  237. package/lib/hooks/useInputState/index.d.ts +1 -0
  238. package/lib/hooks/useInputState/useInputState.d.ts +22 -0
  239. package/lib/hooks/useLockedBody/index.d.ts +1 -0
  240. package/lib/hooks/useLockedBody/useLockedBody.d.ts +46 -0
  241. package/lib/hooks/useModal/index.d.ts +1 -0
  242. package/lib/hooks/useModal/useModal.d.ts +32 -0
  243. package/lib/hooks/useMountTransition/index.d.ts +24 -0
  244. package/lib/hooks/usePagination/index.d.ts +1 -0
  245. package/lib/hooks/usePagination/usePagination.d.ts +140 -0
  246. package/lib/hooks/useToastPortal/index.d.ts +1 -0
  247. package/lib/hooks/useToastPortal/useToastPortal.d.ts +31 -0
  248. package/lib/hooks/useToggle/index.d.ts +1 -0
  249. package/lib/hooks/useToggle/useToggle.d.ts +11 -0
  250. package/lib/hooks/useWindowSize/index.d.ts +1 -0
  251. package/lib/hooks/useWindowSize/useWindowSize.d.ts +28 -0
  252. package/lib/index.d.ts +5 -0
  253. package/lib/styles/index.d.ts +267 -0
  254. package/lib/styles/variables/_border.d.ts +12 -0
  255. package/lib/styles/variables/_color.d.ts +104 -0
  256. package/lib/styles/variables/_elevation.d.ts +7 -0
  257. package/lib/styles/variables/_font.d.ts +30 -0
  258. package/lib/styles/variables/_motion.d.ts +6 -0
  259. package/lib/styles/variables/_opacity.d.ts +15 -0
  260. package/lib/styles/variables/_shadow.d.ts +24 -0
  261. package/lib/styles/variables/_size.d.ts +57 -0
  262. package/lib/styles/variables/_space.d.ts +12 -0
  263. package/lib/types/charts.d.ts +225 -0
  264. package/lib/types/common.d.ts +10 -0
  265. package/lib/types/date-range-picker.d.ts +17 -0
  266. package/lib/types/date-range-picker.js.flow +2 -3
  267. package/lib/types/index.d.ts +6 -0
  268. package/lib/types/menu.d.ts +13 -0
  269. package/lib/types/toast.d.ts +32 -0
  270. package/lib/types/typography.d.ts +17 -0
  271. package/lib/utils/array/are-arrays-equal.d.ts +11 -0
  272. package/lib/utils/array/index.d.ts +1 -0
  273. package/lib/utils/charts/charts.d.ts +102 -0
  274. package/lib/utils/charts/columnChart.d.ts +51 -0
  275. package/lib/utils/charts/donutChart.d.ts +116 -0
  276. package/lib/utils/charts/funnelChart.d.ts +94 -0
  277. package/lib/utils/charts/helpers.d.ts +44 -0
  278. package/lib/utils/charts/index.d.ts +7 -0
  279. package/lib/utils/charts/lineChart.d.ts +44 -0
  280. package/lib/utils/charts/spiderChart.d.ts +46 -0
  281. package/lib/utils/charts/typography.d.ts +42 -0
  282. package/lib/utils/classify/index.d.ts +27 -0
  283. package/lib/utils/click-away/click-away.d.ts +194 -0
  284. package/lib/utils/click-away/index.d.ts +1 -0
  285. package/lib/utils/date-range-picker/date-range-picker.d.ts +391 -0
  286. package/lib/utils/date-range-picker/index.d.ts +2 -0
  287. package/lib/utils/date-range-picker/timezones.d.ts +262 -0
  288. package/lib/utils/dom/dom.d.ts +245 -0
  289. package/lib/utils/dom/index.d.ts +1 -0
  290. package/lib/utils/helpers/helpers.d.ts +48 -0
  291. package/lib/utils/helpers/index.d.ts +1 -0
  292. package/lib/utils/index.d.ts +14 -0
  293. package/lib/utils/makeClassNameComponent/index.d.ts +1 -0
  294. package/lib/utils/makeClassNameComponent/makeClassNameComponent.d.ts +73 -0
  295. package/lib/utils/menu/index.d.ts +1 -0
  296. package/lib/utils/merge-refs/index.d.ts +1 -0
  297. package/lib/utils/merge-refs/merge-refs.d.ts +15 -0
  298. package/lib/utils/rating/index.d.ts +1 -0
  299. package/lib/utils/rating/rating.d.ts +31 -0
  300. package/lib/utils/score-bar/index.d.ts +1 -0
  301. package/lib/utils/score-bar/score-bar.d.ts +54 -0
  302. package/lib/utils/string/index.d.ts +1 -0
  303. package/lib/utils/string/string.d.ts +30 -0
  304. package/lib/utils/token-list-input/token-list-input.d.ts +32 -0
  305. package/lib/utils/tokens/index.d.ts +1 -0
  306. package/lib/utils/tokens/tokens.d.ts +230 -0
  307. package/package.json +5 -5
@@ -0,0 +1,1021 @@
1
+ import * as React from 'react';
2
+ import type {ColorTypes} from '../../types/typography';
3
+ import {TEXT_COLORS} from '../../types/typography';
4
+ import classify from '../../utils/classify';
5
+ import {escapeRegExp} from '../../utils/string';
6
+ import css from '../../styles/typography.module.css';
7
+ export type TextProps = {
8
+ color?: ColorTypes;
9
+ children?: React.ReactNode;
10
+ className?: string;
11
+ highlightedTextClassName?: string;
12
+ highlightString?: string | string[];
13
+ caseSensitiveHighlighting?: boolean;
14
+ highlightWithBackground?: boolean;
15
+ };
16
+ export type HighlightTextProps = {
17
+ text: string;
18
+ highlight: string | string[];
19
+ highlightClassName?: string;
20
+ caseSensitiveHighlighting?: boolean;
21
+ highlightWithBackground?: boolean;
22
+ };
23
+ const HighlightText: React$AbstractComponent<
24
+ HighlightTextProps,
25
+ HTMLSpanElement
26
+ > = React.forwardRef<HighlightTextProps, HTMLSpanElement>(
27
+ (
28
+ {
29
+ text,
30
+ highlight,
31
+ highlightClassName,
32
+ caseSensitiveHighlighting,
33
+ highlightWithBackground,
34
+ }: HighlightTextProps,
35
+ ref,
36
+ ) => {
37
+ // Split text on highlight term, include term itself into parts, ignore case
38
+ // Convert highlight to an array if it's not already
39
+ const highlightArray = [].concat(highlight).filter((item) => item !== '');
40
+ const highlights = highlightArray.map(escapeRegExp).join('|');
41
+ const parts = text
42
+ .split(
43
+ new RegExp(`(${highlights})`, caseSensitiveHighlighting ? '' : 'gi'),
44
+ )
45
+ .filter((part) => part !== '');
46
+ return (
47
+ <span ref={ref}>
48
+ {parts.map((part, idx) => {
49
+ const isHighlighted = highlightArray.some((highlightTerm) =>
50
+ caseSensitiveHighlighting
51
+ ? escapeRegExp(part).includes(escapeRegExp(highlightTerm))
52
+ : escapeRegExp(part)
53
+ .toLowerCase()
54
+ .includes(escapeRegExp(highlightTerm).toLowerCase()),
55
+ );
56
+ return isHighlighted ? (
57
+ <span // eslint-disable-next-line react/no-array-index-key
58
+ key={idx}
59
+ className={classify(
60
+ css.highlightText,
61
+ {
62
+ [css.bgHighlighting]: highlightWithBackground,
63
+ },
64
+ highlightClassName,
65
+ )}
66
+ >
67
+ {part}
68
+ </span>
69
+ ) : (
70
+ part
71
+ );
72
+ })}
73
+ </span>
74
+ );
75
+ },
76
+ );
77
+ export const JumboLarge: React$AbstractComponent<TextProps, HTMLSpanElement> =
78
+ React.forwardRef<TextProps, HTMLSpanElement>(
79
+ (
80
+ {
81
+ color = TEXT_COLORS.primary,
82
+ children,
83
+ className,
84
+ highlightedTextClassName,
85
+ highlightString,
86
+ caseSensitiveHighlighting,
87
+ highlightWithBackground,
88
+ ...props
89
+ }: TextProps,
90
+ ref,
91
+ ): React.ReactNode => (
92
+ <span
93
+ {...props}
94
+ className={classify(css.jumboLarge, css[color], className)}
95
+ ref={ref}
96
+ >
97
+ {!!highlightString?.length && typeof children === 'string' ? (
98
+ <HighlightText
99
+ text={children}
100
+ highlight={highlightString}
101
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
102
+ highlightClassName={highlightedTextClassName}
103
+ highlightWithBackground={highlightWithBackground}
104
+ />
105
+ ) : (
106
+ children
107
+ )}
108
+ </span>
109
+ ),
110
+ );
111
+ export const JumboMedium: React$AbstractComponent<TextProps, HTMLSpanElement> =
112
+ React.forwardRef<TextProps, HTMLSpanElement>(
113
+ (
114
+ {
115
+ color = TEXT_COLORS.primary,
116
+ children,
117
+ className,
118
+ highlightedTextClassName,
119
+ highlightString,
120
+ caseSensitiveHighlighting,
121
+ highlightWithBackground,
122
+ ...props
123
+ }: TextProps,
124
+ ref,
125
+ ): React.ReactNode => (
126
+ <span
127
+ {...props}
128
+ className={classify(css.jumboMedium, css[color], className)}
129
+ ref={ref}
130
+ >
131
+ {!!highlightString?.length && typeof children === 'string' ? (
132
+ <HighlightText
133
+ text={children}
134
+ highlight={highlightString}
135
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
136
+ highlightClassName={highlightedTextClassName}
137
+ highlightWithBackground={highlightWithBackground}
138
+ />
139
+ ) : (
140
+ children
141
+ )}
142
+ </span>
143
+ ),
144
+ );
145
+ export const JumboSmall: React$AbstractComponent<TextProps, HTMLSpanElement> =
146
+ React.forwardRef<TextProps, HTMLSpanElement>(
147
+ (
148
+ {
149
+ color = TEXT_COLORS.primary,
150
+ children,
151
+ className,
152
+ highlightedTextClassName,
153
+ highlightString,
154
+ caseSensitiveHighlighting,
155
+ highlightWithBackground,
156
+ ...props
157
+ }: TextProps,
158
+ ref,
159
+ ): React.ReactNode => (
160
+ <span
161
+ {...props}
162
+ className={classify(css.jumboSmall, css[color], className)}
163
+ ref={ref}
164
+ >
165
+ {!!highlightString?.length && typeof children === 'string' ? (
166
+ <HighlightText
167
+ text={children}
168
+ highlight={highlightString}
169
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
170
+ highlightClassName={highlightedTextClassName}
171
+ highlightWithBackground={highlightWithBackground}
172
+ />
173
+ ) : (
174
+ children
175
+ )}
176
+ </span>
177
+ ),
178
+ );
179
+ export const TitleMedium: React$AbstractComponent<
180
+ TextProps,
181
+ HTMLHeadingElement
182
+ > = React.forwardRef<TextProps, HTMLHeadingElement>(
183
+ (
184
+ {
185
+ color = TEXT_COLORS.primary,
186
+ children,
187
+ className,
188
+ highlightedTextClassName,
189
+ highlightString,
190
+ caseSensitiveHighlighting,
191
+ highlightWithBackground,
192
+ ...props
193
+ }: TextProps,
194
+ ref,
195
+ ): React.ReactNode => (
196
+ <h1
197
+ {...props}
198
+ className={classify(css.titleMedium, css[color], className)}
199
+ ref={ref}
200
+ >
201
+ {!!highlightString?.length && typeof children === 'string' ? (
202
+ <HighlightText
203
+ text={children}
204
+ highlight={highlightString}
205
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
206
+ highlightClassName={highlightedTextClassName}
207
+ highlightWithBackground={highlightWithBackground}
208
+ />
209
+ ) : (
210
+ children
211
+ )}
212
+ </h1>
213
+ ),
214
+ );
215
+ export const SubTitleLarge: React$AbstractComponent<
216
+ TextProps,
217
+ HTMLHeadingElement
218
+ > = React.forwardRef<TextProps, HTMLHeadingElement>(
219
+ (
220
+ {
221
+ color = TEXT_COLORS.primary,
222
+ children,
223
+ className,
224
+ highlightedTextClassName,
225
+ highlightString,
226
+ caseSensitiveHighlighting,
227
+ highlightWithBackground,
228
+ ...props
229
+ }: TextProps,
230
+ ref,
231
+ ): React.ReactNode => (
232
+ <h2
233
+ {...props}
234
+ className={classify(css.subTitleLarge, css[color], className)}
235
+ ref={ref}
236
+ >
237
+ {!!highlightString?.length && typeof children === 'string' ? (
238
+ <HighlightText
239
+ text={children}
240
+ highlight={highlightString}
241
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
242
+ highlightClassName={highlightedTextClassName}
243
+ highlightWithBackground={highlightWithBackground}
244
+ />
245
+ ) : (
246
+ children
247
+ )}
248
+ </h2>
249
+ ),
250
+ );
251
+ export const SubTitleMedium: React$AbstractComponent<
252
+ TextProps,
253
+ HTMLHeadingElement
254
+ > = React.forwardRef<TextProps, HTMLHeadingElement>(
255
+ (
256
+ {
257
+ color = TEXT_COLORS.primary,
258
+ children,
259
+ className,
260
+ highlightedTextClassName,
261
+ highlightString,
262
+ caseSensitiveHighlighting,
263
+ highlightWithBackground,
264
+ ...props
265
+ }: TextProps,
266
+ ref,
267
+ ): React.ReactNode => (
268
+ <h3
269
+ {...props}
270
+ className={classify(css.subTitleMedium, css[color], className)}
271
+ ref={ref}
272
+ >
273
+ {!!highlightString?.length && typeof children === 'string' ? (
274
+ <HighlightText
275
+ text={children}
276
+ highlight={highlightString}
277
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
278
+ highlightClassName={highlightedTextClassName}
279
+ highlightWithBackground={highlightWithBackground}
280
+ />
281
+ ) : (
282
+ children
283
+ )}
284
+ </h3>
285
+ ),
286
+ );
287
+ export const SubTitleSmall: React$AbstractComponent<
288
+ TextProps,
289
+ HTMLHeadingElement
290
+ > = React.forwardRef<TextProps, HTMLHeadingElement>(
291
+ (
292
+ {
293
+ color = TEXT_COLORS.primary,
294
+ children,
295
+ className,
296
+ highlightedTextClassName,
297
+ highlightString,
298
+ caseSensitiveHighlighting,
299
+ highlightWithBackground,
300
+ ...props
301
+ }: TextProps,
302
+ ref,
303
+ ): React.ReactNode => (
304
+ <h4
305
+ {...props}
306
+ className={classify(css.subTitleSmall, css[color], className)}
307
+ ref={ref}
308
+ >
309
+ {!!highlightString?.length && typeof children === 'string' ? (
310
+ <HighlightText
311
+ text={children}
312
+ highlight={highlightString}
313
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
314
+ highlightClassName={highlightedTextClassName}
315
+ highlightWithBackground={highlightWithBackground}
316
+ />
317
+ ) : (
318
+ children
319
+ )}
320
+ </h4>
321
+ ),
322
+ );
323
+ export const SubTitleExtraSmall: React$AbstractComponent<
324
+ TextProps,
325
+ HTMLHeadingElement
326
+ > = React.forwardRef<TextProps, HTMLHeadingElement>(
327
+ (
328
+ {
329
+ color = TEXT_COLORS.primary,
330
+ children,
331
+ className,
332
+ highlightedTextClassName,
333
+ highlightString,
334
+ caseSensitiveHighlighting,
335
+ highlightWithBackground,
336
+ ...props
337
+ }: TextProps,
338
+ ref,
339
+ ): React.ReactNode => (
340
+ <h5
341
+ {...props}
342
+ className={classify(css.subTitleExtraSmall, css[color], className)}
343
+ ref={ref}
344
+ >
345
+ {!!highlightString?.length && typeof children === 'string' ? (
346
+ <HighlightText
347
+ text={children}
348
+ highlight={highlightString}
349
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
350
+ highlightClassName={highlightedTextClassName}
351
+ highlightWithBackground={highlightWithBackground}
352
+ />
353
+ ) : (
354
+ children
355
+ )}
356
+ </h5>
357
+ ),
358
+ );
359
+ export const ButtonTextMedium: React$AbstractComponent<
360
+ TextProps,
361
+ HTMLSpanElement
362
+ > = React.forwardRef<TextProps, HTMLSpanElement>(
363
+ (
364
+ {
365
+ color = TEXT_COLORS.primary,
366
+ children,
367
+ className,
368
+ highlightedTextClassName,
369
+ highlightString,
370
+ caseSensitiveHighlighting,
371
+ highlightWithBackground,
372
+ ...props
373
+ }: TextProps,
374
+ ref,
375
+ ): React.ReactNode => (
376
+ <span
377
+ {...props}
378
+ className={classify(css.buttonTextMedium, css[color], className)}
379
+ ref={ref}
380
+ >
381
+ {!!highlightString?.length && typeof children === 'string' ? (
382
+ <HighlightText
383
+ text={children}
384
+ highlight={highlightString}
385
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
386
+ highlightClassName={highlightedTextClassName}
387
+ highlightWithBackground={highlightWithBackground}
388
+ />
389
+ ) : (
390
+ children
391
+ )}
392
+ </span>
393
+ ),
394
+ );
395
+ export const ButtonTextSmall: React$AbstractComponent<
396
+ TextProps,
397
+ HTMLSpanElement
398
+ > = React.forwardRef<TextProps, HTMLSpanElement>(
399
+ (
400
+ {
401
+ color = TEXT_COLORS.primary,
402
+ children,
403
+ className,
404
+ highlightedTextClassName,
405
+ highlightString,
406
+ caseSensitiveHighlighting,
407
+ highlightWithBackground,
408
+ ...props
409
+ }: TextProps,
410
+ ref,
411
+ ): React.ReactNode => (
412
+ <span
413
+ {...props}
414
+ className={classify(css.buttonTextSmall, css[color], className)}
415
+ ref={ref}
416
+ >
417
+ {!!highlightString?.length && typeof children === 'string' ? (
418
+ <HighlightText
419
+ text={children}
420
+ highlight={highlightString}
421
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
422
+ highlightClassName={highlightedTextClassName}
423
+ highlightWithBackground={highlightWithBackground}
424
+ />
425
+ ) : (
426
+ children
427
+ )}
428
+ </span>
429
+ ),
430
+ );
431
+ export const MenuTextMedium: React$AbstractComponent<
432
+ TextProps,
433
+ HTMLSpanElement
434
+ > = React.forwardRef<TextProps, HTMLSpanElement>(
435
+ (
436
+ {
437
+ color = TEXT_COLORS.primary,
438
+ children,
439
+ className,
440
+ highlightedTextClassName,
441
+ highlightString,
442
+ caseSensitiveHighlighting,
443
+ highlightWithBackground,
444
+ ...props
445
+ }: TextProps,
446
+ ref,
447
+ ): React.ReactNode => (
448
+ <span
449
+ {...props}
450
+ className={classify(css.menuTextMedium, css[color], className)}
451
+ ref={ref}
452
+ >
453
+ {!!highlightString?.length && typeof children === 'string' ? (
454
+ <HighlightText
455
+ text={children}
456
+ highlight={highlightString}
457
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
458
+ highlightClassName={highlightedTextClassName}
459
+ highlightWithBackground={highlightWithBackground}
460
+ />
461
+ ) : (
462
+ children
463
+ )}
464
+ </span>
465
+ ),
466
+ );
467
+ export const MenuTextSmall: React$AbstractComponent<
468
+ TextProps,
469
+ HTMLSpanElement
470
+ > = React.forwardRef<TextProps, HTMLSpanElement>(
471
+ (
472
+ {
473
+ color = TEXT_COLORS.primary,
474
+ children,
475
+ className,
476
+ highlightedTextClassName,
477
+ highlightString,
478
+ caseSensitiveHighlighting,
479
+ highlightWithBackground,
480
+ ...props
481
+ }: TextProps,
482
+ ref,
483
+ ): React.ReactNode => (
484
+ <span
485
+ {...props}
486
+ className={classify(css.menuTextSmall, css[color], className)}
487
+ ref={ref}
488
+ >
489
+ {!!highlightString?.length && typeof children === 'string' ? (
490
+ <HighlightText
491
+ text={children}
492
+ highlight={highlightString}
493
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
494
+ highlightClassName={highlightedTextClassName}
495
+ highlightWithBackground={highlightWithBackground}
496
+ />
497
+ ) : (
498
+ children
499
+ )}
500
+ </span>
501
+ ),
502
+ );
503
+ export const ButtonTextExtraSmall: React$AbstractComponent<
504
+ TextProps,
505
+ HTMLSpanElement
506
+ > = React.forwardRef<TextProps, HTMLSpanElement>(
507
+ (
508
+ {
509
+ color = TEXT_COLORS.primary,
510
+ children,
511
+ className,
512
+ highlightedTextClassName,
513
+ highlightString,
514
+ caseSensitiveHighlighting,
515
+ highlightWithBackground,
516
+ ...props
517
+ }: TextProps,
518
+ ref,
519
+ ): React.ReactNode => (
520
+ <span
521
+ {...props}
522
+ className={classify(css.buttonTextExtraSmall, css[color], className)}
523
+ ref={ref}
524
+ >
525
+ {!!highlightString?.length && typeof children === 'string' ? (
526
+ <HighlightText
527
+ text={children}
528
+ highlight={highlightString}
529
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
530
+ highlightClassName={highlightedTextClassName}
531
+ highlightWithBackground={highlightWithBackground}
532
+ />
533
+ ) : (
534
+ children
535
+ )}
536
+ </span>
537
+ ),
538
+ );
539
+ export const ButtonTextMediumUnderline: React$AbstractComponent<
540
+ TextProps,
541
+ HTMLSpanElement
542
+ > = React.forwardRef<TextProps, HTMLSpanElement>(
543
+ (
544
+ {
545
+ color = TEXT_COLORS.primary,
546
+ children,
547
+ className,
548
+ highlightedTextClassName,
549
+ highlightString,
550
+ caseSensitiveHighlighting,
551
+ highlightWithBackground,
552
+ ...props
553
+ }: TextProps,
554
+ ref,
555
+ ): React.ReactNode => (
556
+ <span
557
+ {...props}
558
+ className={classify(
559
+ css.buttonTextMedium,
560
+ css.underline,
561
+ css[color],
562
+ className,
563
+ )}
564
+ ref={ref}
565
+ >
566
+ {!!highlightString?.length && typeof children === 'string' ? (
567
+ <HighlightText
568
+ text={children}
569
+ highlight={highlightString}
570
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
571
+ highlightClassName={highlightedTextClassName}
572
+ highlightWithBackground={highlightWithBackground}
573
+ />
574
+ ) : (
575
+ children
576
+ )}
577
+ </span>
578
+ ),
579
+ );
580
+ export const ButtonTextSmallUnderline: React$AbstractComponent<
581
+ TextProps,
582
+ HTMLSpanElement
583
+ > = React.forwardRef<TextProps, HTMLSpanElement>(
584
+ (
585
+ {
586
+ color = TEXT_COLORS.primary,
587
+ children,
588
+ className,
589
+ highlightedTextClassName,
590
+ highlightString,
591
+ caseSensitiveHighlighting,
592
+ highlightWithBackground,
593
+ ...props
594
+ }: TextProps,
595
+ ref,
596
+ ): React.ReactNode => (
597
+ <span
598
+ {...props}
599
+ className={classify(
600
+ css.buttonTextSmall,
601
+ css.underline,
602
+ css[color],
603
+ className,
604
+ )}
605
+ ref={ref}
606
+ >
607
+ {!!highlightString?.length && typeof children === 'string' ? (
608
+ <HighlightText
609
+ text={children}
610
+ highlight={highlightString}
611
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
612
+ highlightClassName={highlightedTextClassName}
613
+ highlightWithBackground={highlightWithBackground}
614
+ />
615
+ ) : (
616
+ children
617
+ )}
618
+ </span>
619
+ ),
620
+ );
621
+ export const ButtonTextExtraSmallUnderline: React$AbstractComponent<
622
+ TextProps,
623
+ HTMLSpanElement
624
+ > = React.forwardRef<TextProps, HTMLSpanElement>(
625
+ (
626
+ {
627
+ color = TEXT_COLORS.primary,
628
+ children,
629
+ className,
630
+ highlightedTextClassName,
631
+ highlightString,
632
+ caseSensitiveHighlighting,
633
+ highlightWithBackground,
634
+ ...props
635
+ }: TextProps,
636
+ ref,
637
+ ): React.ReactNode => (
638
+ <span
639
+ {...props}
640
+ className={classify(
641
+ css.buttonTextExtraSmall,
642
+ css.underline,
643
+ css[color],
644
+ className,
645
+ )}
646
+ ref={ref}
647
+ >
648
+ {!!highlightString?.length && typeof children === 'string' ? (
649
+ <HighlightText
650
+ text={children}
651
+ highlight={highlightString}
652
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
653
+ highlightClassName={highlightedTextClassName}
654
+ highlightWithBackground={highlightWithBackground}
655
+ />
656
+ ) : (
657
+ children
658
+ )}
659
+ </span>
660
+ ),
661
+ );
662
+ export const FormInputMedium: React$AbstractComponent<
663
+ TextProps,
664
+ HTMLParagraphElement
665
+ > = React.forwardRef<TextProps, HTMLParagraphElement>(
666
+ (
667
+ {
668
+ color = TEXT_COLORS.primary,
669
+ children,
670
+ className,
671
+ highlightedTextClassName,
672
+ highlightString,
673
+ caseSensitiveHighlighting,
674
+ highlightWithBackground,
675
+ ...props
676
+ }: TextProps,
677
+ ref,
678
+ ): React.ReactNode => (
679
+ <p
680
+ {...props}
681
+ className={classify(css.formInputMedium, css[color], className)}
682
+ ref={ref}
683
+ >
684
+ {!!highlightString?.length && typeof children === 'string' ? (
685
+ <HighlightText
686
+ text={children}
687
+ highlight={highlightString}
688
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
689
+ highlightClassName={highlightedTextClassName}
690
+ highlightWithBackground={highlightWithBackground}
691
+ />
692
+ ) : (
693
+ children
694
+ )}
695
+ </p>
696
+ ),
697
+ );
698
+ export const FormInputSmall: React$AbstractComponent<
699
+ TextProps,
700
+ HTMLParagraphElement
701
+ > = React.forwardRef<TextProps, HTMLParagraphElement>(
702
+ (
703
+ {
704
+ color = TEXT_COLORS.primary,
705
+ children,
706
+ className,
707
+ highlightedTextClassName,
708
+ highlightString,
709
+ caseSensitiveHighlighting,
710
+ highlightWithBackground,
711
+ ...props
712
+ }: TextProps,
713
+ ref,
714
+ ): React.ReactNode => (
715
+ <p
716
+ {...props}
717
+ className={classify(css.formInputSmall, css[color], className)}
718
+ ref={ref}
719
+ >
720
+ {!!highlightString?.length && typeof children === 'string' ? (
721
+ <HighlightText
722
+ text={children}
723
+ highlight={highlightString}
724
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
725
+ highlightClassName={highlightedTextClassName}
726
+ highlightWithBackground={highlightWithBackground}
727
+ />
728
+ ) : (
729
+ children
730
+ )}
731
+ </p>
732
+ ),
733
+ );
734
+ export const BodyLarge: React$AbstractComponent<
735
+ TextProps,
736
+ HTMLParagraphElement
737
+ > = React.forwardRef<TextProps, HTMLParagraphElement>(
738
+ (
739
+ {
740
+ color = TEXT_COLORS.primary,
741
+ children,
742
+ className,
743
+ highlightedTextClassName,
744
+ highlightString,
745
+ caseSensitiveHighlighting,
746
+ highlightWithBackground,
747
+ ...props
748
+ }: TextProps,
749
+ ref,
750
+ ): React.ReactNode => (
751
+ <p
752
+ {...props}
753
+ className={classify(css.bodyLarge, css[color], className)}
754
+ ref={ref}
755
+ >
756
+ {!!highlightString?.length && typeof children === 'string' ? (
757
+ <HighlightText
758
+ text={children}
759
+ highlight={highlightString}
760
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
761
+ highlightClassName={highlightedTextClassName}
762
+ highlightWithBackground={highlightWithBackground}
763
+ />
764
+ ) : (
765
+ children
766
+ )}
767
+ </p>
768
+ ),
769
+ );
770
+ export const BodyMedium: React$AbstractComponent<
771
+ TextProps,
772
+ HTMLParagraphElement
773
+ > = React.forwardRef<TextProps, HTMLParagraphElement>(
774
+ (
775
+ {
776
+ color = TEXT_COLORS.primary,
777
+ children,
778
+ className,
779
+ highlightedTextClassName,
780
+ highlightString,
781
+ caseSensitiveHighlighting,
782
+ highlightWithBackground,
783
+ ...props
784
+ }: TextProps,
785
+ ref,
786
+ ): React.ReactNode => (
787
+ <p
788
+ {...props}
789
+ className={classify(css.bodyMedium, css[color], className)}
790
+ ref={ref}
791
+ >
792
+ {!!highlightString?.length && typeof children === 'string' ? (
793
+ <HighlightText
794
+ text={children}
795
+ highlight={highlightString}
796
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
797
+ highlightClassName={highlightedTextClassName}
798
+ highlightWithBackground={highlightWithBackground}
799
+ />
800
+ ) : (
801
+ children
802
+ )}
803
+ </p>
804
+ ),
805
+ );
806
+ export const BodySmall: React$AbstractComponent<
807
+ TextProps,
808
+ HTMLParagraphElement
809
+ > = React.forwardRef<TextProps, HTMLParagraphElement>(
810
+ (
811
+ {
812
+ color = TEXT_COLORS.primary,
813
+ children,
814
+ className,
815
+ highlightedTextClassName,
816
+ highlightString,
817
+ caseSensitiveHighlighting,
818
+ highlightWithBackground,
819
+ ...props
820
+ }: TextProps,
821
+ ref,
822
+ ): React.ReactNode => (
823
+ <p
824
+ {...props}
825
+ className={classify(css.bodySmall, css[color], className)}
826
+ ref={ref}
827
+ >
828
+ {!!highlightString?.length && typeof children === 'string' ? (
829
+ <HighlightText
830
+ text={children}
831
+ highlight={highlightString}
832
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
833
+ highlightClassName={highlightedTextClassName}
834
+ highlightWithBackground={highlightWithBackground}
835
+ />
836
+ ) : (
837
+ children
838
+ )}
839
+ </p>
840
+ ),
841
+ );
842
+ export const BodyLargeBold: React$AbstractComponent<
843
+ TextProps,
844
+ HTMLParagraphElement
845
+ > = React.forwardRef<TextProps, HTMLParagraphElement>(
846
+ (
847
+ {
848
+ color = TEXT_COLORS.primary,
849
+ children,
850
+ className,
851
+ highlightedTextClassName,
852
+ highlightString,
853
+ caseSensitiveHighlighting,
854
+ highlightWithBackground,
855
+ ...props
856
+ }: TextProps,
857
+ ref,
858
+ ): React.ReactNode => (
859
+ <p
860
+ {...props}
861
+ className={classify(css.bodyLarge, css.bold, css[color], className)}
862
+ ref={ref}
863
+ >
864
+ {!!highlightString?.length && typeof children === 'string' ? (
865
+ <HighlightText
866
+ text={children}
867
+ highlight={highlightString}
868
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
869
+ highlightClassName={highlightedTextClassName}
870
+ highlightWithBackground={highlightWithBackground}
871
+ />
872
+ ) : (
873
+ children
874
+ )}
875
+ </p>
876
+ ),
877
+ );
878
+ export const BodyMediumBold: React$AbstractComponent<
879
+ TextProps,
880
+ HTMLParagraphElement
881
+ > = React.forwardRef<TextProps, HTMLParagraphElement>(
882
+ (
883
+ {
884
+ color = TEXT_COLORS.primary,
885
+ children,
886
+ className,
887
+ highlightedTextClassName,
888
+ highlightString,
889
+ caseSensitiveHighlighting,
890
+ highlightWithBackground,
891
+ ...props
892
+ }: TextProps,
893
+ ref,
894
+ ): React.ReactNode => (
895
+ <p
896
+ {...props}
897
+ className={classify(css.bodyMedium, css.bold, css[color], className)}
898
+ ref={ref}
899
+ >
900
+ {!!highlightString?.length && typeof children === 'string' ? (
901
+ <HighlightText
902
+ text={children}
903
+ highlight={highlightString}
904
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
905
+ highlightClassName={highlightedTextClassName}
906
+ highlightWithBackground={highlightWithBackground}
907
+ />
908
+ ) : (
909
+ children
910
+ )}
911
+ </p>
912
+ ),
913
+ );
914
+ export const BodySmallBold: React$AbstractComponent<
915
+ TextProps,
916
+ HTMLParagraphElement
917
+ > = React.forwardRef<TextProps, HTMLParagraphElement>(
918
+ (
919
+ {
920
+ color = TEXT_COLORS.primary,
921
+ children,
922
+ className,
923
+ highlightedTextClassName,
924
+ highlightString,
925
+ caseSensitiveHighlighting,
926
+ highlightWithBackground,
927
+ ...props
928
+ }: TextProps,
929
+ ref,
930
+ ): React.ReactNode => (
931
+ <p
932
+ {...props}
933
+ className={classify(css.bodySmall, css.bold, css[color], className)}
934
+ ref={ref}
935
+ >
936
+ {!!highlightString?.length && typeof children === 'string' ? (
937
+ <HighlightText
938
+ text={children}
939
+ highlight={highlightString}
940
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
941
+ highlightClassName={highlightedTextClassName}
942
+ highlightWithBackground={highlightWithBackground}
943
+ />
944
+ ) : (
945
+ children
946
+ )}
947
+ </p>
948
+ ),
949
+ );
950
+ export const FormLabelMedium: React$AbstractComponent<
951
+ TextProps,
952
+ HTMLSpanElement
953
+ > = React.forwardRef<TextProps, HTMLSpanElement>(
954
+ (
955
+ {
956
+ color = TEXT_COLORS.primary,
957
+ children,
958
+ className,
959
+ highlightedTextClassName,
960
+ highlightString,
961
+ caseSensitiveHighlighting,
962
+ highlightWithBackground,
963
+ ...props
964
+ }: TextProps,
965
+ ref,
966
+ ): React.ReactNode => (
967
+ <span
968
+ {...props}
969
+ className={classify(css.formLabelMedium, css[color], className)}
970
+ ref={ref}
971
+ >
972
+ {!!highlightString?.length && typeof children === 'string' ? (
973
+ <HighlightText
974
+ text={children}
975
+ highlight={highlightString}
976
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
977
+ highlightClassName={highlightedTextClassName}
978
+ highlightWithBackground={highlightWithBackground}
979
+ />
980
+ ) : (
981
+ children
982
+ )}
983
+ </span>
984
+ ),
985
+ );
986
+ export const FormLabelSmall: React$AbstractComponent<
987
+ TextProps,
988
+ HTMLSpanElement
989
+ > = React.forwardRef<TextProps, HTMLSpanElement>(
990
+ (
991
+ {
992
+ color = TEXT_COLORS.primary,
993
+ children,
994
+ className,
995
+ highlightedTextClassName,
996
+ highlightString,
997
+ caseSensitiveHighlighting,
998
+ highlightWithBackground,
999
+ ...props
1000
+ }: TextProps,
1001
+ ref,
1002
+ ): React.ReactNode => (
1003
+ <span
1004
+ {...props}
1005
+ className={classify(css.formLabelSmall, css[color], className)}
1006
+ ref={ref}
1007
+ >
1008
+ {!!highlightString?.length && typeof children === 'string' ? (
1009
+ <HighlightText
1010
+ text={children}
1011
+ highlight={highlightString}
1012
+ caseSensitiveHighlighting={caseSensitiveHighlighting}
1013
+ highlightClassName={highlightedTextClassName}
1014
+ highlightWithBackground={highlightWithBackground}
1015
+ />
1016
+ ) : (
1017
+ children
1018
+ )}
1019
+ </span>
1020
+ ),
1021
+ );