@pareto-engineering/design-system 2.0.0-alpha.7 → 2.0.0-alpha.70

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 (536) hide show
  1. package/.env.scripts.example +4 -0
  2. package/.eslintrc.js +25 -1
  3. package/babel.config.js +1 -0
  4. package/dist/cjs/a/{GradientBackground/GradientBackground.js → Alert/Alert.js} +68 -67
  5. package/dist/cjs/{c/SiteFooter/common/Section → a/Alert}/index.js +3 -3
  6. package/dist/cjs/a/Alert/styles.scss +74 -0
  7. package/dist/cjs/{c/BlogContext → a/AppContext}/Context.js +0 -0
  8. package/dist/cjs/a/AppContext/ContextProvider.js +96 -0
  9. package/dist/cjs/{c/BlogContext → a/AppContext}/index.js +13 -5
  10. package/dist/cjs/{c/BlogContext/useBlog.js → a/AppContext/useApp.js} +0 -0
  11. package/dist/cjs/a/AppContext/useTheme.js +45 -0
  12. package/dist/cjs/{c/SiteFooter/common/Section/Section.js → a/BackgroundGradient/BackgroundGradient.js} +20 -38
  13. package/dist/cjs/a/BackgroundGradient/index.js +15 -0
  14. package/dist/cjs/a/BackgroundGradient/styles.scss +16 -0
  15. package/dist/cjs/{experimental/GradientBackground/GradientBackground.js → a/ColumnLabel/ColumnLabel.js} +32 -30
  16. package/dist/cjs/{c/SiteMission → a/ColumnLabel}/index.js +3 -3
  17. package/dist/cjs/a/ColumnLabel/styles.scss +22 -0
  18. package/dist/cjs/{c/TeamGallery/TeamGallery.js → a/ContentTree/ContentTree.js} +23 -20
  19. package/dist/cjs/a/ContentTree/common/Tree/Tree.js +116 -0
  20. package/dist/cjs/{c/BlogPostsList/common/Card → a/ContentTree/common/Tree}/index.js +3 -3
  21. package/dist/cjs/a/ContentTree/common/index.js +31 -0
  22. package/dist/cjs/a/ContentTree/common/useContentTree.js +82 -0
  23. package/dist/cjs/a/ContentTree/common/useFirstVisibleNode.js +65 -0
  24. package/dist/cjs/{c/SitePricing → a/ContentTree}/index.js +3 -3
  25. package/dist/cjs/a/ContentTree/styles.scss +33 -0
  26. package/dist/cjs/a/Conversation/Conversation.js +14 -8
  27. package/dist/cjs/a/Conversation/common/Message/Message.js +32 -6
  28. package/dist/cjs/a/Conversation/styles.scss +132 -33
  29. package/dist/cjs/{c/SiteFooter/SiteFooter.js → a/Label/Label.js} +28 -14
  30. package/dist/cjs/{f/fields/TextArea → a/Label}/index.js +3 -3
  31. package/dist/cjs/a/Label/styles.scss +34 -0
  32. package/dist/cjs/a/ModalContextProvider/Context.js +16 -0
  33. package/dist/cjs/{c/BlogContext/ContextProvider.js → a/ModalContextProvider/ModalContextProvider.js} +27 -25
  34. package/dist/cjs/a/ModalContextProvider/common/ModalRoot/ModalRoot.js +53 -0
  35. package/dist/cjs/a/ModalContextProvider/common/ModalRoot/index.js +15 -0
  36. package/dist/cjs/a/ModalContextProvider/common/ModalRoot/styles.scss +14 -0
  37. package/dist/cjs/{c/BlogPostsList → a/ModalContextProvider}/common/index.js +3 -3
  38. package/dist/cjs/a/ModalContextProvider/index.js +31 -0
  39. package/dist/cjs/a/ModalContextProvider/useModal.js +16 -0
  40. package/dist/cjs/a/OvalIllustration/OvalIllustration.js +35 -4
  41. package/dist/cjs/a/OvalIllustration/styles.scss +13 -16
  42. package/dist/cjs/{c/AcceptCookies/AcceptCookies.js → a/Popover/Popover.js} +57 -57
  43. package/dist/cjs/{c/BlogPost → a/Popover}/index.js +3 -3
  44. package/dist/cjs/a/Popover/styles.scss +33 -0
  45. package/dist/cjs/a/Shapes/Shapes.js +9 -1
  46. package/dist/cjs/a/Shapes/styles.scss +42 -9
  47. package/dist/cjs/{c/BlogPostsList/BlogPostsList.js → a/SnapScroller/SnapScroller.js} +15 -11
  48. package/dist/cjs/{c/SiteFooter → a/SnapScroller}/index.js +3 -3
  49. package/dist/cjs/a/SnapScroller/styles.scss +38 -0
  50. package/dist/cjs/a/index.js +57 -9
  51. package/dist/cjs/b/Button/Button.js +10 -4
  52. package/dist/cjs/b/Button/styles.scss +55 -10
  53. package/dist/cjs/b/Logo/Logo.js +41 -41
  54. package/dist/cjs/b/Logo/styles.scss +0 -138
  55. package/dist/cjs/b/Page/common/PageHelmet/PageHelmet.js +1 -1
  56. package/dist/cjs/b/Page/common/Section/Section.js +17 -3
  57. package/dist/cjs/b/SocialMediaButton/SocialMediaButton.js +4 -4
  58. package/dist/cjs/b/ThemeSelector/ThemeSelector.js +1 -1
  59. package/dist/cjs/c/ContentSlides/common/HorizontalMenu/HorizontalMenu.js +16 -9
  60. package/dist/cjs/c/ContentSlides/common/Navigator/Navigator.js +4 -3
  61. package/dist/cjs/c/ContentSlides/styles.scss +10 -4
  62. package/dist/cjs/c/{SiteOnboardingStep/SiteOnboardingStep.js → Modal/Modal.js} +45 -35
  63. package/dist/cjs/c/Modal/common/ModalHeader/ModalHeader.js +88 -0
  64. package/dist/cjs/c/{TeamGallery → Modal/common/ModalHeader}/index.js +3 -3
  65. package/dist/cjs/c/{TeamGallery → Modal}/common/index.js +3 -3
  66. package/dist/cjs/c/Modal/index.js +15 -0
  67. package/dist/cjs/c/Modal/styles.scss +46 -0
  68. package/dist/cjs/c/{BlogContext/BlogContextProvider.js → ModalButton/ModalButton.js} +28 -25
  69. package/dist/cjs/c/ModalButton/index.js +15 -0
  70. package/dist/cjs/c/{SiteMission/SiteMission.js → ObjectButton/ObjectButton.js} +59 -43
  71. package/dist/cjs/c/ObjectButton/index.js +15 -0
  72. package/dist/cjs/c/ObjectButton/styles.scss +52 -0
  73. package/dist/cjs/c/{SiteHeaderCTA/SiteHeaderCTA.js → SocialMediaShareButton/SocialMediaShareButton.js} +46 -43
  74. package/dist/cjs/c/SocialMediaShareButton/index.js +15 -0
  75. package/dist/cjs/c/SocialMediaShareButton/styles.scss +39 -0
  76. package/dist/cjs/c/index.js +17 -1
  77. package/dist/cjs/{c/TeamGallery/common/PersonCard/PersonCard.js → d/Modal/Modal.js} +35 -25
  78. package/dist/cjs/d/Modal/common/ModalFooter/ModalFooter.js +77 -0
  79. package/dist/cjs/d/Modal/common/ModalFooter/index.js +15 -0
  80. package/dist/cjs/d/Modal/common/ModalHeader/ModalHeader.js +79 -0
  81. package/dist/cjs/d/Modal/common/ModalHeader/index.js +15 -0
  82. package/dist/cjs/d/Modal/common/index.js +21 -0
  83. package/dist/cjs/d/Modal/index.js +15 -0
  84. package/dist/cjs/d/Modal/styles.scss +52 -0
  85. package/dist/cjs/f/FormInput/FormInput.js +33 -3
  86. package/dist/cjs/f/FormInput/styles.scss +11 -0
  87. package/dist/cjs/f/common/Debugger/Debugger.js +1 -1
  88. package/dist/cjs/f/common/Description/Description.js +20 -14
  89. package/dist/cjs/f/common/Label/Label.js +11 -5
  90. package/dist/cjs/f/common/Label/styles.scss +2 -5
  91. package/dist/cjs/f/fields/{TaskRecommendation/TaskRecommendation.js → Checkbox/Checkbox.js} +36 -48
  92. package/dist/cjs/f/fields/Checkbox/index.js +15 -0
  93. package/dist/cjs/f/fields/Checkbox/styles.scss +14 -0
  94. package/dist/cjs/f/fields/ChoicesInput/ChoicesInput.js +11 -4
  95. package/dist/cjs/f/fields/ChoicesInput/common/Choice/Choice.js +5 -2
  96. package/dist/cjs/f/fields/ChoicesInput/styles.scss +17 -2
  97. package/dist/cjs/f/fields/QueryCombobox/QueryCombobox.js +251 -0
  98. package/dist/cjs/f/fields/QueryCombobox/common/Combobox/Combobox.js +229 -0
  99. package/dist/cjs/f/fields/QueryCombobox/common/Combobox/index.js +15 -0
  100. package/dist/cjs/{c/BlogCategoryButton/BlogCategoryButton.js → f/fields/QueryCombobox/common/Menu/Menu.js} +39 -31
  101. package/dist/cjs/f/fields/QueryCombobox/common/Menu/index.js +15 -0
  102. package/dist/cjs/f/fields/QueryCombobox/common/MultipleCombobox/MultipleCombobox.js +326 -0
  103. package/dist/cjs/f/fields/QueryCombobox/common/MultipleCombobox/index.js +15 -0
  104. package/dist/cjs/f/fields/QueryCombobox/common/index.js +29 -0
  105. package/dist/cjs/{c/AcceptCookies → f/fields/QueryCombobox}/index.js +3 -3
  106. package/dist/cjs/f/fields/QueryCombobox/styles.scss +91 -0
  107. package/dist/cjs/f/fields/QuerySelect/QuerySelect.js +217 -0
  108. package/dist/cjs/f/fields/QuerySelect/index.js +15 -0
  109. package/dist/cjs/f/fields/RatingsInput/RatingsInput.js +39 -6
  110. package/dist/cjs/f/fields/RatingsInput/common/Rating/Rating.js +11 -2
  111. package/dist/cjs/f/fields/RatingsInput/styles.scss +29 -20
  112. package/dist/cjs/f/fields/SelectInput/SelectInput.js +67 -15
  113. package/dist/cjs/f/fields/SelectInput/styles.scss +33 -13
  114. package/dist/cjs/f/fields/TaskRecommendationInput/TaskRecommendationInput.js +2 -2
  115. package/dist/cjs/f/fields/TaskRecommendationInput/styles.scss +0 -4
  116. package/dist/cjs/f/fields/TextInput/TextInput.js +50 -13
  117. package/dist/cjs/f/fields/TextInput/styles.scss +16 -7
  118. package/dist/cjs/f/fields/TextareaInput/TextareaInput.js +48 -15
  119. package/dist/cjs/f/fields/TextareaInput/styles.scss +19 -6
  120. package/dist/cjs/f/fields/index.js +18 -18
  121. package/dist/cjs/form-reset.scss +1 -1
  122. package/dist/cjs/index.js +26 -0
  123. package/dist/cjs/test/QueryLoader/QueryLoader.js +41 -0
  124. package/dist/cjs/test/QueryLoader/__generated__/QueryLoaderHelloQuery.graphql.js +71 -0
  125. package/dist/cjs/test/QueryLoader/common/PreloadedTestData/PreloadedTestData.js +49 -0
  126. package/dist/cjs/test/QueryLoader/common/PreloadedTestData/index.js +15 -0
  127. package/dist/cjs/test/QueryLoader/common/index.js +13 -0
  128. package/dist/cjs/test/QueryLoader/index.js +15 -0
  129. package/dist/cjs/{c/SiteFooter/common → test}/index.js +3 -3
  130. package/dist/cjs/utils/hooks/index.js +23 -0
  131. package/dist/cjs/utils/hooks/useDynamicPosition.js +107 -0
  132. package/dist/cjs/utils/hooks/useWindowSize.js +39 -0
  133. package/dist/cjs/utils/index.js +19 -0
  134. package/dist/cjs/utils/relay/EnvironmentProvider.js +23 -0
  135. package/dist/cjs/utils/relay/environment.js +12 -0
  136. package/dist/cjs/utils/relay/index.js +39 -0
  137. package/dist/cjs/utils/relay/mockRelayOperation.js +23 -0
  138. package/dist/cjs/utils/relay/mockResolvers.js +282 -0
  139. package/dist/es/a/Alert/Alert.js +118 -0
  140. package/dist/es/{c/SiteFooter/common/Section → a/Alert}/index.js +1 -1
  141. package/dist/es/a/Alert/styles.scss +74 -0
  142. package/dist/es/{c/BlogContext → a/AppContext}/Context.js +0 -0
  143. package/dist/es/a/AppContext/ContextProvider.js +78 -0
  144. package/dist/es/a/AppContext/index.js +5 -0
  145. package/dist/es/{c/BlogContext/useBlog.js → a/AppContext/useApp.js} +0 -0
  146. package/dist/es/a/AppContext/useTheme.js +34 -0
  147. package/dist/es/{c/SiteFooter/SiteFooter.js → a/BackgroundGradient/BackgroundGradient.js} +14 -15
  148. package/dist/es/a/BackgroundGradient/index.js +2 -0
  149. package/dist/es/a/BackgroundGradient/styles.scss +16 -0
  150. package/dist/es/a/ColumnLabel/ColumnLabel.js +78 -0
  151. package/dist/es/a/ColumnLabel/index.js +2 -0
  152. package/dist/es/a/ColumnLabel/styles.scss +22 -0
  153. package/dist/es/a/ContentTree/ContentTree.js +67 -0
  154. package/dist/es/a/ContentTree/common/Tree/Tree.js +98 -0
  155. package/dist/es/{c/BlogPostsList/common/Card → a/ContentTree/common/Tree}/index.js +1 -1
  156. package/dist/es/a/ContentTree/common/index.js +3 -0
  157. package/dist/es/a/ContentTree/common/useContentTree.js +74 -0
  158. package/dist/es/a/ContentTree/common/useFirstVisibleNode.js +54 -0
  159. package/dist/es/a/ContentTree/index.js +2 -0
  160. package/dist/es/a/ContentTree/styles.scss +33 -0
  161. package/dist/es/a/Conversation/Conversation.js +14 -8
  162. package/dist/es/a/Conversation/common/Message/Message.js +32 -6
  163. package/dist/es/a/Conversation/styles.scss +132 -33
  164. package/dist/es/{c/TeamGallery/TeamGallery.js → a/Label/Label.js} +30 -23
  165. package/dist/es/{f/fields/TextArea → a/Label}/index.js +1 -1
  166. package/dist/es/a/Label/styles.scss +34 -0
  167. package/dist/es/a/ModalContextProvider/Context.js +2 -0
  168. package/dist/es/a/ModalContextProvider/ModalContextProvider.js +47 -0
  169. package/dist/es/a/ModalContextProvider/common/ModalRoot/ModalRoot.js +36 -0
  170. package/dist/es/a/ModalContextProvider/common/ModalRoot/index.js +2 -0
  171. package/dist/es/a/ModalContextProvider/common/ModalRoot/styles.scss +14 -0
  172. package/dist/es/{c/BlogPost → a/ModalContextProvider/common}/index.js +1 -1
  173. package/dist/es/a/ModalContextProvider/index.js +4 -0
  174. package/dist/es/a/ModalContextProvider/useModal.js +3 -0
  175. package/dist/es/a/OvalIllustration/OvalIllustration.js +29 -4
  176. package/dist/es/a/OvalIllustration/styles.scss +13 -16
  177. package/dist/es/a/Popover/Popover.js +118 -0
  178. package/dist/es/a/Popover/index.js +2 -0
  179. package/dist/es/a/Popover/styles.scss +33 -0
  180. package/dist/es/a/Shapes/Shapes.js +9 -1
  181. package/dist/es/a/Shapes/styles.scss +42 -9
  182. package/dist/es/{c/BlogPostsList/BlogPostsList.js → a/SnapScroller/SnapScroller.js} +16 -11
  183. package/dist/es/a/SnapScroller/index.js +2 -0
  184. package/dist/es/a/SnapScroller/styles.scss +38 -0
  185. package/dist/es/a/index.js +8 -2
  186. package/dist/es/b/Button/Button.js +8 -2
  187. package/dist/es/b/Button/styles.scss +55 -10
  188. package/dist/es/b/Logo/Logo.js +41 -41
  189. package/dist/es/b/Logo/styles.scss +0 -138
  190. package/dist/es/b/Page/common/PageHelmet/PageHelmet.js +2 -2
  191. package/dist/es/b/Page/common/Section/Section.js +17 -3
  192. package/dist/es/b/SocialMediaButton/SocialMediaButton.js +5 -5
  193. package/dist/es/b/ThemeSelector/ThemeSelector.js +2 -2
  194. package/dist/es/c/ContentSlides/common/HorizontalMenu/HorizontalMenu.js +16 -9
  195. package/dist/es/c/ContentSlides/common/Navigator/Navigator.js +4 -3
  196. package/dist/es/c/ContentSlides/styles.scss +10 -4
  197. package/dist/es/c/Modal/Modal.js +91 -0
  198. package/dist/es/c/Modal/common/ModalHeader/ModalHeader.js +67 -0
  199. package/dist/es/c/Modal/common/ModalHeader/index.js +1 -0
  200. package/dist/es/c/Modal/common/index.js +1 -0
  201. package/dist/es/c/Modal/index.js +2 -0
  202. package/dist/es/c/Modal/styles.scss +46 -0
  203. package/dist/es/c/ModalButton/ModalButton.js +48 -0
  204. package/dist/es/c/ModalButton/index.js +2 -0
  205. package/dist/es/c/ObjectButton/ObjectButton.js +111 -0
  206. package/dist/es/c/ObjectButton/index.js +2 -0
  207. package/dist/es/c/ObjectButton/styles.scss +52 -0
  208. package/dist/es/c/SocialMediaShareButton/SocialMediaShareButton.js +95 -0
  209. package/dist/es/c/SocialMediaShareButton/index.js +2 -0
  210. package/dist/es/c/SocialMediaShareButton/styles.scss +39 -0
  211. package/dist/es/c/index.js +3 -1
  212. package/dist/es/d/Modal/Modal.js +77 -0
  213. package/dist/es/d/Modal/common/ModalFooter/ModalFooter.js +56 -0
  214. package/dist/es/d/Modal/common/ModalFooter/index.js +1 -0
  215. package/dist/es/d/Modal/common/ModalHeader/ModalHeader.js +60 -0
  216. package/dist/es/d/Modal/common/ModalHeader/index.js +1 -0
  217. package/dist/es/d/Modal/common/index.js +2 -0
  218. package/dist/es/d/Modal/index.js +2 -0
  219. package/dist/es/d/Modal/styles.scss +52 -0
  220. package/dist/es/f/FormInput/FormInput.js +33 -3
  221. package/dist/es/f/FormInput/styles.scss +11 -0
  222. package/dist/es/f/common/Debugger/Debugger.js +1 -1
  223. package/dist/es/f/common/Description/Description.js +19 -14
  224. package/dist/es/f/common/Label/Label.js +11 -5
  225. package/dist/es/f/common/Label/styles.scss +2 -5
  226. package/dist/es/f/fields/Checkbox/Checkbox.js +99 -0
  227. package/dist/es/f/fields/Checkbox/index.js +2 -0
  228. package/dist/es/f/fields/Checkbox/styles.scss +14 -0
  229. package/dist/es/f/fields/ChoicesInput/ChoicesInput.js +11 -4
  230. package/dist/es/f/fields/ChoicesInput/common/Choice/Choice.js +5 -2
  231. package/dist/es/f/fields/ChoicesInput/styles.scss +17 -2
  232. package/dist/es/f/fields/QueryCombobox/QueryCombobox.js +228 -0
  233. package/dist/es/f/fields/QueryCombobox/common/Combobox/Combobox.js +208 -0
  234. package/dist/es/f/fields/QueryCombobox/common/Combobox/index.js +2 -0
  235. package/dist/es/f/fields/QueryCombobox/common/Menu/Menu.js +77 -0
  236. package/dist/es/f/fields/QueryCombobox/common/Menu/index.js +2 -0
  237. package/dist/es/f/fields/QueryCombobox/common/MultipleCombobox/MultipleCombobox.js +298 -0
  238. package/dist/es/f/fields/QueryCombobox/common/MultipleCombobox/index.js +2 -0
  239. package/dist/es/f/fields/QueryCombobox/common/index.js +3 -0
  240. package/dist/es/f/fields/QueryCombobox/index.js +2 -0
  241. package/dist/es/f/fields/QueryCombobox/styles.scss +91 -0
  242. package/dist/es/f/fields/QuerySelect/QuerySelect.js +195 -0
  243. package/dist/es/f/fields/QuerySelect/index.js +2 -0
  244. package/dist/es/f/fields/RatingsInput/RatingsInput.js +38 -6
  245. package/dist/es/f/fields/RatingsInput/common/Rating/Rating.js +11 -2
  246. package/dist/es/f/fields/RatingsInput/styles.scss +29 -20
  247. package/dist/es/f/fields/SelectInput/SelectInput.js +66 -15
  248. package/dist/es/f/fields/SelectInput/styles.scss +33 -13
  249. package/dist/es/f/fields/TaskRecommendationInput/TaskRecommendationInput.js +2 -2
  250. package/dist/es/f/fields/TaskRecommendationInput/styles.scss +0 -4
  251. package/dist/es/f/fields/TextInput/TextInput.js +50 -13
  252. package/dist/es/f/fields/TextInput/styles.scss +16 -7
  253. package/dist/es/f/fields/TextareaInput/TextareaInput.js +48 -15
  254. package/dist/es/f/fields/TextareaInput/styles.scss +19 -6
  255. package/dist/es/f/fields/index.js +4 -4
  256. package/dist/es/form-reset.scss +1 -1
  257. package/dist/es/index.js +3 -1
  258. package/dist/es/test/QueryLoader/QueryLoader.js +29 -0
  259. package/dist/es/test/QueryLoader/__generated__/QueryLoaderHelloQuery.graphql.js +71 -0
  260. package/dist/es/test/QueryLoader/common/PreloadedTestData/PreloadedTestData.js +31 -0
  261. package/dist/es/test/QueryLoader/common/PreloadedTestData/index.js +2 -0
  262. package/dist/es/test/QueryLoader/common/index.js +1 -0
  263. package/dist/es/test/QueryLoader/index.js +2 -0
  264. package/dist/es/test/index.js +1 -0
  265. package/dist/es/utils/hooks/index.js +2 -0
  266. package/dist/es/utils/hooks/useDynamicPosition.js +93 -0
  267. package/dist/es/utils/hooks/useWindowSize.js +27 -0
  268. package/dist/es/utils/index.js +1 -0
  269. package/dist/es/utils/relay/EnvironmentProvider.js +11 -0
  270. package/dist/es/utils/relay/environment.js +3 -0
  271. package/dist/es/utils/relay/index.js +4 -0
  272. package/dist/es/utils/relay/mockRelayOperation.js +9 -0
  273. package/dist/es/utils/relay/mockResolvers.js +275 -0
  274. package/package.json +18 -4
  275. package/relay.config.js +12 -0
  276. package/schema.graphql +4075 -0
  277. package/scripts/fetchSchema.js +74 -0
  278. package/src/__snapshots__/Storyshots.test.js.snap +13491 -7157
  279. package/src/local.scss +4 -2
  280. package/src/stories/StyleGuide/Sprites.stories.mdx +25 -0
  281. package/src/stories/StyleGuide/helpers.js +16 -0
  282. package/src/stories/a/Alert.stories.jsx +75 -0
  283. package/src/stories/a/{SiteContext.stories.jsx → AppContext.stories.jsx} +8 -8
  284. package/src/stories/a/BackgroundGradient.stories.jsx +38 -0
  285. package/src/stories/a/ContentTree.stories.jsx +662 -0
  286. package/src/stories/a/Conversation.stories.jsx +78 -1
  287. package/src/stories/a/DotInfo.stories.jsx +14 -13
  288. package/src/stories/a/Label.stories.jsx +49 -0
  289. package/src/stories/a/OvalIllustration.stories.jsx +39 -16
  290. package/src/stories/a/Popover.stories.jsx +106 -0
  291. package/src/stories/a/ProgressBar.stories.jsx +16 -7
  292. package/src/stories/a/Shapes.stories.jsx +18 -0
  293. package/src/stories/a/SnapScroller.stories.jsx +98 -0
  294. package/src/stories/a/Timestamp.stories.jsx +35 -39
  295. package/src/stories/b/Button.stories.jsx +27 -4
  296. package/src/stories/b/Logo.stories.jsx +23 -14
  297. package/src/stories/b/Page.stories.jsx +25 -1
  298. package/src/stories/b/QuestionDropdown.stories.jsx +20 -30
  299. package/src/stories/b/SocialMediaButton.stories.jsx +36 -53
  300. package/src/stories/b/ThemeSelector.stories.jsx +5 -5
  301. package/src/stories/b/Title.stories.jsx +13 -15
  302. package/src/stories/c/ContentSlides.stories.jsx +35 -151
  303. package/src/stories/c/Modal.stories.jsx +66 -0
  304. package/src/stories/c/Shortener.stories.jsx +9 -3
  305. package/src/stories/c/SocialMediaShareButton.stories.jsx +33 -0
  306. package/src/stories/f/Checkbox.stories.jsx +95 -0
  307. package/src/stories/f/ChoicesInput.stories.jsx +100 -128
  308. package/src/stories/f/Description.stories.jsx +22 -4
  309. package/src/stories/f/FormInput.stories.jsx +264 -0
  310. package/src/stories/f/Label.stories.jsx +8 -3
  311. package/src/stories/f/QueryCombobox.stories.jsx +279 -0
  312. package/src/stories/f/QuerySelect.stories.jsx +142 -0
  313. package/src/stories/f/RatingsInput.stories.jsx +36 -22
  314. package/src/stories/f/SelectInput.stories.jsx +48 -49
  315. package/src/stories/f/TextInput.stories.jsx +70 -43
  316. package/src/stories/f/TextareaInput.stories.jsx +70 -19
  317. package/src/stories/f/__generated__/FormInputAllTaskStatusesQuery.graphql.js +122 -0
  318. package/src/stories/f/__generated__/FormInputAllTeamsQuery.graphql.js +139 -0
  319. package/src/stories/f/__generated__/QueryComboboxAllTeamsQuery.graphql.js +139 -0
  320. package/src/stories/f/__generated__/QuerySelectAllTaskStatusesQuery.graphql.js +122 -0
  321. package/src/stories/test/QueryLoader.stories.jsx +36 -0
  322. package/src/stories/utils/generateNodeId.js +12 -0
  323. package/src/stories/utils/lorem.js +15 -0
  324. package/src/stories/utils/relay/EnvironmentProvider.jsx +14 -0
  325. package/src/stories/utils/relay/environment.js +5 -0
  326. package/src/stories/utils/relay/index.js +4 -0
  327. package/src/stories/utils/relay/mockRelayOperation.js +14 -0
  328. package/src/stories/utils/relay/mockResolvers.js +299 -0
  329. package/src/stories/utils/testData.js +63 -0
  330. package/src/ui/a/Alert/Alert.jsx +144 -0
  331. package/src/ui/a/Alert/index.js +2 -0
  332. package/src/ui/a/Alert/styles.scss +74 -0
  333. package/src/ui/a/{SiteContext → AppContext}/Context.js +0 -0
  334. package/src/ui/a/{SiteContext → AppContext}/ContextProvider.jsx +8 -7
  335. package/src/ui/a/AppContext/index.js +5 -0
  336. package/src/ui/a/{SiteContext/useSite.js → AppContext/useApp.js} +0 -0
  337. package/src/ui/a/{SiteContext → AppContext}/useTheme.js +0 -0
  338. package/src/ui/a/BackgroundGradient/BackgroundGradient.jsx +76 -0
  339. package/src/ui/a/BackgroundGradient/index.js +2 -0
  340. package/src/ui/a/BackgroundGradient/styles.scss +16 -0
  341. package/src/ui/a/ContentTree/ContentTree.jsx +88 -0
  342. package/src/ui/a/ContentTree/common/Tree/Tree.jsx +138 -0
  343. package/src/ui/a/ContentTree/common/Tree/index.js +2 -0
  344. package/src/ui/a/ContentTree/common/index.js +3 -0
  345. package/src/ui/a/ContentTree/common/useContentTree.js +83 -0
  346. package/src/ui/a/ContentTree/common/useFirstVisibleNode.js +59 -0
  347. package/src/ui/a/ContentTree/index.js +2 -0
  348. package/src/ui/a/ContentTree/styles.scss +33 -0
  349. package/src/ui/a/Conversation/Conversation.jsx +15 -7
  350. package/src/ui/a/Conversation/common/Message/Message.jsx +38 -6
  351. package/src/ui/a/Conversation/styles.scss +132 -33
  352. package/src/ui/a/Label/Label.jsx +93 -0
  353. package/src/ui/a/Label/index.js +2 -0
  354. package/src/ui/a/Label/styles.scss +34 -0
  355. package/src/ui/a/OvalIllustration/OvalIllustration.jsx +28 -2
  356. package/src/ui/a/OvalIllustration/styles.scss +13 -16
  357. package/src/ui/a/Popover/Popover.jsx +157 -0
  358. package/src/ui/a/Popover/index.js +2 -0
  359. package/src/ui/a/Popover/styles.scss +33 -0
  360. package/src/ui/a/Shapes/Shapes.jsx +10 -0
  361. package/src/ui/a/Shapes/styles.scss +42 -9
  362. package/src/ui/a/SnapScroller/SnapScroller.jsx +83 -0
  363. package/src/ui/a/SnapScroller/index.js +2 -0
  364. package/src/ui/a/SnapScroller/styles.scss +38 -0
  365. package/src/ui/a/index.js +10 -4
  366. package/src/ui/b/Button/Button.jsx +9 -1
  367. package/src/ui/b/Button/styles.scss +55 -10
  368. package/src/ui/b/Logo/Logo.jsx +41 -41
  369. package/src/ui/b/Logo/styles.scss +0 -138
  370. package/src/ui/b/Page/common/PageHelmet/PageHelmet.jsx +2 -2
  371. package/src/ui/b/Page/common/Section/Section.jsx +19 -2
  372. package/src/ui/b/SocialMediaButton/SocialMediaButton.jsx +4 -4
  373. package/src/ui/b/ThemeSelector/ThemeSelector.jsx +2 -2
  374. package/src/ui/c/ContentSlides/common/HorizontalMenu/HorizontalMenu.jsx +12 -5
  375. package/src/ui/c/ContentSlides/common/Navigator/Navigator.jsx +3 -2
  376. package/src/ui/c/ContentSlides/styles.scss +10 -4
  377. package/src/ui/{f/fields/RadioInput/RadioInput.jsx → c/Modal/Modal.jsx} +34 -34
  378. package/src/ui/c/Modal/common/ModalHeader/ModalHeader.jsx +89 -0
  379. package/src/ui/c/Modal/common/ModalHeader/index.js +1 -0
  380. package/src/ui/c/Modal/common/index.js +1 -0
  381. package/src/ui/c/Modal/index.js +2 -0
  382. package/src/ui/c/Modal/styles.scss +46 -0
  383. package/src/ui/c/SocialMediaShareButton/SocialMediaShareButton.jsx +121 -0
  384. package/src/ui/c/SocialMediaShareButton/index.js +2 -0
  385. package/src/ui/c/SocialMediaShareButton/styles.scss +39 -0
  386. package/src/ui/c/index.js +2 -0
  387. package/src/ui/f/FormInput/FormInput.jsx +50 -1
  388. package/src/ui/f/FormInput/styles.scss +11 -0
  389. package/src/ui/f/common/Debugger/Debugger.jsx +1 -1
  390. package/src/ui/f/common/Description/Description.jsx +34 -29
  391. package/src/ui/f/common/Label/Label.jsx +10 -4
  392. package/src/ui/f/common/Label/styles.scss +2 -5
  393. package/src/ui/f/fields/{CheckboxInput/CheckboxInput.jsx → Checkbox/Checkbox.jsx} +43 -32
  394. package/src/ui/f/fields/Checkbox/index.js +2 -0
  395. package/src/ui/f/fields/Checkbox/styles.scss +14 -0
  396. package/src/ui/f/fields/ChoicesInput/ChoicesInput.jsx +9 -3
  397. package/src/ui/f/fields/ChoicesInput/common/Choice/Choice.jsx +10 -2
  398. package/src/ui/f/fields/ChoicesInput/styles.scss +17 -2
  399. package/src/ui/f/fields/QueryCombobox/QueryCombobox.jsx +240 -0
  400. package/src/ui/f/fields/QueryCombobox/common/Combobox/Combobox.jsx +241 -0
  401. package/src/ui/f/fields/QueryCombobox/common/Combobox/index.js +2 -0
  402. package/src/ui/f/fields/QueryCombobox/common/Menu/Menu.jsx +103 -0
  403. package/src/ui/f/fields/QueryCombobox/common/Menu/index.js +2 -0
  404. package/src/ui/f/fields/QueryCombobox/common/MultipleCombobox/MultipleCombobox.jsx +340 -0
  405. package/src/ui/f/fields/QueryCombobox/common/MultipleCombobox/index.js +2 -0
  406. package/src/ui/f/fields/QueryCombobox/common/index.js +3 -0
  407. package/src/ui/f/fields/QueryCombobox/index.js +2 -0
  408. package/src/ui/f/fields/QueryCombobox/styles.scss +91 -0
  409. package/src/ui/f/fields/QuerySelect/QuerySelect.jsx +213 -0
  410. package/src/ui/f/fields/QuerySelect/index.js +2 -0
  411. package/src/ui/f/fields/RatingsInput/RatingsInput.jsx +54 -19
  412. package/src/ui/f/fields/RatingsInput/common/Rating/Rating.jsx +7 -1
  413. package/src/ui/f/fields/RatingsInput/styles.scss +29 -20
  414. package/src/ui/f/fields/SelectInput/SelectInput.jsx +72 -8
  415. package/src/ui/f/fields/SelectInput/styles.scss +33 -13
  416. package/src/ui/f/fields/TextInput/TextInput.jsx +44 -10
  417. package/src/ui/f/fields/TextInput/styles.scss +16 -7
  418. package/src/ui/f/fields/TextareaInput/TextareaInput.jsx +49 -21
  419. package/src/ui/f/fields/TextareaInput/styles.scss +19 -6
  420. package/src/ui/f/fields/index.js +3 -3
  421. package/src/ui/form-reset.scss +1 -1
  422. package/src/ui/index.js +2 -0
  423. package/src/ui/test/QueryLoader/QueryLoader.jsx +41 -0
  424. package/src/ui/test/QueryLoader/__generated__/QueryLoaderHelloQuery.graphql.js +68 -0
  425. package/src/ui/test/QueryLoader/common/PreloadedTestData/PreloadedTestData.jsx +51 -0
  426. package/src/ui/test/QueryLoader/common/PreloadedTestData/index.js +2 -0
  427. package/src/ui/test/QueryLoader/common/index.js +1 -0
  428. package/src/ui/test/QueryLoader/index.js +2 -0
  429. package/src/ui/test/index.js +1 -0
  430. package/src/ui/utils/hooks/index.js +2 -0
  431. package/src/ui/utils/hooks/useDynamicPosition.js +104 -0
  432. package/src/ui/utils/hooks/useWindowSize.js +32 -0
  433. package/src/ui/utils/index.js +1 -0
  434. package/stylelint.config.js +13 -13
  435. package/dist/cjs/a/GradientBackground/index.js +0 -15
  436. package/dist/cjs/a/GradientBackground/styles.scss +0 -191
  437. package/dist/cjs/c/AcceptCookies/styles.scss +0 -49
  438. package/dist/cjs/c/BlogCategoryButton/index.js +0 -15
  439. package/dist/cjs/c/BlogPost/BlogPost.js +0 -147
  440. package/dist/cjs/c/BlogPost/styles.scss +0 -33
  441. package/dist/cjs/c/BlogPostsList/common/Card/Card.js +0 -170
  442. package/dist/cjs/c/BlogPostsList/index.js +0 -15
  443. package/dist/cjs/c/BlogPostsList/styles.scss +0 -72
  444. package/dist/cjs/c/SiteFooter/styles.scss +0 -34
  445. package/dist/cjs/c/SiteHeaderCTA/index.js +0 -15
  446. package/dist/cjs/c/SiteHeaderCTA/styles.scss +0 -44
  447. package/dist/cjs/c/SiteMission/styles.scss +0 -30
  448. package/dist/cjs/c/SiteNavigation/SiteNavigation.js +0 -130
  449. package/dist/cjs/c/SiteNavigation/index.js +0 -15
  450. package/dist/cjs/c/SiteNavigation/styles.scss +0 -118
  451. package/dist/cjs/c/SiteOnboardingStep/index.js +0 -15
  452. package/dist/cjs/c/SiteOnboardingStep/styles.scss +0 -51
  453. package/dist/cjs/c/SitePricing/SitePricing.js +0 -108
  454. package/dist/cjs/c/SitePricing/styles.scss +0 -73
  455. package/dist/cjs/c/SiteServices/SiteServices.js +0 -211
  456. package/dist/cjs/c/SiteServices/index.js +0 -15
  457. package/dist/cjs/c/SiteServices/styles.scss +0 -138
  458. package/dist/cjs/c/TeamGallery/common/PersonCard/index.js +0 -15
  459. package/dist/cjs/c/TeamGallery/styles.scss +0 -100
  460. package/dist/cjs/c/Testimonials/Testimonials.js +0 -119
  461. package/dist/cjs/c/Testimonials/index.js +0 -15
  462. package/dist/cjs/c/Testimonials/styles.scss +0 -112
  463. package/dist/cjs/experimental/GradientBackground/index.js +0 -15
  464. package/dist/cjs/experimental/GradientBackground/styles.scss +0 -64
  465. package/dist/cjs/experimental/index.js +0 -13
  466. package/dist/cjs/f/fields/TaskRecommendation/index.js +0 -15
  467. package/dist/cjs/f/fields/TaskRecommendation/styles.scss +0 -37
  468. package/dist/cjs/f/fields/TextArea/TextArea.js +0 -141
  469. package/dist/cjs/f/fields/TextArea/styles.scss +0 -19
  470. package/dist/es/a/GradientBackground/GradientBackground.js +0 -118
  471. package/dist/es/a/GradientBackground/index.js +0 -2
  472. package/dist/es/a/GradientBackground/styles.scss +0 -191
  473. package/dist/es/c/AcceptCookies/AcceptCookies.js +0 -117
  474. package/dist/es/c/AcceptCookies/index.js +0 -2
  475. package/dist/es/c/AcceptCookies/styles.scss +0 -49
  476. package/dist/es/c/BlogCategoryButton/BlogCategoryButton.js +0 -68
  477. package/dist/es/c/BlogCategoryButton/index.js +0 -2
  478. package/dist/es/c/BlogContext/BlogContextProvider.js +0 -45
  479. package/dist/es/c/BlogContext/ContextProvider.js +0 -45
  480. package/dist/es/c/BlogContext/index.js +0 -4
  481. package/dist/es/c/BlogPost/BlogPost.js +0 -128
  482. package/dist/es/c/BlogPost/styles.scss +0 -33
  483. package/dist/es/c/BlogPostsList/common/Card/Card.js +0 -143
  484. package/dist/es/c/BlogPostsList/common/index.js +0 -1
  485. package/dist/es/c/BlogPostsList/index.js +0 -2
  486. package/dist/es/c/BlogPostsList/styles.scss +0 -72
  487. package/dist/es/c/SiteFooter/common/Section/Section.js +0 -73
  488. package/dist/es/c/SiteFooter/common/index.js +0 -1
  489. package/dist/es/c/SiteFooter/index.js +0 -2
  490. package/dist/es/c/SiteFooter/styles.scss +0 -34
  491. package/dist/es/c/SiteHeaderCTA/SiteHeaderCTA.js +0 -92
  492. package/dist/es/c/SiteHeaderCTA/index.js +0 -2
  493. package/dist/es/c/SiteHeaderCTA/styles.scss +0 -44
  494. package/dist/es/c/SiteMission/SiteMission.js +0 -96
  495. package/dist/es/c/SiteMission/index.js +0 -2
  496. package/dist/es/c/SiteMission/styles.scss +0 -30
  497. package/dist/es/c/SiteNavigation/SiteNavigation.js +0 -111
  498. package/dist/es/c/SiteNavigation/index.js +0 -2
  499. package/dist/es/c/SiteNavigation/styles.scss +0 -118
  500. package/dist/es/c/SiteOnboardingStep/SiteOnboardingStep.js +0 -81
  501. package/dist/es/c/SiteOnboardingStep/index.js +0 -2
  502. package/dist/es/c/SiteOnboardingStep/styles.scss +0 -51
  503. package/dist/es/c/SitePricing/SitePricing.js +0 -91
  504. package/dist/es/c/SitePricing/index.js +0 -2
  505. package/dist/es/c/SitePricing/styles.scss +0 -73
  506. package/dist/es/c/SiteServices/SiteServices.js +0 -195
  507. package/dist/es/c/SiteServices/index.js +0 -2
  508. package/dist/es/c/SiteServices/styles.scss +0 -138
  509. package/dist/es/c/TeamGallery/common/PersonCard/PersonCard.js +0 -64
  510. package/dist/es/c/TeamGallery/common/PersonCard/index.js +0 -2
  511. package/dist/es/c/TeamGallery/common/index.js +0 -1
  512. package/dist/es/c/TeamGallery/index.js +0 -2
  513. package/dist/es/c/TeamGallery/styles.scss +0 -100
  514. package/dist/es/c/Testimonials/Testimonials.js +0 -99
  515. package/dist/es/c/Testimonials/index.js +0 -2
  516. package/dist/es/c/Testimonials/styles.scss +0 -112
  517. package/dist/es/experimental/GradientBackground/GradientBackground.js +0 -76
  518. package/dist/es/experimental/GradientBackground/index.js +0 -2
  519. package/dist/es/experimental/GradientBackground/styles.scss +0 -64
  520. package/dist/es/experimental/index.js +0 -1
  521. package/dist/es/f/fields/TaskRecommendation/TaskRecommendation.js +0 -111
  522. package/dist/es/f/fields/TaskRecommendation/index.js +0 -2
  523. package/dist/es/f/fields/TaskRecommendation/styles.scss +0 -37
  524. package/dist/es/f/fields/TextArea/TextArea.js +0 -124
  525. package/dist/es/f/fields/TextArea/styles.scss +0 -19
  526. package/src/stories/f/CheckboxInput.stories.jsx +0 -37
  527. package/src/stories/f/RadioInput.stories.jsx +0 -37
  528. package/src/stories/f/TaskRecommendationInput.stories.jsx +0 -38
  529. package/src/ui/a/SiteContext/index.js +0 -5
  530. package/src/ui/f/fields/CheckboxInput/index.js +0 -2
  531. package/src/ui/f/fields/CheckboxInput/styles.scss +0 -28
  532. package/src/ui/f/fields/RadioInput/index.js +0 -2
  533. package/src/ui/f/fields/RadioInput/styles.scss +0 -26
  534. package/src/ui/f/fields/TaskRecommendationInput/TaskRecommendationInput.jsx +0 -130
  535. package/src/ui/f/fields/TaskRecommendationInput/index.js +0 -2
  536. package/src/ui/f/fields/TaskRecommendationInput/styles.scss +0 -41
@@ -0,0 +1,195 @@
1
+ /* @pareto-engineering/generator-front 1.0.12 */
2
+ import * as React from 'react';
3
+ import { useState, useEffect } from 'react';
4
+ import { useRelayEnvironment, fetchQuery } from 'react-relay';
5
+ import { useField } from 'formik';
6
+ import PropTypes from 'prop-types'; // Local Definitions
7
+
8
+ import { SelectInput } from "../..";
9
+ /**
10
+ * This is the component description.
11
+ */
12
+
13
+ const QuerySelect = ({
14
+ id,
15
+ className: userClassName,
16
+ style,
17
+ name,
18
+ label,
19
+ optional,
20
+ query,
21
+ variables,
22
+ optionsKeyMap,
23
+ description,
24
+ disabled,
25
+ color,
26
+ loadingOption,
27
+ defaultOption,
28
+ validate // ...otherProps
29
+
30
+ }) => {
31
+ const [,, helpers] = useField({
32
+ name,
33
+ validate
34
+ });
35
+ const {
36
+ setError
37
+ } = helpers;
38
+ const environment = useRelayEnvironment();
39
+ const [isFetching, setIsFetching] = useState(false);
40
+ const [options, setOptions] = useState([]);
41
+ const {
42
+ graphql,
43
+ accessor
44
+ } = query;
45
+
46
+ const getOptions = () => {
47
+ if (isFetching) return;
48
+ fetchQuery(environment, graphql, variables).subscribe({
49
+ start: () => {
50
+ setIsFetching(true);
51
+ setOptions([loadingOption]);
52
+ },
53
+ complete: () => {
54
+ setIsFetching(false);
55
+ },
56
+ error: fetchError => {
57
+ setIsFetching(false);
58
+ if (setError) setError(fetchError.message);
59
+ },
60
+ next: data => {
61
+ setOptions([defaultOption, ...data[accessor].edges.map(({
62
+ node
63
+ }) => ({
64
+ value: node[optionsKeyMap.value],
65
+ label: optionsKeyMap.getLabel(node)
66
+ }))]);
67
+ }
68
+ });
69
+ };
70
+
71
+ useEffect(() => {
72
+ getOptions();
73
+ }, [variables]);
74
+ return /*#__PURE__*/React.createElement(SelectInput, {
75
+ id: id,
76
+ className: userClassName,
77
+ style: style,
78
+ name: name,
79
+ label: label,
80
+ optional: optional,
81
+ color: color,
82
+ description: description,
83
+ disabled: isFetching || disabled,
84
+ options: options,
85
+ isLoading: isFetching
86
+ });
87
+ };
88
+
89
+ QuerySelect.propTypes = {
90
+ /**
91
+ * The HTML id for this element
92
+ */
93
+ id: PropTypes.string,
94
+
95
+ /**
96
+ * The HTML class names for this element
97
+ */
98
+ className: PropTypes.string,
99
+
100
+ /**
101
+ * The React-written, css properties for this element.
102
+ */
103
+ style: PropTypes.objectOf(PropTypes.string),
104
+
105
+ /**
106
+ * The name of the custom select input
107
+ */
108
+ name: PropTypes.string,
109
+
110
+ /**
111
+ * The label of the custom select input
112
+ */
113
+ label: PropTypes.string,
114
+
115
+ /**
116
+ * The custom select input description
117
+ */
118
+ description: PropTypes.string,
119
+
120
+ /**
121
+ * Whether the input should be disabled
122
+ */
123
+ disabled: PropTypes.bool,
124
+
125
+ /**
126
+ * The base color of the custom select input
127
+ */
128
+ color: PropTypes.string,
129
+
130
+ /**
131
+ * The graphql query to fetch the options and the accessor to destructure the results from
132
+ */
133
+ query: PropTypes.shape({
134
+ accessor: PropTypes.string,
135
+ graphql: PropTypes.oneOfType([PropTypes.string, PropTypes.object]).isRequired
136
+ }),
137
+
138
+ /**
139
+ * The variables that might be required to be used in the query to fetch
140
+ * select options.
141
+ */
142
+ variables: PropTypes.objectOf(PropTypes.string),
143
+
144
+ /**
145
+ * The select option keys to be used to map the data to the select options.
146
+ * i.e `{ value: 'id', label: 'name' }`
147
+ */
148
+ optionsKeyMap: PropTypes.shape({
149
+ value: PropTypes.string.isRequired,
150
+ getLabel: PropTypes.func.isRequired
151
+ }).isRequired,
152
+
153
+ /**
154
+ * The default select option for the query select
155
+ */
156
+ defaultOption: PropTypes.shape({
157
+ value: PropTypes.string.isRequired,
158
+ label: PropTypes.string.isRequired,
159
+ disabled: PropTypes.bool.isRequired
160
+ }),
161
+
162
+ /**
163
+ * The option to dipslayed when the select options are being fetched
164
+ */
165
+ loadingOption: PropTypes.shape({
166
+ value: PropTypes.string.isRequired,
167
+ label: PropTypes.string.isRequired,
168
+ disabled: PropTypes.bool.isRequired
169
+ }),
170
+
171
+ /**
172
+ * The query select field validator function
173
+ */
174
+ validate: PropTypes.func,
175
+
176
+ /*
177
+ * Whether the input is optional or not
178
+ */
179
+ optional: PropTypes.bool
180
+ };
181
+ QuerySelect.defaultProps = {
182
+ disabled: false,
183
+ color: 'background2',
184
+ defaultOption: {
185
+ value: '',
186
+ label: 'Select an option',
187
+ disabled: true
188
+ },
189
+ loadingOption: {
190
+ value: '',
191
+ label: 'Fetching Options',
192
+ disabled: true
193
+ }
194
+ };
195
+ export default QuerySelect;
@@ -0,0 +1,2 @@
1
+ /* @pareto-engineering/generator-front 1.0.12 */
2
+ export { default as QuerySelect } from "./QuerySelect";
@@ -5,6 +5,7 @@ import PropTypes from 'prop-types';
5
5
  import styleNames from '@pareto-engineering/bem'; // Local Definitions
6
6
 
7
7
  import { Rating } from "./common";
8
+ import { FormLabel } from "../../common";
8
9
  const baseClassName = styleNames.base;
9
10
  const componentClassName = 'ratings-input';
10
11
  /**
@@ -18,9 +19,13 @@ const RatingsInput = ({
18
19
  name,
19
20
  ratingCount,
20
21
  showRatingValue,
22
+ oneInputLabel,
23
+ label,
24
+ labelColor,
21
25
  labelMax,
22
26
  labelMin,
23
- displayRatingsLabel // ...otherProps
27
+ displayRatingsLabel,
28
+ optional // ...otherProps
24
29
 
25
30
  }) => {
26
31
  useLayoutEffect(() => {
@@ -30,8 +35,14 @@ const RatingsInput = ({
30
35
  return /*#__PURE__*/React.createElement("div", {
31
36
  id: id,
32
37
  className: [baseClassName, componentClassName, userClassName].filter(e => e).join(' '),
33
- style: style // {...otherProps}
34
-
38
+ style: style
39
+ }, /*#__PURE__*/React.createElement(FormLabel, {
40
+ className: ['input-label', oneInputLabel ? 'md-s2 s0 v1 mb-v' : 'v50 mb-v'].filter(e => e).join(' '),
41
+ name: name,
42
+ color: labelColor,
43
+ optional: optional
44
+ }, label), /*#__PURE__*/React.createElement("div", {
45
+ className: "stars"
35
46
  }, displayRatingsLabel && /*#__PURE__*/React.createElement("p", {
36
47
  className: "label-text md-s-1 s-2 x-metadata c-x"
37
48
  }, labelMin), [...Array(ratingCount)].map((_, index) => {
@@ -47,7 +58,7 @@ const RatingsInput = ({
47
58
  });
48
59
  }), displayRatingsLabel && /*#__PURE__*/React.createElement("p", {
49
60
  className: "label-text md-s-1 s-2 x-metadata c-x"
50
- }, labelMax));
61
+ }, labelMax)));
51
62
  };
52
63
 
53
64
  RatingsInput.propTypes = {
@@ -81,6 +92,11 @@ RatingsInput.propTypes = {
81
92
  */
82
93
  showRatingValue: PropTypes.bool,
83
94
 
95
+ /**
96
+ * The label of the ratings input
97
+ */
98
+ label: PropTypes.string.isRequired,
99
+
84
100
  /**
85
101
  * description for the highest rating value
86
102
  */
@@ -94,10 +110,26 @@ RatingsInput.propTypes = {
94
110
  /**
95
111
  * If the rating lables should be shown
96
112
  */
97
- displayRatingsLabel: PropTypes.bool
113
+ displayRatingsLabel: PropTypes.bool,
114
+
115
+ /**
116
+ * Whether the input is optional or not
117
+ */
118
+ optional: PropTypes.bool,
119
+
120
+ /**
121
+ * If the slide will only have one input
122
+ */
123
+ oneInputLabel: PropTypes.bool,
124
+
125
+ /**
126
+ * String that will represent color for the label
127
+ */
128
+ labelColor: PropTypes.string
98
129
  };
99
130
  RatingsInput.defaultProps = {
100
131
  labelMin: 'not satisfied.',
101
- labelMax: 'very satisfied.'
132
+ labelMax: 'very satisfied.',
133
+ labelColor: 'main2'
102
134
  };
103
135
  export default /*#__PURE__*/memo(RatingsInput);
@@ -21,12 +21,16 @@ const Rating = ({
21
21
  ratingId,
22
22
  hover,
23
23
  setHover,
24
+ validate,
24
25
  activeBackgroundColor,
25
26
  inactiveBackgroundColor,
26
27
  showRatingValue // ...otherProps
27
28
 
28
29
  }) => {
29
- const [field] = useField(name);
30
+ const [field] = useField({
31
+ name,
32
+ validate
33
+ });
30
34
  return /*#__PURE__*/React.createElement("div", {
31
35
  id: id,
32
36
  className: [baseClassName, componentClassName, userClassName, `x-${activeBackgroundColor}`, `y-${inactiveBackgroundColor}`].filter(e => e).join(' '),
@@ -101,7 +105,12 @@ Rating.propTypes = {
101
105
  /**
102
106
  * Determines if the rating start value should be shown
103
107
  */
104
- showRatingValue: PropTypes.bool
108
+ showRatingValue: PropTypes.bool,
109
+
110
+ /**
111
+ * The rating field validator function
112
+ */
113
+ validate: PropTypes.func
105
114
  };
106
115
  Rating.defaultProps = {
107
116
  activeBackgroundColor: 'main1',
@@ -7,34 +7,43 @@ $default-transition: all .2s;
7
7
 
8
8
  .#{bem.$base}.ratings-input {
9
9
  display: flex;
10
+ flex-direction: column;
10
11
 
11
- >:not(:last-child) {
12
- margin-right: $default-rating-icon-margin;
12
+ p {
13
+ padding: $default-padding;
13
14
  }
14
15
 
15
- .#{bem.$base}.rating {
16
+ .stars {
16
17
  display: flex;
17
18
 
18
- input {
19
- opacity: 0;
20
- position: absolute;
21
- visibility: none;
22
- z-index: -1;
19
+ >:not(:last-child) {
20
+ margin-right: $default-rating-icon-margin;
23
21
  }
24
-
25
- label {
22
+
23
+ .#{bem.$base}.rating {
26
24
  display: flex;
27
- flex-direction: column;
28
- align-items: center;
29
- padding: $default-padding;
30
- transition: $default-transition;
31
- cursor: pointer;
25
+
26
+ input {
27
+ opacity: 0;
28
+ position: absolute;
29
+ visibility: none;
30
+ z-index: -1;
31
+ }
32
+
33
+ label {
34
+ display: flex;
35
+ flex-direction: column;
36
+ align-items: center;
37
+ padding: $default-padding;
38
+ transition: $default-transition;
39
+ cursor: pointer;
40
+ }
41
+ }
42
+
43
+ .label-text {
44
+ margin-bottom: 0;
45
+ align-self: flex-end;
32
46
  }
33
- }
34
-
35
- .label-text {
36
- margin-bottom: 0;
37
- align-self: flex-end;
38
47
  }
39
48
  }
40
49
 
@@ -6,6 +6,7 @@ import { useLayoutEffect, memo } from 'react';
6
6
  import { useField } from 'formik';
7
7
  import PropTypes from 'prop-types';
8
8
  import styleNames from '@pareto-engineering/bem';
9
+ import { LoadingCircle } from "../../../a";
9
10
  import { FormLabel, FormDescription } from "../../common"; // Local Definitions
10
11
 
11
12
  const baseClassName = styleNames.base;
@@ -20,27 +21,40 @@ const SelectInput = ({
20
21
  style,
21
22
  name,
22
23
  label,
24
+ color,
23
25
  options,
24
- disabled // ...otherProps
26
+ validate,
27
+ optional,
28
+ description,
29
+ disabled,
30
+ isLoading,
31
+ autoComplete // ...otherProps
25
32
 
26
33
  }) => {
27
34
  useLayoutEffect(() => {
28
35
  import("./styles.scss");
29
36
  }, []);
30
- const [field, meta] = useField(name);
37
+ const [field] = useField({
38
+ name,
39
+ validate
40
+ });
31
41
  return /*#__PURE__*/React.createElement("div", {
32
42
  id: id,
33
- className: [baseClassName, componentClassName, userClassName].filter(e => e).join(' '),
43
+ className: [baseClassName, componentClassName, userClassName, `y-${color}`].filter(e => e).join(' '),
34
44
  style: style // {...otherProps}
35
45
 
36
46
  }, /*#__PURE__*/React.createElement(FormLabel, {
37
- className: "input-label",
38
- name: name
39
- }, label), /*#__PURE__*/React.createElement("select", _extends({
40
- className: "input v25 pv-v"
47
+ name: name,
48
+ optional: optional
49
+ }, label), /*#__PURE__*/React.createElement("div", {
50
+ className: "select-wrapper"
51
+ }, /*#__PURE__*/React.createElement("select", _extends({
52
+ className: "input"
41
53
  }, field, {
54
+ value: field.value || '',
42
55
  id: name,
43
- disabled: disabled
56
+ disabled: disabled,
57
+ autoComplete: autoComplete
44
58
  }), options.map(option => {
45
59
  // i.e if option is a string like "blah", return { value: "blah", label: "blah" }
46
60
  const newOption = typeof option === 'string' ? {
@@ -49,11 +63,16 @@ const SelectInput = ({
49
63
  } : option;
50
64
  return /*#__PURE__*/React.createElement("option", {
51
65
  key: newOption.value,
52
- value: newOption.value
66
+ value: newOption.value,
67
+ disabled: (newOption === null || newOption === void 0 ? void 0 : newOption.disabled) || false
53
68
  }, newOption.label);
54
- })), meta.error && meta.touched && /*#__PURE__*/React.createElement(FormDescription, {
55
- error: true
56
- }, meta.error));
69
+ })), isLoading && /*#__PURE__*/React.createElement(LoadingCircle, {
70
+ className: "x-main2"
71
+ })), /*#__PURE__*/React.createElement(FormDescription, {
72
+ className: "v50 mt-v s-1",
73
+ description: description,
74
+ name: name
75
+ }));
57
76
  };
58
77
 
59
78
  SelectInput.propTypes = {
@@ -82,20 +101,52 @@ SelectInput.propTypes = {
82
101
  */
83
102
  label: PropTypes.string,
84
103
 
104
+ /**
105
+ * The input field validator function
106
+ */
107
+ validate: PropTypes.func,
108
+
109
+ /**
110
+ * The select input description
111
+ */
112
+ description: PropTypes.string,
113
+
85
114
  /**
86
115
  * The options of the select input
87
116
  */
88
117
  options: PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.string, PropTypes.shape({
89
118
  value: PropTypes.string,
90
- label: PropTypes.string
119
+ label: PropTypes.string,
120
+ disabled: PropTypes.bool
91
121
  })])),
92
122
 
93
123
  /**
94
124
  * Whether the select input should be disabled
95
125
  */
96
- disabled: PropTypes.bool
126
+ disabled: PropTypes.bool,
127
+
128
+ /**
129
+ * The color of the select input
130
+ */
131
+ color: PropTypes.string,
132
+
133
+ /*
134
+ * Whether the query that is fetching the select options is still in flight
135
+ */
136
+ isLoading: PropTypes.bool,
137
+
138
+ /**
139
+ * The autoComplete value that the browser should watch for the input
140
+ */
141
+ autoComplete: PropTypes.string,
142
+
143
+ /**
144
+ * Whether the input is optional or not
145
+ */
146
+ optional: PropTypes.bool
97
147
  };
98
148
  SelectInput.defaultProps = {
99
- disabled: false
149
+ disabled: false,
150
+ color: 'background2'
100
151
  };
101
152
  export default /*#__PURE__*/memo(SelectInput);
@@ -5,26 +5,46 @@
5
5
  @use "../../../form.scss";
6
6
 
7
7
 
8
- $default-padding: 0.75em 0.75em 0.55em;
9
-
8
+ $default-padding: 0.75em;
9
+ $default-margin: 1em;
10
10
 
11
11
  .#{bem.$base}.select-input {
12
12
  display: flex;
13
13
  flex-direction: column;
14
14
 
15
-
16
- .input-label {
17
- color: var(--main1);
15
+ .#{bem.$base}.label {
16
+ margin-bottom: $default-margin
18
17
  }
19
18
 
20
- .input {
21
- background: var(--light-background1);
22
- color: var(--on-background1);
23
- padding: $default-padding;
19
+ .select-wrapper {
20
+ position: relative;
24
21
 
25
- &:focus {
26
- background: var(--dark-background1);
22
+ >.#{bem.$base}.loading-circle {
23
+ position: absolute;
24
+ right: 0;
25
+ top: 50%;
26
+ transform: translateY(-50%);
27
27
  }
28
- }
29
- }
30
28
 
29
+ >.input {
30
+ width: 100%;
31
+ border: var(--theme-border-style) var(--dark-y);
32
+ background: var(--light-y);
33
+ color: var(--on-y);
34
+ padding: $default-padding;
35
+
36
+ &:not(:disabled):hover {
37
+ border: var(--theme-border-style) var(--light-background4);
38
+ }
39
+
40
+ &:disabled {
41
+ background-color: var(--dark-y);
42
+ appearance: none;
43
+ }
44
+
45
+ &:focus {
46
+ background: var(--y);
47
+ }
48
+ }
49
+ }
50
+ }
@@ -43,7 +43,7 @@ const TaskRecommendationInput = ({
43
43
  }, /*#__PURE__*/React.createElement("div", {
44
44
  className: "v1 p-v task"
45
45
  }, /*#__PURE__*/React.createElement(FormLabel, {
46
- className: `uc mb-v ${isOptionSelected ? styleNames.modifierActive : ''}`,
46
+ className: `uc mb-v ${isOptionSelected ? 'c-on-x' : 'c-x'}`,
47
47
  name: name
48
48
  }, label), /*#__PURE__*/React.createElement("input", _extends({}, field, {
49
49
  value: value,
@@ -106,6 +106,6 @@ TaskRecommendationInput.propTypes = {
106
106
  image: PropTypes.string.isRequired
107
107
  };
108
108
  TaskRecommendationInput.defaultProps = {
109
- color: 'main1'
109
+ color: 'main2'
110
110
  };
111
111
  export default /*#__PURE__*/memo(TaskRecommendationInput);
@@ -16,10 +16,6 @@
16
16
  align-items: center;
17
17
  height: 100%;
18
18
 
19
- .#{bem.$modifier-active} {
20
- color: var(--on-x);
21
- }
22
-
23
19
  .input {
24
20
  appearance: none;
25
21
  position: absolute;