@spaced-out/ui-design-system 0.3.38 → 0.3.39-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (307) hide show
  1. package/.cspell/custom-words.txt +4 -0
  2. package/.github/workflows/publish_to_npm.yml +32 -4
  3. package/CHANGELOG.md +14 -0
  4. package/dts-generator/.editorconfig +10 -0
  5. package/dts-generator/.gitattributes +4 -0
  6. package/dts-generator/README.md +63 -0
  7. package/dts-generator/convert.js +101 -0
  8. package/dts-generator/package.json +16 -0
  9. package/gulpfile.js +20 -1
  10. package/lib/components/Avatar/Avatar.d.ts +264 -0
  11. package/lib/components/Avatar/index.d.ts +1 -0
  12. package/lib/components/AvatarGroup/AvatarGroup.d.ts +161 -0
  13. package/lib/components/AvatarGroup/index.d.ts +1 -0
  14. package/lib/components/Badge/Badge.d.ts +138 -0
  15. package/lib/components/Badge/index.d.ts +1 -0
  16. package/lib/components/Banner/Banner.d.ts +52 -0
  17. package/lib/components/Banner/index.d.ts +1 -0
  18. package/lib/components/Breadcrumbs/BreadcrumbLink/BreadcrumbLink.d.ts +50 -0
  19. package/lib/components/Breadcrumbs/BreadcrumbLink/index.d.ts +1 -0
  20. package/lib/components/Breadcrumbs/Breadcrumbs.d.ts +64 -0
  21. package/lib/components/Breadcrumbs/index.d.ts +2 -0
  22. package/lib/components/Button/Button.d.ts +288 -0
  23. package/lib/components/Button/index.d.ts +14 -0
  24. package/lib/components/ButtonDropdown/ButtonDropdown.d.ts +192 -0
  25. package/lib/components/ButtonDropdown/SimpleButtonDropdown.d.ts +148 -0
  26. package/lib/components/ButtonDropdown/index.d.ts +2 -0
  27. package/lib/components/ButtonTabs/ButtonTab/ButtonTab.d.ts +82 -0
  28. package/lib/components/ButtonTabs/ButtonTab/index.d.ts +1 -0
  29. package/lib/components/ButtonTabs/ButtonTabDropdown.d.ts +118 -0
  30. package/lib/components/ButtonTabs/ButtonTabs.d.ts +113 -0
  31. package/lib/components/ButtonTabs/index.d.ts +2 -0
  32. package/lib/components/Card/Card.d.ts +163 -0
  33. package/lib/components/Card/index.d.ts +1 -0
  34. package/lib/components/Charts/ChartTooltip/index.d.ts +10 -0
  35. package/lib/components/Charts/ChartWrapper/ChartWrapper.d.ts +184 -0
  36. package/lib/components/Charts/ChartWrapper/index.d.ts +1 -0
  37. package/lib/components/Charts/ColumnChart/ColumnChart.d.ts +111 -0
  38. package/lib/components/Charts/ColumnChart/index.d.ts +1 -0
  39. package/lib/components/Charts/DonutChart/DonutChart.d.ts +142 -0
  40. package/lib/components/Charts/DonutChart/index.d.ts +1 -0
  41. package/lib/components/Charts/FunnelChart/FunnelChart.d.ts +99 -0
  42. package/lib/components/Charts/FunnelChart/index.d.ts +1 -0
  43. package/lib/components/Charts/LineChart/LineChart.d.ts +97 -0
  44. package/lib/components/Charts/LineChart/index.d.ts +1 -0
  45. package/lib/components/Charts/SpiderChart/SpiderChart.d.ts +95 -0
  46. package/lib/components/Charts/SpiderChart/index.d.ts +1 -0
  47. package/lib/components/Charts/index.d.ts +7 -0
  48. package/lib/components/ChatBubble/ChatBubble.d.ts +203 -0
  49. package/lib/components/ChatBubble/index.d.ts +1 -0
  50. package/lib/components/Checkbox/Checkbox.d.ts +165 -0
  51. package/lib/components/Checkbox/CheckboxGroup.d.ts +113 -0
  52. package/lib/components/Checkbox/index.d.ts +2 -0
  53. package/lib/components/Chip/Chip.d.ts +181 -0
  54. package/lib/components/Chip/index.d.ts +2 -0
  55. package/lib/components/CircularLoader/CircularLoader.d.ts +56 -0
  56. package/lib/components/CircularLoader/index.d.ts +1 -0
  57. package/lib/components/CollapsibleCard/CollapsibleCard.d.ts +134 -0
  58. package/lib/components/CollapsibleCard/index.d.ts +1 -0
  59. package/lib/components/Combobox/Combobox.d.ts +292 -0
  60. package/lib/components/Combobox/helper.d.ts +205 -0
  61. package/lib/components/Combobox/index.d.ts +1 -0
  62. package/lib/components/ConditionalWrapper/ConditionalWrapper.d.ts +12 -0
  63. package/lib/components/ConditionalWrapper/index.d.ts +1 -0
  64. package/lib/components/DateRangePicker/Calendar.d.ts +119 -0
  65. package/lib/components/DateRangePicker/DateRangePicker.d.ts +196 -0
  66. package/lib/components/DateRangePicker/DateRangeWrapper.d.ts +311 -0
  67. package/lib/components/DateRangePicker/Day.d.ts +70 -0
  68. package/lib/components/DateRangePicker/index.d.ts +1 -0
  69. package/lib/components/Dialog/Dialog.d.ts +208 -0
  70. package/lib/components/Dialog/index.d.ts +1 -0
  71. package/lib/components/Disclaimer/Disclaimer.d.ts +32 -0
  72. package/lib/components/Disclaimer/index.d.ts +1 -0
  73. package/lib/components/Dropdown/Dropdown.d.ts +145 -0
  74. package/lib/components/Dropdown/SimpleDropdown.d.ts +142 -0
  75. package/lib/components/Dropdown/index.d.ts +2 -0
  76. package/lib/components/EmptyState/EmptyImages/CalendarEmptyImage.d.ts +108 -0
  77. package/lib/components/EmptyState/EmptyImages/ChartEmptyImage.d.ts +194 -0
  78. package/lib/components/EmptyState/EmptyImages/DataEmptyImage.d.ts +116 -0
  79. package/lib/components/EmptyState/EmptyImages/FileEmptyImage.d.ts +133 -0
  80. package/lib/components/EmptyState/EmptyImages/MessageEmptyImage.d.ts +64 -0
  81. package/lib/components/EmptyState/EmptyImages/UploadEmptyImage.d.ts +67 -0
  82. package/lib/components/EmptyState/EmptyImages/index.d.ts +6 -0
  83. package/lib/components/EmptyState/EmptyState.d.ts +82 -0
  84. package/lib/components/EmptyState/index.d.ts +1 -0
  85. package/lib/components/ErrorMessage/ErrorImages/ForbiddenImage.d.ts +85 -0
  86. package/lib/components/ErrorMessage/ErrorImages/NotFoundImage.d.ts +117 -0
  87. package/lib/components/ErrorMessage/ErrorImages/ServerErrorImage.d.ts +237 -0
  88. package/lib/components/ErrorMessage/ErrorImages/UnauthorizedImage.d.ts +73 -0
  89. package/lib/components/ErrorMessage/ErrorImages/index.d.ts +4 -0
  90. package/lib/components/ErrorMessage/ErrorMessage.d.ts +86 -0
  91. package/lib/components/ErrorMessage/index.d.ts +1 -0
  92. package/lib/components/FileUpload/FileBlock/FileBlock.d.ts +137 -0
  93. package/lib/components/FileUpload/FileBlock/index.d.ts +1 -0
  94. package/lib/components/FileUpload/FileUpload.d.ts +190 -0
  95. package/lib/components/FileUpload/index.d.ts +2 -0
  96. package/lib/components/FocusManager/FocusManager.d.ts +52 -0
  97. package/lib/components/FocusManager/index.d.ts +1 -0
  98. package/lib/components/FocusManagerWithArrowKeyNavigation/FocusManagerWithArrowKeyNavigation.d.ts +137 -0
  99. package/lib/components/FocusManagerWithArrowKeyNavigation/index.d.ts +1 -0
  100. package/lib/components/FormTitleWrapper/FormTitleWrapper.d.ts +62 -0
  101. package/lib/components/FormTitleWrapper/index.d.ts +1 -0
  102. package/lib/components/Grid/Grid.d.ts +104 -0
  103. package/lib/components/Grid/index.d.ts +1 -0
  104. package/lib/components/Icon/ClickableIcon.d.ts +101 -0
  105. package/lib/components/Icon/Icon.d.ts +71 -0
  106. package/lib/components/Icon/Icon.docs.d.ts +138 -0
  107. package/lib/components/Icon/SemanticIcon.d.ts +42 -0
  108. package/lib/components/Icon/index.d.ts +3 -0
  109. package/lib/components/InContextAlert/InContextAlert.d.ts +210 -0
  110. package/lib/components/InContextAlert/index.d.ts +1 -0
  111. package/lib/components/InlineDropdown/InlineDropdown.d.ts +146 -0
  112. package/lib/components/InlineDropdown/SimpleInlineDropdown.d.ts +145 -0
  113. package/lib/components/InlineDropdown/index.d.ts +2 -0
  114. package/lib/components/Input/Input.d.ts +327 -0
  115. package/lib/components/Input/index.d.ts +1 -0
  116. package/lib/components/KPIBox/KPIBox.d.ts +89 -0
  117. package/lib/components/KPIBox/index.d.ts +1 -0
  118. package/lib/components/LinearLoader/LinearLoader.d.ts +44 -0
  119. package/lib/components/LinearLoader/index.d.ts +1 -0
  120. package/lib/components/Link/Link.d.ts +225 -0
  121. package/lib/components/Link/index.d.ts +1 -0
  122. package/lib/components/Menu/Menu.d.ts +379 -0
  123. package/lib/components/Menu/MenuOptionButton.d.ts +199 -0
  124. package/lib/components/Menu/index.d.ts +2 -0
  125. package/lib/components/Modal/Modal.d.ts +354 -0
  126. package/lib/components/Modal/index.d.ts +14 -0
  127. package/lib/components/Notification/Notification.d.ts +147 -0
  128. package/lib/components/Notification/index.d.ts +1 -0
  129. package/lib/components/OptionButton/OptionButton.d.ts +150 -0
  130. package/lib/components/OptionButton/SimpleOptionButton.d.ts +150 -0
  131. package/lib/components/OptionButton/index.d.ts +2 -0
  132. package/lib/components/PageTitle/PageTitle.d.ts +256 -0
  133. package/lib/components/PageTitle/index.d.ts +1 -0
  134. package/lib/components/Pagination/Pagination.d.ts +144 -0
  135. package/lib/components/Pagination/PaginationItem.d.ts +136 -0
  136. package/lib/components/Pagination/index.d.ts +1 -0
  137. package/lib/components/Panel/Panel.d.ts +168 -0
  138. package/lib/components/Panel/index.d.ts +9 -0
  139. package/lib/components/ProgressDonut/ProgressDonut.d.ts +102 -0
  140. package/lib/components/ProgressDonut/index.d.ts +1 -0
  141. package/lib/components/PromptChip/PromptChip.d.ts +167 -0
  142. package/lib/components/PromptChip/index.d.ts +1 -0
  143. package/lib/components/PromptInput/PromptInput.d.ts +189 -0
  144. package/lib/components/PromptInput/index.d.ts +1 -0
  145. package/lib/components/RadioButton/RadioButton.d.ts +132 -0
  146. package/lib/components/RadioButton/RadioGroup.d.ts +88 -0
  147. package/lib/components/RadioButton/index.d.ts +2 -0
  148. package/lib/components/RadioTile/RadioTile.d.ts +109 -0
  149. package/lib/components/RadioTile/index.d.ts +1 -0
  150. package/lib/components/RangeSlider/RangeSlider.d.ts +207 -0
  151. package/lib/components/RangeSlider/index.d.ts +1 -0
  152. package/lib/components/Rating/Rating.d.ts +131 -0
  153. package/lib/components/Rating/index.d.ts +1 -0
  154. package/lib/components/ScoreBar/ScoreBar.d.ts +122 -0
  155. package/lib/components/ScoreBar/index.d.ts +1 -0
  156. package/lib/components/SearchInput/SearchInput.d.ts +79 -0
  157. package/lib/components/SearchInput/index.d.ts +2 -0
  158. package/lib/components/Separator/Separator.d.ts +51 -0
  159. package/lib/components/Separator/index.d.ts +1 -0
  160. package/lib/components/Shimmer/Shimmer.d.ts +131 -0
  161. package/lib/components/Shimmer/index.d.ts +1 -0
  162. package/lib/components/SideMenuLink/SideMenuLink.d.ts +336 -0
  163. package/lib/components/SideMenuLink/index.d.ts +1 -0
  164. package/lib/components/StatusIndicator/StatusIndicator.d.ts +60 -0
  165. package/lib/components/StatusIndicator/index.d.ts +1 -0
  166. package/lib/components/Stepper/Step/Step.d.ts +119 -0
  167. package/lib/components/Stepper/Step/StepContent.d.ts +35 -0
  168. package/lib/components/Stepper/Step/StepLabel.d.ts +35 -0
  169. package/lib/components/Stepper/Step/index.d.ts +3 -0
  170. package/lib/components/Stepper/Stepper.d.ts +60 -0
  171. package/lib/components/Stepper/index.d.ts +2 -0
  172. package/lib/components/StickyBar/StickyBar.d.ts +55 -0
  173. package/lib/components/StickyBar/index.d.ts +1 -0
  174. package/lib/components/SubMenu/SubMenu.d.ts +89 -0
  175. package/lib/components/SubMenu/SubMenuGroup.d.ts +156 -0
  176. package/lib/components/SubMenu/SubMenuItem.d.ts +161 -0
  177. package/lib/components/SubMenu/SubMenuLink.d.ts +81 -0
  178. package/lib/components/SubMenu/index.d.ts +4 -0
  179. package/lib/components/Table/Cell.d.ts +107 -0
  180. package/lib/components/Table/DefaultRow.d.ts +144 -0
  181. package/lib/components/Table/DefaultTableHeader.d.ts +236 -0
  182. package/lib/components/Table/StaticTable.d.ts +198 -0
  183. package/lib/components/Table/Table.d.ts +113 -0
  184. package/lib/components/Table/Table.docs.d.ts +532 -0
  185. package/lib/components/Table/TableActionBar.d.ts +48 -0
  186. package/lib/components/Table/TableBottomBar.d.ts +20 -0
  187. package/lib/components/Table/TableTopBar.d.ts +20 -0
  188. package/lib/components/Table/dummyTableData.d.ts +2189 -0
  189. package/lib/components/Table/hooks.d.ts +98 -0
  190. package/lib/components/Table/index.d.ts +8 -0
  191. package/lib/components/Tabs/Tab/Tab.d.ts +146 -0
  192. package/lib/components/Tabs/Tab/index.d.ts +1 -0
  193. package/lib/components/Tabs/TabList/TabDropdown.d.ts +100 -0
  194. package/lib/components/Tabs/TabList/TabList.d.ts +157 -0
  195. package/lib/components/Tabs/TabList/index.d.ts +1 -0
  196. package/lib/components/Tabs/index.d.ts +2 -0
  197. package/lib/components/Text/Text.d.ts +1021 -0
  198. package/lib/components/Text/index.d.ts +30 -0
  199. package/lib/components/TextTile/TextTile.d.ts +40 -0
  200. package/lib/components/TextTile/index.d.ts +1 -0
  201. package/lib/components/Textarea/Textarea.d.ts +132 -0
  202. package/lib/components/Textarea/index.d.ts +2 -0
  203. package/lib/components/Timeline/Timeline.d.ts +40 -0
  204. package/lib/components/Timeline/TimelineItem/TimelineItem.d.ts +121 -0
  205. package/lib/components/Timeline/TimelineItem/index.d.ts +1 -0
  206. package/lib/components/Timeline/index.d.ts +2 -0
  207. package/lib/components/Toast/Toast.d.ts +248 -0
  208. package/lib/components/Toast/ToastContainer.d.ts +140 -0
  209. package/lib/components/Toast/ToastManager.d.ts +58 -0
  210. package/lib/components/Toast/index.d.ts +10 -0
  211. package/lib/components/Toggle/Toggle.d.ts +111 -0
  212. package/lib/components/Toggle/index.d.ts +1 -0
  213. package/lib/components/TokenListInput/TokenListInput.d.ts +333 -0
  214. package/lib/components/TokenListInput/TokenValueChips.d.ts +64 -0
  215. package/lib/components/TokenListInput/index.d.ts +1 -0
  216. package/lib/components/Tooltip/Tooltip.d.ts +186 -0
  217. package/lib/components/Tooltip/index.d.ts +1 -0
  218. package/lib/components/Truncate/Truncate.d.ts +87 -0
  219. package/lib/components/Truncate/index.d.ts +2 -0
  220. package/lib/components/TruncatedTextWithTooltip/TruncatedTextWithTooltip.d.ts +95 -0
  221. package/lib/components/TruncatedTextWithTooltip/index.d.ts +1 -0
  222. package/lib/components/Typeahead/SimpleTypeahead.d.ts +141 -0
  223. package/lib/components/Typeahead/Typeahead.d.ts +217 -0
  224. package/lib/components/Typeahead/index.d.ts +2 -0
  225. package/lib/components/WeekdayPicker/WeekdayPicker.d.ts +242 -0
  226. package/lib/components/WeekdayPicker/index.d.ts +1 -0
  227. package/lib/components/index.d.ts +71 -0
  228. package/lib/hooks/index.d.ts +12 -0
  229. package/lib/hooks/useArbitraryOptionAddition/index.d.ts +1 -0
  230. package/lib/hooks/useArbitraryOptionAddition/useArbitraryOptionAddition.d.ts +124 -0
  231. package/lib/hooks/useCopyToClipboard/index.d.ts +1 -0
  232. package/lib/hooks/useCopyToClipboard/useCopyToClipboard.d.ts +27 -0
  233. package/lib/hooks/useFileUpload/index.d.ts +1 -0
  234. package/lib/hooks/useFileUpload/useFileUpload.d.ts +342 -0
  235. package/lib/hooks/useFilteredOptions/index.d.ts +1 -0
  236. package/lib/hooks/useFilteredOptions/useFilteredOptions.d.ts +87 -0
  237. package/lib/hooks/useInputState/index.d.ts +1 -0
  238. package/lib/hooks/useInputState/useInputState.d.ts +22 -0
  239. package/lib/hooks/useLockedBody/index.d.ts +1 -0
  240. package/lib/hooks/useLockedBody/useLockedBody.d.ts +46 -0
  241. package/lib/hooks/useModal/index.d.ts +1 -0
  242. package/lib/hooks/useModal/useModal.d.ts +32 -0
  243. package/lib/hooks/useMountTransition/index.d.ts +24 -0
  244. package/lib/hooks/usePagination/index.d.ts +1 -0
  245. package/lib/hooks/usePagination/usePagination.d.ts +140 -0
  246. package/lib/hooks/useToastPortal/index.d.ts +1 -0
  247. package/lib/hooks/useToastPortal/useToastPortal.d.ts +31 -0
  248. package/lib/hooks/useToggle/index.d.ts +1 -0
  249. package/lib/hooks/useToggle/useToggle.d.ts +11 -0
  250. package/lib/hooks/useWindowSize/index.d.ts +1 -0
  251. package/lib/hooks/useWindowSize/useWindowSize.d.ts +28 -0
  252. package/lib/index.d.ts +5 -0
  253. package/lib/styles/index.d.ts +267 -0
  254. package/lib/styles/variables/_border.d.ts +12 -0
  255. package/lib/styles/variables/_color.d.ts +104 -0
  256. package/lib/styles/variables/_elevation.d.ts +7 -0
  257. package/lib/styles/variables/_font.d.ts +30 -0
  258. package/lib/styles/variables/_motion.d.ts +6 -0
  259. package/lib/styles/variables/_opacity.d.ts +15 -0
  260. package/lib/styles/variables/_shadow.d.ts +24 -0
  261. package/lib/styles/variables/_size.d.ts +57 -0
  262. package/lib/styles/variables/_space.d.ts +12 -0
  263. package/lib/types/charts.d.ts +225 -0
  264. package/lib/types/common.d.ts +10 -0
  265. package/lib/types/date-range-picker.d.ts +17 -0
  266. package/lib/types/date-range-picker.js.flow +2 -3
  267. package/lib/types/index.d.ts +6 -0
  268. package/lib/types/menu.d.ts +13 -0
  269. package/lib/types/toast.d.ts +32 -0
  270. package/lib/types/typography.d.ts +17 -0
  271. package/lib/utils/array/are-arrays-equal.d.ts +11 -0
  272. package/lib/utils/array/index.d.ts +1 -0
  273. package/lib/utils/charts/charts.d.ts +102 -0
  274. package/lib/utils/charts/columnChart.d.ts +51 -0
  275. package/lib/utils/charts/donutChart.d.ts +116 -0
  276. package/lib/utils/charts/funnelChart.d.ts +94 -0
  277. package/lib/utils/charts/helpers.d.ts +44 -0
  278. package/lib/utils/charts/index.d.ts +7 -0
  279. package/lib/utils/charts/lineChart.d.ts +44 -0
  280. package/lib/utils/charts/spiderChart.d.ts +46 -0
  281. package/lib/utils/charts/typography.d.ts +42 -0
  282. package/lib/utils/classify/index.d.ts +27 -0
  283. package/lib/utils/click-away/click-away.d.ts +194 -0
  284. package/lib/utils/click-away/index.d.ts +1 -0
  285. package/lib/utils/date-range-picker/date-range-picker.d.ts +391 -0
  286. package/lib/utils/date-range-picker/index.d.ts +2 -0
  287. package/lib/utils/date-range-picker/timezones.d.ts +262 -0
  288. package/lib/utils/dom/dom.d.ts +245 -0
  289. package/lib/utils/dom/index.d.ts +1 -0
  290. package/lib/utils/helpers/helpers.d.ts +48 -0
  291. package/lib/utils/helpers/index.d.ts +1 -0
  292. package/lib/utils/index.d.ts +14 -0
  293. package/lib/utils/makeClassNameComponent/index.d.ts +1 -0
  294. package/lib/utils/makeClassNameComponent/makeClassNameComponent.d.ts +73 -0
  295. package/lib/utils/menu/index.d.ts +1 -0
  296. package/lib/utils/merge-refs/index.d.ts +1 -0
  297. package/lib/utils/merge-refs/merge-refs.d.ts +15 -0
  298. package/lib/utils/rating/index.d.ts +1 -0
  299. package/lib/utils/rating/rating.d.ts +31 -0
  300. package/lib/utils/score-bar/index.d.ts +1 -0
  301. package/lib/utils/score-bar/score-bar.d.ts +54 -0
  302. package/lib/utils/string/index.d.ts +1 -0
  303. package/lib/utils/string/string.d.ts +30 -0
  304. package/lib/utils/token-list-input/token-list-input.d.ts +32 -0
  305. package/lib/utils/tokens/index.d.ts +1 -0
  306. package/lib/utils/tokens/tokens.d.ts +230 -0
  307. package/package.json +5 -5
@@ -0,0 +1,189 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ import {size200} from '../../styles/variables/_size';
4
+ import classify from '../../utils/classify';
5
+ import {Button, BUTTON_TYPES} from '../Button';
6
+ import type {IconType} from '../Icon';
7
+ import {ICON_TYPE} from '../Icon';
8
+ import {BodySmallBold, FormLabelSmall} from '../Text';
9
+ import {Textarea} from '../Textarea';
10
+ import css from './PromptInput.module.css';
11
+ const CONSTANTS = {
12
+ DEFAULT_INPUT_PLACEHOLDER: 'Ask me anything',
13
+ INPUT_NAME: 'prompt-textarea',
14
+ BUTTON_TEXT: 'Generate',
15
+ BUTTON_ICON: 'sparkles',
16
+ BUTTON_ARIA_LABEL: 'Prompt Button',
17
+ TEXT_AREA_ROWS: 1,
18
+ };
19
+ type ClassNames = $ReadOnly<{
20
+ wrapper?: string;
21
+ inputBox?: string;
22
+ textarea?: string;
23
+ buttonWrapper?: string;
24
+ buttonIcon?: string;
25
+ buttonText?: string;
26
+ }>;
27
+ export type PromptInputProps = {
28
+ // textArea Props
29
+ value?: string;
30
+ onInputChange?: (
31
+ evt: React.SyntheticEvent<HTMLInputElement>,
32
+ isEnter?: boolean,
33
+ ) => unknown;
34
+ onInputFocus?: (e: React.SyntheticEvent<HTMLInputElement>) => unknown;
35
+ onInputBlur?: (e: React.SyntheticEvent<HTMLInputElement>) => unknown;
36
+ onInputKeyDown?: (e: React.KeyboardEvent<HTMLInputElement>) => unknown;
37
+ inputName?: string;
38
+ inputDisabled?: boolean;
39
+ inputPlaceholder?: string;
40
+ inputLocked?: boolean;
41
+ inputError?: boolean;
42
+ inputErrorText?: string;
43
+ // Common props
44
+ helperContent?: React.ReactNode;
45
+ textCountLimit?: number;
46
+ classNames?: ClassNames;
47
+ withPadding?: boolean;
48
+ // Button Props
49
+ buttonText?: string;
50
+ buttonDisabled?: boolean;
51
+ onButtonClick?:
52
+ | ((arg0: React.SyntheticEvent<HTMLElement>) => unknown)
53
+ | null
54
+ | undefined;
55
+ buttonAriaLabel?: string;
56
+ isButtonLoading?: boolean;
57
+ buttonIconLeftName?: string;
58
+ buttonIconLeftType?: IconType;
59
+ };
60
+ export const PromptInput: React$AbstractComponent<
61
+ PromptInputProps,
62
+ HTMLDivElement
63
+ > = React.forwardRef<PromptInputProps, HTMLDivElement>(
64
+ (
65
+ {
66
+ value,
67
+ onInputChange,
68
+ onInputFocus,
69
+ onInputBlur,
70
+ onInputKeyDown,
71
+ inputName = CONSTANTS.INPUT_NAME,
72
+ inputDisabled,
73
+ inputPlaceholder = CONSTANTS.DEFAULT_INPUT_PLACEHOLDER,
74
+ inputLocked,
75
+ inputError,
76
+ inputErrorText,
77
+ helperContent,
78
+ textCountLimit,
79
+ classNames,
80
+ withPadding = true,
81
+ buttonText = CONSTANTS.BUTTON_TEXT,
82
+ buttonDisabled,
83
+ onButtonClick,
84
+ buttonAriaLabel = CONSTANTS.BUTTON_ARIA_LABEL,
85
+ isButtonLoading,
86
+ buttonIconLeftName = CONSTANTS.BUTTON_ICON,
87
+ buttonIconLeftType = ICON_TYPE.solid,
88
+ }: PromptInputProps,
89
+ ref,
90
+ ) => {
91
+ const textareaRef = React.useRef(null);
92
+
93
+ const handleInput = () => {
94
+ const textarea = textareaRef.current;
95
+
96
+ if (textarea) {
97
+ textarea.style.height = 'auto'; // Reset height to auto to shrink
98
+
99
+ if (textarea.scrollHeight > parseInt(size200)) {
100
+ textarea.style.height = size200; // Limit height to size200
101
+
102
+ textarea.style.overflowY = 'auto';
103
+ } else {
104
+ textarea.style.height = `${textarea.scrollHeight}px`; // Adjust to content height
105
+
106
+ textarea.style.overflowY = 'hidden';
107
+ }
108
+ }
109
+ };
110
+
111
+ // Reset height on value change
112
+ React.useEffect(() => {
113
+ handleInput();
114
+ }, [value]);
115
+ const textCountError = React.useMemo(() => {
116
+ const charCount = value ? value.length : 0;
117
+ return textCountLimit != null && charCount > textCountLimit;
118
+ }, [value, textCountLimit]);
119
+ return (
120
+ <div
121
+ ref={ref}
122
+ data-testid="PromptInput"
123
+ className={classify(
124
+ css.wrapper,
125
+ {
126
+ [css.styledPromptContainer]: withPadding,
127
+ },
128
+ classNames?.wrapper,
129
+ )}
130
+ >
131
+ <div className={css.inputActionWrapper}>
132
+ <Textarea
133
+ classNames={{
134
+ box: classify(css.promptInputBox, classNames?.inputBox),
135
+ textarea: classify(css.textarea, classNames?.textarea),
136
+ }}
137
+ ref={textareaRef}
138
+ value={value}
139
+ onChange={onInputChange}
140
+ onFocus={onInputFocus}
141
+ onBlur={onInputBlur}
142
+ onKeyDown={onInputKeyDown}
143
+ name={inputName}
144
+ disabled={inputDisabled}
145
+ placeholder={inputPlaceholder}
146
+ locked={inputLocked}
147
+ error={inputError || textCountError}
148
+ errorText={inputErrorText}
149
+ rows={CONSTANTS.TEXT_AREA_ROWS}
150
+ ></Textarea>
151
+ <Button
152
+ iconLeftName={buttonIconLeftName}
153
+ iconLeftType={buttonIconLeftType}
154
+ onClick={onButtonClick}
155
+ type={BUTTON_TYPES.gradient}
156
+ disabled={buttonDisabled}
157
+ ariaLabel={buttonAriaLabel}
158
+ isLoading={isButtonLoading}
159
+ classNames={{
160
+ wrapper: classify(css.actionButton, classNames?.buttonWrapper),
161
+ icon: classNames?.buttonIcon,
162
+ text: classNames?.buttonText,
163
+ }}
164
+ >
165
+ {buttonText}
166
+ </Button>
167
+ </div>
168
+ {(!!helperContent || !!textCountLimit) && (
169
+ <div className={css.secondaryRow}>
170
+ {typeof helperContent === 'string' ? (
171
+ <BodySmallBold color={inputDisabled ? 'disabled' : 'secondary'}>
172
+ {helperContent}
173
+ </BodySmallBold>
174
+ ) : (
175
+ helperContent
176
+ )}
177
+ <FormLabelSmall
178
+ color={inputError || textCountError ? 'danger' : 'secondary'}
179
+ className={css.textCounter}
180
+ >
181
+ {!!textCountLimit &&
182
+ ((value && value.length) || 0) + '/' + textCountLimit}
183
+ </FormLabelSmall>
184
+ </div>
185
+ )}
186
+ </div>
187
+ );
188
+ },
189
+ );
@@ -0,0 +1 @@
1
+ export * from './PromptInput';
@@ -0,0 +1,132 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ import type {GroupAlign} from '../../types/common';
4
+ import classify from '../../utils/classify';
5
+ import css from './RadioButton.module.css';
6
+
7
+ /**
8
+ * Note:
9
+ * Do not wrap Radio in a label. For simplicity's sake, Radio uses an
10
+ * internal label tag to handle click delegation to the hidden input, and
11
+ * nesting labels is a bad idea.
12
+ */
13
+ type ClassNames = $ReadOnly<{
14
+ wrapper?: string;
15
+ label?: string;
16
+ radio?: string;
17
+ }>;
18
+ export type RadioButtonProps = {
19
+ children?: React.ReactNode;
20
+ value?: string;
21
+ disabled?: boolean;
22
+ focused?: boolean;
23
+ name?: string;
24
+ selectedValue?: string;
25
+ align?: GroupAlign;
26
+ classNames?: ClassNames;
27
+ error?: boolean;
28
+ onChange?: (newValue: string) => unknown;
29
+ tabIndex?: number;
30
+ ariaLabel?: string;
31
+ };
32
+ export const RadioButton: React$AbstractComponent<
33
+ RadioButtonProps,
34
+ HTMLInputElement
35
+ > = React.forwardRef<RadioButtonProps, HTMLInputElement>(
36
+ (
37
+ {
38
+ children,
39
+ disabled = false,
40
+ value = '',
41
+ focused = false,
42
+ name = 'radio',
43
+ selectedValue,
44
+ onChange,
45
+ align = 'vertical',
46
+ classNames,
47
+ error = false,
48
+ tabIndex = 0,
49
+ ariaLabel = '',
50
+ ...props
51
+ }: RadioButtonProps,
52
+ forwardRef,
53
+ ): React.ReactNode => {
54
+ const radioInput = React.createRef<HTMLInputElement>();
55
+ React.useImperativeHandle(forwardRef, () => radioInput.current);
56
+ const checked = selectedValue === value;
57
+ React.useEffect(() => {
58
+ if (radioInput.current && focused) {
59
+ radioInput.current.focus();
60
+ }
61
+ }, [focused]);
62
+
63
+ const onWrapClickHandler = () => {
64
+ radioInput.current?.click();
65
+ };
66
+
67
+ const onChangeHandler = (e) => {
68
+ if (!disabled) {
69
+ onChange && onChange(e?.target?.value);
70
+ }
71
+ };
72
+
73
+ const onKeyDownHandler = (e) => {
74
+ if (e.key === 'Enter') {
75
+ onChangeHandler(e);
76
+ }
77
+ };
78
+
79
+ return (
80
+ <div
81
+ className={classify(
82
+ css.container,
83
+ {
84
+ [css.horizontalRadioButton]: align === 'horizontal-fixed',
85
+ [css.fluidRadioButton]: align === 'horizontal-fluid',
86
+ [css.containerDisabled]: disabled,
87
+ },
88
+ classNames?.wrapper,
89
+ )}
90
+ onClick={onWrapClickHandler}
91
+ >
92
+ <input
93
+ type="radio"
94
+ checked={checked}
95
+ disabled={disabled}
96
+ className={classify(
97
+ css.radio,
98
+ {
99
+ [css.unselected]: !checked && !disabled && !error,
100
+ [css.selected]: checked && !disabled && !error,
101
+ [css.disabled]: disabled,
102
+ [css.error]: error && !disabled,
103
+ },
104
+ classNames?.radio,
105
+ )}
106
+ ref={radioInput}
107
+ onChange={onChangeHandler}
108
+ onKeyDown={onKeyDownHandler}
109
+ tabIndex={disabled ? -1 : tabIndex}
110
+ name={name}
111
+ value={value || ''}
112
+ aria-label={ariaLabel || children}
113
+ {...props}
114
+ />
115
+ {React.Children.count(children) > 0 && (
116
+ <div
117
+ color="secondary"
118
+ className={classify(
119
+ css.radioLabel,
120
+ {
121
+ [css.labelDisabled]: disabled,
122
+ },
123
+ classNames?.label,
124
+ )}
125
+ >
126
+ {children}
127
+ </div>
128
+ )}
129
+ </div>
130
+ );
131
+ },
132
+ );
@@ -0,0 +1,88 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ import type {GroupAlign} from '../../types/common';
4
+ import classify from '../../utils/classify';
5
+ import {BodySmall} from '../Text/Text';
6
+ import css from './RadioGroup.module.css';
7
+
8
+ /**
9
+ * Note:
10
+ * Do not wrap Radio in a label. For simplicity's sake, Radio uses an
11
+ * internal label tag to handle click delegation to the hidden input, and
12
+ * nesting labels is a bad idea.
13
+ */
14
+ type ClassNames = $ReadOnly<{
15
+ wrapper?: string;
16
+ radioGroup?: string;
17
+ errorText?: string;
18
+ }>;
19
+ export type RadioGroupProps = {
20
+ align?: GroupAlign;
21
+ name: string;
22
+ value?: string;
23
+ onChange?: (value: string) => unknown;
24
+ children?: React.ReactNode;
25
+ classNames?: ClassNames;
26
+ error?: boolean;
27
+ errorText?: string;
28
+ };
29
+ export const RadioGroup: React$AbstractComponent<
30
+ RadioGroupProps,
31
+ HTMLDivElement
32
+ > = React.forwardRef<RadioGroupProps, HTMLDivElement>(
33
+ (
34
+ {
35
+ align = 'vertical',
36
+ name,
37
+ value,
38
+ onChange,
39
+ children,
40
+ classNames,
41
+ error = false,
42
+ errorText = '',
43
+ }: RadioGroupProps,
44
+ forwardRef,
45
+ ): React.ReactNode => {
46
+ const onChangeHandler = (value) => {
47
+ if (onChange) {
48
+ onChange(value);
49
+ }
50
+ };
51
+
52
+ const childrenWithProps = React.Children.map(children, (child) => {
53
+ if (React.isValidElement(child)) {
54
+ return React.cloneElement(child, {
55
+ name,
56
+ selectedValue: value,
57
+ onChange: onChangeHandler,
58
+ align,
59
+ error,
60
+ });
61
+ }
62
+
63
+ return child;
64
+ });
65
+ return (
66
+ <div className={classify(css.radioGroupContainer, classNames?.wrapper)}>
67
+ <div
68
+ className={classify(
69
+ {
70
+ [css.vertical]: align === 'vertical',
71
+ [css.horizontal]: align === 'horizontal-fixed',
72
+ [css.horizontalFluid]: align === 'horizontal-fluid',
73
+ },
74
+ classNames?.radioGroup,
75
+ )}
76
+ ref={forwardRef}
77
+ >
78
+ {childrenWithProps}
79
+ </div>
80
+ {error && (
81
+ <BodySmall color="danger" className={classNames?.errorText}>
82
+ {errorText}
83
+ </BodySmall>
84
+ )}
85
+ </div>
86
+ );
87
+ },
88
+ );
@@ -0,0 +1,2 @@
1
+ export {RadioButton} from './RadioButton';
2
+ export {RadioGroup} from './RadioGroup';
@@ -0,0 +1,109 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ import type {AlertSemanticType} from '../../types/common';
4
+ import {ALERT_SEMANTIC} from '../../types/common';
5
+ import classify from '../../utils/classify';
6
+ import {ClickableCard} from '../Card';
7
+ import {Chip} from '../Chip';
8
+ import type {IconSize, IconType} from '../Icon';
9
+ import {ICON_SIZE, ICON_TYPE, SemanticIcon} from '../Icon';
10
+ import {RadioButton} from '../RadioButton';
11
+ import {BodyMedium, SubTitleMedium} from '../Text';
12
+ import css from './RadioTile.module.css';
13
+ type ClassNames = $ReadOnly<{
14
+ wrapper?: string;
15
+ }>;
16
+ export type RadioTileProps = {
17
+ id: string;
18
+ classNames?: ClassNames;
19
+ semantic?: AlertSemanticType;
20
+ header?: string;
21
+ description?: string;
22
+ chipItems?: Array<string>;
23
+ onTileClick?: (e: React.SyntheticEvent<HTMLElement>, id: string) => void;
24
+ iconName?: string;
25
+ iconSize?: IconSize;
26
+ iconType?: IconType;
27
+ isSelected?: boolean;
28
+ };
29
+ export const RadioTile: React$AbstractComponent<
30
+ RadioTileProps,
31
+ HTMLDivElement
32
+ > = React.forwardRef<RadioTileProps, HTMLDivElement>(
33
+ (
34
+ {
35
+ classNames,
36
+ id,
37
+ semantic = ALERT_SEMANTIC.neutral,
38
+ header,
39
+ description,
40
+ chipItems,
41
+ iconName,
42
+ iconSize = ICON_SIZE.medium,
43
+ iconType = ICON_TYPE.solid,
44
+ onTileClick,
45
+ isSelected = false,
46
+ ...props
47
+ }: RadioTileProps,
48
+ ref,
49
+ ) => {
50
+ const handleTileClick = (e: React.SyntheticEvent<HTMLElement>) => {
51
+ onTileClick && onTileClick(e, id);
52
+ };
53
+
54
+ return (
55
+ <ClickableCard
56
+ {...props}
57
+ ref={ref}
58
+ data-testid="RadioTile"
59
+ classNames={{
60
+ wrapper: classify(css.wrapper, classNames?.wrapper),
61
+ }}
62
+ onClick={handleTileClick}
63
+ >
64
+ <div className={css.iconContainer}>
65
+ {!!iconName && (
66
+ <SemanticIcon
67
+ semantic={semantic}
68
+ name={iconName}
69
+ size={iconSize}
70
+ type={iconType}
71
+ />
72
+ )}
73
+ </div>
74
+ <div className={css.contentContainer}>
75
+ <div className={css.textContainer}>
76
+ {!!header && <SubTitleMedium>{header}</SubTitleMedium>}
77
+ {!!description && (
78
+ <BodyMedium color="secondary">{description}</BodyMedium>
79
+ )}
80
+ </div>
81
+ {!!chipItems?.length && (
82
+ <div className={css.chipsContainer}>
83
+ {chipItems.map(
84
+ (
85
+ item,
86
+ index, // eslint-disable-next-line react/no-array-index-key
87
+ ) => (
88
+ <Chip key={index} semantic="primary">
89
+ {item}
90
+ </Chip>
91
+ ),
92
+ )}
93
+ </div>
94
+ )}
95
+ </div>
96
+ <div className={css.btnContainer}>
97
+ <RadioButton
98
+ classNames={{
99
+ wrapper: css.radioButtonWrapper,
100
+ }}
101
+ value={id}
102
+ selectedValue={isSelected ? id : ''}
103
+ tabIndex={-1}
104
+ />
105
+ </div>
106
+ </ClickableCard>
107
+ );
108
+ },
109
+ );
@@ -0,0 +1 @@
1
+ export * from './RadioTile';