@pareto-engineering/design-system 4.0.0-alpha.4 → 4.0.0-alpha.42

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 (398) hide show
  1. package/dist/cjs/a/AnimatedBlobs/AnimatedBlobs.js +90 -0
  2. package/dist/cjs/a/AnimatedBlobs/index.js +13 -0
  3. package/dist/cjs/a/AnimatedBlobs/styles.scss +87 -0
  4. package/dist/cjs/a/AnimatedGradient/AnimatedGradient.js +60 -0
  5. package/dist/cjs/a/AnimatedGradient/index.js +13 -0
  6. package/dist/cjs/a/AnimatedGradient/styles.scss +14 -0
  7. package/dist/cjs/a/AnimatedGradient/webGIRenderer.js +528 -0
  8. package/dist/cjs/a/AppContext/ContextProvider.js +0 -2
  9. package/dist/cjs/a/AppContext/useTheme.js +0 -4
  10. package/dist/cjs/a/BlurOverlay/BlurOverlay.js +59 -0
  11. package/dist/cjs/a/BlurOverlay/index.js +13 -0
  12. package/dist/cjs/a/BlurOverlay/styles.scss +31 -0
  13. package/dist/cjs/a/ContentTree/ContentTree.js +11 -5
  14. package/dist/cjs/a/ContentTree/common/Tree/Tree.js +12 -5
  15. package/dist/cjs/a/ContentTree/styles.scss +34 -11
  16. package/dist/cjs/a/Conversation/Conversation.js +12 -17
  17. package/dist/cjs/a/Conversation/common/Message/Message.js +15 -12
  18. package/dist/cjs/a/Conversation/styles.scss +56 -124
  19. package/dist/cjs/a/DotInfo/DotInfo.js +2 -2
  20. package/dist/cjs/a/Figure/Figure.js +2 -2
  21. package/dist/cjs/a/HamburgerButton/HamburgerButton.js +2 -2
  22. package/dist/cjs/a/IconList/IconList.js +2 -2
  23. package/dist/cjs/a/IconList/common/Item/Item.js +1 -1
  24. package/dist/cjs/a/Label/Label.js +14 -6
  25. package/dist/cjs/a/Label/styles.scss +4 -4
  26. package/dist/cjs/a/LoadingCircle/LoadingCircle.js +2 -2
  27. package/dist/cjs/a/MetaCard/MetaCard.js +65 -0
  28. package/dist/cjs/a/MetaCard/index.js +13 -0
  29. package/dist/cjs/a/MetaCard/styles.scss +45 -0
  30. package/dist/cjs/a/People/People.js +2 -2
  31. package/dist/cjs/a/People/common/Person/Person.js +5 -5
  32. package/dist/cjs/a/People/styles.scss +10 -4
  33. package/dist/cjs/a/Popover/Popover.js +4 -4
  34. package/dist/cjs/a/Popover/styles.scss +1 -1
  35. package/dist/cjs/a/ProgressBar/ProgressBar.js +2 -2
  36. package/dist/cjs/a/Quote/Quote.js +2 -2
  37. package/dist/cjs/a/SVG/SVG.js +2 -2
  38. package/dist/cjs/a/SnapScroller/SnapScroller.js +2 -2
  39. package/dist/cjs/a/SnapScroller/styles.scss +30 -9
  40. package/dist/cjs/a/Spinner/Spinner.js +2 -2
  41. package/dist/cjs/a/TextSteps/TextSteps.js +70 -0
  42. package/dist/cjs/a/TextSteps/index.js +13 -0
  43. package/dist/cjs/a/TextSteps/styles.scss +29 -0
  44. package/dist/cjs/a/Timestamp/Timestamp.js +2 -2
  45. package/dist/cjs/a/Tip/Tip.js +72 -0
  46. package/dist/cjs/a/Tip/index.js +13 -0
  47. package/dist/cjs/a/Tip/styles.scss +22 -0
  48. package/dist/cjs/a/index.js +43 -1
  49. package/dist/cjs/b/Button/Button.js +21 -8
  50. package/dist/cjs/b/Button/common/Group/Group.js +57 -0
  51. package/dist/cjs/b/Button/common/Group/index.js +13 -0
  52. package/dist/cjs/b/Button/common/Group/styles.scss +11 -0
  53. package/dist/cjs/b/Button/common/index.js +12 -0
  54. package/dist/cjs/b/Button/styles.scss +38 -8
  55. package/dist/cjs/b/Card/Card.js +74 -0
  56. package/dist/cjs/b/Card/common/Group/Group.js +73 -0
  57. package/dist/cjs/b/Card/common/Group/index.js +13 -0
  58. package/dist/cjs/b/Card/common/Group/styles.scss +38 -0
  59. package/dist/cjs/b/Card/common/Section/Section.js +59 -0
  60. package/dist/cjs/b/Card/common/Section/index.js +13 -0
  61. package/dist/cjs/b/Card/common/index.js +19 -0
  62. package/dist/cjs/b/Card/index.js +13 -0
  63. package/dist/cjs/b/Card/styles.scss +57 -0
  64. package/dist/cjs/b/Logo/Logo.js +2 -2
  65. package/dist/cjs/b/Page/Page.js +16 -6
  66. package/dist/cjs/b/Page/common/PageHelmet/PageHelmet.js +4 -2
  67. package/dist/cjs/b/Page/common/Section/Section.js +13 -3
  68. package/dist/cjs/b/Page/styles.scss +25 -4
  69. package/dist/cjs/b/SocialMediaButton/SocialMediaButton.js +2 -2
  70. package/dist/cjs/b/SocialMediaButton/styles.scss +1 -15
  71. package/dist/cjs/b/ThemeSelector/ThemeSelector.js +19 -31
  72. package/dist/cjs/b/ThemeSelector/styles.scss +2 -7
  73. package/dist/cjs/b/Title/Title.js +5 -3
  74. package/dist/cjs/b/index.js +8 -1
  75. package/dist/cjs/c/ContentSlides/ContentSlides.js +3 -3
  76. package/dist/cjs/c/ContentSlides/common/HorizontalMenu/HorizontalMenu.js +1 -3
  77. package/dist/cjs/c/ContentSlides/common/Sidebar/Sidebar.js +0 -2
  78. package/dist/cjs/c/ContentSlides/styles.scss +2 -2
  79. package/dist/cjs/c/Modal/Modal.js +3 -3
  80. package/dist/cjs/c/Modal/common/ModalHeader/ModalHeader.js +1 -1
  81. package/dist/cjs/c/Modal/styles.scss +9 -13
  82. package/dist/cjs/c/Shortener/Shortener.js +2 -2
  83. package/dist/cjs/c/SocialMediaShareButton/SocialMediaShareButton.js +2 -2
  84. package/dist/cjs/f/FormInput/FormInput.js +14 -4
  85. package/dist/cjs/f/common/Debugger/Debugger.js +2 -2
  86. package/dist/cjs/f/common/Description/Description.js +2 -2
  87. package/dist/cjs/f/common/InputWrapper/InputWrapper.js +74 -0
  88. package/dist/cjs/f/common/InputWrapper/index.js +13 -0
  89. package/dist/cjs/f/common/InputWrapper/styles.scss +13 -0
  90. package/dist/cjs/f/common/Label/Label.js +20 -6
  91. package/dist/cjs/f/common/Label/styles.scss +8 -2
  92. package/dist/cjs/f/common/index.js +8 -1
  93. package/dist/cjs/f/fields/Checkbox/Checkbox.js +42 -12
  94. package/dist/cjs/f/fields/Checkbox/styles.scss +6 -8
  95. package/dist/cjs/f/fields/ChoicesInput/ChoicesInput.js +57 -26
  96. package/dist/cjs/f/fields/ChoicesInput/common/Choice/Choice.js +2 -2
  97. package/dist/cjs/f/fields/ChoicesInput/styles.scss +52 -43
  98. package/dist/cjs/f/fields/EditorInput/EditorInput.js +223 -0
  99. package/dist/cjs/f/fields/EditorInput/common/Toolbar.js +193 -0
  100. package/dist/cjs/f/fields/EditorInput/common/TreeViewPlugin.js +19 -0
  101. package/dist/cjs/f/fields/EditorInput/common/index.js +20 -0
  102. package/dist/cjs/f/fields/EditorInput/index.js +13 -0
  103. package/dist/cjs/f/fields/EditorInput/styles.scss +121 -0
  104. package/dist/cjs/f/fields/LinkInput/LinkInput.js +164 -0
  105. package/dist/cjs/f/fields/LinkInput/index.js +13 -0
  106. package/dist/cjs/f/fields/LinkInput/styles.scss +89 -0
  107. package/dist/cjs/f/fields/QueryChoices/QueryChoices.js +27 -3
  108. package/dist/cjs/f/fields/QueryCombobox/QueryCombobox.js +37 -7
  109. package/dist/cjs/f/fields/QueryCombobox/common/Combobox/Combobox.js +44 -17
  110. package/dist/cjs/f/fields/QueryCombobox/common/Menu/Menu.js +1 -1
  111. package/dist/cjs/f/fields/QueryCombobox/common/MultipleCombobox/MultipleCombobox.js +36 -26
  112. package/dist/cjs/f/fields/QueryCombobox/styles.scss +64 -29
  113. package/dist/cjs/f/fields/QuerySelect/QuerySelect.js +17 -3
  114. package/dist/cjs/f/fields/RatingsInput/RatingsInput.js +43 -21
  115. package/dist/cjs/f/fields/RatingsInput/common/Rating/Rating.js +5 -5
  116. package/dist/cjs/f/fields/RatingsInput/styles.scss +6 -13
  117. package/dist/cjs/f/fields/SelectInput/SelectInput.js +47 -17
  118. package/dist/cjs/f/fields/SelectInput/styles.scss +60 -26
  119. package/dist/cjs/f/fields/TextInput/TextInput.js +50 -17
  120. package/dist/cjs/f/fields/TextInput/styles.scss +56 -20
  121. package/dist/cjs/f/fields/TextareaInput/TextareaInput.js +45 -24
  122. package/dist/cjs/f/fields/TextareaInput/styles.scss +42 -25
  123. package/dist/cjs/f/fields/index.js +15 -1
  124. package/dist/cjs/form.scss +1 -1
  125. package/dist/cjs/r/SwitchRouteMap/SwitchRouteMap.js +1 -1
  126. package/dist/cjs/r/common/PrivateRoute/PrivateRoute.js +1 -1
  127. package/dist/cjs/test/QueryLoader/QueryLoader.js +2 -0
  128. package/dist/es/a/AnimatedBlobs/AnimatedBlobs.js +82 -0
  129. package/dist/es/a/AnimatedBlobs/index.js +1 -0
  130. package/dist/es/a/AnimatedBlobs/styles.scss +87 -0
  131. package/dist/es/a/AnimatedGradient/AnimatedGradient.js +52 -0
  132. package/dist/es/a/AnimatedGradient/index.js +1 -0
  133. package/dist/es/a/AnimatedGradient/styles.scss +14 -0
  134. package/dist/es/a/AnimatedGradient/webGIRenderer.js +492 -0
  135. package/dist/es/a/AppContext/useTheme.js +0 -4
  136. package/dist/es/a/BlurOverlay/BlurOverlay.js +51 -0
  137. package/dist/es/a/BlurOverlay/index.js +2 -0
  138. package/dist/es/a/BlurOverlay/styles.scss +31 -0
  139. package/dist/es/a/ContentTree/ContentTree.js +11 -5
  140. package/dist/es/a/ContentTree/common/Tree/Tree.js +12 -5
  141. package/dist/es/a/ContentTree/styles.scss +34 -11
  142. package/dist/es/a/Conversation/Conversation.js +12 -17
  143. package/dist/es/a/Conversation/common/Message/Message.js +15 -12
  144. package/dist/es/a/Conversation/styles.scss +56 -124
  145. package/dist/es/a/DotInfo/DotInfo.js +2 -2
  146. package/dist/es/a/Figure/Figure.js +2 -2
  147. package/dist/es/a/HamburgerButton/HamburgerButton.js +2 -2
  148. package/dist/es/a/IconList/IconList.js +2 -2
  149. package/dist/es/a/Label/Label.js +14 -6
  150. package/dist/es/a/Label/styles.scss +4 -4
  151. package/dist/es/a/LoadingCircle/LoadingCircle.js +2 -2
  152. package/dist/es/a/MetaCard/MetaCard.js +57 -0
  153. package/dist/es/a/MetaCard/index.js +1 -0
  154. package/dist/es/a/MetaCard/styles.scss +45 -0
  155. package/dist/es/a/People/People.js +2 -2
  156. package/dist/es/a/People/common/Person/Person.js +5 -5
  157. package/dist/es/a/People/styles.scss +10 -4
  158. package/dist/es/a/Popover/Popover.js +4 -4
  159. package/dist/es/a/Popover/styles.scss +1 -1
  160. package/dist/es/a/ProgressBar/ProgressBar.js +2 -2
  161. package/dist/es/a/Quote/Quote.js +2 -2
  162. package/dist/es/a/SVG/SVG.js +2 -2
  163. package/dist/es/a/SnapScroller/SnapScroller.js +2 -2
  164. package/dist/es/a/SnapScroller/styles.scss +30 -9
  165. package/dist/es/a/Spinner/Spinner.js +2 -2
  166. package/dist/es/a/TextSteps/TextSteps.js +61 -0
  167. package/dist/es/a/TextSteps/index.js +1 -0
  168. package/dist/es/a/TextSteps/styles.scss +29 -0
  169. package/dist/es/a/Timestamp/Timestamp.js +2 -2
  170. package/dist/es/a/Tip/Tip.js +64 -0
  171. package/dist/es/a/Tip/index.js +2 -0
  172. package/dist/es/a/Tip/styles.scss +22 -0
  173. package/dist/es/a/index.js +7 -1
  174. package/dist/es/b/Button/Button.js +21 -7
  175. package/dist/es/b/Button/common/Group/Group.js +49 -0
  176. package/dist/es/b/Button/common/Group/index.js +1 -0
  177. package/dist/es/b/Button/common/Group/styles.scss +11 -0
  178. package/dist/es/b/Button/common/index.js +1 -0
  179. package/dist/es/b/Button/styles.scss +38 -8
  180. package/dist/es/b/Card/Card.js +66 -0
  181. package/dist/es/b/Card/common/Group/Group.js +65 -0
  182. package/dist/es/b/Card/common/Group/index.js +1 -0
  183. package/dist/es/b/Card/common/Group/styles.scss +38 -0
  184. package/dist/es/b/Card/common/Section/Section.js +48 -0
  185. package/dist/es/b/Card/common/Section/index.js +1 -0
  186. package/dist/es/b/Card/common/index.js +2 -0
  187. package/dist/es/b/Card/index.js +1 -0
  188. package/dist/es/b/Card/styles.scss +57 -0
  189. package/dist/es/b/Logo/Logo.js +2 -2
  190. package/dist/es/b/Page/Page.js +16 -5
  191. package/dist/es/b/Page/common/PageHelmet/PageHelmet.js +4 -2
  192. package/dist/es/b/Page/common/Section/Section.js +12 -2
  193. package/dist/es/b/Page/styles.scss +25 -4
  194. package/dist/es/b/SocialMediaButton/SocialMediaButton.js +2 -2
  195. package/dist/es/b/SocialMediaButton/styles.scss +1 -15
  196. package/dist/es/b/ThemeSelector/ThemeSelector.js +19 -32
  197. package/dist/es/b/ThemeSelector/styles.scss +2 -7
  198. package/dist/es/b/Title/Title.js +18 -12
  199. package/dist/es/b/index.js +2 -1
  200. package/dist/es/c/ContentSlides/ContentSlides.js +3 -3
  201. package/dist/es/c/ContentSlides/common/HorizontalMenu/HorizontalMenu.js +1 -1
  202. package/dist/es/c/ContentSlides/styles.scss +2 -2
  203. package/dist/es/c/Modal/Modal.js +3 -3
  204. package/dist/es/c/Modal/common/ModalHeader/ModalHeader.js +1 -1
  205. package/dist/es/c/Modal/styles.scss +9 -13
  206. package/dist/es/c/Shortener/Shortener.js +2 -2
  207. package/dist/es/c/SocialMediaShareButton/SocialMediaShareButton.js +2 -2
  208. package/dist/es/f/FormInput/FormInput.js +15 -3
  209. package/dist/es/f/common/Debugger/Debugger.js +2 -2
  210. package/dist/es/f/common/Description/Description.js +2 -2
  211. package/dist/es/f/common/InputWrapper/InputWrapper.js +66 -0
  212. package/dist/es/f/common/InputWrapper/index.js +2 -0
  213. package/dist/es/f/common/InputWrapper/styles.scss +13 -0
  214. package/dist/es/f/common/Label/Label.js +20 -6
  215. package/dist/es/f/common/Label/styles.scss +8 -2
  216. package/dist/es/f/common/index.js +2 -1
  217. package/dist/es/f/fields/Checkbox/Checkbox.js +43 -13
  218. package/dist/es/f/fields/Checkbox/styles.scss +6 -8
  219. package/dist/es/f/fields/ChoicesInput/ChoicesInput.js +58 -27
  220. package/dist/es/f/fields/ChoicesInput/common/Choice/Choice.js +1 -1
  221. package/dist/es/f/fields/ChoicesInput/styles.scss +52 -43
  222. package/dist/es/f/fields/EditorInput/EditorInput.js +218 -0
  223. package/dist/es/f/fields/EditorInput/common/Toolbar.js +182 -0
  224. package/dist/es/f/fields/EditorInput/common/TreeViewPlugin.js +11 -0
  225. package/dist/es/f/fields/EditorInput/common/index.js +2 -0
  226. package/dist/es/f/fields/EditorInput/index.js +2 -0
  227. package/dist/es/f/fields/EditorInput/styles.scss +121 -0
  228. package/dist/es/f/fields/LinkInput/LinkInput.js +156 -0
  229. package/dist/es/f/fields/LinkInput/index.js +2 -0
  230. package/dist/es/f/fields/LinkInput/styles.scss +89 -0
  231. package/dist/es/f/fields/QueryChoices/QueryChoices.js +26 -2
  232. package/dist/es/f/fields/QueryCombobox/QueryCombobox.js +37 -7
  233. package/dist/es/f/fields/QueryCombobox/common/Combobox/Combobox.js +43 -16
  234. package/dist/es/f/fields/QueryCombobox/common/MultipleCombobox/MultipleCombobox.js +35 -25
  235. package/dist/es/f/fields/QueryCombobox/styles.scss +64 -29
  236. package/dist/es/f/fields/QuerySelect/QuerySelect.js +17 -3
  237. package/dist/es/f/fields/RatingsInput/RatingsInput.js +44 -22
  238. package/dist/es/f/fields/RatingsInput/common/Rating/Rating.js +4 -4
  239. package/dist/es/f/fields/RatingsInput/styles.scss +6 -13
  240. package/dist/es/f/fields/SelectInput/SelectInput.js +48 -18
  241. package/dist/es/f/fields/SelectInput/styles.scss +60 -26
  242. package/dist/es/f/fields/TextInput/TextInput.js +51 -18
  243. package/dist/es/f/fields/TextInput/styles.scss +56 -20
  244. package/dist/es/f/fields/TextareaInput/TextareaInput.js +46 -25
  245. package/dist/es/f/fields/TextareaInput/styles.scss +42 -25
  246. package/dist/es/f/fields/index.js +3 -1
  247. package/dist/es/form.scss +1 -1
  248. package/package.json +19 -16
  249. package/src/stories/a/BlurOverlay.stories.jsx +39 -0
  250. package/src/stories/a/Conversation.stories.jsx +11 -42
  251. package/src/stories/a/MetaCard.stories.jsx +35 -0
  252. package/src/stories/a/People.stories.jsx +22 -2
  253. package/src/stories/a/Quote.stories.jsx +1 -1
  254. package/src/stories/a/SnapScroller.stories.jsx +2 -2
  255. package/src/stories/a/Spinner.stories.jsx +1 -1
  256. package/src/stories/a/TextSteps.stories.jsx +19 -0
  257. package/src/stories/a/Tip.stories.jsx +28 -0
  258. package/src/stories/b/{Button.stories.jsx → Button/Button.stories.jsx} +18 -0
  259. package/src/stories/b/Button/Group.stories.jsx +35 -0
  260. package/src/stories/b/Card/Card.stories.jsx +59 -0
  261. package/src/stories/b/Card/Group.stories.jsx +59 -0
  262. package/src/stories/b/Page.stories.jsx +19 -3
  263. package/src/stories/b/ThemeSelector.stories.jsx +1 -1
  264. package/src/stories/b/Title.stories.jsx +1 -1
  265. package/src/stories/c/ContentSlides.stories.jsx +1 -1
  266. package/src/stories/colors.js +22 -10
  267. package/src/stories/f/Checkbox.stories.jsx +22 -7
  268. package/src/stories/f/ChoicesInput.stories.jsx +21 -7
  269. package/src/stories/f/EditorInput.stories.jsx +88 -0
  270. package/src/stories/f/LinkInput.stories.jsx +100 -0
  271. package/src/stories/f/QueryChoices.stories.jsx +20 -4
  272. package/src/stories/f/QueryCombobox.stories.jsx +25 -13
  273. package/src/stories/f/QuerySelect.stories.jsx +20 -5
  274. package/src/stories/f/RatingsInput.stories.jsx +16 -2
  275. package/src/stories/f/SelectInput.stories.jsx +27 -5
  276. package/src/stories/f/TextInput.stories.jsx +33 -12
  277. package/src/stories/f/TextareaInput.stories.jsx +16 -2
  278. package/src/ui/a/AnimatedBlobs/AnimatedBlobs.jsx +102 -0
  279. package/src/ui/a/AnimatedBlobs/index.js +1 -0
  280. package/src/ui/a/AnimatedBlobs/styles.scss +87 -0
  281. package/src/ui/a/AnimatedGradient/AnimatedGradient.jsx +73 -0
  282. package/src/ui/a/AnimatedGradient/index.js +1 -0
  283. package/src/ui/a/AnimatedGradient/styles.scss +14 -0
  284. package/src/ui/a/AnimatedGradient/webGIRenderer.js +541 -0
  285. package/src/ui/a/AppContext/useTheme.js +0 -4
  286. package/src/ui/a/BlurOverlay/BlurOverlay.jsx +75 -0
  287. package/src/ui/a/BlurOverlay/index.js +2 -0
  288. package/src/ui/a/BlurOverlay/styles.scss +31 -0
  289. package/src/ui/a/ContentTree/ContentTree.jsx +10 -6
  290. package/src/ui/a/ContentTree/common/Tree/Tree.jsx +19 -7
  291. package/src/ui/a/ContentTree/styles.scss +34 -11
  292. package/src/ui/a/Conversation/Conversation.jsx +16 -20
  293. package/src/ui/a/Conversation/common/Message/Message.jsx +18 -11
  294. package/src/ui/a/Conversation/styles.scss +56 -124
  295. package/src/ui/a/DotInfo/DotInfo.jsx +2 -2
  296. package/src/ui/a/Figure/Figure.jsx +2 -2
  297. package/src/ui/a/HamburgerButton/HamburgerButton.jsx +2 -2
  298. package/src/ui/a/IconList/IconList.jsx +2 -2
  299. package/src/ui/a/Label/Label.jsx +13 -4
  300. package/src/ui/a/Label/styles.scss +4 -4
  301. package/src/ui/a/LoadingCircle/LoadingCircle.jsx +2 -2
  302. package/src/ui/a/MetaCard/MetaCard.jsx +81 -0
  303. package/src/ui/a/MetaCard/index.js +1 -0
  304. package/src/ui/a/MetaCard/styles.scss +45 -0
  305. package/src/ui/a/People/People.jsx +2 -2
  306. package/src/ui/a/People/common/Person/Person.jsx +5 -5
  307. package/src/ui/a/People/styles.scss +10 -4
  308. package/src/ui/a/Popover/Popover.jsx +4 -4
  309. package/src/ui/a/Popover/styles.scss +1 -1
  310. package/src/ui/a/ProgressBar/ProgressBar.jsx +2 -2
  311. package/src/ui/a/Quote/Quote.jsx +2 -2
  312. package/src/ui/a/SVG/SVG.jsx +2 -2
  313. package/src/ui/a/SnapScroller/SnapScroller.jsx +2 -2
  314. package/src/ui/a/SnapScroller/styles.scss +30 -9
  315. package/src/ui/a/Spinner/Spinner.jsx +2 -2
  316. package/src/ui/a/TextSteps/TextSteps.jsx +87 -0
  317. package/src/ui/a/TextSteps/index.js +1 -0
  318. package/src/ui/a/TextSteps/styles.scss +29 -0
  319. package/src/ui/a/Timestamp/Timestamp.jsx +2 -2
  320. package/src/ui/a/Tip/Tip.jsx +88 -0
  321. package/src/ui/a/Tip/index.js +2 -0
  322. package/src/ui/a/Tip/styles.scss +22 -0
  323. package/src/ui/a/index.js +6 -0
  324. package/src/ui/b/Button/Button.jsx +26 -7
  325. package/src/ui/b/Button/common/Group/Group.jsx +71 -0
  326. package/src/ui/b/Button/common/Group/index.js +1 -0
  327. package/src/ui/b/Button/common/Group/styles.scss +11 -0
  328. package/src/ui/b/Button/common/index.js +1 -0
  329. package/src/ui/b/Button/styles.scss +38 -8
  330. package/src/ui/b/Card/Card.jsx +94 -0
  331. package/src/ui/b/Card/common/Group/Group.jsx +91 -0
  332. package/src/ui/b/Card/common/Group/index.js +1 -0
  333. package/src/ui/b/Card/common/Group/styles.scss +38 -0
  334. package/src/ui/b/Card/common/Section/Section.jsx +70 -0
  335. package/src/ui/b/Card/common/Section/index.js +1 -0
  336. package/src/ui/b/Card/common/index.js +2 -0
  337. package/src/ui/b/Card/index.js +1 -0
  338. package/src/ui/b/Card/styles.scss +57 -0
  339. package/src/ui/b/Logo/Logo.jsx +2 -2
  340. package/src/ui/b/Page/Page.jsx +13 -3
  341. package/src/ui/b/Page/common/PageHelmet/PageHelmet.jsx +2 -3
  342. package/src/ui/b/Page/common/Section/Section.jsx +16 -1
  343. package/src/ui/b/Page/styles.scss +25 -4
  344. package/src/ui/b/SocialMediaButton/SocialMediaButton.jsx +2 -2
  345. package/src/ui/b/SocialMediaButton/styles.scss +1 -15
  346. package/src/ui/b/ThemeSelector/ThemeSelector.jsx +12 -30
  347. package/src/ui/b/ThemeSelector/styles.scss +2 -7
  348. package/src/ui/b/Title/Title.jsx +30 -23
  349. package/src/ui/b/index.js +1 -0
  350. package/src/ui/c/ContentSlides/ContentSlides.jsx +3 -3
  351. package/src/ui/c/ContentSlides/common/HorizontalMenu/HorizontalMenu.jsx +1 -1
  352. package/src/ui/c/ContentSlides/styles.scss +2 -2
  353. package/src/ui/c/Modal/Modal.jsx +3 -3
  354. package/src/ui/c/Modal/common/ModalHeader/ModalHeader.jsx +1 -1
  355. package/src/ui/c/Modal/styles.scss +9 -13
  356. package/src/ui/c/Shortener/Shortener.jsx +2 -2
  357. package/src/ui/c/SocialMediaShareButton/SocialMediaShareButton.jsx +2 -2
  358. package/src/ui/f/FormInput/FormInput.jsx +25 -2
  359. package/src/ui/f/common/Debugger/Debugger.jsx +2 -2
  360. package/src/ui/f/common/Description/Description.jsx +2 -2
  361. package/src/ui/f/common/InputWrapper/InputWrapper.jsx +89 -0
  362. package/src/ui/f/common/InputWrapper/index.js +2 -0
  363. package/src/ui/f/common/InputWrapper/styles.scss +13 -0
  364. package/src/ui/f/common/Label/Label.jsx +20 -4
  365. package/src/ui/f/common/Label/styles.scss +8 -2
  366. package/src/ui/f/common/index.js +1 -0
  367. package/src/ui/f/fields/Checkbox/Checkbox.jsx +67 -29
  368. package/src/ui/f/fields/Checkbox/styles.scss +6 -8
  369. package/src/ui/f/fields/ChoicesInput/ChoicesInput.jsx +85 -50
  370. package/src/ui/f/fields/ChoicesInput/common/Choice/Choice.jsx +10 -3
  371. package/src/ui/f/fields/ChoicesInput/styles.scss +52 -43
  372. package/src/ui/f/fields/EditorInput/EditorInput.jsx +273 -0
  373. package/src/ui/f/fields/EditorInput/common/Toolbar.jsx +254 -0
  374. package/src/ui/f/fields/EditorInput/common/TreeViewPlugin.jsx +16 -0
  375. package/src/ui/f/fields/EditorInput/common/index.jsx +2 -0
  376. package/src/ui/f/fields/EditorInput/index.js +2 -0
  377. package/src/ui/f/fields/EditorInput/styles.scss +121 -0
  378. package/src/ui/f/fields/LinkInput/LinkInput.jsx +197 -0
  379. package/src/ui/f/fields/LinkInput/index.js +2 -0
  380. package/src/ui/f/fields/LinkInput/styles.scss +89 -0
  381. package/src/ui/f/fields/QueryChoices/QueryChoices.jsx +28 -0
  382. package/src/ui/f/fields/QueryCombobox/QueryCombobox.jsx +39 -4
  383. package/src/ui/f/fields/QueryCombobox/common/Combobox/Combobox.jsx +68 -38
  384. package/src/ui/f/fields/QueryCombobox/common/MultipleCombobox/MultipleCombobox.jsx +81 -66
  385. package/src/ui/f/fields/QueryCombobox/styles.scss +64 -29
  386. package/src/ui/f/fields/QuerySelect/QuerySelect.jsx +16 -1
  387. package/src/ui/f/fields/RatingsInput/RatingsInput.jsx +57 -30
  388. package/src/ui/f/fields/RatingsInput/common/Rating/Rating.jsx +4 -4
  389. package/src/ui/f/fields/RatingsInput/styles.scss +6 -13
  390. package/src/ui/f/fields/SelectInput/SelectInput.jsx +90 -51
  391. package/src/ui/f/fields/SelectInput/styles.scss +60 -26
  392. package/src/ui/f/fields/TextInput/TextInput.jsx +71 -35
  393. package/src/ui/f/fields/TextInput/styles.scss +56 -20
  394. package/src/ui/f/fields/TextareaInput/TextareaInput.jsx +67 -45
  395. package/src/ui/f/fields/TextareaInput/styles.scss +42 -25
  396. package/src/ui/f/fields/index.js +2 -0
  397. package/src/ui/form.scss +1 -1
  398. package/tests/__snapshots__/Storyshots.test.js.snap +14551 -6190
@@ -1,7 +1,7 @@
1
1
  /* @pareto-engineering/generator-front 1.0.12 */
2
2
  import * as React from 'react'
3
3
 
4
- import { useState, useLayoutEffect, memo } from 'react'
4
+ import { useState, useInsertionEffect, memo } from 'react'
5
5
 
6
6
  import PropTypes from 'prop-types'
7
7
 
@@ -10,7 +10,7 @@ import styleNames from '@pareto-engineering/bem/exports'
10
10
  // Local Definitions
11
11
 
12
12
  import { Rating } from './common'
13
- import { FormLabel } from '../../common'
13
+ import { FormLabel, InputWrapper } from '../../common'
14
14
 
15
15
  const baseClassName = styleNames.base
16
16
 
@@ -26,46 +26,52 @@ const RatingsInput = ({
26
26
  name,
27
27
  ratingCount,
28
28
  showRatingValue,
29
- oneInputLabel,
29
+ color,
30
30
  label,
31
31
  labelColor,
32
32
  labelMax,
33
33
  labelMin,
34
34
  displayRatingsLabel,
35
35
  optional,
36
+ labelSpan,
37
+ desktopLabelSpan,
38
+ inputSpan,
39
+ desktopInputSpan,
36
40
  // ...otherProps
37
41
  }) => {
38
- useLayoutEffect(() => {
42
+ useInsertionEffect(() => {
39
43
  import('./styles.scss')
40
44
  }, [])
41
45
 
42
46
  const [hover, setHover] = useState(null)
43
47
 
44
48
  return (
45
- <div
46
- id={id}
47
- className={[
48
- baseClassName,
49
- componentClassName,
50
- userClassName,
51
- ]
52
- .filter((e) => e)
53
- .join(' ')}
54
- style={style}
55
- >
49
+ <>
56
50
  <FormLabel
57
- className={[
58
- 'input-label', oneInputLabel ? 'md-s2 s0 v1 mb-v' : 'v50 mb-v']
59
- .filter((e) => e)
60
- .join(' ')}
61
51
  name={name}
62
52
  color={labelColor}
63
53
  optional={optional}
54
+ columnSpan={labelSpan}
55
+ desktopColumnSpan={desktopLabelSpan}
56
+ // {...otherProps}
64
57
  >
65
- { label }
58
+ {label}
66
59
  </FormLabel>
67
- <div className="stars">
68
- {displayRatingsLabel && <p className="label-text md-s-1 s-2 x-metadata c-x">{labelMin}</p>}
60
+ <InputWrapper
61
+ id={id}
62
+ className={[
63
+ baseClassName,
64
+ componentClassName,
65
+ userClassName,
66
+ 'stars',
67
+ ]
68
+ .filter((e) => e)
69
+ .join(' ')}
70
+ style={style}
71
+ columnSpan={inputSpan}
72
+ desktopColumnSpan={desktopInputSpan}
73
+ >
74
+ {displayRatingsLabel && <p className="label-text s-2 x-metadata c-x">{labelMin}</p>}
69
75
  {[...Array(ratingCount)].map((_, index) => {
70
76
  const ratingValue = index + 1
71
77
  return (
@@ -77,12 +83,13 @@ const RatingsInput = ({
77
83
  hover={hover}
78
84
  setHover={setHover}
79
85
  showRatingValue={showRatingValue}
86
+ activeBackgroundColor={color}
80
87
  />
81
88
  )
82
89
  })}
83
- {displayRatingsLabel && <p className="label-text md-s-1 s-2 x-metadata c-x">{labelMax}</p>}
84
- </div>
85
- </div>
90
+ {displayRatingsLabel && <p className="label-text s-2 x-metadata c-x">{labelMax}</p>}
91
+ </InputWrapper>
92
+ </>
86
93
  )
87
94
  }
88
95
 
@@ -134,21 +141,41 @@ RatingsInput.propTypes = {
134
141
  * Whether the input is optional or not
135
142
  */
136
143
  optional :PropTypes.bool,
144
+
137
145
  /**
138
- * If the slide will only have one input
146
+ * The color of the stars
139
147
  */
140
- oneInputLabel :PropTypes.bool,
148
+ color:PropTypes.string,
141
149
 
142
150
  /**
143
151
  * String that will represent color for the label
144
152
  */
145
153
  labelColor:PropTypes.string,
154
+
155
+ /**
156
+ * The number of columns the label should span
157
+ */
158
+ labelSpan:PropTypes.number,
159
+
160
+ /**
161
+ * The number of columns the input should span
162
+ */
163
+ inputSpan:PropTypes.number,
164
+
165
+ /**
166
+ * The number of columns the label should span on desktop
167
+ */
168
+ desktopLabelSpan:PropTypes.number,
169
+
170
+ /**
171
+ * The number of columns the input should span on desktop
172
+ */
173
+ desktopInputSpan:PropTypes.number,
146
174
  }
147
175
 
148
176
  RatingsInput.defaultProps = {
149
- labelMin :'not satisfied.',
150
- labelMax :'very satisfied.',
151
- labelColor:'main2',
177
+ labelMin:'not satisfied.',
178
+ labelMax:'very satisfied.',
152
179
  }
153
180
 
154
181
  export default memo(RatingsInput)
@@ -53,13 +53,13 @@ const Rating = ({
53
53
  onMouseLeave={() => setHover(null)}
54
54
  >
55
55
  {showRatingValue && (
56
- <span className="v25 mb-v md-s-1 s-2 x-metadata c-x">
56
+ <span className="s-2 x-metadata c-x">
57
57
  {value}
58
58
  </span>
59
59
  )}
60
60
  <span
61
61
  className={[
62
- 'f-icons',
62
+ 'icon',
63
63
  value <= (hover || Number(field.value)) ? 'c-x' : 'c-hard-y',
64
64
  ]
65
65
  .filter((e) => e)
@@ -134,8 +134,8 @@ Rating.propTypes = {
134
134
  }
135
135
 
136
136
  Rating.defaultProps = {
137
- activeBackgroundColor :'main1',
138
- inactiveBackgroundColor:'background2',
137
+ activeBackgroundColor :'interactive',
138
+ inactiveBackgroundColor:'background-inputs',
139
139
  showRatingValue :false,
140
140
  }
141
141
 
@@ -1,37 +1,32 @@
1
1
  /* @pareto-engineering/generator-front 1.0.12 */
2
2
 
3
3
  @use "@pareto-engineering/bem";
4
+ @use "@pareto-engineering/styles/src/mixins";
5
+ @use "@pareto-engineering/styles/src/globals" as *;
4
6
 
5
7
  $default-rating-icon-margin: .5em;
6
8
  $default-padding: .2em;
7
9
  $default-transition: all .2s;
8
10
 
9
11
  .#{bem.$base}.ratings-input {
10
- display: flex;
11
- flex-direction: column;
12
-
13
- p {
14
- padding: $default-padding;
15
- }
16
-
17
- .stars {
12
+ &.stars {
18
13
  display: flex;
19
14
 
20
15
  >:not(:last-child) {
21
16
  margin-right: $default-rating-icon-margin;
22
17
  }
23
18
 
24
- .#{bem.$base}.rating {
19
+ > .#{bem.$base}.rating {
25
20
  display: flex;
26
21
 
27
- input {
22
+ > input {
28
23
  opacity: 0;
29
24
  position: absolute;
30
25
  visibility: none;
31
26
  z-index: -1;
32
27
  }
33
28
 
34
- label {
29
+ > label {
35
30
  align-items: center;
36
31
  cursor: pointer;
37
32
  display: flex;
@@ -47,5 +42,3 @@ $default-transition: all .2s;
47
42
  }
48
43
  }
49
44
  }
50
-
51
-
@@ -1,7 +1,7 @@
1
1
  /* @pareto-engineering/generator-front 1.0.12 */
2
2
  import * as React from 'react'
3
3
 
4
- import { useLayoutEffect, memo } from 'react'
4
+ import { useInsertionEffect, memo } from 'react'
5
5
 
6
6
  import { useField } from 'formik'
7
7
 
@@ -11,7 +11,7 @@ import styleNames from '@pareto-engineering/bem/exports'
11
11
 
12
12
  import { LoadingCircle } from 'ui/a'
13
13
 
14
- import { FormLabel, FormDescription } from '../../common'
14
+ import { FormLabel, FormDescription, InputWrapper } from '../../common'
15
15
 
16
16
  // Local Definitions
17
17
 
@@ -28,6 +28,7 @@ const SelectInput = ({
28
28
  style,
29
29
  name,
30
30
  label,
31
+ labelColor,
31
32
  color,
32
33
  options,
33
34
  validate,
@@ -36,63 +37,76 @@ const SelectInput = ({
36
37
  disabled,
37
38
  isLoading,
38
39
  autoComplete,
40
+ labelSpan,
41
+ desktopLabelSpan,
42
+ inputSpan,
43
+ desktopInputSpan,
39
44
  // ...otherProps
40
45
  }) => {
41
- useLayoutEffect(() => {
46
+ useInsertionEffect(() => {
42
47
  import('./styles.scss')
43
48
  }, [])
44
49
 
45
50
  const [field] = useField({ name, validate })
46
51
 
47
52
  return (
48
- <div
49
- id={id}
50
- className={[
51
-
52
- baseClassName,
53
-
54
- componentClassName,
55
- userClassName,
56
- `y-${color}`,
57
- ]
58
- .filter((e) => e)
59
- .join(' ')}
60
- style={style}
53
+ <>
54
+ <FormLabel
55
+ name={name}
56
+ color={labelColor}
57
+ optional={optional}
58
+ columnSpan={labelSpan}
59
+ desktopColumnSpan={desktopLabelSpan}
61
60
  // {...otherProps}
62
- >
63
- <FormLabel name={name} optional={optional}>{label}</FormLabel>
64
- <div className="select-wrapper">
65
- <select
66
- className="input"
67
- {...field}
68
- value={field.value || ''}
69
- id={name}
70
- disabled={disabled}
71
- autoComplete={autoComplete}
72
- >
73
- {
74
- options.map((option) => {
75
- // i.e if option is a string like "blah", return { value: "blah", label: "blah" }
76
- const newOption = typeof option === 'string' ? { value: option, label: option } : option
77
-
78
- return (
79
- <option
80
- key={newOption.value}
81
- value={newOption.value}
82
- disabled={newOption?.disabled || false}
83
- >
84
- {newOption.label}
85
- </option>
86
- )
87
- })
88
- }
89
- </select>
90
- {isLoading && (
91
- <LoadingCircle className="x-main2" />
92
- )}
93
- </div>
94
- <FormDescription className="v50 mt-v s-1" description={description} name={name} />
95
- </div>
61
+ >
62
+ {label}
63
+ </FormLabel>
64
+ <InputWrapper
65
+ id={id}
66
+ className={[
67
+ baseClassName,
68
+ componentClassName,
69
+ userClassName,
70
+ ]
71
+ .filter((e) => e)
72
+ .join(' ')}
73
+ style={style}
74
+ columnSpan={inputSpan}
75
+ desktopColumnSpan={desktopInputSpan}
76
+ >
77
+ <div className={`select-wrapper${disabled ? ' disabled' : ''}`}>
78
+ <select
79
+ className={`input y-${color}`}
80
+ {...field}
81
+ value={field.value || ''}
82
+ id={name}
83
+ disabled={disabled}
84
+ autoComplete={autoComplete}
85
+ >
86
+ {
87
+ options.map((option) => {
88
+ // i.e if option is a string like "blah", return { value: "blah", label: "blah" }
89
+ const newOption = typeof option === 'string' ? { value: option, label: option } : option
90
+
91
+ return (
92
+ <option
93
+ key={newOption.value}
94
+ value={newOption.value}
95
+ disabled={newOption?.disabled || false}
96
+ >
97
+ {newOption.label}
98
+ </option>
99
+ )
100
+ })
101
+ }
102
+ </select>
103
+ {isLoading && (
104
+ <LoadingCircle className="x-main" />
105
+ )}
106
+ </div>
107
+ <FormDescription className="s-1" description={description} name={name} />
108
+ </InputWrapper>
109
+ </>
96
110
  )
97
111
  }
98
112
 
@@ -155,6 +169,11 @@ SelectInput.propTypes = {
155
169
  */
156
170
  color:PropTypes.string,
157
171
 
172
+ /**
173
+ * The color of the select input label
174
+ */
175
+ labelColor:PropTypes.string,
176
+
158
177
  /*
159
178
  * Whether the query that is fetching the select options is still in flight
160
179
  */
@@ -164,6 +183,26 @@ SelectInput.propTypes = {
164
183
  */
165
184
  autoComplete:PropTypes.string,
166
185
 
186
+ /**
187
+ * The number of columns the label should span
188
+ */
189
+ labelSpan:PropTypes.number,
190
+
191
+ /**
192
+ * The number of columns the input should span
193
+ */
194
+ inputSpan:PropTypes.number,
195
+
196
+ /**
197
+ * The number of columns the label should span on desktop
198
+ */
199
+ desktopLabelSpan:PropTypes.number,
200
+
201
+ /**
202
+ * The number of columns the input should span on desktop
203
+ */
204
+ desktopInputSpan:PropTypes.number,
205
+
167
206
  /**
168
207
  * Whether the input is optional or not
169
208
  */
@@ -172,7 +211,7 @@ SelectInput.propTypes = {
172
211
 
173
212
  SelectInput.defaultProps = {
174
213
  disabled:false,
175
- color :'background2',
214
+ color :'paragraph',
176
215
  }
177
216
 
178
217
  export default memo(SelectInput)
@@ -2,48 +2,82 @@
2
2
 
3
3
 
4
4
  @use "@pareto-engineering/bem";
5
- @use "../../../form.scss";
5
+ @use "@pareto-engineering/styles/src/mixins";
6
+ @use "@pareto-engineering/styles/src/globals" as *;
6
7
 
7
-
8
- $default-padding: .75em;
9
- $default-margin: 1em;
8
+ $default-spacing-size: 1em;
9
+ $default-padding: .55em .75em;
10
+ $default-bg-gradient: var(--background-far);
11
+ $default-input-border-radius: var(--theme-default-input-border-radius);
12
+ $default-border: var(--theme-default-input-border);
13
+ $hover-border: var(--theme-hover-input-border);
14
+ $focus-border: var(--theme-focus-input-border);
15
+ $default-background: var(--background-inputs);
16
+ $disabled-background: var(--background-inputs-30);
10
17
 
11
18
  .#{bem.$base}.select-input {
12
- display: flex;
13
- flex-direction: column;
14
-
15
- .#{bem.$base}.label {
16
- margin-bottom: $default-margin;
19
+ &.#{bem.$base}.label {
20
+ margin-bottom: $default-spacing-size;
17
21
  }
18
22
 
19
23
  .select-wrapper {
24
+ background-color: $default-background;
25
+ border: $default-border;
26
+ border-radius: $default-input-border-radius;
27
+ display: flex;
28
+ flex-direction: column;
29
+ padding: $default-padding;
30
+ padding-right: 0;
20
31
  position: relative;
21
32
 
33
+ &:not(.disabled) {
34
+ &:hover,
35
+ &:active {
36
+ border: $hover-border;
37
+ }
38
+
39
+ &:focus {
40
+ border: $focus-border;
41
+ }
42
+ }
43
+
44
+ &.disabled {
45
+ background: $disabled-background;
46
+ }
47
+
48
+ &::placeholder {
49
+ color: var(--metadata);
50
+ }
51
+
52
+ &::after {
53
+ border-radius: $default-input-border-radius;
54
+ }
55
+
22
56
  >.#{bem.$base}.loading-circle {
23
57
  position: absolute;
24
- right: 0;
58
+ right: $default-spacing-size;
25
59
  top: 50%;
26
60
  transform: translateY(-50%);
27
61
  }
28
62
 
29
- >.input {
30
- background: var(--soft-y);
31
- border: var(--theme-border-style) var(--hard-y);
32
- color: var(--on-y);
33
- padding: $default-padding;
34
- width: 100%;
63
+ select {
64
+ appearance: none;
65
+ background-color: $default-background;
66
+ background-image: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjAiIGhlaWdodD0iMTIiIHZpZXdCb3g9IjAgMCAyMCAxMiIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTE5IDEuNUwxMCAxMC41TDEgMS41IiBzdHJva2U9IiM0QzRENTMiIHN0cm9rZS13aWR0aD0iMiIvPgo8L3N2Zz4=");
67
+ background-position: calc(100% - $default-spacing-size);
68
+ background-repeat: no-repeat;
69
+ background-size: $default-spacing-size;
70
+ padding-right: $default-spacing-size;
35
71
 
36
- &:not(:disabled):hover {
37
- border: var(--theme-border-style) var(--soft-background4);
38
- }
39
-
40
- &:disabled {
41
- appearance: none;
42
- background-color: var(--hard-y);
43
- }
72
+ &.input {
73
+ border: none;
74
+ color: var(--y);
75
+ outline: none;
76
+ width: 100%;
44
77
 
45
- &:focus {
46
- background: var(--y);
78
+ &:disabled {
79
+ opacity: 0%;
80
+ }
47
81
  }
48
82
  }
49
83
  }
@@ -1,7 +1,7 @@
1
1
  /* @pareto-engineering/generator-front 1.0.12 */
2
2
  import * as React from 'react'
3
3
 
4
- import { useLayoutEffect, memo } from 'react'
4
+ import { useInsertionEffect, memo } from 'react'
5
5
 
6
6
  import PropTypes from 'prop-types'
7
7
 
@@ -9,7 +9,7 @@ import styleNames from '@pareto-engineering/bem/exports'
9
9
 
10
10
  import { useField } from 'formik'
11
11
 
12
- import { FormLabel, FormDescription } from '../../common'
12
+ import { FormLabel, FormDescription, InputWrapper } from '../../common'
13
13
 
14
14
  // Local Definitions
15
15
 
@@ -30,57 +30,68 @@ const TextInput = ({
30
30
  color,
31
31
  labelColor,
32
32
  validate,
33
- oneInputLabel,
34
33
  description,
35
34
  disabled,
36
35
  placeholder,
37
36
  optional,
38
37
  autoComplete,
38
+ labelSpan,
39
+ desktopLabelSpan,
40
+ inputSpan,
41
+ desktopInputSpan,
42
+ symbol,
39
43
  // ...otherProps
40
44
  }) => {
41
- useLayoutEffect(() => {
45
+ useInsertionEffect(() => {
42
46
  import('./styles.scss')
43
47
  }, [])
44
48
 
45
49
  const [field] = useField({ name, validate })
50
+ const symbolStyle = symbol
51
+ ? { '--symbol': symbol }
52
+ : {}
46
53
 
47
54
  return (
48
- <div
49
- id={id}
50
- className={[
51
- baseClassName,
52
- componentClassName,
53
- userClassName,
54
- `y-${color}`,
55
- ]
56
- .filter((e) => e)
57
- .join(' ')}
58
- style={style}
59
- // {...otherProps}
60
- >
55
+ <>
61
56
  <FormLabel
62
- className={[oneInputLabel ? 'md-s2 s0 v1 mb-v' : 'v50 mb-v']
63
- .filter((e) => e)
64
- .join(' ')}
65
57
  name={name}
66
58
  color={labelColor}
67
59
  optional={optional}
60
+ columnSpan={labelSpan}
61
+ desktopColumnSpan={desktopLabelSpan}
62
+ // {...otherProps}
68
63
  >
69
- { label }
64
+ {label}
70
65
  </FormLabel>
71
- <input
72
- id={name}
73
- className="input"
74
- type={type}
75
- disabled={disabled}
76
- placeholder={placeholder}
77
- autoComplete={autoComplete}
78
- {...field}
79
- />
80
-
81
- <FormDescription className="v50 mt-v s-1" description={description} name={name} />
82
-
83
- </div>
66
+ <InputWrapper
67
+ id={id}
68
+ className={[
69
+ baseClassName,
70
+ componentClassName,
71
+ userClassName,
72
+ `y-${color} ${symbol ? 'has-symbol' : ''}`,
73
+ ]
74
+ .filter((e) => e)
75
+ .join(' ')}
76
+ style={{
77
+ ...symbolStyle,
78
+ ...style,
79
+ }}
80
+ columnSpan={inputSpan}
81
+ desktopColumnSpan={desktopInputSpan}
82
+ >
83
+ <input
84
+ id={name}
85
+ className="input"
86
+ type={type}
87
+ disabled={disabled}
88
+ placeholder={placeholder}
89
+ autoComplete={autoComplete}
90
+ {...field}
91
+ />
92
+ <FormDescription className="s-1" description={description} name={name} />
93
+ </InputWrapper>
94
+ </>
84
95
  )
85
96
  }
86
97
 
@@ -169,11 +180,36 @@ TextInput.propTypes = {
169
180
  * `https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autocomplete`
170
181
  */
171
182
  autoComplete:PropTypes.string,
183
+
184
+ /**
185
+ * The number of columns the label should span
186
+ */
187
+ labelSpan:PropTypes.number,
188
+
189
+ /**
190
+ * The number of columns the input should span
191
+ */
192
+ inputSpan:PropTypes.number,
193
+
194
+ /**
195
+ * The number of columns the label should span on desktop
196
+ */
197
+ desktopLabelSpan:PropTypes.number,
198
+
199
+ /**
200
+ * The number of columns the input should span on desktop
201
+ */
202
+ desktopInputSpan:PropTypes.number,
203
+
204
+ /**
205
+ * A symbol to be set inside the input field
206
+ */
207
+ symbol:PropTypes.string,
172
208
  }
173
209
 
174
210
  TextInput.defaultProps = {
175
211
  type :'text',
176
- color :'background2',
212
+ color :'paragraph',
177
213
  disabled:false,
178
214
  }
179
215