@laerdal/life-react-components 6.0.0-dev.2.full → 6.0.0-dev.20.full

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 (421) hide show
  1. package/dist/Accordion/ContentAccordion.cjs +40 -11
  2. package/dist/Accordion/ContentAccordion.cjs.map +1 -1
  3. package/dist/Accordion/ContentAccordion.js +40 -11
  4. package/dist/Accordion/ContentAccordion.js.map +1 -1
  5. package/dist/Accordion/__tests__/AccordionMenu.test.tsx +42 -0
  6. package/dist/Accordion/__tests__/ContentAccordion.test.tsx +150 -0
  7. package/dist/Accordion/styles.cjs +51 -13
  8. package/dist/Accordion/styles.cjs.map +1 -1
  9. package/dist/Accordion/styles.js +51 -13
  10. package/dist/Accordion/styles.js.map +1 -1
  11. package/dist/AuthPage/__tests__/AuthPage.test.tsx +27 -0
  12. package/dist/Banners/Banner.cjs +38 -34
  13. package/dist/Banners/Banner.cjs.map +1 -1
  14. package/dist/Banners/Banner.d.ts +2 -3
  15. package/dist/Banners/Banner.js +38 -34
  16. package/dist/Banners/Banner.js.map +1 -1
  17. package/dist/Banners/__tests__/Banner.test.tsx +47 -0
  18. package/dist/Banners/__tests__/OverviewBanner.test.tsx +20 -0
  19. package/dist/Banners/styles.cjs +8 -16
  20. package/dist/Banners/styles.cjs.map +1 -1
  21. package/dist/Banners/styles.js +8 -16
  22. package/dist/Banners/styles.js.map +1 -1
  23. package/dist/Breadcrumb/Breadcrumb.cjs +8 -2
  24. package/dist/Breadcrumb/Breadcrumb.cjs.map +1 -1
  25. package/dist/Breadcrumb/Breadcrumb.js +8 -2
  26. package/dist/Breadcrumb/Breadcrumb.js.map +1 -1
  27. package/dist/Breadcrumb/__tests__/Breadcrumb.test.tsx +78 -0
  28. package/dist/Breadcrumb/styles.cjs +15 -4
  29. package/dist/Breadcrumb/styles.cjs.map +1 -1
  30. package/dist/Breadcrumb/styles.js +15 -4
  31. package/dist/Breadcrumb/styles.js.map +1 -1
  32. package/dist/Button/BackButton.cjs +27 -6
  33. package/dist/Button/BackButton.cjs.map +1 -1
  34. package/dist/Button/BackButton.js +27 -6
  35. package/dist/Button/BackButton.js.map +1 -1
  36. package/dist/Button/Button.cjs +179 -47
  37. package/dist/Button/Button.cjs.map +1 -1
  38. package/dist/Button/Button.d.ts +2 -0
  39. package/dist/Button/Button.js +179 -47
  40. package/dist/Button/Button.js.map +1 -1
  41. package/dist/Button/Iconbutton.cjs +83 -21
  42. package/dist/Button/Iconbutton.cjs.map +1 -1
  43. package/dist/Button/Iconbutton.js +83 -21
  44. package/dist/Button/Iconbutton.js.map +1 -1
  45. package/dist/Button/__tests__/BackButton.test.tsx +32 -0
  46. package/dist/Button/__tests__/Button.test.tsx +45 -0
  47. package/dist/Button/__tests__/DualButton.test.tsx +119 -0
  48. package/dist/Card/HorizontalCard/HorizontalCard.cjs +20 -5
  49. package/dist/Card/HorizontalCard/HorizontalCard.cjs.map +1 -1
  50. package/dist/Card/HorizontalCard/HorizontalCard.js +20 -5
  51. package/dist/Card/HorizontalCard/HorizontalCard.js.map +1 -1
  52. package/dist/Card/HorizontalCard/HorizontalCardBody.cjs +12 -3
  53. package/dist/Card/HorizontalCard/HorizontalCardBody.cjs.map +1 -1
  54. package/dist/Card/HorizontalCard/HorizontalCardBody.js +12 -3
  55. package/dist/Card/HorizontalCard/HorizontalCardBody.js.map +1 -1
  56. package/dist/Card/HorizontalCard/HorizontalCardThumbnail.cjs +8 -2
  57. package/dist/Card/HorizontalCard/HorizontalCardThumbnail.cjs.map +1 -1
  58. package/dist/Card/HorizontalCard/HorizontalCardThumbnail.js +8 -2
  59. package/dist/Card/HorizontalCard/HorizontalCardThumbnail.js.map +1 -1
  60. package/dist/Card/HorizontalCard/__tests__/HorizontalCard.test.tsx +71 -0
  61. package/dist/Card/HorizontalCard/__tests__/VerticalCard.test.tsx +124 -0
  62. package/dist/Card/VerticalCard/Card.cjs +20 -5
  63. package/dist/Card/VerticalCard/Card.cjs.map +1 -1
  64. package/dist/Card/VerticalCard/Card.js +20 -5
  65. package/dist/Card/VerticalCard/Card.js.map +1 -1
  66. package/dist/Card/VerticalCard/CardBottomSection.cjs +28 -7
  67. package/dist/Card/VerticalCard/CardBottomSection.cjs.map +1 -1
  68. package/dist/Card/VerticalCard/CardBottomSection.js +28 -7
  69. package/dist/Card/VerticalCard/CardBottomSection.js.map +1 -1
  70. package/dist/Card/VerticalCard/CardMiddleSection.cjs +19 -4
  71. package/dist/Card/VerticalCard/CardMiddleSection.cjs.map +1 -1
  72. package/dist/Card/VerticalCard/CardMiddleSection.js +19 -4
  73. package/dist/Card/VerticalCard/CardMiddleSection.js.map +1 -1
  74. package/dist/Card/VerticalCard/CardTopSection.cjs +9 -2
  75. package/dist/Card/VerticalCard/CardTopSection.cjs.map +1 -1
  76. package/dist/Card/VerticalCard/CardTopSection.js +9 -2
  77. package/dist/Card/VerticalCard/CardTopSection.js.map +1 -1
  78. package/dist/Card/__tests__/Card.test.tsx +146 -0
  79. package/dist/Chips/ChipStyles.cjs +4 -1
  80. package/dist/Chips/ChipStyles.cjs.map +1 -1
  81. package/dist/Chips/ChipStyles.js +4 -1
  82. package/dist/Chips/ChipStyles.js.map +1 -1
  83. package/dist/Chips/__tests__/ActionChip.test.tsx +94 -0
  84. package/dist/Chips/__tests__/ChoiceChips.test.tsx +79 -0
  85. package/dist/Chips/__tests__/FilterChip.test.tsx +95 -0
  86. package/dist/Chips/__tests__/InputChip.test.tsx +155 -0
  87. package/dist/ChipsInput/ChipInputField.cjs +16 -4
  88. package/dist/ChipsInput/ChipInputField.cjs.map +1 -1
  89. package/dist/ChipsInput/ChipInputField.js +16 -4
  90. package/dist/ChipsInput/ChipInputField.js.map +1 -1
  91. package/dist/ChipsInput/__tests__/ChipDropdownInput.test.tsx +100 -0
  92. package/dist/ChipsInput/__tests__/ChipInputFields.test.tsx +155 -0
  93. package/dist/Dropdown/BasicDropdown.cjs +12 -3
  94. package/dist/Dropdown/BasicDropdown.cjs.map +1 -1
  95. package/dist/Dropdown/BasicDropdown.js +12 -3
  96. package/dist/Dropdown/BasicDropdown.js.map +1 -1
  97. package/dist/Dropdown/CommonStyling.cjs +172 -42
  98. package/dist/Dropdown/CommonStyling.cjs.map +1 -1
  99. package/dist/Dropdown/CommonStyling.js +172 -42
  100. package/dist/Dropdown/CommonStyling.js.map +1 -1
  101. package/dist/Dropdown/DropdownContent.cjs +36 -10
  102. package/dist/Dropdown/DropdownContent.cjs.map +1 -1
  103. package/dist/Dropdown/DropdownContent.js +36 -10
  104. package/dist/Dropdown/DropdownContent.js.map +1 -1
  105. package/dist/Dropdown/DropdownFilter.cjs +12 -3
  106. package/dist/Dropdown/DropdownFilter.cjs.map +1 -1
  107. package/dist/Dropdown/DropdownFilter.js +12 -3
  108. package/dist/Dropdown/DropdownFilter.js.map +1 -1
  109. package/dist/Dropdown/__tests__/DropdownFilter.test.tsx +39 -0
  110. package/dist/Footer/Components/FooterNewsletterAndSocialSection.cjs +4 -1
  111. package/dist/Footer/Components/FooterNewsletterAndSocialSection.cjs.map +1 -1
  112. package/dist/Footer/Components/FooterNewsletterAndSocialSection.js +4 -1
  113. package/dist/Footer/Components/FooterNewsletterAndSocialSection.js.map +1 -1
  114. package/dist/Footer/__tests__/Footer.test.tsx +182 -0
  115. package/dist/GlobalNavigationBar/Logo.cjs +2 -1
  116. package/dist/GlobalNavigationBar/Logo.cjs.map +1 -1
  117. package/dist/GlobalNavigationBar/Logo.js +2 -1
  118. package/dist/GlobalNavigationBar/Logo.js.map +1 -1
  119. package/dist/GlobalNavigationBar/__tests__/GlobalNavigationBar.tests.d.ts +1 -0
  120. package/dist/GlobalNavigationBar/__tests__/Logo.test.tsx +39 -0
  121. package/dist/GlobalNavigationBar/__tests__/Logo.tests.d.ts +1 -0
  122. package/dist/GlobalNavigationBar/desktop/MainMenu.cjs +10 -1
  123. package/dist/GlobalNavigationBar/desktop/MainMenu.cjs.map +1 -1
  124. package/dist/GlobalNavigationBar/desktop/MainMenu.js +10 -1
  125. package/dist/GlobalNavigationBar/desktop/MainMenu.js.map +1 -1
  126. package/dist/GlobalNavigationBar/desktop/RightSideNav.cjs +3 -2
  127. package/dist/GlobalNavigationBar/desktop/RightSideNav.cjs.map +1 -1
  128. package/dist/GlobalNavigationBar/desktop/RightSideNav.js +3 -2
  129. package/dist/GlobalNavigationBar/desktop/RightSideNav.js.map +1 -1
  130. package/dist/GlobalNavigationBar/desktop/UserMenu.cjs +4 -1
  131. package/dist/GlobalNavigationBar/desktop/UserMenu.cjs.map +1 -1
  132. package/dist/GlobalNavigationBar/desktop/UserMenu.js +4 -1
  133. package/dist/GlobalNavigationBar/desktop/UserMenu.js.map +1 -1
  134. package/dist/GlobalNavigationBar/desktop/__tests__/DesktopActions.test.tsx +108 -0
  135. package/dist/GlobalNavigationBar/desktop/__tests__/ExtendedMainMenu.test.tsx +28 -0
  136. package/dist/GlobalNavigationBar/desktop/__tests__/MainMenu.test.tsx +55 -0
  137. package/dist/GlobalNavigationBar/desktop/__tests__/RightSideNav.test.tsx +45 -0
  138. package/dist/GlobalNavigationBar/desktop/__tests__/UserMenu.test.tsx +125 -0
  139. package/dist/GlobalNavigationBar/mobile/CommonStyles.cjs.map +1 -1
  140. package/dist/GlobalNavigationBar/mobile/CommonStyles.js.map +1 -1
  141. package/dist/GlobalNavigationBar/mobile/__tests__/MobileMenu.test.tsx +317 -0
  142. package/dist/GlobalNavigationBar/mobile/__tests__/MobileMenuContent.test.tsx +294 -0
  143. package/dist/GlobalNavigationBar/mobile/__tests__/MobileMenuHeader.test.tsx +195 -0
  144. package/dist/HyperLink/HyperLink.cjs +18 -2
  145. package/dist/HyperLink/HyperLink.cjs.map +1 -1
  146. package/dist/HyperLink/HyperLink.d.ts +2 -0
  147. package/dist/HyperLink/HyperLink.js +18 -2
  148. package/dist/HyperLink/HyperLink.js.map +1 -1
  149. package/dist/HyperLink/styling.cjs +38 -8
  150. package/dist/HyperLink/styling.cjs.map +1 -1
  151. package/dist/HyperLink/styling.js +38 -8
  152. package/dist/HyperLink/styling.js.map +1 -1
  153. package/dist/InputFields/Checkbox.cjs +54 -14
  154. package/dist/InputFields/Checkbox.cjs.map +1 -1
  155. package/dist/InputFields/Checkbox.js +54 -14
  156. package/dist/InputFields/Checkbox.js.map +1 -1
  157. package/dist/InputFields/DatepickerField.cjs +149 -43
  158. package/dist/InputFields/DatepickerField.cjs.map +1 -1
  159. package/dist/InputFields/DatepickerField.d.ts +1 -1
  160. package/dist/InputFields/DatepickerField.js +150 -44
  161. package/dist/InputFields/DatepickerField.js.map +1 -1
  162. package/dist/InputFields/DatepickerFieldHeader.cjs +20 -5
  163. package/dist/InputFields/DatepickerFieldHeader.cjs.map +1 -1
  164. package/dist/InputFields/DatepickerFieldHeader.js +20 -5
  165. package/dist/InputFields/DatepickerFieldHeader.js.map +1 -1
  166. package/dist/InputFields/Label.cjs +38 -11
  167. package/dist/InputFields/Label.cjs.map +1 -1
  168. package/dist/InputFields/Label.js +38 -11
  169. package/dist/InputFields/Label.js.map +1 -1
  170. package/dist/InputFields/NumberField.cjs +66 -16
  171. package/dist/InputFields/NumberField.cjs.map +1 -1
  172. package/dist/InputFields/NumberField.js +66 -16
  173. package/dist/InputFields/NumberField.js.map +1 -1
  174. package/dist/InputFields/PasswordField.cjs +4 -1
  175. package/dist/InputFields/PasswordField.cjs.map +1 -1
  176. package/dist/InputFields/PasswordField.d.ts +1 -1
  177. package/dist/InputFields/PasswordField.js +4 -1
  178. package/dist/InputFields/PasswordField.js.map +1 -1
  179. package/dist/InputFields/QuickSearch.cjs +30 -6
  180. package/dist/InputFields/QuickSearch.cjs.map +1 -1
  181. package/dist/InputFields/QuickSearch.js +30 -6
  182. package/dist/InputFields/QuickSearch.js.map +1 -1
  183. package/dist/InputFields/RadioButton.cjs +63 -15
  184. package/dist/InputFields/RadioButton.cjs.map +1 -1
  185. package/dist/InputFields/RadioButton.js +63 -15
  186. package/dist/InputFields/RadioButton.js.map +1 -1
  187. package/dist/InputFields/RichTextField.cjs +60 -15
  188. package/dist/InputFields/RichTextField.cjs.map +1 -1
  189. package/dist/InputFields/RichTextField.js +60 -15
  190. package/dist/InputFields/RichTextField.js.map +1 -1
  191. package/dist/InputFields/SearchBar.cjs +4 -1
  192. package/dist/InputFields/SearchBar.cjs.map +1 -1
  193. package/dist/InputFields/SearchBar.js +4 -1
  194. package/dist/InputFields/SearchBar.js.map +1 -1
  195. package/dist/InputFields/TextField.cjs +9 -3
  196. package/dist/InputFields/TextField.cjs.map +1 -1
  197. package/dist/InputFields/TextField.d.ts +1 -1
  198. package/dist/InputFields/TextField.js +9 -3
  199. package/dist/InputFields/TextField.js.map +1 -1
  200. package/dist/InputFields/Textarea.cjs +68 -17
  201. package/dist/InputFields/Textarea.cjs.map +1 -1
  202. package/dist/InputFields/Textarea.js +68 -17
  203. package/dist/InputFields/Textarea.js.map +1 -1
  204. package/dist/InputFields/__tests__/NumberField.test.tsx +67 -0
  205. package/dist/InputFields/__tests__/NumberInput.test.tsx +68 -0
  206. package/dist/InputFields/__tests__/QuickSearch.test.tsx +42 -0
  207. package/dist/InputFields/components/SearchBarInput.cjs +28 -7
  208. package/dist/InputFields/components/SearchBarInput.cjs.map +1 -1
  209. package/dist/InputFields/components/SearchBarInput.js +28 -7
  210. package/dist/InputFields/components/SearchBarInput.js.map +1 -1
  211. package/dist/InputFields/components/SearchField.cjs +60 -15
  212. package/dist/InputFields/components/SearchField.cjs.map +1 -1
  213. package/dist/InputFields/components/SearchField.js +60 -15
  214. package/dist/InputFields/components/SearchField.js.map +1 -1
  215. package/dist/InputFields/styling.cjs +95 -39
  216. package/dist/InputFields/styling.cjs.map +1 -1
  217. package/dist/InputFields/styling.d.ts +1 -2
  218. package/dist/InputFields/styling.js +95 -39
  219. package/dist/InputFields/styling.js.map +1 -1
  220. package/dist/LinearProgress/LinearProgress.cjs +161 -53
  221. package/dist/LinearProgress/LinearProgress.cjs.map +1 -1
  222. package/dist/LinearProgress/LinearProgress.js +161 -53
  223. package/dist/LinearProgress/LinearProgress.js.map +1 -1
  224. package/dist/LinearProgress/__tests__/LinearProgress.test.tsx +25 -0
  225. package/dist/List/ListRow.cjs +36 -9
  226. package/dist/List/ListRow.cjs.map +1 -1
  227. package/dist/List/ListRow.js +36 -9
  228. package/dist/List/ListRow.js.map +1 -1
  229. package/dist/List/__tests__/ListRow.test.tsx +18 -0
  230. package/dist/List/__tests__/ListRow.tests.d.ts +1 -0
  231. package/dist/LoadingIndicator/LoadingIndicator.cjs +4 -1
  232. package/dist/LoadingIndicator/LoadingIndicator.cjs.map +1 -1
  233. package/dist/LoadingIndicator/LoadingIndicator.js +4 -1
  234. package/dist/LoadingIndicator/LoadingIndicator.js.map +1 -1
  235. package/dist/LoadingPage/GlobalLoadingPage.cjs +4 -1
  236. package/dist/LoadingPage/GlobalLoadingPage.cjs.map +1 -1
  237. package/dist/LoadingPage/GlobalLoadingPage.js +4 -1
  238. package/dist/LoadingPage/GlobalLoadingPage.js.map +1 -1
  239. package/dist/LoadingPage/__tests__/GlobalLoadingPage.test.tsx +23 -0
  240. package/dist/MenuItem/MenuItem.cjs +101 -26
  241. package/dist/MenuItem/MenuItem.cjs.map +1 -1
  242. package/dist/MenuItem/MenuItem.js +101 -26
  243. package/dist/MenuItem/MenuItem.js.map +1 -1
  244. package/dist/MiniProductCard/MiniProductCard.cjs +15 -1
  245. package/dist/MiniProductCard/MiniProductCard.cjs.map +1 -1
  246. package/dist/MiniProductCard/MiniProductCard.d.ts +1 -0
  247. package/dist/MiniProductCard/MiniProductCard.js +15 -1
  248. package/dist/MiniProductCard/MiniProductCard.js.map +1 -1
  249. package/dist/Modals/Modal.cjs +4 -1
  250. package/dist/Modals/Modal.cjs.map +1 -1
  251. package/dist/Modals/Modal.js +4 -1
  252. package/dist/Modals/Modal.js.map +1 -1
  253. package/dist/Modals/ModalContent.cjs +24 -6
  254. package/dist/Modals/ModalContent.cjs.map +1 -1
  255. package/dist/Modals/ModalContent.js +24 -6
  256. package/dist/Modals/ModalContent.js.map +1 -1
  257. package/dist/Modals/ModalDialog.cjs +12 -3
  258. package/dist/Modals/ModalDialog.cjs.map +1 -1
  259. package/dist/Modals/ModalDialog.js +12 -3
  260. package/dist/Modals/ModalDialog.js.map +1 -1
  261. package/dist/Modals/ModalNote.cjs +16 -4
  262. package/dist/Modals/ModalNote.cjs.map +1 -1
  263. package/dist/Modals/ModalNote.js +16 -4
  264. package/dist/Modals/ModalNote.js.map +1 -1
  265. package/dist/Modals/ModalStyles.cjs +44 -11
  266. package/dist/Modals/ModalStyles.cjs.map +1 -1
  267. package/dist/Modals/ModalStyles.js +44 -11
  268. package/dist/Modals/ModalStyles.js.map +1 -1
  269. package/dist/Modals/__tests__/Modal.test.tsx +169 -0
  270. package/dist/Modals/__tests__/ModalContainer.test.tsx +77 -0
  271. package/dist/Modals/__tests__/ModalContent.test.tsx +126 -0
  272. package/dist/NavItem/NavItem.cjs +11 -2
  273. package/dist/NavItem/NavItem.cjs.map +1 -1
  274. package/dist/NavItem/NavItem.js +11 -2
  275. package/dist/NavItem/NavItem.js.map +1 -1
  276. package/dist/NavItem/__tests__/NavItem.test.ts +6 -0
  277. package/dist/NotificationDot/NotificationDot.cjs +17 -2
  278. package/dist/NotificationDot/NotificationDot.cjs.map +1 -1
  279. package/dist/NotificationDot/NotificationDot.js +17 -2
  280. package/dist/NotificationDot/NotificationDot.js.map +1 -1
  281. package/dist/NotificationDot/__tests__/NotificationDot.test.tsx +33 -0
  282. package/dist/Paginator/Paginator.cjs +76 -29
  283. package/dist/Paginator/Paginator.cjs.map +1 -1
  284. package/dist/Paginator/Paginator.js +76 -29
  285. package/dist/Paginator/Paginator.js.map +1 -1
  286. package/dist/Paginator/__tests__/Paginator.test.tsx +39 -0
  287. package/dist/Panel/Panel.cjs +4 -1
  288. package/dist/Panel/Panel.cjs.map +1 -1
  289. package/dist/Panel/Panel.js +4 -1
  290. package/dist/Panel/Panel.js.map +1 -1
  291. package/dist/Popover/Popover.cjs +22 -3
  292. package/dist/Popover/Popover.cjs.map +1 -1
  293. package/dist/Popover/Popover.js +22 -3
  294. package/dist/Popover/Popover.js.map +1 -1
  295. package/dist/Popover/__tests__/Popover.test.tsx +64 -0
  296. package/dist/ProfileButton/ProfileButton.cjs +9 -2
  297. package/dist/ProfileButton/ProfileButton.cjs.map +1 -1
  298. package/dist/ProfileButton/ProfileButton.js +9 -2
  299. package/dist/ProfileButton/ProfileButton.js.map +1 -1
  300. package/dist/ProfileButton/__tests__/ProfileButton.test.tsx +31 -0
  301. package/dist/QuizButton/__tests__/QuizButton.test.tsx +53 -0
  302. package/dist/SegmentControl/SegmentControl.cjs +46 -11
  303. package/dist/SegmentControl/SegmentControl.cjs.map +1 -1
  304. package/dist/SegmentControl/SegmentControl.js +46 -11
  305. package/dist/SegmentControl/SegmentControl.js.map +1 -1
  306. package/dist/SegmentControl/__tests__/SegmentControl.test.tsx +145 -0
  307. package/dist/SideMenu/SideMenuHeader.cjs +12 -3
  308. package/dist/SideMenu/SideMenuHeader.cjs.map +1 -1
  309. package/dist/SideMenu/SideMenuHeader.js +12 -3
  310. package/dist/SideMenu/SideMenuHeader.js.map +1 -1
  311. package/dist/SideMenu/__tests__/SideMenu.test.tsx +99 -0
  312. package/dist/Switcher/SwitcherMenuItem.cjs +4 -1
  313. package/dist/Switcher/SwitcherMenuItem.cjs.map +1 -1
  314. package/dist/Switcher/SwitcherMenuItem.js +4 -1
  315. package/dist/Switcher/SwitcherMenuItem.js.map +1 -1
  316. package/dist/Switcher/__tests__/SwitcherMenuItem.tsx +14 -0
  317. package/dist/Table/TableFooter.cjs +8 -2
  318. package/dist/Table/TableFooter.cjs.map +1 -1
  319. package/dist/Table/TableFooter.js +8 -2
  320. package/dist/Table/TableFooter.js.map +1 -1
  321. package/dist/Table/TableStyles.cjs +132 -33
  322. package/dist/Table/TableStyles.cjs.map +1 -1
  323. package/dist/Table/TableStyles.js +132 -33
  324. package/dist/Table/TableStyles.js.map +1 -1
  325. package/dist/Table/__tests__/Table.test.tsx +499 -0
  326. package/dist/Tabs/HorizontalTabs.cjs +68 -18
  327. package/dist/Tabs/HorizontalTabs.cjs.map +1 -1
  328. package/dist/Tabs/HorizontalTabs.js +68 -18
  329. package/dist/Tabs/HorizontalTabs.js.map +1 -1
  330. package/dist/Tabs/TabLink.cjs +4 -1
  331. package/dist/Tabs/TabLink.cjs.map +1 -1
  332. package/dist/Tabs/TabLink.js +4 -1
  333. package/dist/Tabs/TabLink.js.map +1 -1
  334. package/dist/Tabs/VerticalTabs.cjs +1 -0
  335. package/dist/Tabs/VerticalTabs.cjs.map +1 -1
  336. package/dist/Tabs/VerticalTabs.js +1 -0
  337. package/dist/Tabs/VerticalTabs.js.map +1 -1
  338. package/dist/Tabs/__tests__/HorizontalTabs.test.tsx +95 -0
  339. package/dist/Tabs/__tests__/TabLink.test.tsx +40 -0
  340. package/dist/Tabs/__tests__/TabLink.tests.d.ts +1 -0
  341. package/dist/Tabs/__tests__/Tablist.test.tsx +37 -0
  342. package/dist/Tabs/__tests__/Tablist.tests.d.ts +2 -0
  343. package/dist/Tag/Tag.cjs +2 -2
  344. package/dist/Tag/Tag.cjs.map +1 -1
  345. package/dist/Tag/Tag.js +2 -2
  346. package/dist/Tag/Tag.js.map +1 -1
  347. package/dist/Tag/__tests__/Tag.test.tsx +86 -0
  348. package/dist/Tile/Tile.cjs +8 -2
  349. package/dist/Tile/Tile.cjs.map +1 -1
  350. package/dist/Tile/Tile.js +8 -2
  351. package/dist/Tile/Tile.js.map +1 -1
  352. package/dist/Tile/TileCommonItems.cjs +8 -2
  353. package/dist/Tile/TileCommonItems.cjs.map +1 -1
  354. package/dist/Tile/TileCommonItems.js +8 -2
  355. package/dist/Tile/TileCommonItems.js.map +1 -1
  356. package/dist/Tile/TileFooter.cjs +4 -1
  357. package/dist/Tile/TileFooter.cjs.map +1 -1
  358. package/dist/Tile/TileFooter.js +4 -1
  359. package/dist/Tile/TileFooter.js.map +1 -1
  360. package/dist/Tile/TileHeader.cjs +12 -3
  361. package/dist/Tile/TileHeader.cjs.map +1 -1
  362. package/dist/Tile/TileHeader.js +12 -3
  363. package/dist/Tile/TileHeader.js.map +1 -1
  364. package/dist/Toasters/Toast.cjs +62 -13
  365. package/dist/Toasters/Toast.cjs.map +1 -1
  366. package/dist/Toasters/Toast.js +62 -13
  367. package/dist/Toasters/Toast.js.map +1 -1
  368. package/dist/Toasters/__tests__/Toast.test.tsx +74 -0
  369. package/dist/Toggles/ToggleButton.cjs +9 -3
  370. package/dist/Toggles/ToggleButton.cjs.map +1 -1
  371. package/dist/Toggles/ToggleButton.d.ts +1 -1
  372. package/dist/Toggles/ToggleButton.js +9 -3
  373. package/dist/Toggles/ToggleButton.js.map +1 -1
  374. package/dist/Toggles/TogglerStyles.cjs +22 -8
  375. package/dist/Toggles/TogglerStyles.cjs.map +1 -1
  376. package/dist/Toggles/TogglerStyles.js +22 -8
  377. package/dist/Toggles/TogglerStyles.js.map +1 -1
  378. package/dist/Toggles/__tests__/ToggleButton.test.tsx +53 -0
  379. package/dist/Toggles/__tests__/ToggleSwitch.test.tsx +87 -0
  380. package/dist/Tooltips/TooltipStyles.cjs +28 -6
  381. package/dist/Tooltips/TooltipStyles.cjs.map +1 -1
  382. package/dist/Tooltips/TooltipStyles.js +28 -6
  383. package/dist/Tooltips/TooltipStyles.js.map +1 -1
  384. package/dist/Tooltips/__tests__/TooltipWrapper.test.tsx +16 -0
  385. package/dist/common/InputStyling.cjs +30 -7
  386. package/dist/common/InputStyling.cjs.map +1 -1
  387. package/dist/common/InputStyling.js +30 -7
  388. package/dist/common/InputStyling.js.map +1 -1
  389. package/dist/common/Link.cjs +45 -0
  390. package/dist/common/Link.cjs.map +1 -0
  391. package/dist/common/Link.d.ts +9 -0
  392. package/dist/common/Link.js +37 -0
  393. package/dist/common/Link.js.map +1 -0
  394. package/dist/common/NavigationHelper.cjs +30 -0
  395. package/dist/common/NavigationHelper.cjs.map +1 -0
  396. package/dist/common/NavigationHelper.d.ts +4 -0
  397. package/dist/common/NavigationHelper.js +23 -0
  398. package/dist/common/NavigationHelper.js.map +1 -0
  399. package/dist/custom.d.ts +2 -0
  400. package/dist/styles/colors.cjs +439 -84
  401. package/dist/styles/colors.cjs.map +1 -1
  402. package/dist/styles/colors.d.ts +200 -11
  403. package/dist/styles/colors.js +439 -84
  404. package/dist/styles/colors.js.map +1 -1
  405. package/dist/styles/global.cjs +19 -2
  406. package/dist/styles/global.cjs.map +1 -1
  407. package/dist/styles/global.d.ts +3 -2
  408. package/dist/styles/global.js +18 -3
  409. package/dist/styles/global.js.map +1 -1
  410. package/dist/styles/index.cjs +21 -9
  411. package/dist/styles/index.cjs.map +1 -1
  412. package/dist/styles/index.d.ts +2 -2
  413. package/dist/styles/index.js +18 -6
  414. package/dist/styles/index.js.map +1 -1
  415. package/dist/styles/react-datepicker.css +766 -0
  416. package/dist/utils/color-tokens.cjs +91 -0
  417. package/dist/utils/color-tokens.cjs.map +1 -0
  418. package/dist/utils/color-tokens.d.ts +19 -0
  419. package/dist/utils/color-tokens.js +82 -0
  420. package/dist/utils/color-tokens.js.map +1 -0
  421. package/package.json +144 -141
@@ -1 +1 @@
1
- {"version":3,"file":"RichTextField.js","names":["React","ReactQuill","styled","useTheme","NoteMessage","readOnlyState","ValidationMessage","Size","States","COLORS","ComponentMStyling","ComponentSStyling","ComponentTextStyle","scrollBarStyling","CheckMark","TechnicalWarning","jsx","_jsx","jsxs","_jsxs","RichTextFieldContainer","div","props","getColor","theme","Regular","Italic","Small","RichTextFieldFormats","defaultToolBarOptions","header","RichTextField","forwardRef","_ref","ref","readOnly","disabled","validationMessage","note","size","Medium","state","resizable","modules","formats","rest","_objectWithoutProperties","_excluded","m","_objectSpread","toolbar","f","Object","values","filter","a","Image","Video","Formula","className","children","type","Invalid","Valid","color","icon","message","propTypes","id","_pt","string","placeholder","bool","arrayOf","oneOf","onKeyDown","func","onKeyPress","onKeyUp","value","any","isRequired","onChange"],"sources":["../../src/InputFields/RichTextField.tsx"],"sourcesContent":["import React from 'react';\r\nimport ReactQuill, {Range, UnprivilegedEditor} from \"react-quill\";\r\nimport {TextFieldNote} from \"./types\";\r\nimport styled, { useTheme } from \"styled-components\";\r\nimport {NoteMessage, readOnlyState, ValidationMessage} from \"./styling\";\r\nimport {Size, States} from \"../types\";\r\nimport {COLORS, ComponentMStyling, ComponentSStyling, ComponentTextStyle, scrollBarStyling} from \"../styles\";\r\nimport {CheckMark, TechnicalWarning} from \"../icons/systemicons\";\r\nimport {Sources, StringMap} from \"quill\";\r\nimport 'react-quill/dist/quill.snow.css';\r\n\r\nexport const RichTextFieldContainer = styled.div`\r\n .quill {\r\n width: 100%;\r\n margin-bottom: 4px;\r\n overflow: hidden;\r\n\r\n box-shadow: inset 0 0 0 1px ${props => COLORS.getColor('neutral_400', props.theme)};\r\n border-radius: 4px;\r\n }\r\n\r\n .quill.valid {\r\n box-shadow: inset 0 0 0 2px ${props => COLORS.getColor('correct_500', props.theme)};\r\n }\r\n\r\n .quill.invalid {\r\n box-shadow: inset 0 0 0 2px ${props => COLORS.getColor('critical_500', props.theme)};\r\n }\r\n\r\n .quill:hover {\r\n box-shadow: inset 0 0 0 2px ${props => COLORS.getColor('primary_700', props.theme)};\r\n }\r\n\r\n .quill:focus-within {\r\n box-shadow: inset 0 0 0 2px ${props => COLORS.getColor('primary_800', props.theme)};\r\n }\r\n\r\n .ql-editor,\r\n .ql-editor p{\r\n ${props => ComponentSStyling(ComponentTextStyle.Regular, COLORS.getColor('black', props.theme))}\r\n }\r\n\r\n .ql-editor.ql-blank::before {\r\n ${props => ComponentSStyling(ComponentTextStyle.Italic, COLORS.getColor('neutral_500', props.theme))}\r\n }\r\n\r\n &.medium {\r\n .ql-editor,\r\n .ql-editor p{\r\n ${props => ComponentMStyling(ComponentTextStyle.Regular, COLORS.getColor('black', props.theme))}\r\n }\r\n\r\n .ql-editor.ql-blank::before {\r\n ${props => ComponentMStyling(ComponentTextStyle.Italic, COLORS.getColor('neutral_500', props.theme))}\r\n }\r\n }\r\n\r\n .ql-toolbar.ql-snow {\r\n border: none;\r\n padding: 8px 7px;\r\n margin: 0 1px;\r\n border-bottom: 1px solid ${props => COLORS.getColor('neutral_200', props.theme)};\r\n }\r\n\r\n .quill.valid .ql-toolbar,\r\n .quill.invalid .ql-toolbar,\r\n .quill:hover .ql-toolbar,\r\n .quill:focus-within .ql-toolbar {\r\n padding: 8px 6px;\r\n margin: 0 2px;\r\n }\r\n\r\n .ql-container {\r\n font-family: unset !important;\r\n }\r\n\r\n .ql-container.ql-snow {\r\n border: none;\r\n overflow-y: hidden;\r\n padding: 8px;\r\n }\r\n\r\n .ql-editor {\r\n padding: 8px;\r\n overflow-y: auto;\r\n\r\n ${scrollBarStyling(Size.Small)}\r\n }\r\n\r\n &.resizable {\r\n height: initial;\r\n\r\n .quill {\r\n flex: none;\r\n overflow: initial;\r\n }\r\n\r\n .ql-container {\r\n flex: none;\r\n resize: vertical;\r\n }\r\n\r\n .ql-editor {\r\n height: 100%;\r\n }\r\n }\r\n\r\n &.readonly {\r\n .quill {\r\n ${readOnlyState}\r\n }\r\n }\r\n\r\n &.disabled {\r\n cursor: not-allowed;\r\n\r\n .quill {\r\n pointer-events: none;\r\n box-shadow: inset 0 0 0 1px ${props => COLORS.getColor('neutral_100', props.theme)};\r\n color: ${props => COLORS.getColor('neutral_300', props.theme)};\r\n\r\n .ql-editor.ql-blank::before {\r\n color: ${props => COLORS.getColor('neutral_300', props.theme)};\r\n }\r\n }\r\n }\r\n`;\r\n\r\nexport enum RichTextFieldFormats {\r\n Background = 'background',\r\n Bold = 'bold',\r\n Color = 'color',\r\n Font = 'font',\r\n Code = 'code',\r\n Italic = 'italic',\r\n Link = 'link',\r\n Size = 'size',\r\n Strike = 'strike',\r\n Script = 'script',\r\n Underline = 'underline',\r\n Blockquote = 'blockquote',\r\n Header = 'header',\r\n Indent = 'indent',\r\n List = 'list',\r\n Align = 'align',\r\n Direction = 'direction',\r\n CodeBlock = 'code-block',\r\n Formula = 'formula',\r\n Image = 'image',\r\n Video = 'video'\r\n}\r\n\r\nconst defaultToolBarOptions = [\r\n [{header: [1, 2, 3, false]}],\r\n ['bold', 'italic', 'underline', 'strike'],\r\n [{'list': 'ordered'}, {'list': 'bullet'}],\r\n ['link'],\r\n ['clean']\r\n];\r\n\r\nexport interface RichTextFieldProps {\r\n /**\r\n * Optional. The ID of the rich text field.\r\n */\r\n id?: string;\r\n\r\n /**\r\n * Optional. The CSS class name of the rich text field.\r\n */\r\n className?: string;\r\n\r\n /**\r\n * Optional. The placeholder text to be displayed in the rich text field when it is empty.\r\n */\r\n placeholder?: string;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the rich text field is read-only.\r\n */\r\n readOnly?: boolean;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the rich text field is disabled.\r\n */\r\n disabled?: boolean;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the rich text field is resizable.\r\n */\r\n resizable?: boolean;\r\n\r\n /**\r\n * Optional. An object containing the modules to be used by the rich text field.\r\n */\r\n modules?: StringMap;\r\n\r\n /**\r\n * Optional. An array of formats to be used by the rich text field.\r\n */\r\n formats?: RichTextFieldFormats[];\r\n\r\n /**\r\n * Optional. A function to be called when the rich text field gains focus.\r\n */\r\n onFocus?(selection: Range, source: Sources, editor: UnprivilegedEditor): void;\r\n\r\n /**\r\n * Optional. A function to be called when the rich text field loses focus.\r\n */\r\n onBlur?(previousSelection: Range, source: Sources, editor: UnprivilegedEditor): void;\r\n\r\n /**\r\n * Optional. A function to be called when a keydown event occurs in the rich text field.\r\n */\r\n onKeyDown?: React.EventHandler<any>;\r\n\r\n /**\r\n * Optional. A function to be called when a keypress event occurs in the rich text field.\r\n */\r\n onKeyPress?: React.EventHandler<any>;\r\n\r\n /**\r\n * Optional. A function to be called when a keyup event occurs in the rich text field.\r\n */\r\n onKeyUp?: React.EventHandler<any>;\r\n\r\n /**\r\n * Required. The current value of the rich text field.\r\n */\r\n value: any;\r\n\r\n /**\r\n * Required. A function to be called when the value of the rich text field changes.\r\n */\r\n onChange: (value: any) => void;\r\n\r\n /**\r\n * Optional. The validation message to be displayed when the rich text field is in an error state.\r\n */\r\n validationMessage?: string;\r\n\r\n /**\r\n * Optional. A note to be displayed below the rich text field.\r\n */\r\n note?: TextFieldNote;\r\n\r\n /**\r\n * Optional. The size of the rich text field. Can be 'Small' or 'Medium'.\r\n */\r\n size?: Size.Small | Size.Medium;\r\n\r\n /**\r\n * Optional. The state of the rich text field. Can be 'Invalid' or 'Valid'.\r\n */\r\n state?: States.Invalid | States.Valid;\r\n}\r\n\r\nexport const RichTextField = React.forwardRef<any, RichTextFieldProps>(({\r\n readOnly,\r\n disabled,\r\n validationMessage,\r\n note,\r\n size = Size.Medium,\r\n state,\r\n resizable,\r\n modules,\r\n formats,\r\n ...rest\r\n }: RichTextFieldProps, ref) => {\r\n\r\n const theme = useTheme();\r\n let m = {...(modules ?? {}), toolbar: modules?.toolbar ?? defaultToolBarOptions};\r\n let f = formats ?? Object.values(RichTextFieldFormats).filter(a => a !== RichTextFieldFormats.Image && a !== RichTextFieldFormats.Video && a !== RichTextFieldFormats.Formula);\r\n\r\n return (\r\n <RichTextFieldContainer\r\n className={`${resizable ? 'resizable' : ''} ${size} ${state || ''} ${readOnly ? 'readonly' : ''} ${disabled ? 'disabled' : ''}`}>\r\n <ReactQuill ref={ref}\r\n readOnly={readOnly || disabled}\r\n modules={m}\r\n theme={'snow'}\r\n formats={f}\r\n {...rest}\r\n />\r\n {validationMessage && (\r\n <ValidationMessage className={size || ''} type={state ?? States.Invalid}>\r\n {\r\n state === States.Valid\r\n ? <CheckMark color={COLORS.getColor('correct_400', theme)}/>\r\n : <TechnicalWarning color={COLORS.getColor('critical_400', theme)}/>\r\n }\r\n <span>{validationMessage}</span>\r\n </ValidationMessage>\r\n )}\r\n {note && !disabled && (\r\n <NoteMessage className={size}>\r\n {note.icon}\r\n <span>{note.message}</span>\r\n </NoteMessage>\r\n )}\r\n </RichTextFieldContainer>\r\n )\r\n});"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"RichTextField.js","names":["React","ReactQuill","styled","useTheme","NoteMessage","readOnlyState","ValidationMessage","Size","States","COLORS","ComponentMStyling","ComponentSStyling","ComponentTextStyle","scrollBarStyling","CheckMark","TechnicalWarning","jsx","_jsx","jsxs","_jsxs","RichTextFieldContainer","div","props","generateToken","componentType","defaultVariant","theme","state","Regular","Italic","Small","RichTextFieldFormats","defaultToolBarOptions","header","RichTextField","forwardRef","_ref","ref","readOnly","disabled","validationMessage","note","size","Medium","resizable","modules","formats","rest","_objectWithoutProperties","_excluded","m","_objectSpread","toolbar","f","Object","values","filter","a","Image","Video","Formula","className","children","type","Invalid","Valid","color","icon","message","propTypes","id","_pt","string","placeholder","bool","arrayOf","oneOf","onKeyDown","func","onKeyPress","onKeyUp","value","any","isRequired","onChange"],"sources":["../../src/InputFields/RichTextField.tsx"],"sourcesContent":["import React from 'react';\r\nimport ReactQuill, {Range, UnprivilegedEditor} from \"react-quill\";\r\nimport {TextFieldNote} from \"./types\";\r\nimport styled, { useTheme } from \"styled-components\";\r\nimport {NoteMessage, readOnlyState, ValidationMessage} from \"./styling\";\r\nimport {Size, States} from \"../types\";\r\nimport {COLORS, ComponentMStyling, ComponentSStyling, ComponentTextStyle, scrollBarStyling} from \"../styles\";\r\nimport {CheckMark, TechnicalWarning} from \"../icons/systemicons\";\r\nimport {Sources, StringMap} from \"quill\";\r\nimport 'react-quill/dist/quill.snow.css';\r\n\r\nexport const RichTextFieldContainer = styled.div`\r\n .quill {\r\n width: 100%;\r\n margin-bottom: 4px;\r\n overflow: hidden;\r\n\r\n box-shadow: inset 0 0 0 1px ${props => COLORS.generateToken({componentType:'border', defaultVariant:'default'}, props.theme)};\r\n border-radius: 4px;\r\n }\r\n\r\n .quill.valid {\r\n box-shadow: inset 0 0 0 2px ${props => COLORS.generateToken({componentType:'border', defaultVariant:'positive'}, props.theme)};\r\n }\r\n\r\n .quill.invalid {\r\n box-shadow: inset 0 0 0 2px ${props => COLORS.generateToken({componentType:'border', defaultVariant:'critical'}, props.theme)};\r\n }\r\n\r\n .quill:hover {\r\n box-shadow: inset 0 0 0 2px ${props => COLORS.generateToken({componentType:'border', state:'hover'}, props.theme)};\r\n }\r\n\r\n .quill:focus-within {\r\n box-shadow: inset 0 0 0 2px ${props => COLORS.generateToken({componentType:'border', state:'hover'}, props.theme)};\r\n }\r\n\r\n .ql-editor,\r\n .ql-editor p{\r\n ${props => ComponentSStyling(ComponentTextStyle.Regular, COLORS.generateToken({componentType:'text', defaultVariant:'default'}, props.theme))}\r\n }\r\n\r\n .ql-editor.ql-blank::before {\r\n ${props => ComponentSStyling(ComponentTextStyle.Italic, COLORS.generateToken({componentType:'text', defaultVariant:'subtle'}, props.theme))}\r\n }\r\n\r\n &.medium {\r\n .ql-editor,\r\n .ql-editor p{\r\n ${props => ComponentMStyling(ComponentTextStyle.Regular, COLORS.generateToken({componentType:'text', defaultVariant:'default'}, props.theme))}\r\n }\r\n\r\n .ql-editor.ql-blank::before {\r\n ${props => ComponentMStyling(ComponentTextStyle.Italic, COLORS.generateToken({componentType:'text', defaultVariant:'subtle'}, props.theme))}\r\n }\r\n }\r\n\r\n .ql-toolbar.ql-snow {\r\n border: none;\r\n padding: 8px 7px;\r\n margin: 0 1px;\r\n border-bottom: 1px solid ${props => COLORS.generateToken({componentType:'border', defaultVariant:'subtle'}, props.theme)};\r\n }\r\n\r\n .quill.valid .ql-toolbar,\r\n .quill.invalid .ql-toolbar,\r\n .quill:hover .ql-toolbar,\r\n .quill:focus-within .ql-toolbar {\r\n padding: 8px 6px;\r\n margin: 0 2px;\r\n }\r\n\r\n .ql-container {\r\n font-family: unset !important;\r\n }\r\n\r\n .ql-container.ql-snow {\r\n border: none;\r\n overflow-y: hidden;\r\n padding: 8px;\r\n }\r\n\r\n .ql-editor {\r\n padding: 8px;\r\n overflow-y: auto;\r\n\r\n ${scrollBarStyling(Size.Small)}\r\n }\r\n\r\n &.resizable {\r\n height: initial;\r\n\r\n .quill {\r\n flex: none;\r\n overflow: initial;\r\n }\r\n\r\n .ql-container {\r\n flex: none;\r\n resize: vertical;\r\n }\r\n\r\n .ql-editor {\r\n height: 100%;\r\n }\r\n }\r\n\r\n &.readonly {\r\n .quill {\r\n ${readOnlyState}\r\n }\r\n }\r\n\r\n &.disabled {\r\n cursor: not-allowed;\r\n\r\n .quill {\r\n pointer-events: none;\r\n box-shadow: inset 0 0 0 1px ${props => COLORS.generateToken({componentType:'border', state:'disabled'}, props.theme)};\r\n color: ${props => COLORS.generateToken({componentType:'text', state:'disabled'}, props.theme)};\r\n\r\n .ql-editor.ql-blank::before {\r\n color: ${props => COLORS.generateToken({componentType:'text', state:'disabled'}, props.theme)};\r\n }\r\n }\r\n }\r\n`;\r\n\r\nexport enum RichTextFieldFormats {\r\n Background = 'background',\r\n Bold = 'bold',\r\n Color = 'color',\r\n Font = 'font',\r\n Code = 'code',\r\n Italic = 'italic',\r\n Link = 'link',\r\n Size = 'size',\r\n Strike = 'strike',\r\n Script = 'script',\r\n Underline = 'underline',\r\n Blockquote = 'blockquote',\r\n Header = 'header',\r\n Indent = 'indent',\r\n List = 'list',\r\n Align = 'align',\r\n Direction = 'direction',\r\n CodeBlock = 'code-block',\r\n Formula = 'formula',\r\n Image = 'image',\r\n Video = 'video'\r\n}\r\n\r\nconst defaultToolBarOptions = [\r\n [{header: [1, 2, 3, false]}],\r\n ['bold', 'italic', 'underline', 'strike'],\r\n [{'list': 'ordered'}, {'list': 'bullet'}],\r\n ['link'],\r\n ['clean']\r\n];\r\n\r\nexport interface RichTextFieldProps {\r\n /**\r\n * Optional. The ID of the rich text field.\r\n */\r\n id?: string;\r\n\r\n /**\r\n * Optional. The CSS class name of the rich text field.\r\n */\r\n className?: string;\r\n\r\n /**\r\n * Optional. The placeholder text to be displayed in the rich text field when it is empty.\r\n */\r\n placeholder?: string;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the rich text field is read-only.\r\n */\r\n readOnly?: boolean;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the rich text field is disabled.\r\n */\r\n disabled?: boolean;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the rich text field is resizable.\r\n */\r\n resizable?: boolean;\r\n\r\n /**\r\n * Optional. An object containing the modules to be used by the rich text field.\r\n */\r\n modules?: StringMap;\r\n\r\n /**\r\n * Optional. An array of formats to be used by the rich text field.\r\n */\r\n formats?: RichTextFieldFormats[];\r\n\r\n /**\r\n * Optional. A function to be called when the rich text field gains focus.\r\n */\r\n onFocus?(selection: Range, source: Sources, editor: UnprivilegedEditor): void;\r\n\r\n /**\r\n * Optional. A function to be called when the rich text field loses focus.\r\n */\r\n onBlur?(previousSelection: Range, source: Sources, editor: UnprivilegedEditor): void;\r\n\r\n /**\r\n * Optional. A function to be called when a keydown event occurs in the rich text field.\r\n */\r\n onKeyDown?: React.EventHandler<any>;\r\n\r\n /**\r\n * Optional. A function to be called when a keypress event occurs in the rich text field.\r\n */\r\n onKeyPress?: React.EventHandler<any>;\r\n\r\n /**\r\n * Optional. A function to be called when a keyup event occurs in the rich text field.\r\n */\r\n onKeyUp?: React.EventHandler<any>;\r\n\r\n /**\r\n * Required. The current value of the rich text field.\r\n */\r\n value: any;\r\n\r\n /**\r\n * Required. A function to be called when the value of the rich text field changes.\r\n */\r\n onChange: (value: any) => void;\r\n\r\n /**\r\n * Optional. The validation message to be displayed when the rich text field is in an error state.\r\n */\r\n validationMessage?: string;\r\n\r\n /**\r\n * Optional. A note to be displayed below the rich text field.\r\n */\r\n note?: TextFieldNote;\r\n\r\n /**\r\n * Optional. The size of the rich text field. Can be 'Small' or 'Medium'.\r\n */\r\n size?: Size.Small | Size.Medium;\r\n\r\n /**\r\n * Optional. The state of the rich text field. Can be 'Invalid' or 'Valid'.\r\n */\r\n state?: States.Invalid | States.Valid;\r\n}\r\n\r\nexport const RichTextField = React.forwardRef<any, RichTextFieldProps>(({\r\n readOnly,\r\n disabled,\r\n validationMessage,\r\n note,\r\n size = Size.Medium,\r\n state,\r\n resizable,\r\n modules,\r\n formats,\r\n ...rest\r\n }: RichTextFieldProps, ref) => {\r\n\r\n const theme = useTheme();\r\n let m = {...(modules ?? {}), toolbar: modules?.toolbar ?? defaultToolBarOptions};\r\n let f = formats ?? Object.values(RichTextFieldFormats).filter(a => a !== RichTextFieldFormats.Image && a !== RichTextFieldFormats.Video && a !== RichTextFieldFormats.Formula);\r\n\r\n return (\r\n <RichTextFieldContainer\r\n className={`${resizable ? 'resizable' : ''} ${size} ${state || ''} ${readOnly ? 'readonly' : ''} ${disabled ? 'disabled' : ''}`}>\r\n <ReactQuill ref={ref}\r\n readOnly={readOnly || disabled}\r\n modules={m}\r\n theme={'snow'}\r\n formats={f}\r\n {...rest}\r\n />\r\n {validationMessage && (\r\n <ValidationMessage className={size || ''} type={state ?? States.Invalid}>\r\n {\r\n state === States.Valid\r\n ? <CheckMark color={COLORS.generateToken({componentType:'text', defaultVariant:'positive'}, theme)}/>\r\n : <TechnicalWarning color={COLORS.generateToken({componentType:'text', defaultVariant:'critical'}, theme)}/>\r\n }\r\n <span>{validationMessage}</span>\r\n </ValidationMessage>\r\n )}\r\n {note && !disabled && (\r\n <NoteMessage className={size}>\r\n {note.icon}\r\n <span>{note.message}</span>\r\n </NoteMessage>\r\n )}\r\n </RichTextFieldContainer>\r\n )\r\n});"],"mappings":"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","ignoreList":[]}
@@ -152,7 +152,10 @@ const SearchBar = _ref => {
152
152
  }), validationMessage && /*#__PURE__*/(0, _jsxRuntime.jsxs)(_styling.ErrorMessage, {
153
153
  className: size || '',
154
154
  children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_icons.SystemIcons.TechnicalWarning, {
155
- color: _index.COLORS.getColor('critical_400', theme),
155
+ color: _index.COLORS.generateToken({
156
+ componentType: 'text',
157
+ defaultVariant: 'critical'
158
+ }, theme),
156
159
  className: size || ''
157
160
  }), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
158
161
  children: validationMessage
@@ -1 +1 @@
1
- {"version":3,"file":"SearchBar.cjs","names":["_react","_interopRequireDefault","require","_index","_icons","_styling","_Button","_SearchBarInput","_SearchField","_styledComponents","_interopRequireWildcard","_Dropdown","_common","_jsxRuntime","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ClearIconWrapper","styled","div","SearchBar","_ref","id","searchTerm","setSearchTerm","enterSearch","removeSearch","placeholder","performSearchLabel","disabled","validationMessage","onKeyDown","size","margin","showDropdown","dropdownButtonIcon","dropdownButtonLabel","dropdownButtonVariant","dropdownButtonAction","searchList","addToSearchList","dropdownScrollable","containerRef","React","useRef","theme","useTheme","topLevelRef","isOpen","setIsOpen","useState","dropdownRef","useClickOutsideRef","isPressingEnter","key","preventDefault","stopPropagation","enteredSearchTerm","value","target","dropdownAction","jsxs","Fragment","children","InputWrapper","$disabled","ref","$margin","jsx","term","focusParentRefs","onClick","SearchIconWrapper","className","IconButton","variant","shape","action","onKeyPress","SystemIcons","Search","concat","Clear","DropdownContent","isButton","ariaRolesType","customizationProps","items","actionLabel","actionIcon","actionVariant","onValueUpdate","scrollable","pinTopItem","filter","selectedValues","setSelectedValues","messageOnNoResults","focused","setFocused","ErrorMessage","TechnicalWarning","color","COLORS","getColor","propTypes","_propTypes","string","isRequired","func","bool","node","oneOf","array","_default","exports"],"sources":["../../src/InputFields/SearchBar.tsx"],"sourcesContent":["import React from 'react';\r\nimport {COLORS} from '../styles/index';\r\nimport {SystemIcons} from '../icons';\r\nimport {ErrorMessage, InputWrapper, SearchIconWrapper} from './styling';\r\nimport {IconButton} from '../Button';\r\nimport SearchBarInput from './components/SearchBarInput';\r\nimport SearchField from './components/SearchField';\r\nimport {Size} from '../types';\r\nimport styled, { useTheme } from 'styled-components';\r\nimport { DropdownContent, DropdownItem } from '../Dropdown';\r\nimport { useClickOutsideRef } from '../common';\r\n\r\nexport type SearchBarProps = {\r\n /**\r\n * Required. The ID of the search bar.\r\n */\r\n id: string;\r\n\r\n /**\r\n * Optional. The current search term in the search bar.\r\n */\r\n searchTerm?: string;\r\n /**\r\n * Required. A function to be called when the search term changes.\r\n * It should take a string representing the new search term.\r\n */\r\n setSearchTerm: (term: string) => void;\r\n /**\r\n * Required. A function to be called when the enter key is pressed in the search bar.\r\n * It should take an event object as a parameter.\r\n */\r\n enterSearch: (e: any) => void;\r\n /**\r\n * Required. A function to be called when the search term is removed.\r\n * It should take an event object as a parameter.\r\n */\r\n removeSearch: (e: any) => void;\r\n /**\r\n * Optional. The placeholder text to be displayed in the search bar when it is empty.\r\n */\r\n placeholder?: string;\r\n /**\r\n * Optional. The label for the search button in the search bar.\r\n */\r\n performSearchLabel?: string;\r\n /**\r\n * Optional. A boolean indicating whether the search bar is disabled.\r\n */\r\n disabled?: boolean;\r\n /**\r\n * Optional. The validation message to be displayed when the search bar is in an error state.\r\n */\r\n validationMessage?: string;\r\n /**\r\n * Optional. A function to be called when a keydown event occurs in the search bar.\r\n */\r\n onKeyDown?: (e: React.KeyboardEvent) => void;\r\n /**\r\n * Optional. The size of the search bar. Can be 'Small' or 'Medium'.\r\n */\r\n size?: Size.Small | Size.Medium;\r\n /**\r\n * Optional. The margin of the search bar. Can be any valid CSS margin value.\r\n */\r\n margin?: string;\r\n /**\r\n * Optional. A boolean indicating whether the dropdown in the search bar should be shown.\r\n */\r\n showDropdown?: boolean;\r\n /**\r\n * Optional. The icon for the dropdown button in the search bar.\r\n */\r\n dropdownButtonIcon?: React.ReactNode;\r\n /**\r\n * Optional. The label for the dropdown button in the search bar.\r\n */ \r\n dropdownButtonLabel?: string;\r\n /**\r\n * Optional. The variant of the dropdown button in the search bar. Can be 'primary', 'secondary', or 'tertiary'.\r\n */ \r\n dropdownButtonVariant?: 'primary' | 'secondary' | 'tertiary';\r\n /**\r\n * Optional. A function to be called when the dropdown button in the search bar is clicked.\r\n */ \r\n dropdownButtonAction?: () => boolean | void | undefined;\r\n /**\r\n * Optional. An array of DropdownItem objects representing the items in the dropdown.\r\n */\r\n searchList?: DropdownItem[];\r\n /**\r\n * Optional. A function to be called when an item is added to the dropdown.\r\n * It should take a DropdownItem object as a parameter.\r\n */\r\n addToSearchList?: (e: DropdownItem) => void;\r\n /**\r\n * Optional. A boolean indicating whether the dropdown in the search bar is scrollable.\r\n */\r\n dropdownScrollable?: boolean;\r\n};\r\n\r\nconst ClearIconWrapper = styled.div`\r\n display: flex;\r\n align-items: center;\r\n\r\n &.hidden {\r\n display: none !important;\r\n }\r\n`;\r\n\r\nconst SearchBar: React.FunctionComponent<SearchBarProps> = ({\r\n id,\r\n searchTerm,\r\n setSearchTerm,\r\n enterSearch,\r\n removeSearch,\r\n placeholder,\r\n performSearchLabel,\r\n disabled,\r\n validationMessage,\r\n onKeyDown,\r\n size,\r\n margin,\r\n showDropdown,\r\n dropdownButtonIcon,\r\n dropdownButtonLabel,\r\n dropdownButtonVariant,\r\n dropdownButtonAction,\r\n searchList=[],\r\n addToSearchList,\r\n dropdownScrollable\r\n }) => {\r\n const containerRef = React.useRef<any>(null);\r\n const theme = useTheme();\r\n const topLevelRef = React.useRef<any>(null);\r\n\r\n const [isOpen, setIsOpen] = React.useState(false);\r\n const dropdownRef = useClickOutsideRef(()=>setIsOpen(false), [containerRef, topLevelRef]);\r\n\r\n const isPressingEnter = (e: any) => {\r\n if (e.key === 'Enter') {\r\n e.preventDefault();\r\n e.stopPropagation();\r\n return true;\r\n }\r\n return false;\r\n };\r\n\r\n const enteredSearchTerm = (e: any) => {\r\n addToSearchList && addToSearchList({value:e.target.value});\r\n enterSearch(e);\r\n }\r\n\r\n const dropdownAction = () => {\r\n if(dropdownButtonAction)\r\n dropdownButtonAction(); \r\n }\r\n\r\n return (\r\n <>\r\n <InputWrapper\r\n $disabled={disabled}\r\n ref={topLevelRef}\r\n $margin={margin}>\r\n <SearchField id={'id'} size={size}\r\n ref={containerRef}\r\n searchTerm={searchTerm}\r\n disabled={disabled}\r\n validationMessage={validationMessage}>\r\n <SearchBarInput\r\n placeholder={disabled ? '' : placeholder}\r\n id={id}\r\n size={size}\r\n disabled={disabled}\r\n setSearchTerm={(term: string) => setSearchTerm(term)}\r\n searchTerm={searchTerm}\r\n onKeyDown={onKeyDown}\r\n enterSearch={enteredSearchTerm}\r\n focusParentRefs={[containerRef]}\r\n onClick={()=>setIsOpen(!isOpen)}\r\n ref={dropdownRef}\r\n />\r\n <SearchIconWrapper className={size ? size : ''} aria-label={performSearchLabel}>\r\n <IconButton id={`${id}_Search`}\r\n variant=\"secondary\"\r\n shape=\"circular\"\r\n action={enterSearch}\r\n disabled={disabled}\r\n onKeyPress={(e: any) => (isPressingEnter(e) ? enterSearch(e) : null)}>\r\n <SystemIcons.Search size=\"24px\"/>\r\n </IconButton>\r\n </SearchIconWrapper>\r\n <ClearIconWrapper className={(size ? size : '').concat(!searchTerm ? ' hidden' : '')}>\r\n <IconButton id={`${id}_Clear`}\r\n variant=\"secondary\"\r\n shape=\"circular\"\r\n action={removeSearch}\r\n disabled={disabled}\r\n onKeyPress={(e: any) => (isPressingEnter(e) ? removeSearch(e) : null)}>\r\n <SystemIcons.Clear size=\"24px\"/>\r\n </IconButton>\r\n </ClearIconWrapper>\r\n </SearchField>\r\n\r\n {showDropdown && <DropdownContent id={'search'}\r\n containerRef={containerRef}\r\n size={size}\r\n isButton={false}\r\n ariaRolesType=\"input\"\r\n customizationProps={{\r\n items:searchList,\r\n action: dropdownAction,\r\n actionLabel: dropdownButtonLabel,\r\n actionIcon: dropdownButtonIcon,\r\n actionVariant: dropdownButtonVariant,\r\n onValueUpdate:(e)=>{},\r\n scrollable: dropdownScrollable,\r\n pinTopItem: true\r\n }}\r\n isOpen={isOpen}\r\n setIsOpen={setIsOpen}\r\n filter={''}\r\n selectedValues={searchTerm ? [searchTerm] : []}\r\n setSelectedValues={(e)=>setSearchTerm(e[0])}\r\n messageOnNoResults={''}\r\n focused={null}\r\n setFocused={()=>{}}\r\n />}\r\n\r\n </InputWrapper>\r\n {validationMessage && (\r\n <ErrorMessage className={size || ''}>\r\n <SystemIcons.TechnicalWarning color={COLORS.getColor('critical_400', theme)} className={size || ''}/>\r\n <span>{validationMessage}</span>\r\n </ErrorMessage>\r\n )}\r\n </>\r\n );\r\n};\r\n\r\nexport default SearchBar;\r\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"SearchBar.cjs","names":["_react","_interopRequireDefault","require","_index","_icons","_styling","_Button","_SearchBarInput","_SearchField","_styledComponents","_interopRequireWildcard","_Dropdown","_common","_jsxRuntime","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ClearIconWrapper","styled","div","SearchBar","_ref","id","searchTerm","setSearchTerm","enterSearch","removeSearch","placeholder","performSearchLabel","disabled","validationMessage","onKeyDown","size","margin","showDropdown","dropdownButtonIcon","dropdownButtonLabel","dropdownButtonVariant","dropdownButtonAction","searchList","addToSearchList","dropdownScrollable","containerRef","React","useRef","theme","useTheme","topLevelRef","isOpen","setIsOpen","useState","dropdownRef","useClickOutsideRef","isPressingEnter","key","preventDefault","stopPropagation","enteredSearchTerm","value","target","dropdownAction","jsxs","Fragment","children","InputWrapper","$disabled","ref","$margin","jsx","term","focusParentRefs","onClick","SearchIconWrapper","className","IconButton","variant","shape","action","onKeyPress","SystemIcons","Search","concat","Clear","DropdownContent","isButton","ariaRolesType","customizationProps","items","actionLabel","actionIcon","actionVariant","onValueUpdate","scrollable","pinTopItem","filter","selectedValues","setSelectedValues","messageOnNoResults","focused","setFocused","ErrorMessage","TechnicalWarning","color","COLORS","generateToken","componentType","defaultVariant","propTypes","_propTypes","string","isRequired","func","bool","node","oneOf","array","_default","exports"],"sources":["../../src/InputFields/SearchBar.tsx"],"sourcesContent":["import React from 'react';\r\nimport {COLORS} from '../styles/index';\r\nimport {SystemIcons} from '../icons';\r\nimport {ErrorMessage, InputWrapper, SearchIconWrapper} from './styling';\r\nimport {IconButton} from '../Button';\r\nimport SearchBarInput from './components/SearchBarInput';\r\nimport SearchField from './components/SearchField';\r\nimport {Size} from '../types';\r\nimport styled, { useTheme } from 'styled-components';\r\nimport { DropdownContent, DropdownItem } from '../Dropdown';\r\nimport { useClickOutsideRef } from '../common';\r\n\r\nexport type SearchBarProps = {\r\n /**\r\n * Required. The ID of the search bar.\r\n */\r\n id: string;\r\n\r\n /**\r\n * Optional. The current search term in the search bar.\r\n */\r\n searchTerm?: string;\r\n /**\r\n * Required. A function to be called when the search term changes.\r\n * It should take a string representing the new search term.\r\n */\r\n setSearchTerm: (term: string) => void;\r\n /**\r\n * Required. A function to be called when the enter key is pressed in the search bar.\r\n * It should take an event object as a parameter.\r\n */\r\n enterSearch: (e: any) => void;\r\n /**\r\n * Required. A function to be called when the search term is removed.\r\n * It should take an event object as a parameter.\r\n */\r\n removeSearch: (e: any) => void;\r\n /**\r\n * Optional. The placeholder text to be displayed in the search bar when it is empty.\r\n */\r\n placeholder?: string;\r\n /**\r\n * Optional. The label for the search button in the search bar.\r\n */\r\n performSearchLabel?: string;\r\n /**\r\n * Optional. A boolean indicating whether the search bar is disabled.\r\n */\r\n disabled?: boolean;\r\n /**\r\n * Optional. The validation message to be displayed when the search bar is in an error state.\r\n */\r\n validationMessage?: string;\r\n /**\r\n * Optional. A function to be called when a keydown event occurs in the search bar.\r\n */\r\n onKeyDown?: (e: React.KeyboardEvent) => void;\r\n /**\r\n * Optional. The size of the search bar. Can be 'Small' or 'Medium'.\r\n */\r\n size?: Size.Small | Size.Medium;\r\n /**\r\n * Optional. The margin of the search bar. Can be any valid CSS margin value.\r\n */\r\n margin?: string;\r\n /**\r\n * Optional. A boolean indicating whether the dropdown in the search bar should be shown.\r\n */\r\n showDropdown?: boolean;\r\n /**\r\n * Optional. The icon for the dropdown button in the search bar.\r\n */\r\n dropdownButtonIcon?: React.ReactNode;\r\n /**\r\n * Optional. The label for the dropdown button in the search bar.\r\n */ \r\n dropdownButtonLabel?: string;\r\n /**\r\n * Optional. The variant of the dropdown button in the search bar. Can be 'primary', 'secondary', or 'tertiary'.\r\n */ \r\n dropdownButtonVariant?: 'primary' | 'secondary' | 'tertiary';\r\n /**\r\n * Optional. A function to be called when the dropdown button in the search bar is clicked.\r\n */ \r\n dropdownButtonAction?: () => boolean | void | undefined;\r\n /**\r\n * Optional. An array of DropdownItem objects representing the items in the dropdown.\r\n */\r\n searchList?: DropdownItem[];\r\n /**\r\n * Optional. A function to be called when an item is added to the dropdown.\r\n * It should take a DropdownItem object as a parameter.\r\n */\r\n addToSearchList?: (e: DropdownItem) => void;\r\n /**\r\n * Optional. A boolean indicating whether the dropdown in the search bar is scrollable.\r\n */\r\n dropdownScrollable?: boolean;\r\n};\r\n\r\nconst ClearIconWrapper = styled.div`\r\n display: flex;\r\n align-items: center;\r\n\r\n &.hidden {\r\n display: none !important;\r\n }\r\n`;\r\n\r\nconst SearchBar: React.FunctionComponent<SearchBarProps> = ({\r\n id,\r\n searchTerm,\r\n setSearchTerm,\r\n enterSearch,\r\n removeSearch,\r\n placeholder,\r\n performSearchLabel,\r\n disabled,\r\n validationMessage,\r\n onKeyDown,\r\n size,\r\n margin,\r\n showDropdown,\r\n dropdownButtonIcon,\r\n dropdownButtonLabel,\r\n dropdownButtonVariant,\r\n dropdownButtonAction,\r\n searchList=[],\r\n addToSearchList,\r\n dropdownScrollable\r\n }) => {\r\n const containerRef = React.useRef<any>(null);\r\n const theme = useTheme();\r\n const topLevelRef = React.useRef<any>(null);\r\n\r\n const [isOpen, setIsOpen] = React.useState(false);\r\n const dropdownRef = useClickOutsideRef(()=>setIsOpen(false), [containerRef, topLevelRef]);\r\n\r\n const isPressingEnter = (e: any) => {\r\n if (e.key === 'Enter') {\r\n e.preventDefault();\r\n e.stopPropagation();\r\n return true;\r\n }\r\n return false;\r\n };\r\n\r\n const enteredSearchTerm = (e: any) => {\r\n addToSearchList && addToSearchList({value:e.target.value});\r\n enterSearch(e);\r\n }\r\n\r\n const dropdownAction = () => {\r\n if(dropdownButtonAction)\r\n dropdownButtonAction(); \r\n }\r\n\r\n return (\r\n <>\r\n <InputWrapper\r\n $disabled={disabled}\r\n ref={topLevelRef}\r\n $margin={margin}>\r\n <SearchField id={'id'} size={size}\r\n ref={containerRef}\r\n searchTerm={searchTerm}\r\n disabled={disabled}\r\n validationMessage={validationMessage}>\r\n <SearchBarInput\r\n placeholder={disabled ? '' : placeholder}\r\n id={id}\r\n size={size}\r\n disabled={disabled}\r\n setSearchTerm={(term: string) => setSearchTerm(term)}\r\n searchTerm={searchTerm}\r\n onKeyDown={onKeyDown}\r\n enterSearch={enteredSearchTerm}\r\n focusParentRefs={[containerRef]}\r\n onClick={()=>setIsOpen(!isOpen)}\r\n ref={dropdownRef}\r\n />\r\n <SearchIconWrapper className={size ? size : ''} aria-label={performSearchLabel}>\r\n <IconButton id={`${id}_Search`}\r\n variant=\"secondary\"\r\n shape=\"circular\"\r\n action={enterSearch}\r\n disabled={disabled}\r\n onKeyPress={(e: any) => (isPressingEnter(e) ? enterSearch(e) : null)}>\r\n <SystemIcons.Search size=\"24px\"/>\r\n </IconButton>\r\n </SearchIconWrapper>\r\n <ClearIconWrapper className={(size ? size : '').concat(!searchTerm ? ' hidden' : '')}>\r\n <IconButton id={`${id}_Clear`}\r\n variant=\"secondary\"\r\n shape=\"circular\"\r\n action={removeSearch}\r\n disabled={disabled}\r\n onKeyPress={(e: any) => (isPressingEnter(e) ? removeSearch(e) : null)}>\r\n <SystemIcons.Clear size=\"24px\"/>\r\n </IconButton>\r\n </ClearIconWrapper>\r\n </SearchField>\r\n\r\n {showDropdown && <DropdownContent id={'search'}\r\n containerRef={containerRef}\r\n size={size}\r\n isButton={false}\r\n ariaRolesType=\"input\"\r\n customizationProps={{\r\n items:searchList,\r\n action: dropdownAction,\r\n actionLabel: dropdownButtonLabel,\r\n actionIcon: dropdownButtonIcon,\r\n actionVariant: dropdownButtonVariant,\r\n onValueUpdate:(e)=>{},\r\n scrollable: dropdownScrollable,\r\n pinTopItem: true\r\n }}\r\n isOpen={isOpen}\r\n setIsOpen={setIsOpen}\r\n filter={''}\r\n selectedValues={searchTerm ? [searchTerm] : []}\r\n setSelectedValues={(e)=>setSearchTerm(e[0])}\r\n messageOnNoResults={''}\r\n focused={null}\r\n setFocused={()=>{}}\r\n />}\r\n\r\n </InputWrapper>\r\n {validationMessage && (\r\n <ErrorMessage className={size || ''}>\r\n <SystemIcons.TechnicalWarning color={COLORS.generateToken({componentType:'text', defaultVariant:'critical'}, theme)} className={size || ''}/>\r\n <span>{validationMessage}</span>\r\n </ErrorMessage>\r\n )}\r\n </>\r\n );\r\n};\r\n\r\nexport default SearchBar;\r\n"],"mappings":"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","ignoreList":[]}
@@ -143,7 +143,10 @@ const SearchBar = _ref => {
143
143
  }), validationMessage && /*#__PURE__*/_jsxs(ErrorMessage, {
144
144
  className: size || '',
145
145
  children: [/*#__PURE__*/_jsx(SystemIcons.TechnicalWarning, {
146
- color: COLORS.getColor('critical_400', theme),
146
+ color: COLORS.generateToken({
147
+ componentType: 'text',
148
+ defaultVariant: 'critical'
149
+ }, theme),
147
150
  className: size || ''
148
151
  }), /*#__PURE__*/_jsx("span", {
149
152
  children: validationMessage
@@ -1 +1 @@
1
- {"version":3,"file":"SearchBar.js","names":["React","COLORS","SystemIcons","ErrorMessage","InputWrapper","SearchIconWrapper","IconButton","SearchBarInput","SearchField","styled","useTheme","DropdownContent","useClickOutsideRef","jsx","_jsx","jsxs","_jsxs","Fragment","_Fragment","ClearIconWrapper","div","SearchBar","_ref","id","searchTerm","setSearchTerm","enterSearch","removeSearch","placeholder","performSearchLabel","disabled","validationMessage","onKeyDown","size","margin","showDropdown","dropdownButtonIcon","dropdownButtonLabel","dropdownButtonVariant","dropdownButtonAction","searchList","addToSearchList","dropdownScrollable","containerRef","useRef","theme","topLevelRef","isOpen","setIsOpen","useState","dropdownRef","isPressingEnter","e","key","preventDefault","stopPropagation","enteredSearchTerm","value","target","dropdownAction","children","$disabled","ref","$margin","term","focusParentRefs","onClick","className","variant","shape","action","onKeyPress","Search","concat","Clear","isButton","ariaRolesType","customizationProps","items","actionLabel","actionIcon","actionVariant","onValueUpdate","scrollable","pinTopItem","filter","selectedValues","setSelectedValues","messageOnNoResults","focused","setFocused","TechnicalWarning","color","getColor","propTypes","_pt","string","isRequired","func","bool","node","oneOf","array"],"sources":["../../src/InputFields/SearchBar.tsx"],"sourcesContent":["import React from 'react';\r\nimport {COLORS} from '../styles/index';\r\nimport {SystemIcons} from '../icons';\r\nimport {ErrorMessage, InputWrapper, SearchIconWrapper} from './styling';\r\nimport {IconButton} from '../Button';\r\nimport SearchBarInput from './components/SearchBarInput';\r\nimport SearchField from './components/SearchField';\r\nimport {Size} from '../types';\r\nimport styled, { useTheme } from 'styled-components';\r\nimport { DropdownContent, DropdownItem } from '../Dropdown';\r\nimport { useClickOutsideRef } from '../common';\r\n\r\nexport type SearchBarProps = {\r\n /**\r\n * Required. The ID of the search bar.\r\n */\r\n id: string;\r\n\r\n /**\r\n * Optional. The current search term in the search bar.\r\n */\r\n searchTerm?: string;\r\n /**\r\n * Required. A function to be called when the search term changes.\r\n * It should take a string representing the new search term.\r\n */\r\n setSearchTerm: (term: string) => void;\r\n /**\r\n * Required. A function to be called when the enter key is pressed in the search bar.\r\n * It should take an event object as a parameter.\r\n */\r\n enterSearch: (e: any) => void;\r\n /**\r\n * Required. A function to be called when the search term is removed.\r\n * It should take an event object as a parameter.\r\n */\r\n removeSearch: (e: any) => void;\r\n /**\r\n * Optional. The placeholder text to be displayed in the search bar when it is empty.\r\n */\r\n placeholder?: string;\r\n /**\r\n * Optional. The label for the search button in the search bar.\r\n */\r\n performSearchLabel?: string;\r\n /**\r\n * Optional. A boolean indicating whether the search bar is disabled.\r\n */\r\n disabled?: boolean;\r\n /**\r\n * Optional. The validation message to be displayed when the search bar is in an error state.\r\n */\r\n validationMessage?: string;\r\n /**\r\n * Optional. A function to be called when a keydown event occurs in the search bar.\r\n */\r\n onKeyDown?: (e: React.KeyboardEvent) => void;\r\n /**\r\n * Optional. The size of the search bar. Can be 'Small' or 'Medium'.\r\n */\r\n size?: Size.Small | Size.Medium;\r\n /**\r\n * Optional. The margin of the search bar. Can be any valid CSS margin value.\r\n */\r\n margin?: string;\r\n /**\r\n * Optional. A boolean indicating whether the dropdown in the search bar should be shown.\r\n */\r\n showDropdown?: boolean;\r\n /**\r\n * Optional. The icon for the dropdown button in the search bar.\r\n */\r\n dropdownButtonIcon?: React.ReactNode;\r\n /**\r\n * Optional. The label for the dropdown button in the search bar.\r\n */ \r\n dropdownButtonLabel?: string;\r\n /**\r\n * Optional. The variant of the dropdown button in the search bar. Can be 'primary', 'secondary', or 'tertiary'.\r\n */ \r\n dropdownButtonVariant?: 'primary' | 'secondary' | 'tertiary';\r\n /**\r\n * Optional. A function to be called when the dropdown button in the search bar is clicked.\r\n */ \r\n dropdownButtonAction?: () => boolean | void | undefined;\r\n /**\r\n * Optional. An array of DropdownItem objects representing the items in the dropdown.\r\n */\r\n searchList?: DropdownItem[];\r\n /**\r\n * Optional. A function to be called when an item is added to the dropdown.\r\n * It should take a DropdownItem object as a parameter.\r\n */\r\n addToSearchList?: (e: DropdownItem) => void;\r\n /**\r\n * Optional. A boolean indicating whether the dropdown in the search bar is scrollable.\r\n */\r\n dropdownScrollable?: boolean;\r\n};\r\n\r\nconst ClearIconWrapper = styled.div`\r\n display: flex;\r\n align-items: center;\r\n\r\n &.hidden {\r\n display: none !important;\r\n }\r\n`;\r\n\r\nconst SearchBar: React.FunctionComponent<SearchBarProps> = ({\r\n id,\r\n searchTerm,\r\n setSearchTerm,\r\n enterSearch,\r\n removeSearch,\r\n placeholder,\r\n performSearchLabel,\r\n disabled,\r\n validationMessage,\r\n onKeyDown,\r\n size,\r\n margin,\r\n showDropdown,\r\n dropdownButtonIcon,\r\n dropdownButtonLabel,\r\n dropdownButtonVariant,\r\n dropdownButtonAction,\r\n searchList=[],\r\n addToSearchList,\r\n dropdownScrollable\r\n }) => {\r\n const containerRef = React.useRef<any>(null);\r\n const theme = useTheme();\r\n const topLevelRef = React.useRef<any>(null);\r\n\r\n const [isOpen, setIsOpen] = React.useState(false);\r\n const dropdownRef = useClickOutsideRef(()=>setIsOpen(false), [containerRef, topLevelRef]);\r\n\r\n const isPressingEnter = (e: any) => {\r\n if (e.key === 'Enter') {\r\n e.preventDefault();\r\n e.stopPropagation();\r\n return true;\r\n }\r\n return false;\r\n };\r\n\r\n const enteredSearchTerm = (e: any) => {\r\n addToSearchList && addToSearchList({value:e.target.value});\r\n enterSearch(e);\r\n }\r\n\r\n const dropdownAction = () => {\r\n if(dropdownButtonAction)\r\n dropdownButtonAction(); \r\n }\r\n\r\n return (\r\n <>\r\n <InputWrapper\r\n $disabled={disabled}\r\n ref={topLevelRef}\r\n $margin={margin}>\r\n <SearchField id={'id'} size={size}\r\n ref={containerRef}\r\n searchTerm={searchTerm}\r\n disabled={disabled}\r\n validationMessage={validationMessage}>\r\n <SearchBarInput\r\n placeholder={disabled ? '' : placeholder}\r\n id={id}\r\n size={size}\r\n disabled={disabled}\r\n setSearchTerm={(term: string) => setSearchTerm(term)}\r\n searchTerm={searchTerm}\r\n onKeyDown={onKeyDown}\r\n enterSearch={enteredSearchTerm}\r\n focusParentRefs={[containerRef]}\r\n onClick={()=>setIsOpen(!isOpen)}\r\n ref={dropdownRef}\r\n />\r\n <SearchIconWrapper className={size ? size : ''} aria-label={performSearchLabel}>\r\n <IconButton id={`${id}_Search`}\r\n variant=\"secondary\"\r\n shape=\"circular\"\r\n action={enterSearch}\r\n disabled={disabled}\r\n onKeyPress={(e: any) => (isPressingEnter(e) ? enterSearch(e) : null)}>\r\n <SystemIcons.Search size=\"24px\"/>\r\n </IconButton>\r\n </SearchIconWrapper>\r\n <ClearIconWrapper className={(size ? size : '').concat(!searchTerm ? ' hidden' : '')}>\r\n <IconButton id={`${id}_Clear`}\r\n variant=\"secondary\"\r\n shape=\"circular\"\r\n action={removeSearch}\r\n disabled={disabled}\r\n onKeyPress={(e: any) => (isPressingEnter(e) ? removeSearch(e) : null)}>\r\n <SystemIcons.Clear size=\"24px\"/>\r\n </IconButton>\r\n </ClearIconWrapper>\r\n </SearchField>\r\n\r\n {showDropdown && <DropdownContent id={'search'}\r\n containerRef={containerRef}\r\n size={size}\r\n isButton={false}\r\n ariaRolesType=\"input\"\r\n customizationProps={{\r\n items:searchList,\r\n action: dropdownAction,\r\n actionLabel: dropdownButtonLabel,\r\n actionIcon: dropdownButtonIcon,\r\n actionVariant: dropdownButtonVariant,\r\n onValueUpdate:(e)=>{},\r\n scrollable: dropdownScrollable,\r\n pinTopItem: true\r\n }}\r\n isOpen={isOpen}\r\n setIsOpen={setIsOpen}\r\n filter={''}\r\n selectedValues={searchTerm ? [searchTerm] : []}\r\n setSelectedValues={(e)=>setSearchTerm(e[0])}\r\n messageOnNoResults={''}\r\n focused={null}\r\n setFocused={()=>{}}\r\n />}\r\n\r\n </InputWrapper>\r\n {validationMessage && (\r\n <ErrorMessage className={size || ''}>\r\n <SystemIcons.TechnicalWarning color={COLORS.getColor('critical_400', theme)} className={size || ''}/>\r\n <span>{validationMessage}</span>\r\n </ErrorMessage>\r\n )}\r\n </>\r\n );\r\n};\r\n\r\nexport default SearchBar;\r\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"SearchBar.js","names":["React","COLORS","SystemIcons","ErrorMessage","InputWrapper","SearchIconWrapper","IconButton","SearchBarInput","SearchField","styled","useTheme","DropdownContent","useClickOutsideRef","jsx","_jsx","jsxs","_jsxs","Fragment","_Fragment","ClearIconWrapper","div","SearchBar","_ref","id","searchTerm","setSearchTerm","enterSearch","removeSearch","placeholder","performSearchLabel","disabled","validationMessage","onKeyDown","size","margin","showDropdown","dropdownButtonIcon","dropdownButtonLabel","dropdownButtonVariant","dropdownButtonAction","searchList","addToSearchList","dropdownScrollable","containerRef","useRef","theme","topLevelRef","isOpen","setIsOpen","useState","dropdownRef","isPressingEnter","e","key","preventDefault","stopPropagation","enteredSearchTerm","value","target","dropdownAction","children","$disabled","ref","$margin","term","focusParentRefs","onClick","className","variant","shape","action","onKeyPress","Search","concat","Clear","isButton","ariaRolesType","customizationProps","items","actionLabel","actionIcon","actionVariant","onValueUpdate","scrollable","pinTopItem","filter","selectedValues","setSelectedValues","messageOnNoResults","focused","setFocused","TechnicalWarning","color","generateToken","componentType","defaultVariant","propTypes","_pt","string","isRequired","func","bool","node","oneOf","array"],"sources":["../../src/InputFields/SearchBar.tsx"],"sourcesContent":["import React from 'react';\r\nimport {COLORS} from '../styles/index';\r\nimport {SystemIcons} from '../icons';\r\nimport {ErrorMessage, InputWrapper, SearchIconWrapper} from './styling';\r\nimport {IconButton} from '../Button';\r\nimport SearchBarInput from './components/SearchBarInput';\r\nimport SearchField from './components/SearchField';\r\nimport {Size} from '../types';\r\nimport styled, { useTheme } from 'styled-components';\r\nimport { DropdownContent, DropdownItem } from '../Dropdown';\r\nimport { useClickOutsideRef } from '../common';\r\n\r\nexport type SearchBarProps = {\r\n /**\r\n * Required. The ID of the search bar.\r\n */\r\n id: string;\r\n\r\n /**\r\n * Optional. The current search term in the search bar.\r\n */\r\n searchTerm?: string;\r\n /**\r\n * Required. A function to be called when the search term changes.\r\n * It should take a string representing the new search term.\r\n */\r\n setSearchTerm: (term: string) => void;\r\n /**\r\n * Required. A function to be called when the enter key is pressed in the search bar.\r\n * It should take an event object as a parameter.\r\n */\r\n enterSearch: (e: any) => void;\r\n /**\r\n * Required. A function to be called when the search term is removed.\r\n * It should take an event object as a parameter.\r\n */\r\n removeSearch: (e: any) => void;\r\n /**\r\n * Optional. The placeholder text to be displayed in the search bar when it is empty.\r\n */\r\n placeholder?: string;\r\n /**\r\n * Optional. The label for the search button in the search bar.\r\n */\r\n performSearchLabel?: string;\r\n /**\r\n * Optional. A boolean indicating whether the search bar is disabled.\r\n */\r\n disabled?: boolean;\r\n /**\r\n * Optional. The validation message to be displayed when the search bar is in an error state.\r\n */\r\n validationMessage?: string;\r\n /**\r\n * Optional. A function to be called when a keydown event occurs in the search bar.\r\n */\r\n onKeyDown?: (e: React.KeyboardEvent) => void;\r\n /**\r\n * Optional. The size of the search bar. Can be 'Small' or 'Medium'.\r\n */\r\n size?: Size.Small | Size.Medium;\r\n /**\r\n * Optional. The margin of the search bar. Can be any valid CSS margin value.\r\n */\r\n margin?: string;\r\n /**\r\n * Optional. A boolean indicating whether the dropdown in the search bar should be shown.\r\n */\r\n showDropdown?: boolean;\r\n /**\r\n * Optional. The icon for the dropdown button in the search bar.\r\n */\r\n dropdownButtonIcon?: React.ReactNode;\r\n /**\r\n * Optional. The label for the dropdown button in the search bar.\r\n */ \r\n dropdownButtonLabel?: string;\r\n /**\r\n * Optional. The variant of the dropdown button in the search bar. Can be 'primary', 'secondary', or 'tertiary'.\r\n */ \r\n dropdownButtonVariant?: 'primary' | 'secondary' | 'tertiary';\r\n /**\r\n * Optional. A function to be called when the dropdown button in the search bar is clicked.\r\n */ \r\n dropdownButtonAction?: () => boolean | void | undefined;\r\n /**\r\n * Optional. An array of DropdownItem objects representing the items in the dropdown.\r\n */\r\n searchList?: DropdownItem[];\r\n /**\r\n * Optional. A function to be called when an item is added to the dropdown.\r\n * It should take a DropdownItem object as a parameter.\r\n */\r\n addToSearchList?: (e: DropdownItem) => void;\r\n /**\r\n * Optional. A boolean indicating whether the dropdown in the search bar is scrollable.\r\n */\r\n dropdownScrollable?: boolean;\r\n};\r\n\r\nconst ClearIconWrapper = styled.div`\r\n display: flex;\r\n align-items: center;\r\n\r\n &.hidden {\r\n display: none !important;\r\n }\r\n`;\r\n\r\nconst SearchBar: React.FunctionComponent<SearchBarProps> = ({\r\n id,\r\n searchTerm,\r\n setSearchTerm,\r\n enterSearch,\r\n removeSearch,\r\n placeholder,\r\n performSearchLabel,\r\n disabled,\r\n validationMessage,\r\n onKeyDown,\r\n size,\r\n margin,\r\n showDropdown,\r\n dropdownButtonIcon,\r\n dropdownButtonLabel,\r\n dropdownButtonVariant,\r\n dropdownButtonAction,\r\n searchList=[],\r\n addToSearchList,\r\n dropdownScrollable\r\n }) => {\r\n const containerRef = React.useRef<any>(null);\r\n const theme = useTheme();\r\n const topLevelRef = React.useRef<any>(null);\r\n\r\n const [isOpen, setIsOpen] = React.useState(false);\r\n const dropdownRef = useClickOutsideRef(()=>setIsOpen(false), [containerRef, topLevelRef]);\r\n\r\n const isPressingEnter = (e: any) => {\r\n if (e.key === 'Enter') {\r\n e.preventDefault();\r\n e.stopPropagation();\r\n return true;\r\n }\r\n return false;\r\n };\r\n\r\n const enteredSearchTerm = (e: any) => {\r\n addToSearchList && addToSearchList({value:e.target.value});\r\n enterSearch(e);\r\n }\r\n\r\n const dropdownAction = () => {\r\n if(dropdownButtonAction)\r\n dropdownButtonAction(); \r\n }\r\n\r\n return (\r\n <>\r\n <InputWrapper\r\n $disabled={disabled}\r\n ref={topLevelRef}\r\n $margin={margin}>\r\n <SearchField id={'id'} size={size}\r\n ref={containerRef}\r\n searchTerm={searchTerm}\r\n disabled={disabled}\r\n validationMessage={validationMessage}>\r\n <SearchBarInput\r\n placeholder={disabled ? '' : placeholder}\r\n id={id}\r\n size={size}\r\n disabled={disabled}\r\n setSearchTerm={(term: string) => setSearchTerm(term)}\r\n searchTerm={searchTerm}\r\n onKeyDown={onKeyDown}\r\n enterSearch={enteredSearchTerm}\r\n focusParentRefs={[containerRef]}\r\n onClick={()=>setIsOpen(!isOpen)}\r\n ref={dropdownRef}\r\n />\r\n <SearchIconWrapper className={size ? size : ''} aria-label={performSearchLabel}>\r\n <IconButton id={`${id}_Search`}\r\n variant=\"secondary\"\r\n shape=\"circular\"\r\n action={enterSearch}\r\n disabled={disabled}\r\n onKeyPress={(e: any) => (isPressingEnter(e) ? enterSearch(e) : null)}>\r\n <SystemIcons.Search size=\"24px\"/>\r\n </IconButton>\r\n </SearchIconWrapper>\r\n <ClearIconWrapper className={(size ? size : '').concat(!searchTerm ? ' hidden' : '')}>\r\n <IconButton id={`${id}_Clear`}\r\n variant=\"secondary\"\r\n shape=\"circular\"\r\n action={removeSearch}\r\n disabled={disabled}\r\n onKeyPress={(e: any) => (isPressingEnter(e) ? removeSearch(e) : null)}>\r\n <SystemIcons.Clear size=\"24px\"/>\r\n </IconButton>\r\n </ClearIconWrapper>\r\n </SearchField>\r\n\r\n {showDropdown && <DropdownContent id={'search'}\r\n containerRef={containerRef}\r\n size={size}\r\n isButton={false}\r\n ariaRolesType=\"input\"\r\n customizationProps={{\r\n items:searchList,\r\n action: dropdownAction,\r\n actionLabel: dropdownButtonLabel,\r\n actionIcon: dropdownButtonIcon,\r\n actionVariant: dropdownButtonVariant,\r\n onValueUpdate:(e)=>{},\r\n scrollable: dropdownScrollable,\r\n pinTopItem: true\r\n }}\r\n isOpen={isOpen}\r\n setIsOpen={setIsOpen}\r\n filter={''}\r\n selectedValues={searchTerm ? [searchTerm] : []}\r\n setSelectedValues={(e)=>setSearchTerm(e[0])}\r\n messageOnNoResults={''}\r\n focused={null}\r\n setFocused={()=>{}}\r\n />}\r\n\r\n </InputWrapper>\r\n {validationMessage && (\r\n <ErrorMessage className={size || ''}>\r\n <SystemIcons.TechnicalWarning color={COLORS.generateToken({componentType:'text', defaultVariant:'critical'}, theme)} className={size || ''}/>\r\n <span>{validationMessage}</span>\r\n </ErrorMessage>\r\n )}\r\n </>\r\n );\r\n};\r\n\r\nexport default SearchBar;\r\n"],"mappings":"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","ignoreList":[]}
@@ -65,7 +65,7 @@ const TextField = /*#__PURE__*/React.forwardRef((_ref, ref) => {
65
65
  "data-testid": dataTestId,
66
66
  ref: elementRef,
67
67
  type: type || 'text',
68
- value: value,
68
+ value: value ?? '',
69
69
  className: cls,
70
70
  tabIndex: readOnly || disabled ? -1 : 0,
71
71
  autoComplete: autoComplete,
@@ -91,9 +91,15 @@ const TextField = /*#__PURE__*/React.forwardRef((_ref, ref) => {
91
91
  className: size || '',
92
92
  type: state ?? _types.States.Invalid,
93
93
  children: [state === _types.States.Valid ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_icons.SystemIcons.CheckMark, {
94
- color: _styles.COLORS.getColor('correct_400', theme)
94
+ color: _styles.COLORS.generateToken({
95
+ componentType: 'text',
96
+ defaultVariant: 'positive'
97
+ }, theme)
95
98
  }) : /*#__PURE__*/(0, _jsxRuntime.jsx)(_icons.SystemIcons.TechnicalWarning, {
96
- color: _styles.COLORS.getColor('critical_400', theme)
99
+ color: _styles.COLORS.generateToken({
100
+ componentType: 'text',
101
+ defaultVariant: 'critical'
102
+ }, theme)
97
103
  }), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
98
104
  children: validationMessage
99
105
  })]
@@ -1 +1 @@
1
- {"version":3,"file":"TextField.cjs","names":["React","_interopRequireWildcard","require","_icons","_styles","_types","_styling","_common","_TooltipOverflow","_interopRequireDefault","_styledComponents","_jsxRuntime","_excluded","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","TextField","forwardRef","_ref","ref","id","disabled","readOnly","onChange","value","validationMessage","type","autoComplete","placeholder","required","pattern","maxLength","withoutBorder","state","size","margin","overflowTooltipPosition","note","className","dataTestId","rest","_objectWithoutProperties2","elementRef","useFocusVisibleRef","theme","useTheme","useImperativeHandle","current","cls","States","Invalid","jsx","Fragment","children","jsxs","InputWrapper","$readOnly","$disabled","$margin","onClick","preventDefault","InputFieldStyling","tabIndex","undefined","target","$activeErrorMessage","Valid","$withoutBorder","position","input","withArrow","maxWidth","align","ValidationMessage","SystemIcons","CheckMark","color","COLORS","getColor","TechnicalWarning","NoteMessage","icon","message","propTypes","_propTypes","string","bool","func","number","oneOf","_default","exports"],"sources":["../../src/InputFields/TextField.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport {SystemIcons} from '../icons';\r\nimport {COLORS} from '../styles';\r\nimport {Size, States, Testable} from '../types';\r\nimport {InputFieldStyling, InputWrapper, NoteMessage, ValidationMessage} from './styling';\r\nimport {useFocusVisibleRef} from '../common';\r\nimport {TextFieldNote} from './types';\r\nimport TooltipOverflow from '../Tooltips/TooltipOverflow';\r\nimport { useTheme } from 'styled-components';\r\n\r\nexport type TextFieldProps =\r\n Testable & Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size' | 'onChange' | 'value' | 'disabled' | 'id' | 'type' | 'readOnly' | 'autoComplete' | 'pattern' | 'maxLength'>\r\n & {\r\n /**\r\n * Optional. The ID of the text field.\r\n */\r\n id?: string;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the text field is disabled.\r\n */\r\n disabled?: boolean;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the text field is read-only.\r\n */\r\n readOnly?: boolean;\r\n\r\n /**\r\n * Optional. A function to be called when the text in the text field changes.\r\n * It should take a string representing the new text.\r\n */\r\n onChange?: (text: string) => void;\r\n\r\n /**\r\n * Optional. The current value of the text field.\r\n */\r\n value?: string;\r\n\r\n /**\r\n * Optional. The validation message to be displayed when the text field is in an error state.\r\n */\r\n validationMessage?: string;\r\n\r\n /**\r\n * Optional. The type of the text field. Can be any valid HTML input type.\r\n */\r\n type?: string;\r\n\r\n /**\r\n * Optional. The state of the text field. Can be 'Invalid' or 'Valid'.\r\n */\r\n state?: States.Invalid | States.Valid;\r\n\r\n /**\r\n * Optional. The autocomplete attribute of the text field. Can be any valid HTML autocomplete value.\r\n */\r\n autoComplete?: string;\r\n\r\n /**\r\n * Optional. The placeholder text to be displayed in the text field when it is empty.\r\n */\r\n placeholder?: string;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the text field is required.\r\n */\r\n required?: boolean;\r\n\r\n /**\r\n * Optional. The pattern attribute of the text field. Can be any valid HTML pattern value.\r\n */\r\n pattern?: string;\r\n\r\n /**\r\n * Optional. The maximum length of the text that can be entered in the text field.\r\n */\r\n maxLength?: number;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the text field should be displayed without a border.\r\n */\r\n withoutBorder?: boolean;\r\n\r\n /**\r\n * Optional. The position of the overflow tooltip. Can be 'top' or 'bottom'.\r\n */\r\n overflowTooltipPosition?: 'top' | 'bottom';\r\n\r\n /**\r\n * Optional. The size of the text field. Can be 'Small' or 'Medium'.\r\n */\r\n size?: Size.Small | Size.Medium;\r\n\r\n /**\r\n * Optional. The margin of the text field. Can be any valid CSS margin value.\r\n */\r\n margin?: string;\r\n\r\n /**\r\n * Optional. A note to be displayed below the text field.\r\n */\r\n note?: TextFieldNote;\r\n};\r\n\r\nconst TextField = React.forwardRef<HTMLInputElement, TextFieldProps>(({\r\n id,\r\n disabled,\r\n readOnly,\r\n onChange,\r\n value,\r\n validationMessage,\r\n type,\r\n autoComplete,\r\n placeholder,\r\n required,\r\n pattern,\r\n maxLength,\r\n withoutBorder,\r\n state,\r\n size,\r\n margin,\r\n overflowTooltipPosition,\r\n note,\r\n className,\r\n dataTestId,\r\n ...rest\r\n }: TextFieldProps, ref) => {\r\n const elementRef = useFocusVisibleRef();\r\n const theme = useTheme();\r\n\r\n React.useImperativeHandle(ref, () => elementRef.current, [elementRef]);\r\n\r\n const cls = `${state || (validationMessage ? States.Invalid : '')} ${size || ''}`;\r\n\r\n return (\r\n <>\r\n <InputWrapper\r\n $readOnly={readOnly}\r\n $disabled={disabled}\r\n $margin={margin}\r\n onClick={(e: any) => {\r\n if (disabled || readOnly) {\r\n e.preventDefault();\r\n }\r\n }}>\r\n <InputFieldStyling\r\n id={id}\r\n data-testid={dataTestId}\r\n ref={elementRef}\r\n type={type || 'text'}\r\n value={value}\r\n className={cls}\r\n tabIndex={readOnly || disabled ? -1 : 0}\r\n autoComplete={autoComplete}\r\n placeholder={disabled ? undefined : placeholder}\r\n disabled={disabled}\r\n readOnly={readOnly}\r\n onChange={(e: any) => onChange && onChange(e?.target?.value || '')}\r\n $activeErrorMessage={!!validationMessage && state !== States.Valid}\r\n required={required}\r\n pattern={pattern}\r\n maxLength={maxLength}\r\n $withoutBorder={withoutBorder}\r\n {...rest}\r\n />\r\n <TooltipOverflow value={value} position={overflowTooltipPosition} input={elementRef} withArrow={true} maxWidth=\"100%\" size={size} align='end'>\r\n {value}\r\n </TooltipOverflow>\r\n\r\n {validationMessage && (\r\n <ValidationMessage className={size || ''} type={state ?? States.Invalid}>\r\n {state === States.Valid ? <SystemIcons.CheckMark color={COLORS.getColor('correct_400', theme)}/> :\r\n <SystemIcons.TechnicalWarning color={COLORS.getColor('critical_400', theme)}/>}\r\n <span>{validationMessage}</span>\r\n </ValidationMessage>\r\n )}\r\n {note && !disabled && (\r\n <NoteMessage className={size}>\r\n {note.icon}\r\n <span>{note.message}</span>\r\n </NoteMessage>\r\n )}\r\n </InputWrapper>\r\n </>\r\n );\r\n});\r\n\r\nexport default TextField;\r\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"TextField.cjs","names":["React","_interopRequireWildcard","require","_icons","_styles","_types","_styling","_common","_TooltipOverflow","_interopRequireDefault","_styledComponents","_jsxRuntime","_excluded","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","TextField","forwardRef","_ref","ref","id","disabled","readOnly","onChange","value","validationMessage","type","autoComplete","placeholder","required","pattern","maxLength","withoutBorder","state","size","margin","overflowTooltipPosition","note","className","dataTestId","rest","_objectWithoutProperties2","elementRef","useFocusVisibleRef","theme","useTheme","useImperativeHandle","current","cls","States","Invalid","jsx","Fragment","children","jsxs","InputWrapper","$readOnly","$disabled","$margin","onClick","preventDefault","InputFieldStyling","tabIndex","undefined","target","$activeErrorMessage","Valid","$withoutBorder","position","input","withArrow","maxWidth","align","ValidationMessage","SystemIcons","CheckMark","color","COLORS","generateToken","componentType","defaultVariant","TechnicalWarning","NoteMessage","icon","message","propTypes","_propTypes","string","bool","func","number","oneOf","_default","exports"],"sources":["../../src/InputFields/TextField.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport {SystemIcons} from '../icons';\r\nimport {COLORS} from '../styles';\r\nimport {Size, States, Testable} from '../types';\r\nimport {InputFieldStyling, InputWrapper, NoteMessage, ValidationMessage} from './styling';\r\nimport {useFocusVisibleRef} from '../common';\r\nimport {TextFieldNote} from './types';\r\nimport TooltipOverflow from '../Tooltips/TooltipOverflow';\r\nimport { useTheme } from 'styled-components';\r\n\r\nexport type TextFieldProps =\r\n Testable & Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size' | 'onChange' | 'value' | 'disabled' | 'id' | 'type' | 'readOnly' | 'autoComplete' | 'pattern' | 'maxLength'>\r\n & {\r\n /**\r\n * Optional. The ID of the text field.\r\n */\r\n id?: string;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the text field is disabled.\r\n */\r\n disabled?: boolean;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the text field is read-only.\r\n */\r\n readOnly?: boolean;\r\n\r\n /**\r\n * Optional. A function to be called when the text in the text field changes.\r\n * It should take a string representing the new text.\r\n */\r\n onChange?: (text: string) => void;\r\n\r\n /**\r\n * Optional. The current value of the text field.\r\n */\r\n value?: string;\r\n\r\n /**\r\n * Optional. The validation message to be displayed when the text field is in an error state.\r\n */\r\n validationMessage?: string;\r\n\r\n /**\r\n * Optional. The type of the text field. Can be any valid HTML input type.\r\n */\r\n type?: string;\r\n\r\n /**\r\n * Optional. The state of the text field. Can be 'Invalid' or 'Valid'.\r\n */\r\n state?: States.Invalid | States.Valid;\r\n\r\n /**\r\n * Optional. The autocomplete attribute of the text field. Can be any valid HTML autocomplete value.\r\n */\r\n autoComplete?: string;\r\n\r\n /**\r\n * Optional. The placeholder text to be displayed in the text field when it is empty.\r\n */\r\n placeholder?: string;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the text field is required.\r\n */\r\n required?: boolean;\r\n\r\n /**\r\n * Optional. The pattern attribute of the text field. Can be any valid HTML pattern value.\r\n */\r\n pattern?: string;\r\n\r\n /**\r\n * Optional. The maximum length of the text that can be entered in the text field.\r\n */\r\n maxLength?: number;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the text field should be displayed without a border.\r\n */\r\n withoutBorder?: boolean;\r\n\r\n /**\r\n * Optional. The position of the overflow tooltip. Can be 'top' or 'bottom'.\r\n */\r\n overflowTooltipPosition?: 'top' | 'bottom';\r\n\r\n /**\r\n * Optional. The size of the text field. Can be 'Small' or 'Medium'.\r\n */\r\n size?: Size.Small | Size.Medium;\r\n\r\n /**\r\n * Optional. The margin of the text field. Can be any valid CSS margin value.\r\n */\r\n margin?: string;\r\n\r\n /**\r\n * Optional. A note to be displayed below the text field.\r\n */\r\n note?: TextFieldNote;\r\n};\r\n\r\nconst TextField = React.forwardRef<HTMLInputElement, TextFieldProps>(({\r\n id,\r\n disabled,\r\n readOnly,\r\n onChange,\r\n value,\r\n validationMessage,\r\n type,\r\n autoComplete,\r\n placeholder,\r\n required,\r\n pattern,\r\n maxLength,\r\n withoutBorder,\r\n state,\r\n size,\r\n margin,\r\n overflowTooltipPosition,\r\n note,\r\n className,\r\n dataTestId,\r\n ...rest\r\n }: TextFieldProps, ref) => {\r\n const elementRef = useFocusVisibleRef();\r\n const theme = useTheme();\r\n\r\n React.useImperativeHandle(ref, () => elementRef.current, [elementRef]);\r\n\r\n const cls = `${state || (validationMessage ? States.Invalid : '')} ${size || ''}`;\r\n\r\n return (\r\n <>\r\n <InputWrapper\r\n $readOnly={readOnly}\r\n $disabled={disabled}\r\n $margin={margin}\r\n onClick={(e: any) => {\r\n if (disabled || readOnly) {\r\n e.preventDefault();\r\n }\r\n }}>\r\n <InputFieldStyling\r\n id={id}\r\n data-testid={dataTestId}\r\n ref={elementRef}\r\n type={type || 'text'}\r\n value={value ?? ''}\r\n className={cls}\r\n tabIndex={readOnly || disabled ? -1 : 0}\r\n autoComplete={autoComplete}\r\n placeholder={disabled ? undefined : placeholder}\r\n disabled={disabled}\r\n readOnly={readOnly}\r\n onChange={(e: any) => onChange && onChange(e?.target?.value || '')}\r\n $activeErrorMessage={!!validationMessage && state !== States.Valid}\r\n required={required}\r\n pattern={pattern}\r\n maxLength={maxLength}\r\n $withoutBorder={withoutBorder}\r\n {...rest}\r\n />\r\n <TooltipOverflow value={value} position={overflowTooltipPosition} input={elementRef} withArrow={true} maxWidth=\"100%\" size={size} align='end'>\r\n {value}\r\n </TooltipOverflow>\r\n\r\n {validationMessage && (\r\n <ValidationMessage className={size || ''} type={state ?? States.Invalid}>\r\n {state === States.Valid ? <SystemIcons.CheckMark color={COLORS.generateToken({componentType:'text', defaultVariant:'positive'}, theme)}/> :\r\n <SystemIcons.TechnicalWarning color={COLORS.generateToken({componentType:'text', defaultVariant:'critical'}, theme)}/>}\r\n <span>{validationMessage}</span>\r\n </ValidationMessage>\r\n )}\r\n {note && !disabled && (\r\n <NoteMessage className={size}>\r\n {note.icon}\r\n <span>{note.message}</span>\r\n </NoteMessage>\r\n )}\r\n </InputWrapper>\r\n </>\r\n );\r\n});\r\n\r\nexport default TextField;\r\n"],"mappings":"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","ignoreList":[]}
@@ -76,7 +76,7 @@ export type TextFieldProps = Testable & Omit<React.InputHTMLAttributes<HTMLInput
76
76
  */
77
77
  note?: TextFieldNote;
78
78
  };
79
- declare const TextField: React.ForwardRefExoticComponent<Testable & Omit<React.InputHTMLAttributes<HTMLInputElement>, "id" | "onChange" | "size" | "disabled" | "pattern" | "type" | "value" | "autoComplete" | "maxLength" | "readOnly"> & {
79
+ declare const TextField: React.ForwardRefExoticComponent<Testable & Omit<React.InputHTMLAttributes<HTMLInputElement>, "disabled" | "id" | "onChange" | "size" | "pattern" | "type" | "value" | "autoComplete" | "maxLength" | "readOnly"> & {
80
80
  /**
81
81
  * Optional. The ID of the text field.
82
82
  */
@@ -56,7 +56,7 @@ const TextField = /*#__PURE__*/React.forwardRef((_ref, ref) => {
56
56
  "data-testid": dataTestId,
57
57
  ref: elementRef,
58
58
  type: type || 'text',
59
- value: value,
59
+ value: value ?? '',
60
60
  className: cls,
61
61
  tabIndex: readOnly || disabled ? -1 : 0,
62
62
  autoComplete: autoComplete,
@@ -82,9 +82,15 @@ const TextField = /*#__PURE__*/React.forwardRef((_ref, ref) => {
82
82
  className: size || '',
83
83
  type: state ?? States.Invalid,
84
84
  children: [state === States.Valid ? /*#__PURE__*/_jsx(SystemIcons.CheckMark, {
85
- color: COLORS.getColor('correct_400', theme)
85
+ color: COLORS.generateToken({
86
+ componentType: 'text',
87
+ defaultVariant: 'positive'
88
+ }, theme)
86
89
  }) : /*#__PURE__*/_jsx(SystemIcons.TechnicalWarning, {
87
- color: COLORS.getColor('critical_400', theme)
90
+ color: COLORS.generateToken({
91
+ componentType: 'text',
92
+ defaultVariant: 'critical'
93
+ }, theme)
88
94
  }), /*#__PURE__*/_jsx("span", {
89
95
  children: validationMessage
90
96
  })]
@@ -1 +1 @@
1
- {"version":3,"file":"TextField.js","names":["React","SystemIcons","COLORS","States","InputFieldStyling","InputWrapper","NoteMessage","ValidationMessage","useFocusVisibleRef","TooltipOverflow","useTheme","jsx","_jsx","jsxs","_jsxs","Fragment","_Fragment","TextField","forwardRef","_ref","ref","id","disabled","readOnly","onChange","value","validationMessage","type","autoComplete","placeholder","required","pattern","maxLength","withoutBorder","state","size","margin","overflowTooltipPosition","note","className","dataTestId","rest","_objectWithoutProperties","_excluded","elementRef","theme","useImperativeHandle","current","cls","Invalid","children","$readOnly","$disabled","$margin","onClick","e","preventDefault","_objectSpread","tabIndex","undefined","target","$activeErrorMessage","Valid","$withoutBorder","position","input","withArrow","maxWidth","align","CheckMark","color","getColor","TechnicalWarning","icon","message","propTypes","_pt","string","bool","func","number","oneOf"],"sources":["../../src/InputFields/TextField.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport {SystemIcons} from '../icons';\r\nimport {COLORS} from '../styles';\r\nimport {Size, States, Testable} from '../types';\r\nimport {InputFieldStyling, InputWrapper, NoteMessage, ValidationMessage} from './styling';\r\nimport {useFocusVisibleRef} from '../common';\r\nimport {TextFieldNote} from './types';\r\nimport TooltipOverflow from '../Tooltips/TooltipOverflow';\r\nimport { useTheme } from 'styled-components';\r\n\r\nexport type TextFieldProps =\r\n Testable & Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size' | 'onChange' | 'value' | 'disabled' | 'id' | 'type' | 'readOnly' | 'autoComplete' | 'pattern' | 'maxLength'>\r\n & {\r\n /**\r\n * Optional. The ID of the text field.\r\n */\r\n id?: string;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the text field is disabled.\r\n */\r\n disabled?: boolean;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the text field is read-only.\r\n */\r\n readOnly?: boolean;\r\n\r\n /**\r\n * Optional. A function to be called when the text in the text field changes.\r\n * It should take a string representing the new text.\r\n */\r\n onChange?: (text: string) => void;\r\n\r\n /**\r\n * Optional. The current value of the text field.\r\n */\r\n value?: string;\r\n\r\n /**\r\n * Optional. The validation message to be displayed when the text field is in an error state.\r\n */\r\n validationMessage?: string;\r\n\r\n /**\r\n * Optional. The type of the text field. Can be any valid HTML input type.\r\n */\r\n type?: string;\r\n\r\n /**\r\n * Optional. The state of the text field. Can be 'Invalid' or 'Valid'.\r\n */\r\n state?: States.Invalid | States.Valid;\r\n\r\n /**\r\n * Optional. The autocomplete attribute of the text field. Can be any valid HTML autocomplete value.\r\n */\r\n autoComplete?: string;\r\n\r\n /**\r\n * Optional. The placeholder text to be displayed in the text field when it is empty.\r\n */\r\n placeholder?: string;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the text field is required.\r\n */\r\n required?: boolean;\r\n\r\n /**\r\n * Optional. The pattern attribute of the text field. Can be any valid HTML pattern value.\r\n */\r\n pattern?: string;\r\n\r\n /**\r\n * Optional. The maximum length of the text that can be entered in the text field.\r\n */\r\n maxLength?: number;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the text field should be displayed without a border.\r\n */\r\n withoutBorder?: boolean;\r\n\r\n /**\r\n * Optional. The position of the overflow tooltip. Can be 'top' or 'bottom'.\r\n */\r\n overflowTooltipPosition?: 'top' | 'bottom';\r\n\r\n /**\r\n * Optional. The size of the text field. Can be 'Small' or 'Medium'.\r\n */\r\n size?: Size.Small | Size.Medium;\r\n\r\n /**\r\n * Optional. The margin of the text field. Can be any valid CSS margin value.\r\n */\r\n margin?: string;\r\n\r\n /**\r\n * Optional. A note to be displayed below the text field.\r\n */\r\n note?: TextFieldNote;\r\n};\r\n\r\nconst TextField = React.forwardRef<HTMLInputElement, TextFieldProps>(({\r\n id,\r\n disabled,\r\n readOnly,\r\n onChange,\r\n value,\r\n validationMessage,\r\n type,\r\n autoComplete,\r\n placeholder,\r\n required,\r\n pattern,\r\n maxLength,\r\n withoutBorder,\r\n state,\r\n size,\r\n margin,\r\n overflowTooltipPosition,\r\n note,\r\n className,\r\n dataTestId,\r\n ...rest\r\n }: TextFieldProps, ref) => {\r\n const elementRef = useFocusVisibleRef();\r\n const theme = useTheme();\r\n\r\n React.useImperativeHandle(ref, () => elementRef.current, [elementRef]);\r\n\r\n const cls = `${state || (validationMessage ? States.Invalid : '')} ${size || ''}`;\r\n\r\n return (\r\n <>\r\n <InputWrapper\r\n $readOnly={readOnly}\r\n $disabled={disabled}\r\n $margin={margin}\r\n onClick={(e: any) => {\r\n if (disabled || readOnly) {\r\n e.preventDefault();\r\n }\r\n }}>\r\n <InputFieldStyling\r\n id={id}\r\n data-testid={dataTestId}\r\n ref={elementRef}\r\n type={type || 'text'}\r\n value={value}\r\n className={cls}\r\n tabIndex={readOnly || disabled ? -1 : 0}\r\n autoComplete={autoComplete}\r\n placeholder={disabled ? undefined : placeholder}\r\n disabled={disabled}\r\n readOnly={readOnly}\r\n onChange={(e: any) => onChange && onChange(e?.target?.value || '')}\r\n $activeErrorMessage={!!validationMessage && state !== States.Valid}\r\n required={required}\r\n pattern={pattern}\r\n maxLength={maxLength}\r\n $withoutBorder={withoutBorder}\r\n {...rest}\r\n />\r\n <TooltipOverflow value={value} position={overflowTooltipPosition} input={elementRef} withArrow={true} maxWidth=\"100%\" size={size} align='end'>\r\n {value}\r\n </TooltipOverflow>\r\n\r\n {validationMessage && (\r\n <ValidationMessage className={size || ''} type={state ?? States.Invalid}>\r\n {state === States.Valid ? <SystemIcons.CheckMark color={COLORS.getColor('correct_400', theme)}/> :\r\n <SystemIcons.TechnicalWarning color={COLORS.getColor('critical_400', theme)}/>}\r\n <span>{validationMessage}</span>\r\n </ValidationMessage>\r\n )}\r\n {note && !disabled && (\r\n <NoteMessage className={size}>\r\n {note.icon}\r\n <span>{note.message}</span>\r\n </NoteMessage>\r\n )}\r\n </InputWrapper>\r\n </>\r\n );\r\n});\r\n\r\nexport default TextField;\r\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"TextField.js","names":["React","SystemIcons","COLORS","States","InputFieldStyling","InputWrapper","NoteMessage","ValidationMessage","useFocusVisibleRef","TooltipOverflow","useTheme","jsx","_jsx","jsxs","_jsxs","Fragment","_Fragment","TextField","forwardRef","_ref","ref","id","disabled","readOnly","onChange","value","validationMessage","type","autoComplete","placeholder","required","pattern","maxLength","withoutBorder","state","size","margin","overflowTooltipPosition","note","className","dataTestId","rest","_objectWithoutProperties","_excluded","elementRef","theme","useImperativeHandle","current","cls","Invalid","children","$readOnly","$disabled","$margin","onClick","e","preventDefault","_objectSpread","tabIndex","undefined","target","$activeErrorMessage","Valid","$withoutBorder","position","input","withArrow","maxWidth","align","CheckMark","color","generateToken","componentType","defaultVariant","TechnicalWarning","icon","message","propTypes","_pt","string","bool","func","number","oneOf"],"sources":["../../src/InputFields/TextField.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport {SystemIcons} from '../icons';\r\nimport {COLORS} from '../styles';\r\nimport {Size, States, Testable} from '../types';\r\nimport {InputFieldStyling, InputWrapper, NoteMessage, ValidationMessage} from './styling';\r\nimport {useFocusVisibleRef} from '../common';\r\nimport {TextFieldNote} from './types';\r\nimport TooltipOverflow from '../Tooltips/TooltipOverflow';\r\nimport { useTheme } from 'styled-components';\r\n\r\nexport type TextFieldProps =\r\n Testable & Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size' | 'onChange' | 'value' | 'disabled' | 'id' | 'type' | 'readOnly' | 'autoComplete' | 'pattern' | 'maxLength'>\r\n & {\r\n /**\r\n * Optional. The ID of the text field.\r\n */\r\n id?: string;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the text field is disabled.\r\n */\r\n disabled?: boolean;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the text field is read-only.\r\n */\r\n readOnly?: boolean;\r\n\r\n /**\r\n * Optional. A function to be called when the text in the text field changes.\r\n * It should take a string representing the new text.\r\n */\r\n onChange?: (text: string) => void;\r\n\r\n /**\r\n * Optional. The current value of the text field.\r\n */\r\n value?: string;\r\n\r\n /**\r\n * Optional. The validation message to be displayed when the text field is in an error state.\r\n */\r\n validationMessage?: string;\r\n\r\n /**\r\n * Optional. The type of the text field. Can be any valid HTML input type.\r\n */\r\n type?: string;\r\n\r\n /**\r\n * Optional. The state of the text field. Can be 'Invalid' or 'Valid'.\r\n */\r\n state?: States.Invalid | States.Valid;\r\n\r\n /**\r\n * Optional. The autocomplete attribute of the text field. Can be any valid HTML autocomplete value.\r\n */\r\n autoComplete?: string;\r\n\r\n /**\r\n * Optional. The placeholder text to be displayed in the text field when it is empty.\r\n */\r\n placeholder?: string;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the text field is required.\r\n */\r\n required?: boolean;\r\n\r\n /**\r\n * Optional. The pattern attribute of the text field. Can be any valid HTML pattern value.\r\n */\r\n pattern?: string;\r\n\r\n /**\r\n * Optional. The maximum length of the text that can be entered in the text field.\r\n */\r\n maxLength?: number;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the text field should be displayed without a border.\r\n */\r\n withoutBorder?: boolean;\r\n\r\n /**\r\n * Optional. The position of the overflow tooltip. Can be 'top' or 'bottom'.\r\n */\r\n overflowTooltipPosition?: 'top' | 'bottom';\r\n\r\n /**\r\n * Optional. The size of the text field. Can be 'Small' or 'Medium'.\r\n */\r\n size?: Size.Small | Size.Medium;\r\n\r\n /**\r\n * Optional. The margin of the text field. Can be any valid CSS margin value.\r\n */\r\n margin?: string;\r\n\r\n /**\r\n * Optional. A note to be displayed below the text field.\r\n */\r\n note?: TextFieldNote;\r\n};\r\n\r\nconst TextField = React.forwardRef<HTMLInputElement, TextFieldProps>(({\r\n id,\r\n disabled,\r\n readOnly,\r\n onChange,\r\n value,\r\n validationMessage,\r\n type,\r\n autoComplete,\r\n placeholder,\r\n required,\r\n pattern,\r\n maxLength,\r\n withoutBorder,\r\n state,\r\n size,\r\n margin,\r\n overflowTooltipPosition,\r\n note,\r\n className,\r\n dataTestId,\r\n ...rest\r\n }: TextFieldProps, ref) => {\r\n const elementRef = useFocusVisibleRef();\r\n const theme = useTheme();\r\n\r\n React.useImperativeHandle(ref, () => elementRef.current, [elementRef]);\r\n\r\n const cls = `${state || (validationMessage ? States.Invalid : '')} ${size || ''}`;\r\n\r\n return (\r\n <>\r\n <InputWrapper\r\n $readOnly={readOnly}\r\n $disabled={disabled}\r\n $margin={margin}\r\n onClick={(e: any) => {\r\n if (disabled || readOnly) {\r\n e.preventDefault();\r\n }\r\n }}>\r\n <InputFieldStyling\r\n id={id}\r\n data-testid={dataTestId}\r\n ref={elementRef}\r\n type={type || 'text'}\r\n value={value ?? ''}\r\n className={cls}\r\n tabIndex={readOnly || disabled ? -1 : 0}\r\n autoComplete={autoComplete}\r\n placeholder={disabled ? undefined : placeholder}\r\n disabled={disabled}\r\n readOnly={readOnly}\r\n onChange={(e: any) => onChange && onChange(e?.target?.value || '')}\r\n $activeErrorMessage={!!validationMessage && state !== States.Valid}\r\n required={required}\r\n pattern={pattern}\r\n maxLength={maxLength}\r\n $withoutBorder={withoutBorder}\r\n {...rest}\r\n />\r\n <TooltipOverflow value={value} position={overflowTooltipPosition} input={elementRef} withArrow={true} maxWidth=\"100%\" size={size} align='end'>\r\n {value}\r\n </TooltipOverflow>\r\n\r\n {validationMessage && (\r\n <ValidationMessage className={size || ''} type={state ?? States.Invalid}>\r\n {state === States.Valid ? <SystemIcons.CheckMark color={COLORS.generateToken({componentType:'text', defaultVariant:'positive'}, theme)}/> :\r\n <SystemIcons.TechnicalWarning color={COLORS.generateToken({componentType:'text', defaultVariant:'critical'}, theme)}/>}\r\n <span>{validationMessage}</span>\r\n </ValidationMessage>\r\n )}\r\n {note && !disabled && (\r\n <NoteMessage className={size}>\r\n {note.icon}\r\n <span>{note.message}</span>\r\n </NoteMessage>\r\n )}\r\n </InputWrapper>\r\n </>\r\n );\r\n});\r\n\r\nexport default TextField;\r\n"],"mappings":"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","ignoreList":[]}