@openedx/paragon 22.6.0 → 23.0.0-alpha.2

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 (564) hide show
  1. package/README.md +61 -21
  2. package/bin/paragon-scripts.js +128 -9
  3. package/dist/ActionRow/_index.scss +2 -4
  4. package/dist/Alert/index.scss +41 -32
  5. package/dist/Annotation/_mixins.scss +104 -0
  6. package/dist/Annotation/index.scss +130 -103
  7. package/dist/Avatar/index.scss +18 -20
  8. package/dist/AvatarButton/index.scss +3 -5
  9. package/dist/Badge/index.scss +112 -2
  10. package/dist/Breadcrumb/index.scss +14 -16
  11. package/dist/Bubble/index.scss +25 -12
  12. package/dist/Button/_mixins.scss +14 -0
  13. package/dist/Button/button-group.scss +126 -0
  14. package/dist/Button/index.js +15 -40
  15. package/dist/Button/index.js.map +1 -1
  16. package/dist/Button/index.scss +855 -372
  17. package/dist/Card/card-bootstrap.scss +168 -0
  18. package/dist/Card/index.scss +78 -79
  19. package/dist/Carousel/index.scss +168 -2
  20. package/dist/Chip/ChipIcon.d.ts +2 -2
  21. package/dist/Chip/ChipIcon.js.map +1 -1
  22. package/dist/Chip/index.d.ts +2 -2
  23. package/dist/Chip/index.js +2 -2
  24. package/dist/Chip/index.js.map +1 -1
  25. package/dist/Chip/index.scss +48 -38
  26. package/dist/Chip/mixins.scss +8 -3
  27. package/dist/ChipCarousel/index.scss +4 -4
  28. package/dist/CloseButton/index.scss +31 -2
  29. package/dist/Code/index.scss +47 -2
  30. package/dist/Collapsible/index.scss +15 -15
  31. package/dist/ColorPicker/index.scss +9 -11
  32. package/dist/DataTable/CollapsibleButtonGroup.js +2 -2
  33. package/dist/DataTable/CollapsibleButtonGroup.js.map +1 -1
  34. package/dist/DataTable/index.scss +48 -50
  35. package/dist/Dropdown/dropdown-bootstrap.scss +181 -0
  36. package/dist/Dropdown/index.js +0 -2
  37. package/dist/Dropdown/index.js.map +1 -1
  38. package/dist/Dropdown/index.scss +11 -12
  39. package/dist/Dropzone/index.scss +12 -14
  40. package/dist/Form/_FormText.scss +8 -8
  41. package/dist/Form/_bootstrap-custom-forms.scss +551 -0
  42. package/dist/Form/_bootstrap-forms.scss +381 -0
  43. package/dist/Form/_index.scss +168 -146
  44. package/dist/Form/_input-group.scss +188 -0
  45. package/dist/Form/_mixins.scss +216 -3
  46. package/dist/Hyperlink/index.js +32 -20
  47. package/dist/Hyperlink/index.js.map +1 -1
  48. package/dist/Hyperlink/index.scss +1 -1
  49. package/dist/Icon/index.d.ts +2 -4
  50. package/dist/Icon/index.js +1 -1
  51. package/dist/Icon/index.js.map +1 -1
  52. package/dist/Icon/index.scss +10 -12
  53. package/dist/IconButton/_mixins.scss +4 -0
  54. package/dist/IconButton/index.js +5 -11
  55. package/dist/IconButton/index.js.map +1 -1
  56. package/dist/IconButton/index.scss +387 -74
  57. package/dist/IconButtonToggle/index.scss +1 -1
  58. package/dist/Image/index.scss +53 -2
  59. package/dist/Menu/index.scss +25 -27
  60. package/dist/Modal/_ModalDialog.scss +52 -54
  61. package/dist/Modal/index.scss +6 -73
  62. package/dist/Nav/_mixins.scss +4 -4
  63. package/dist/Nav/index.scss +70 -66
  64. package/dist/Navbar/index.scss +276 -2
  65. package/dist/OverflowScroll/data/useOverflowScrollElementAttributes.js +3 -3
  66. package/dist/Overlay/index.js +2 -3
  67. package/dist/Overlay/index.js.map +1 -1
  68. package/dist/PageBanner/index.scss +17 -21
  69. package/dist/Pagination/index.scss +32 -34
  70. package/dist/Pagination/pagination-bootstrap.scss +83 -0
  71. package/dist/Popover/index.scss +9 -10
  72. package/dist/Popover/popover-bootstrap.scss +198 -0
  73. package/dist/ProductTour/Checkpoint.scss +71 -43
  74. package/dist/ProgressBar/_mixins.scss +22 -0
  75. package/dist/ProgressBar/bootstrap-progress.scss +49 -0
  76. package/dist/ProgressBar/index.scss +28 -36
  77. package/dist/Scrollable/index.scss +2 -2
  78. package/dist/SearchField/SearchFieldInput.js +2 -2
  79. package/dist/SearchField/SearchFieldInput.js.map +1 -1
  80. package/dist/SearchField/index.scss +15 -17
  81. package/dist/SelectableBox/index.scss +11 -13
  82. package/dist/Sheet/index.scss +10 -10
  83. package/dist/Spinner/index.scss +57 -2
  84. package/dist/Stack/index.scss +1 -3
  85. package/dist/Stepper/index.scss +20 -20
  86. package/dist/Sticky/index.scss +4 -6
  87. package/dist/Tabs/index.js +0 -2
  88. package/dist/Tabs/index.js.map +1 -1
  89. package/dist/Tabs/index.scss +29 -25
  90. package/dist/Toast/ToastContainer.scss +9 -11
  91. package/dist/Toast/bootstrap-toast.scss +46 -0
  92. package/dist/Toast/index.scss +9 -10
  93. package/dist/Tooltip/index.scss +136 -10
  94. package/dist/ValidationMessage/index.scss +1 -1
  95. package/dist/core.css +16777 -0
  96. package/dist/core.css.map +1 -0
  97. package/dist/core.min.css +2 -0
  98. package/dist/index.d.ts +2 -2
  99. package/dist/index.js +4 -18
  100. package/dist/index.scss +0 -4
  101. package/dist/light.css +4098 -0
  102. package/dist/light.css.map +1 -0
  103. package/dist/light.min.css +2 -0
  104. package/dist/theme-urls.json +21 -0
  105. package/dist/utils/breakpoints.js +1 -1
  106. package/lib/build-scss.js +188 -0
  107. package/lib/build-tokens.js +133 -0
  108. package/lib/help.js +36 -23
  109. package/lib/replace-variables.js +38 -0
  110. package/lib/utils.js +30 -0
  111. package/package.json +30 -14
  112. package/src/ActionRow/_index.scss +2 -4
  113. package/src/Alert/index.scss +41 -32
  114. package/src/Annotation/_mixins.scss +104 -0
  115. package/src/Annotation/index.scss +130 -103
  116. package/src/Avatar/index.scss +18 -20
  117. package/src/AvatarButton/index.scss +3 -5
  118. package/src/Badge/index.scss +112 -2
  119. package/src/Breadcrumb/index.scss +14 -16
  120. package/src/Bubble/index.scss +25 -12
  121. package/src/Button/{Button.test.tsx → Button.test.jsx} +2 -14
  122. package/src/Button/README.md +0 -84
  123. package/src/Button/__snapshots__/{Button.test.tsx.snap → Button.test.jsx.snap} +2 -19
  124. package/src/Button/_mixins.scss +14 -0
  125. package/src/Button/button-group.scss +126 -0
  126. package/src/Button/index.jsx +113 -0
  127. package/src/Button/index.scss +855 -372
  128. package/src/Card/card-bootstrap.scss +168 -0
  129. package/src/Card/index.scss +78 -79
  130. package/src/Carousel/index.scss +168 -2
  131. package/src/Chip/ChipIcon.tsx +1 -1
  132. package/src/Chip/index.scss +48 -38
  133. package/src/Chip/index.tsx +5 -5
  134. package/src/Chip/mixins.scss +8 -3
  135. package/src/ChipCarousel/index.scss +4 -4
  136. package/src/CloseButton/index.scss +31 -2
  137. package/src/Code/index.scss +47 -2
  138. package/src/Collapsible/index.scss +15 -15
  139. package/src/ColorPicker/index.scss +9 -11
  140. package/src/DataTable/CollapsibleButtonGroup.jsx +2 -2
  141. package/src/DataTable/index.scss +48 -50
  142. package/src/Dropdown/README.md +0 -93
  143. package/src/Dropdown/dropdown-bootstrap.scss +181 -0
  144. package/src/Dropdown/index.jsx +0 -2
  145. package/src/Dropdown/index.scss +11 -12
  146. package/src/Dropzone/index.scss +12 -14
  147. package/src/Form/_FormText.scss +8 -8
  148. package/src/Form/_bootstrap-custom-forms.scss +551 -0
  149. package/src/Form/_bootstrap-forms.scss +381 -0
  150. package/src/Form/_index.scss +168 -146
  151. package/src/Form/_input-group.scss +188 -0
  152. package/src/Form/_mixins.scss +216 -3
  153. package/src/Hyperlink/{Hyperlink.test.tsx → Hyperlink.test.jsx} +10 -21
  154. package/src/Hyperlink/{index.tsx → index.jsx} +37 -41
  155. package/src/Hyperlink/index.scss +1 -1
  156. package/src/Icon/index.d.ts +2 -4
  157. package/src/Icon/index.jsx +1 -1
  158. package/src/Icon/index.scss +10 -12
  159. package/src/IconButton/README.md +1 -15
  160. package/src/IconButton/__snapshots__/IconButton.test.jsx.snap +5 -28
  161. package/src/IconButton/_mixins.scss +4 -0
  162. package/src/IconButton/index.jsx +6 -13
  163. package/src/IconButton/index.scss +387 -74
  164. package/src/IconButtonToggle/index.scss +1 -1
  165. package/src/Image/index.scss +53 -2
  166. package/src/Menu/index.scss +25 -27
  167. package/src/Modal/_ModalDialog.scss +52 -54
  168. package/src/Modal/index.scss +6 -73
  169. package/src/Nav/_mixins.scss +4 -4
  170. package/src/Nav/index.scss +70 -66
  171. package/src/Navbar/index.scss +276 -2
  172. package/src/OverflowScroll/data/useOverflowScrollElementAttributes.js +3 -3
  173. package/src/Overlay/index.jsx +2 -3
  174. package/src/PageBanner/index.scss +17 -21
  175. package/src/Pagination/index.scss +32 -34
  176. package/src/Pagination/pagination-bootstrap.scss +83 -0
  177. package/src/Popover/index.scss +9 -10
  178. package/src/Popover/popover-bootstrap.scss +198 -0
  179. package/src/ProductTour/Checkpoint.scss +71 -43
  180. package/src/ProgressBar/_mixins.scss +22 -0
  181. package/src/ProgressBar/bootstrap-progress.scss +49 -0
  182. package/src/ProgressBar/index.scss +28 -36
  183. package/src/Scrollable/index.scss +2 -2
  184. package/src/SearchField/SearchFieldInput.jsx +2 -2
  185. package/src/SearchField/__snapshots__/SearchField.test.jsx.snap +12 -8
  186. package/src/SearchField/index.scss +15 -17
  187. package/src/SelectableBox/index.scss +11 -13
  188. package/src/Sheet/index.scss +10 -10
  189. package/src/Spinner/index.scss +57 -2
  190. package/src/Stack/index.scss +1 -3
  191. package/src/Stepper/index.scss +20 -20
  192. package/src/Sticky/index.scss +4 -6
  193. package/src/Tabs/README.md +1 -23
  194. package/src/Tabs/index.jsx +0 -3
  195. package/src/Tabs/index.scss +29 -25
  196. package/src/Toast/ToastContainer.scss +9 -11
  197. package/src/Toast/bootstrap-toast.scss +46 -0
  198. package/src/Toast/index.scss +9 -10
  199. package/src/Tooltip/index.scss +136 -10
  200. package/src/TransitionReplace/README.md +4 -4
  201. package/src/ValidationMessage/index.scss +1 -1
  202. package/src/index.d.ts +2 -2
  203. package/src/index.js +4 -18
  204. package/src/index.scss +0 -4
  205. package/src/{setupTest.ts → setupTest.js} +0 -7
  206. package/src/utils/breakpoints.js +1 -1
  207. package/styles/css/core/custom-media-breakpoints.css +17 -0
  208. package/styles/css/core/index.css +2 -0
  209. package/styles/css/core/variables.css +603 -0
  210. package/styles/css/themes/light/index.css +2 -0
  211. package/styles/css/themes/light/utility-classes.css +2454 -0
  212. package/styles/css/themes/light/variables.css +1644 -0
  213. package/{scss → styles/scss}/core/_functions.scss +1 -1
  214. package/styles/scss/core/_grid.scss +21 -0
  215. package/{scss → styles/scss}/core/_utilities.scss +17 -11
  216. package/styles/scss/core/_variables.scss +868 -0
  217. package/styles/scss/core/bootstrap-override/_functions.scss +104 -0
  218. package/styles/scss/core/bootstrap-override/_mixins.scss +4 -0
  219. package/styles/scss/core/bootstrap-override/_utilities.scss +4 -0
  220. package/styles/scss/core/bootstrap-override/bootstrap.scss +2 -0
  221. package/styles/scss/core/bootstrap-override/mixins/_grid-framework.scss +80 -0
  222. package/styles/scss/core/bootstrap-override/mixins/_grid.scss +69 -0
  223. package/styles/scss/core/bootstrap-override/mixins/_list-group.scss +22 -0
  224. package/styles/scss/core/bootstrap-override/utilities/_background.scss +7 -0
  225. package/styles/scss/core/bootstrap-override/utilities/_borders.scss +67 -0
  226. package/styles/scss/core/bootstrap-override/utilities/_spacing.scss +70 -0
  227. package/styles/scss/core/bootstrap-override/utilities/_text.scss +68 -0
  228. package/styles/scss/core/core.scss +21 -0
  229. package/{scss → styles/scss}/core/utilities-only.scss +1 -0
  230. package/tokens/README.md +157 -0
  231. package/tokens/css-utilities.js +56 -0
  232. package/tokens/map-scss-to-css.js +24 -0
  233. package/tokens/replace-variables.js +32 -0
  234. package/tokens/sass-helpers.js +98 -0
  235. package/tokens/src/core/alias/size.json +15 -0
  236. package/tokens/src/core/components/ActionRow.json +10 -0
  237. package/tokens/src/core/components/Alert.json +30 -0
  238. package/tokens/src/core/components/Annotation.json +25 -0
  239. package/tokens/src/core/components/Avatar.json +17 -0
  240. package/tokens/src/core/components/AvatarButton.json +11 -0
  241. package/tokens/src/core/components/Badge.json +33 -0
  242. package/tokens/src/core/components/Breadcrumb.json +23 -0
  243. package/tokens/src/core/components/Bubble.json +10 -0
  244. package/tokens/src/core/components/Button/core.json +105 -0
  245. package/tokens/src/core/components/Card.json +96 -0
  246. package/tokens/src/core/components/Carousel.json +37 -0
  247. package/tokens/src/core/components/Chip.json +41 -0
  248. package/tokens/src/core/components/ChipCarousel.json +15 -0
  249. package/tokens/src/core/components/CloseButton.json +14 -0
  250. package/tokens/src/core/components/Code.json +34 -0
  251. package/tokens/src/core/components/Collapsible.json +29 -0
  252. package/tokens/src/core/components/ColorPicker.json +8 -0
  253. package/tokens/src/core/components/Container.json +13 -0
  254. package/tokens/src/core/components/DataTable.json +27 -0
  255. package/tokens/src/core/components/Dropdown.json +67 -0
  256. package/tokens/src/core/components/Dropzone.json +21 -0
  257. package/tokens/src/core/components/Form/other.json +14 -0
  258. package/tokens/src/core/components/Form/size.json +229 -0
  259. package/tokens/src/core/components/Form/spacing.json +155 -0
  260. package/tokens/src/core/components/Form/transition.json +16 -0
  261. package/tokens/src/core/components/Form/typography.json +122 -0
  262. package/tokens/src/core/components/Icon.json +11 -0
  263. package/tokens/src/core/components/IconButton.json +15 -0
  264. package/tokens/src/core/components/Image.json +28 -0
  265. package/tokens/src/core/components/Menu.json +48 -0
  266. package/tokens/src/core/components/Modal.json +47 -0
  267. package/tokens/src/core/components/Nav.json +52 -0
  268. package/tokens/src/core/components/Navbar.json +70 -0
  269. package/tokens/src/core/components/Pagination.json +66 -0
  270. package/tokens/src/core/components/Popover.json +48 -0
  271. package/tokens/src/core/components/ProductTour.json +32 -0
  272. package/tokens/src/core/components/ProgressBar.json +39 -0
  273. package/tokens/src/core/components/SearchField.json +23 -0
  274. package/tokens/src/core/components/SelectableBox.json +9 -0
  275. package/tokens/src/core/components/Sheet.json +10 -0
  276. package/tokens/src/core/components/Spinner.json +19 -0
  277. package/tokens/src/core/components/Stack.json +7 -0
  278. package/tokens/src/core/components/Stepper.json +42 -0
  279. package/tokens/src/core/components/Sticky.json +7 -0
  280. package/tokens/src/core/components/Tab.json +19 -0
  281. package/tokens/src/core/components/Tabs.json +19 -0
  282. package/tokens/src/core/components/Toast.json +30 -0
  283. package/tokens/src/core/components/Tooltip.json +33 -0
  284. package/tokens/src/core/components/general/caret.json +13 -0
  285. package/tokens/src/core/components/general/headings.json +16 -0
  286. package/tokens/src/core/components/general/hr.json +10 -0
  287. package/tokens/src/core/components/general/input.json +51 -0
  288. package/tokens/src/core/components/general/link.json +30 -0
  289. package/tokens/src/core/components/general/list.json +26 -0
  290. package/tokens/src/core/components/general/text.json +24 -0
  291. package/tokens/src/core/global/breakpoints.json +12 -0
  292. package/tokens/src/core/global/display.json +22 -0
  293. package/tokens/src/core/global/elevation.json +19 -0
  294. package/tokens/src/core/global/other.json +4 -0
  295. package/tokens/src/core/global/spacing.json +37 -0
  296. package/tokens/src/core/global/transition.json +14 -0
  297. package/tokens/src/core/global/typography.json +91 -0
  298. package/tokens/src/core/utilities/color.json +12 -0
  299. package/tokens/src/themes/light/alias/color.json +114 -0
  300. package/tokens/src/themes/light/components/Alert.json +38 -0
  301. package/tokens/src/themes/light/components/Annotation.json +29 -0
  302. package/tokens/src/themes/light/components/Avatar.json +7 -0
  303. package/tokens/src/themes/light/components/Badge.json +186 -0
  304. package/tokens/src/themes/light/components/Breadcrumb.json +13 -0
  305. package/tokens/src/themes/light/components/Bubble.json +18 -0
  306. package/tokens/src/themes/light/components/Button/brand.json +260 -0
  307. package/tokens/src/themes/light/components/Button/core.json +24 -0
  308. package/tokens/src/themes/light/components/Button/danger.json +247 -0
  309. package/tokens/src/themes/light/components/Button/dark.json +230 -0
  310. package/tokens/src/themes/light/components/Button/info.json +238 -0
  311. package/tokens/src/themes/light/components/Button/light.json +236 -0
  312. package/tokens/src/themes/light/components/Button/primary.json +250 -0
  313. package/tokens/src/themes/light/components/Button/secondary.json +278 -0
  314. package/tokens/src/themes/light/components/Button/success.json +253 -0
  315. package/tokens/src/themes/light/components/Button/tertiary.json +109 -0
  316. package/tokens/src/themes/light/components/Button/warning.json +276 -0
  317. package/tokens/src/themes/light/components/Card.json +36 -0
  318. package/tokens/src/themes/light/components/Carousel.json +45 -0
  319. package/tokens/src/themes/light/components/Chip.json +50 -0
  320. package/tokens/src/themes/light/components/CloseButton.json +10 -0
  321. package/tokens/src/themes/light/components/Code.json +23 -0
  322. package/tokens/src/themes/light/components/DataTable.json +26 -0
  323. package/tokens/src/themes/light/components/Dropdown.json +41 -0
  324. package/tokens/src/themes/light/components/Dropzone.json +23 -0
  325. package/tokens/src/themes/light/components/Form/color.json +270 -0
  326. package/tokens/src/themes/light/components/Form/elevation.json +76 -0
  327. package/tokens/src/themes/light/components/Form/other.json +131 -0
  328. package/tokens/src/themes/light/components/IconButton.json +451 -0
  329. package/tokens/src/themes/light/components/Image.json +18 -0
  330. package/tokens/src/themes/light/components/Menu.json +30 -0
  331. package/tokens/src/themes/light/components/Modal.json +37 -0
  332. package/tokens/src/themes/light/components/Nav.json +166 -0
  333. package/tokens/src/themes/light/components/Navbar.json +136 -0
  334. package/tokens/src/themes/light/components/OverflowScroll.json +9 -0
  335. package/tokens/src/themes/light/components/PageBanner.json +24 -0
  336. package/tokens/src/themes/light/components/Pagination.json +45 -0
  337. package/tokens/src/themes/light/components/Popover.json +55 -0
  338. package/tokens/src/themes/light/components/ProductTour.json +35 -0
  339. package/tokens/src/themes/light/components/ProgressBar.json +20 -0
  340. package/tokens/src/themes/light/components/Scrollable.json +14 -0
  341. package/tokens/src/themes/light/components/SearchField.json +25 -0
  342. package/tokens/src/themes/light/components/Sheet.json +22 -0
  343. package/tokens/src/themes/light/components/Stepper.json +34 -0
  344. package/tokens/src/themes/light/components/Sticky.json +18 -0
  345. package/tokens/src/themes/light/components/Tab.json +62 -0
  346. package/tokens/src/themes/light/components/Toast.json +33 -0
  347. package/tokens/src/themes/light/components/Tooltip.json +30 -0
  348. package/tokens/src/themes/light/components/general/body.json +8 -0
  349. package/tokens/src/themes/light/components/general/headings.json +7 -0
  350. package/tokens/src/themes/light/components/general/hr.json +15 -0
  351. package/tokens/src/themes/light/components/general/input.json +18 -0
  352. package/tokens/src/themes/light/components/general/link.json +109 -0
  353. package/tokens/src/themes/light/components/general/list.json +38 -0
  354. package/tokens/src/themes/light/components/general/text.json +12 -0
  355. package/tokens/src/themes/light/global/color.json +1661 -0
  356. package/tokens/src/themes/light/global/elevation.json +201 -0
  357. package/tokens/src/themes/light/global/other.json +4 -0
  358. package/tokens/style-dictionary.js +229 -0
  359. package/tokens/utils.js +210 -0
  360. package/dist/ActionRow/_variables.scss +0 -2
  361. package/dist/Alert/_variables.scss +0 -24
  362. package/dist/Annotation/_variables.scss +0 -18
  363. package/dist/Avatar/_variables.scss +0 -10
  364. package/dist/AvatarButton/_variables.scss +0 -3
  365. package/dist/Badge/_variables.scss +0 -16
  366. package/dist/Breadcrumb/_variables.scss +0 -27
  367. package/dist/Bubble/_variables.scss +0 -8
  368. package/dist/Button/_variables.scss +0 -52
  369. package/dist/Button/deprecated/index.js +0 -149
  370. package/dist/Button/deprecated/index.js.map +0 -1
  371. package/dist/Button/index.d.ts +0 -35
  372. package/dist/Card/_variables.scss +0 -55
  373. package/dist/Carousel/_variables.scss +0 -27
  374. package/dist/CheckBox/index.js +0 -102
  375. package/dist/CheckBox/index.js.map +0 -1
  376. package/dist/CheckBoxGroup/index.js +0 -15
  377. package/dist/CheckBoxGroup/index.js.map +0 -1
  378. package/dist/Chip/_variables.scss +0 -28
  379. package/dist/ChipCarousel/_variables.scss +0 -3
  380. package/dist/CloseButton/_variables.scss +0 -6
  381. package/dist/Code/_variables.scss +0 -17
  382. package/dist/Collapsible/_variables.scss +0 -12
  383. package/dist/ColorPicker/_variables.scss +0 -2
  384. package/dist/Container/_variables.scss +0 -5
  385. package/dist/DataTable/_variables.scss +0 -11
  386. package/dist/Dropdown/_variables.scss +0 -33
  387. package/dist/Dropdown/deprecated/DropdownButton.js +0 -44
  388. package/dist/Dropdown/deprecated/DropdownButton.js.map +0 -1
  389. package/dist/Dropdown/deprecated/DropdownItem.js +0 -33
  390. package/dist/Dropdown/deprecated/DropdownItem.js.map +0 -1
  391. package/dist/Dropdown/deprecated/DropdownMenu.js +0 -46
  392. package/dist/Dropdown/deprecated/DropdownMenu.js.map +0 -1
  393. package/dist/Dropdown/deprecated/index.js +0 -241
  394. package/dist/Dropdown/deprecated/index.js.map +0 -1
  395. package/dist/Dropzone/_variables.scss +0 -9
  396. package/dist/Fieldset/index.js +0 -117
  397. package/dist/Fieldset/index.js.map +0 -1
  398. package/dist/Fieldset/index.scss +0 -12
  399. package/dist/Form/_variables.scss +0 -267
  400. package/dist/Hyperlink/index.d.ts +0 -24
  401. package/dist/Icon/_variables.scss +0 -7
  402. package/dist/Image/_variables.scss +0 -13
  403. package/dist/Input/index.js +0 -166
  404. package/dist/Input/index.js.map +0 -1
  405. package/dist/InputSelect/index.js +0 -105
  406. package/dist/InputSelect/index.js.map +0 -1
  407. package/dist/InputText/index.js +0 -45
  408. package/dist/InputText/index.js.map +0 -1
  409. package/dist/ListBox/index.js +0 -148
  410. package/dist/ListBox/index.js.map +0 -1
  411. package/dist/ListBoxOption/index.js +0 -94
  412. package/dist/ListBoxOption/index.js.map +0 -1
  413. package/dist/Menu/_variables.scss +0 -24
  414. package/dist/Modal/_variables.scss +0 -50
  415. package/dist/Modal/index.js +0 -292
  416. package/dist/Modal/index.js.map +0 -1
  417. package/dist/Nav/_variables.scss +0 -58
  418. package/dist/Navbar/_variables.scss +0 -40
  419. package/dist/OverflowScroll/_variables.scss +0 -5
  420. package/dist/OverflowScroll/index.scss +0 -1
  421. package/dist/Pagination/_variables.scss +0 -19
  422. package/dist/Popover/_variables.scss +0 -36
  423. package/dist/ProductTour/_variables.scss +0 -15
  424. package/dist/ProgressBar/_variables.scss +0 -23
  425. package/dist/RadioButtonGroup/index.js +0 -188
  426. package/dist/RadioButtonGroup/index.js.map +0 -1
  427. package/dist/SearchField/_variables.scss +0 -14
  428. package/dist/SelectableBox/_variables.scss +0 -5
  429. package/dist/Spinner/_variables.scss +0 -9
  430. package/dist/Stack/_variables.scss +0 -1
  431. package/dist/StatusAlert/index.js +0 -168
  432. package/dist/StatusAlert/index.js.map +0 -1
  433. package/dist/Stepper/_variables.scss +0 -18
  434. package/dist/Sticky/_variables.scss +0 -3
  435. package/dist/Table/_variables.scss +0 -34
  436. package/dist/Table/index.js +0 -267
  437. package/dist/Table/index.js.map +0 -1
  438. package/dist/Table/index.scss +0 -12
  439. package/dist/Tabs/_variables.scss +0 -24
  440. package/dist/Tabs/deprecated/Tabs.scss +0 -3
  441. package/dist/Tabs/deprecated/index.js +0 -123
  442. package/dist/Tabs/deprecated/index.js.map +0 -1
  443. package/dist/TextArea/index.js +0 -44
  444. package/dist/TextArea/index.js.map +0 -1
  445. package/dist/Toast/_variables.scss +0 -19
  446. package/dist/Tooltip/_variables.scss +0 -21
  447. package/dist/ValidationFormGroup/index.js +0 -106
  448. package/dist/ValidationFormGroup/index.js.map +0 -1
  449. package/dist/paragon.css +0 -45
  450. package/dist/setupTest.d.ts +0 -2
  451. package/dist/setupTest.js.map +0 -1
  452. package/dist/utils/types/bootstrap.d.ts +0 -39
  453. package/dist/utils/types/bootstrap.js +0 -2
  454. package/dist/utils/types/bootstrap.js.map +0 -1
  455. package/scss/core/_grid.scss +0 -21
  456. package/scss/core/_variables.scss +0 -875
  457. package/scss/core/core.scss +0 -21
  458. package/src/ActionRow/_variables.scss +0 -2
  459. package/src/Alert/_variables.scss +0 -24
  460. package/src/Annotation/_variables.scss +0 -18
  461. package/src/Avatar/_variables.scss +0 -10
  462. package/src/AvatarButton/_variables.scss +0 -3
  463. package/src/Badge/_variables.scss +0 -16
  464. package/src/Breadcrumb/_variables.scss +0 -27
  465. package/src/Bubble/_variables.scss +0 -8
  466. package/src/Button/_variables.scss +0 -52
  467. package/src/Button/deprecated/Button.test.jsx +0 -34
  468. package/src/Button/deprecated/index.jsx +0 -145
  469. package/src/Button/index.tsx +0 -159
  470. package/src/Card/_variables.scss +0 -55
  471. package/src/Carousel/_variables.scss +0 -27
  472. package/src/CheckBox/CheckBox.test.jsx +0 -65
  473. package/src/CheckBox/README.md +0 -93
  474. package/src/CheckBox/index.jsx +0 -80
  475. package/src/CheckBoxGroup/CheckBoxGroup.test.jsx +0 -33
  476. package/src/CheckBoxGroup/README.md +0 -35
  477. package/src/CheckBoxGroup/index.jsx +0 -19
  478. package/src/Chip/_variables.scss +0 -28
  479. package/src/ChipCarousel/_variables.scss +0 -3
  480. package/src/CloseButton/_variables.scss +0 -6
  481. package/src/Code/_variables.scss +0 -17
  482. package/src/Collapsible/_variables.scss +0 -12
  483. package/src/ColorPicker/_variables.scss +0 -2
  484. package/src/Container/_variables.scss +0 -5
  485. package/src/DataTable/_variables.scss +0 -11
  486. package/src/Dropdown/_variables.scss +0 -33
  487. package/src/Dropdown/deprecated/Dropdown.test.jsx +0 -238
  488. package/src/Dropdown/deprecated/DropdownButton.jsx +0 -52
  489. package/src/Dropdown/deprecated/DropdownItem.jsx +0 -34
  490. package/src/Dropdown/deprecated/DropdownMenu.jsx +0 -50
  491. package/src/Dropdown/deprecated/__snapshots__/Dropdown.test.jsx.snap +0 -229
  492. package/src/Dropdown/deprecated/index.jsx +0 -222
  493. package/src/Dropzone/_variables.scss +0 -9
  494. package/src/Fieldset/Fieldset.test.jsx +0 -101
  495. package/src/Fieldset/README.md +0 -146
  496. package/src/Fieldset/index.jsx +0 -107
  497. package/src/Fieldset/index.scss +0 -12
  498. package/src/Form/_variables.scss +0 -267
  499. package/src/Icon/_variables.scss +0 -7
  500. package/src/Image/_variables.scss +0 -13
  501. package/src/Input/README.md +0 -74
  502. package/src/Input/__snapshots__/input.test.jsx.snap +0 -53
  503. package/src/Input/index.jsx +0 -151
  504. package/src/Input/input.test.jsx +0 -85
  505. package/src/InputSelect/README.md +0 -136
  506. package/src/InputSelect/index.jsx +0 -92
  507. package/src/InputText/InputText.test.jsx +0 -74
  508. package/src/InputText/README.md +0 -293
  509. package/src/InputText/index.jsx +0 -49
  510. package/src/ListBox/ListBox.test.jsx +0 -161
  511. package/src/ListBox/README.md +0 -185
  512. package/src/ListBox/index.jsx +0 -115
  513. package/src/ListBoxOption/ListBoxOption.test.jsx +0 -154
  514. package/src/ListBoxOption/index.jsx +0 -78
  515. package/src/Menu/_variables.scss +0 -24
  516. package/src/Modal/README.md +0 -148
  517. package/src/Modal/_variables.scss +0 -50
  518. package/src/Modal/index.jsx +0 -319
  519. package/src/Modal/tests/Modal.test.jsx +0 -261
  520. package/src/Nav/_variables.scss +0 -58
  521. package/src/Navbar/_variables.scss +0 -40
  522. package/src/OverflowScroll/_variables.scss +0 -5
  523. package/src/OverflowScroll/index.scss +0 -1
  524. package/src/Pagination/_variables.scss +0 -19
  525. package/src/Popover/_variables.scss +0 -36
  526. package/src/ProductTour/_variables.scss +0 -15
  527. package/src/ProgressBar/_variables.scss +0 -23
  528. package/src/RadioButtonGroup/README.md +0 -50
  529. package/src/RadioButtonGroup/RadioButtonGroup.test.jsx +0 -127
  530. package/src/RadioButtonGroup/index.jsx +0 -185
  531. package/src/SearchField/_variables.scss +0 -14
  532. package/src/SelectableBox/_variables.scss +0 -5
  533. package/src/Spinner/_variables.scss +0 -9
  534. package/src/Stack/_variables.scss +0 -1
  535. package/src/StatusAlert/README.md +0 -149
  536. package/src/StatusAlert/StatusAlert.test.jsx +0 -150
  537. package/src/StatusAlert/index.jsx +0 -144
  538. package/src/Stepper/_variables.scss +0 -18
  539. package/src/Sticky/_variables.scss +0 -3
  540. package/src/Table/README.md +0 -506
  541. package/src/Table/Table.test.jsx +0 -367
  542. package/src/Table/_variables.scss +0 -34
  543. package/src/Table/index.jsx +0 -264
  544. package/src/Table/index.scss +0 -12
  545. package/src/Tabs/_variables.scss +0 -24
  546. package/src/Tabs/deprecated/Tabs.scss +0 -3
  547. package/src/Tabs/deprecated/Tabs.test.jsx +0 -50
  548. package/src/Tabs/deprecated/index.jsx +0 -117
  549. package/src/TextArea/README.md +0 -63
  550. package/src/TextArea/index.jsx +0 -48
  551. package/src/Toast/_variables.scss +0 -19
  552. package/src/Tooltip/_variables.scss +0 -21
  553. package/src/ValidationFormGroup/README.md +0 -116
  554. package/src/ValidationFormGroup/ValidationFormGroup.test.jsx +0 -146
  555. package/src/ValidationFormGroup/__snapshots__/ValidationFormGroup.test.jsx.snap +0 -161
  556. package/src/ValidationFormGroup/index.jsx +0 -114
  557. package/src/utils/types/bootstrap.test.tsx +0 -86
  558. package/src/utils/types/bootstrap.ts +0 -43
  559. /package/src/Button/{ButtonGroup.test.tsx → ButtonGroup.test.jsx} +0 -0
  560. /package/src/Button/{ButtonToolbar.test.tsx → ButtonToolbar.test.jsx} +0 -0
  561. /package/src/Button/__snapshots__/{ButtonGroup.test.tsx.snap → ButtonGroup.test.jsx.snap} +0 -0
  562. /package/src/Button/__snapshots__/{ButtonToolbar.test.tsx.snap → ButtonToolbar.test.jsx.snap} +0 -0
  563. /package/{scss → styles/scss}/core/_exports.module.scss +0 -0
  564. /package/{scss → styles/scss}/core/_typography.scss +0 -0
@@ -1,222 +0,0 @@
1
- import React from 'react';
2
- import PropTypes from 'prop-types';
3
- import classNames from 'classnames';
4
- // eslint-disable-next-line import/no-cycle
5
- import DropdownButton from './DropdownButton';
6
- // eslint-disable-next-line import/no-cycle
7
- import DropdownMenu from './DropdownMenu';
8
- import DropdownItem from './DropdownItem';
9
-
10
- import withDeprecatedProps, { DeprTypes } from '../../withDeprecatedProps';
11
-
12
- const { Provider, Consumer } = React.createContext();
13
-
14
- class Dropdown extends React.Component {
15
- // eslint-disable-next-line react/sort-comp
16
- static idCounter = 0; // For creating unique ids
17
-
18
- constructor(props) {
19
- super(props);
20
- this.state = {
21
- open: false,
22
- };
23
-
24
- // Used for aria labelling. Increment the id counter so the next id can be unique
25
- this.uniqueId = Dropdown.idCounter;
26
- Dropdown.idCounter += 1;
27
- this.triggerId = `pgn__dropdown-trigger-${this.uniqueId}`;
28
-
29
- this.containerRef = React.createRef();
30
- this.menuRef = React.createRef();
31
- this.buttonRef = React.createRef();
32
- }
33
-
34
- componentDidUpdate(prevProps, prevState) {
35
- if (prevState.open !== this.state.open) {
36
- if (this.state.open) {
37
- this.focusFirst();
38
- } else {
39
- this.buttonRef.current.focus();
40
- }
41
- }
42
- }
43
-
44
- componentWillUnmount() {
45
- document.removeEventListener('click', this.handleDocumentClick, true);
46
- }
47
-
48
- getFocusableElements() {
49
- const selector = 'button:not([disabled]), [href]:not([disabled]), input:not([disabled]), select:not([disabled]), textarea:not([disabled]), [tabindex]:not([tabindex="-1"]):not([disabled])';
50
- return Array.from(this.menuRef.current.querySelectorAll(selector));
51
- }
52
-
53
- handleDocumentClick = (e) => {
54
- if (this.containerRef.current.contains(e.target) && this.containerRef.current !== e.target) {
55
- return;
56
- }
57
- if (this.state.open) {
58
- this.close();
59
- }
60
- };
61
-
62
- handleMenuKeyDown = (e) => {
63
- switch (e.key) {
64
- case 'ArrowUp':
65
- e.preventDefault();
66
- this.focusPrevious();
67
- break;
68
- case 'ArrowDown':
69
- e.preventDefault();
70
- this.focusNext();
71
- break;
72
- case 'Tab':
73
- e.preventDefault();
74
- if (e.shiftKey) {
75
- this.focusPrevious();
76
- } else {
77
- this.focusNext();
78
- }
79
- break;
80
- case 'Escape':
81
- e.stopPropagation();
82
- this.close();
83
- break;
84
- default:
85
- break;
86
- }
87
- };
88
-
89
- toggle = () => {
90
- if (this.state.open) {
91
- this.close();
92
- } else {
93
- this.open();
94
- }
95
- };
96
-
97
- close() {
98
- document.removeEventListener('click', this.handleDocumentClick, true);
99
- this.setState({
100
- open: false,
101
- });
102
- }
103
-
104
- open() {
105
- // adding event listener here so the user can close dropdown on click outside of the dropdown
106
- document.addEventListener('click', this.handleDocumentClick, true);
107
- this.setState({
108
- open: true,
109
- });
110
- }
111
-
112
- focusFirst() {
113
- const focusableElements = this.getFocusableElements();
114
- if (focusableElements.length) { focusableElements[0].focus(); }
115
- }
116
-
117
- focusNext() {
118
- const allFocusableElements = this.getFocusableElements();
119
- if (allFocusableElements.length === 0) { return; }
120
- const activeIndex = allFocusableElements.indexOf(document.activeElement);
121
- const nextIndex = (activeIndex + 1) % allFocusableElements.length;
122
- allFocusableElements[nextIndex].focus();
123
- }
124
-
125
- focusPrevious() {
126
- const allFocusableElements = this.getFocusableElements();
127
- if (allFocusableElements.length === 0) { return; }
128
- const activeIndex = allFocusableElements.indexOf(document.activeElement);
129
- const previousIndex = ((activeIndex - 1) + allFocusableElements.length) % allFocusableElements.length;
130
- allFocusableElements[previousIndex].focus();
131
- }
132
-
133
- render() {
134
- const { children, ...other } = this.props;
135
-
136
- return (
137
- <div
138
- {...other}
139
- className={classNames(
140
- 'dropdown',
141
- { show: this.state.open },
142
- other.className,
143
- )}
144
- ref={this.containerRef}
145
- >
146
- <Provider
147
- value={{
148
- buttonRef: this.buttonRef,
149
- handleMenuKeyDown: this.handleMenuKeyDown,
150
- isOpen: this.state.open,
151
- menuRef: this.menuRef,
152
- toggle: this.toggle,
153
- triggerId: this.triggerId,
154
- }}
155
- >
156
- {children}
157
- </Provider>
158
- </div>
159
- );
160
- }
161
- }
162
-
163
- Dropdown.propTypes = {
164
- children: PropTypes.node,
165
- };
166
-
167
- Dropdown.Item = DropdownItem;
168
- Dropdown.Button = DropdownButton;
169
- Dropdown.Menu = DropdownMenu;
170
-
171
- const DropdownWithDeprecatedProps = withDeprecatedProps(Dropdown, 'Dropdown', {
172
- menuItems: {
173
- deprType: DeprTypes.MOVED_AND_FORMAT,
174
- message: 'They should be components sent as children.',
175
- newName: 'children',
176
- transform: (menuItems, allProps) => {
177
- if (!Array.isArray(menuItems)) { return null; }
178
- return (
179
- <>
180
- <DropdownButton>
181
- {React.isValidElement(allProps.iconElement) ? allProps.iconElement : null }
182
- {allProps.title}
183
- </DropdownButton>
184
- <DropdownMenu>
185
- {menuItems.map((menuItem, i) => {
186
- /* eslint-disable react/no-array-index-key */
187
- if (React.isValidElement(menuItem)) {
188
- return React.cloneElement(menuItem, {
189
- className: 'dropdown-item',
190
- key: i,
191
- });
192
- }
193
- return <DropdownItem key={i} href={menuItem.href}>{menuItem.label}</DropdownItem>;
194
- /* eslint-enable react/no-array-index-key */
195
- })}
196
- </DropdownMenu>
197
- </>
198
- );
199
- },
200
- },
201
- title: {
202
- deprType: DeprTypes.REMOVED,
203
- message: 'It should be specified inside the Dropdown.Button component',
204
- },
205
- buttonType: {
206
- deprType: DeprTypes.REMOVED,
207
- message: 'It should be specified as a className prop',
208
- },
209
- iconElement: {
210
- deprType: DeprTypes.REMOVED,
211
- message: 'It should be specified inside the buttonContent prop.',
212
- },
213
- });
214
-
215
- DropdownWithDeprecatedProps.propTypes = Dropdown.propTypes;
216
- DropdownWithDeprecatedProps.defaultProps = Dropdown.defaultProps;
217
- DropdownWithDeprecatedProps.Item = Dropdown.Item;
218
- DropdownWithDeprecatedProps.Button = Dropdown.Button;
219
- DropdownWithDeprecatedProps.Menu = Dropdown.Menu;
220
-
221
- export { Provider, Consumer };
222
- export default DropdownWithDeprecatedProps;
@@ -1,9 +0,0 @@
1
- $dropzone-padding: 1.5rem !default;
2
- $dropzone-border-default: 1px dashed $gray-500 !default;
3
- $dropzone-box-shadow-hover: inset 0 0 0 2px $info-300 !default;
4
- $dropzone-box-shadow-focus: inset 0 0 0 2px $info-300 !default;
5
- $dropzone-box-shadow-active: inset 0 0 0 2px $primary-500 !default;
6
- $dropzone-box-shadow-error: inset 0 0 0 2px $danger-300 !default;
7
- $dropzone-error-wrapper-color: $danger-500 !default;
8
- $dropzone-restriction-msg-font-size: $x-small-font-size !default;
9
- $dropzone-restriction-msg-color: $gray-500 !default;
@@ -1,101 +0,0 @@
1
- import React from 'react';
2
- import { render } from '@testing-library/react';
3
-
4
- import Fieldset from '.';
5
- import Variant from '../utils/constants';
6
-
7
- const dangerVariant = {
8
- status: Variant.status.DANGER,
9
- };
10
- const id = 'input1';
11
- const legend = 'A Fieldset';
12
- const invalidMessage = 'This is invalid!';
13
- const children = 'Input goes here';
14
- const variant = {
15
- status: Variant.status.INFO,
16
- };
17
- const variantIconDescription = 'Error';
18
-
19
- const baseProps = {
20
- className: '',
21
- id,
22
- isValid: true,
23
- legend,
24
- invalidMessage,
25
- variant,
26
- variantIconDescription,
27
- };
28
-
29
- jest.mock('../utils/newId', () => jest.fn().mockReturnValue('fieldset1'));
30
-
31
- describe('Fieldset', () => {
32
- it('renders', () => {
33
- const { getByTestId, getByText } = render(
34
- <Fieldset {...baseProps}>{children}</Fieldset>,
35
- );
36
-
37
- const fieldset = getByTestId('fieldset');
38
- expect(fieldset).toBeInTheDocument();
39
- expect(fieldset).toHaveClass('is-invalid-nodanger');
40
- expect(fieldset).toHaveAttribute('aria-describedby', `error-${id}`);
41
-
42
- const legendElem = getByText(legend);
43
- expect(legendElem).toBeInTheDocument();
44
-
45
- const feedback = getByTestId('validation-message');
46
- expect(feedback).toHaveAttribute('id', `error-${id}`);
47
- });
48
-
49
- it('renders with auto-generated id if not specified', () => {
50
- const props = {
51
- ...baseProps,
52
- id: undefined,
53
- };
54
-
55
- const { getByTestId } = render(<Fieldset {...props} />);
56
- const feedback = getByTestId('validation-message');
57
- expect(feedback).toHaveAttribute('id', 'error-fieldset1');
58
- });
59
-
60
- it('renders invalidMessage when isValid is false', () => {
61
- const { getByTestId } = render(
62
- <Fieldset {...baseProps} isValid={false} />,
63
- );
64
- const feedback = getByTestId('validation-message');
65
- expect(feedback).toHaveTextContent(invalidMessage);
66
- });
67
-
68
- it('renders with danger variant when isValid is false and variant is DANGER', () => {
69
- const { getByTestId } = render(
70
- <Fieldset {...baseProps} isValid={false} variant={dangerVariant} />,
71
- );
72
- const feedback = getByTestId('validation-message');
73
- expect(feedback).not.toHaveClass('invalid-feedback-nodanger');
74
- expect(feedback).toHaveTextContent(invalidMessage);
75
- });
76
-
77
- it('receives new id when a valid one is passed to props', () => {
78
- const nextId = 'new-id';
79
-
80
- const { getByTestId } = render(<Fieldset {...baseProps} id={nextId} />);
81
- const fieldset = getByTestId('fieldset');
82
- const feedback = getByTestId('validation-message');
83
-
84
- expect(fieldset).toHaveAttribute('aria-describedby', `error-${nextId}`);
85
- expect(feedback).toHaveAttribute('id', `error-${nextId}`);
86
- });
87
-
88
- it('auto-generates new id when an invalid one is passed to props', () => {
89
- const nextId = '';
90
-
91
- const { getByTestId } = render(<Fieldset {...baseProps} id={nextId} />);
92
- const fieldset = getByTestId('fieldset');
93
- const feedback = getByTestId('validation-message');
94
-
95
- expect(fieldset).toHaveAttribute(
96
- 'aria-describedby',
97
- 'error-fieldset1',
98
- );
99
- expect(feedback).toHaveAttribute('id', 'error-fieldset1');
100
- });
101
- });
@@ -1,146 +0,0 @@
1
- ---
2
- title: 'Fieldset'
3
- type: 'component'
4
- components:
5
- - Fieldset
6
- categories:
7
- - Forms (deprecated)
8
- status: 'Deprecate Soon'
9
- designStatus: 'TBD'
10
- devStatus: 'To Do'
11
- notes: |
12
- Unneeded. Used in one place (studio-frontend/src/components/EditImageModal/index.jsx)
13
- ---
14
-
15
- ## basic usage
16
-
17
- ```jsx live
18
- <form>
19
- <Fieldset legend="Name">
20
- <InputText
21
- name="firstName"
22
- label="First Name"
23
- value=""
24
- />
25
- <InputText
26
- name="lastName"
27
- label="Last Name"
28
- value=""
29
- />
30
- </Fieldset>
31
- </form>
32
- ```
33
-
34
- ## invalid
35
-
36
- ```jsx live
37
- <form>
38
- <Fieldset legend="Name" invalidMessage="This is invalid!" isValid={false}>
39
- <InputText
40
- name="firstName"
41
- label="First Name"
42
- value=""
43
- />
44
- <InputText
45
- name="lastName"
46
- label="Last Name"
47
- value=""
48
- />
49
- </Fieldset>
50
- </form>
51
- ```
52
-
53
- ## invalid with danger theme
54
-
55
- ```jsx live
56
- <form>
57
- <Fieldset
58
- legend="Name"
59
- invalidMessage="This is invalid!"
60
- isValid={false}
61
- variant={{
62
- status: Variant.status.DANGER,
63
- }}
64
- variantIconDescription="Error"
65
- >
66
- <InputText
67
- name="firstName"
68
- label="First Name"
69
- value=""
70
- />
71
- <InputText
72
- name="lastName"
73
- label="Last Name"
74
- value=""
75
- />
76
- </Fieldset>
77
- </form>
78
- ```
79
-
80
- ## Validated Form
81
-
82
- ```jsx live
83
- class ValidatedForm extends React.Component {
84
- constructor(props) {
85
- super(props);
86
- this.firstInputRef = null;
87
- this.secondInputRef = null;
88
-
89
- this.state = {
90
- isValid: true,
91
- };
92
-
93
- this.handleSubmit = this.handleSubmit.bind(this);
94
- }
95
-
96
- handleSubmit(event) {
97
- if (
98
- this.firstInputRef.value.length === 0 &&
99
- this.secondInputRef.value.length === 0
100
- ) {
101
- this.setState({
102
- isValid: false,
103
- });
104
- } else {
105
- this.setState({
106
- isValid: true,
107
- });
108
- }
109
- event.preventDefault();
110
- }
111
-
112
- render() {
113
- return (
114
- <form onSubmit={this.handleSubmit}>
115
- <Fieldset
116
- legend="Name"
117
- invalidMessage="Please enter at least one name."
118
- isValid={this.state.isValid}
119
- variant={{
120
- status: Variant.status.DANGER,
121
- }}
122
- variantIconDescription="Error"
123
- >
124
- <InputText
125
- name="firstName"
126
- label="First Name"
127
- value=""
128
- inputRef={ref => {
129
- this.firstInputRef = ref;
130
- }}
131
- />
132
- <InputText
133
- name="lastName"
134
- label="Last Name"
135
- value=""
136
- inputRef={ref => {
137
- this.secondInputRef = ref;
138
- }}
139
- />
140
- </Fieldset>
141
- <input type="submit" className="btn btn-primary" value="Submit" />
142
- </form>
143
- );
144
- }
145
- }
146
- ```
@@ -1,107 +0,0 @@
1
- import React from 'react';
2
- import PropTypes from 'prop-types';
3
- import classNames from 'classnames';
4
-
5
- import newId from '../utils/newId';
6
-
7
- import ValidationMessage from '../ValidationMessage/index';
8
- import Variant from '../utils/constants';
9
-
10
- const inputProps = {
11
- legend: PropTypes.oneOfType([PropTypes.string, PropTypes.element]).isRequired,
12
-
13
- children: PropTypes.node,
14
- className: PropTypes.string,
15
- id: PropTypes.string,
16
- isValid: PropTypes.bool,
17
- invalidMessage: PropTypes.oneOfType([PropTypes.string, PropTypes.element]),
18
- variant: PropTypes.shape({
19
- status: PropTypes.oneOf(Object.keys(Variant.status).map(k => Variant.status[k])),
20
- }),
21
- variantIconDescription: PropTypes.oneOfType([PropTypes.string, PropTypes.element]),
22
- };
23
-
24
- const defaultProps = {
25
- children: null,
26
- className: undefined,
27
- id: '',
28
- isValid: true,
29
- invalidMessage: '',
30
- variant: {
31
- status: Variant.status.INFO,
32
- },
33
- variantIconDescription: '',
34
- };
35
-
36
- class Fieldset extends React.Component {
37
- constructor(props) {
38
- super(props);
39
- this.state = { id: props.id || newId('fieldset') };
40
- }
41
-
42
- static getDerivedStateFromProps(nextProps, prevState) {
43
- if (nextProps.id !== prevState.id) {
44
- return { id: nextProps.id || newId('fieldset') };
45
- }
46
-
47
- return null;
48
- }
49
-
50
- getVariantClassName() {
51
- const { variant } = this.props;
52
- let className;
53
-
54
- switch (variant.status) {
55
- case Variant.status.INFO:
56
- className = 'is-invalid-nodanger';
57
- break;
58
- default:
59
- break;
60
- }
61
-
62
- return className;
63
- }
64
-
65
- render() {
66
- const {
67
- className,
68
- children,
69
- variantIconDescription,
70
- invalidMessage,
71
- isValid,
72
- legend,
73
- variant,
74
- } = this.props;
75
- const errorId = `error-${this.state.id}`;
76
- return (
77
- <div className="paragon-fieldset">
78
- <fieldset
79
- className={classNames(
80
- 'form-control',
81
- 'p-3',
82
- { 'is-invalid': !isValid },
83
- this.getVariantClassName(),
84
- className,
85
- )}
86
- aria-describedby={errorId}
87
- data-testid="fieldset"
88
- >
89
- <legend className="p-1">{legend}</legend>
90
- {children}
91
- </fieldset>
92
- <ValidationMessage
93
- id={errorId}
94
- isValid={isValid}
95
- invalidMessage={invalidMessage}
96
- variant={variant}
97
- variantIconDescription={variantIconDescription}
98
- />
99
- </div>
100
- );
101
- }
102
- }
103
-
104
- Fieldset.propTypes = inputProps;
105
- Fieldset.defaultProps = defaultProps;
106
-
107
- export default Fieldset;
@@ -1,12 +0,0 @@
1
- .paragon-fieldset {
2
- margin-bottom: $spacer * 1.5;
3
-
4
- .form-control {
5
- height: auto;
6
- }
7
-
8
- fieldset legend {
9
- width: auto;
10
- margin-bottom: 0;
11
- }
12
- }