@openedx/paragon 22.4.0 → 23.0.0-alpha.1

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 (530) hide show
  1. package/README.md +36 -5
  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 +0 -2
  15. package/dist/Button/index.js.map +1 -1
  16. package/dist/Button/index.scss +855 -370
  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/index.scss +46 -37
  21. package/dist/Chip/mixins.scss +8 -3
  22. package/dist/ChipCarousel/index.scss +4 -4
  23. package/dist/CloseButton/index.scss +31 -2
  24. package/dist/Code/index.scss +47 -2
  25. package/dist/Collapsible/index.scss +15 -15
  26. package/dist/ColorPicker/index.scss +9 -11
  27. package/dist/DataTable/CollapsibleButtonGroup.js +2 -2
  28. package/dist/DataTable/CollapsibleButtonGroup.js.map +1 -1
  29. package/dist/DataTable/index.scss +48 -50
  30. package/dist/Dropdown/dropdown-bootstrap.scss +181 -0
  31. package/dist/Dropdown/index.js +0 -2
  32. package/dist/Dropdown/index.js.map +1 -1
  33. package/dist/Dropdown/index.scss +11 -12
  34. package/dist/Dropzone/index.scss +12 -14
  35. package/dist/Form/_FormText.scss +8 -8
  36. package/dist/Form/_bootstrap-custom-forms.scss +551 -0
  37. package/dist/Form/_bootstrap-forms.scss +381 -0
  38. package/dist/Form/_index.scss +168 -146
  39. package/dist/Form/_input-group.scss +188 -0
  40. package/dist/Form/_mixins.scss +216 -3
  41. package/dist/Hyperlink/index.scss +1 -1
  42. package/dist/Icon/index.scss +10 -12
  43. package/dist/IconButton/_mixins.scss +4 -0
  44. package/dist/IconButton/index.js +5 -11
  45. package/dist/IconButton/index.js.map +1 -1
  46. package/dist/IconButton/index.scss +387 -74
  47. package/dist/IconButtonToggle/index.scss +1 -1
  48. package/dist/Image/index.scss +53 -2
  49. package/dist/Menu/index.scss +25 -27
  50. package/dist/Modal/_ModalDialog.scss +52 -50
  51. package/dist/Modal/index.scss +6 -73
  52. package/dist/Nav/_mixins.scss +4 -4
  53. package/dist/Nav/index.scss +70 -66
  54. package/dist/Navbar/index.scss +276 -2
  55. package/dist/OverflowScroll/data/useOverflowScrollElementAttributes.js +3 -3
  56. package/dist/Overlay/index.js +2 -3
  57. package/dist/Overlay/index.js.map +1 -1
  58. package/dist/PageBanner/index.scss +17 -21
  59. package/dist/Pagination/index.scss +32 -34
  60. package/dist/Pagination/pagination-bootstrap.scss +83 -0
  61. package/dist/Popover/index.scss +9 -10
  62. package/dist/Popover/popover-bootstrap.scss +198 -0
  63. package/dist/ProductTour/Checkpoint.scss +71 -43
  64. package/dist/ProgressBar/_mixins.scss +22 -0
  65. package/dist/ProgressBar/bootstrap-progress.scss +49 -0
  66. package/dist/ProgressBar/index.scss +28 -36
  67. package/dist/Scrollable/index.scss +2 -2
  68. package/dist/SearchField/SearchFieldInput.js +2 -2
  69. package/dist/SearchField/SearchFieldInput.js.map +1 -1
  70. package/dist/SearchField/index.scss +15 -17
  71. package/dist/SelectableBox/index.scss +11 -13
  72. package/dist/Sheet/index.scss +10 -10
  73. package/dist/Spinner/index.scss +57 -2
  74. package/dist/Stack/index.scss +1 -3
  75. package/dist/Stepper/index.scss +19 -20
  76. package/dist/Sticky/index.scss +4 -6
  77. package/dist/Tabs/index.js +0 -2
  78. package/dist/Tabs/index.js.map +1 -1
  79. package/dist/Tabs/index.scss +26 -25
  80. package/dist/Toast/ToastContainer.scss +9 -11
  81. package/dist/Toast/bootstrap-toast.scss +46 -0
  82. package/dist/Toast/index.scss +9 -10
  83. package/dist/Tooltip/index.scss +136 -10
  84. package/dist/ValidationMessage/index.scss +1 -1
  85. package/dist/core.css +16788 -0
  86. package/dist/core.css.map +1 -0
  87. package/dist/core.min.css +2 -0
  88. package/dist/index.js +0 -14
  89. package/dist/index.scss +0 -4
  90. package/dist/light.css +4098 -0
  91. package/dist/light.css.map +1 -0
  92. package/dist/light.min.css +2 -0
  93. package/dist/theme-urls.json +21 -0
  94. package/dist/utils/breakpoints.js +1 -1
  95. package/lib/build-scss.js +188 -0
  96. package/lib/build-tokens.js +119 -0
  97. package/lib/help.js +36 -23
  98. package/lib/replace-variables.js +38 -0
  99. package/lib/utils.js +30 -0
  100. package/package.json +25 -10
  101. package/src/ActionRow/_index.scss +2 -4
  102. package/src/Alert/index.scss +41 -32
  103. package/src/Annotation/_mixins.scss +104 -0
  104. package/src/Annotation/index.scss +130 -103
  105. package/src/Avatar/index.scss +18 -20
  106. package/src/AvatarButton/index.scss +3 -5
  107. package/src/Badge/index.scss +112 -2
  108. package/src/Breadcrumb/index.scss +14 -16
  109. package/src/Bubble/index.scss +25 -12
  110. package/src/Button/README.md +0 -84
  111. package/src/Button/_mixins.scss +14 -0
  112. package/src/Button/button-group.scss +126 -0
  113. package/src/Button/index.jsx +0 -3
  114. package/src/Button/index.scss +855 -370
  115. package/src/Card/card-bootstrap.scss +168 -0
  116. package/src/Card/index.scss +78 -79
  117. package/src/Carousel/index.scss +168 -2
  118. package/src/Chip/index.scss +46 -37
  119. package/src/Chip/mixins.scss +8 -3
  120. package/src/ChipCarousel/index.scss +4 -4
  121. package/src/CloseButton/index.scss +31 -2
  122. package/src/Code/index.scss +47 -2
  123. package/src/Collapsible/index.scss +15 -15
  124. package/src/ColorPicker/index.scss +9 -11
  125. package/src/DataTable/CollapsibleButtonGroup.jsx +2 -2
  126. package/src/DataTable/index.scss +48 -50
  127. package/src/Dropdown/README.md +0 -93
  128. package/src/Dropdown/dropdown-bootstrap.scss +181 -0
  129. package/src/Dropdown/index.jsx +0 -2
  130. package/src/Dropdown/index.scss +11 -12
  131. package/src/Dropzone/index.scss +12 -14
  132. package/src/Form/_FormText.scss +8 -8
  133. package/src/Form/_bootstrap-custom-forms.scss +551 -0
  134. package/src/Form/_bootstrap-forms.scss +381 -0
  135. package/src/Form/_index.scss +168 -146
  136. package/src/Form/_input-group.scss +188 -0
  137. package/src/Form/_mixins.scss +216 -3
  138. package/src/Hyperlink/index.scss +1 -1
  139. package/src/Icon/index.scss +10 -12
  140. package/src/IconButton/README.md +1 -15
  141. package/src/IconButton/__snapshots__/IconButton.test.jsx.snap +5 -28
  142. package/src/IconButton/_mixins.scss +4 -0
  143. package/src/IconButton/index.jsx +6 -13
  144. package/src/IconButton/index.scss +387 -74
  145. package/src/IconButtonToggle/index.scss +1 -1
  146. package/src/Image/index.scss +53 -2
  147. package/src/Menu/index.scss +25 -27
  148. package/src/Modal/_ModalDialog.scss +52 -50
  149. package/src/Modal/index.scss +6 -73
  150. package/src/Nav/_mixins.scss +4 -4
  151. package/src/Nav/index.scss +70 -66
  152. package/src/Navbar/index.scss +276 -2
  153. package/src/OverflowScroll/data/useOverflowScrollElementAttributes.js +3 -3
  154. package/src/Overlay/index.jsx +2 -3
  155. package/src/PageBanner/index.scss +17 -21
  156. package/src/Pagination/index.scss +32 -34
  157. package/src/Pagination/pagination-bootstrap.scss +83 -0
  158. package/src/Popover/index.scss +9 -10
  159. package/src/Popover/popover-bootstrap.scss +198 -0
  160. package/src/ProductTour/Checkpoint.scss +71 -43
  161. package/src/ProgressBar/_mixins.scss +22 -0
  162. package/src/ProgressBar/bootstrap-progress.scss +49 -0
  163. package/src/ProgressBar/index.scss +28 -36
  164. package/src/Scrollable/index.scss +2 -2
  165. package/src/SearchField/SearchFieldInput.jsx +2 -2
  166. package/src/SearchField/__snapshots__/SearchField.test.jsx.snap +12 -8
  167. package/src/SearchField/index.scss +15 -17
  168. package/src/SelectableBox/index.scss +11 -13
  169. package/src/Sheet/index.scss +10 -10
  170. package/src/Spinner/index.scss +57 -2
  171. package/src/Stack/index.scss +1 -3
  172. package/src/Stepper/index.scss +19 -20
  173. package/src/Sticky/index.scss +4 -6
  174. package/src/Tabs/README.md +1 -23
  175. package/src/Tabs/index.jsx +0 -3
  176. package/src/Tabs/index.scss +26 -25
  177. package/src/Toast/ToastContainer.scss +9 -11
  178. package/src/Toast/bootstrap-toast.scss +46 -0
  179. package/src/Toast/index.scss +9 -10
  180. package/src/Tooltip/index.scss +136 -10
  181. package/src/TransitionReplace/README.md +4 -4
  182. package/src/ValidationMessage/index.scss +1 -1
  183. package/src/index.js +0 -14
  184. package/src/index.scss +0 -4
  185. package/src/setupTest.js +0 -6
  186. package/src/utils/breakpoints.js +1 -1
  187. package/styles/css/core/custom-media-breakpoints.css +17 -0
  188. package/styles/css/core/index.css +2 -0
  189. package/styles/css/core/variables.css +614 -0
  190. package/styles/css/themes/light/index.css +2 -0
  191. package/styles/css/themes/light/utility-classes.css +2454 -0
  192. package/styles/css/themes/light/variables.css +1644 -0
  193. package/{scss → styles/scss}/core/_functions.scss +1 -1
  194. package/styles/scss/core/_grid.scss +21 -0
  195. package/{scss → styles/scss}/core/_utilities.scss +17 -11
  196. package/styles/scss/core/_variables.scss +869 -0
  197. package/styles/scss/core/bootstrap-override/_functions.scss +104 -0
  198. package/styles/scss/core/bootstrap-override/_mixins.scss +4 -0
  199. package/styles/scss/core/bootstrap-override/_utilities.scss +4 -0
  200. package/styles/scss/core/bootstrap-override/bootstrap.scss +2 -0
  201. package/styles/scss/core/bootstrap-override/mixins/_grid-framework.scss +80 -0
  202. package/styles/scss/core/bootstrap-override/mixins/_grid.scss +69 -0
  203. package/styles/scss/core/bootstrap-override/mixins/_list-group.scss +22 -0
  204. package/styles/scss/core/bootstrap-override/utilities/_background.scss +7 -0
  205. package/styles/scss/core/bootstrap-override/utilities/_borders.scss +67 -0
  206. package/styles/scss/core/bootstrap-override/utilities/_spacing.scss +70 -0
  207. package/styles/scss/core/bootstrap-override/utilities/_text.scss +68 -0
  208. package/styles/scss/core/core.scss +21 -0
  209. package/{scss → styles/scss}/core/utilities-only.scss +1 -0
  210. package/tokens/README.md +158 -0
  211. package/tokens/css-utilities.js +56 -0
  212. package/tokens/map-scss-to-css.js +24 -0
  213. package/tokens/replace-variables.js +32 -0
  214. package/tokens/sass-helpers.js +98 -0
  215. package/tokens/src/core/alias/size.json +15 -0
  216. package/tokens/src/core/components/ActionRow.json +10 -0
  217. package/tokens/src/core/components/Alert.json +30 -0
  218. package/tokens/src/core/components/Annotation.json +25 -0
  219. package/tokens/src/core/components/Avatar.json +17 -0
  220. package/tokens/src/core/components/AvatarButton.json +11 -0
  221. package/tokens/src/core/components/Badge.json +33 -0
  222. package/tokens/src/core/components/Breadcrumb.json +37 -0
  223. package/tokens/src/core/components/Bubble.json +10 -0
  224. package/tokens/src/core/components/Button/core.json +105 -0
  225. package/tokens/src/core/components/Card.json +91 -0
  226. package/tokens/src/core/components/Carousel.json +37 -0
  227. package/tokens/src/core/components/Chip.json +43 -0
  228. package/tokens/src/core/components/ChipCarousel.json +15 -0
  229. package/tokens/src/core/components/CloseButton.json +14 -0
  230. package/tokens/src/core/components/Code.json +34 -0
  231. package/tokens/src/core/components/Collapsible.json +29 -0
  232. package/tokens/src/core/components/ColorPicker.json +8 -0
  233. package/tokens/src/core/components/Container.json +13 -0
  234. package/tokens/src/core/components/DataTable.json +27 -0
  235. package/tokens/src/core/components/Dropdown.json +67 -0
  236. package/tokens/src/core/components/Dropzone.json +21 -0
  237. package/tokens/src/core/components/Form/other.json +14 -0
  238. package/tokens/src/core/components/Form/size.json +233 -0
  239. package/tokens/src/core/components/Form/spacing.json +155 -0
  240. package/tokens/src/core/components/Form/transition.json +16 -0
  241. package/tokens/src/core/components/Form/typography.json +122 -0
  242. package/tokens/src/core/components/Icon.json +11 -0
  243. package/tokens/src/core/components/IconButton.json +15 -0
  244. package/tokens/src/core/components/Image.json +28 -0
  245. package/tokens/src/core/components/Menu.json +48 -0
  246. package/tokens/src/core/components/Modal.json +47 -0
  247. package/tokens/src/core/components/Nav.json +55 -0
  248. package/tokens/src/core/components/Navbar.json +70 -0
  249. package/tokens/src/core/components/Pagination.json +70 -0
  250. package/tokens/src/core/components/Popover.json +48 -0
  251. package/tokens/src/core/components/ProductTour.json +37 -0
  252. package/tokens/src/core/components/ProgressBar.json +39 -0
  253. package/tokens/src/core/components/SearchField.json +23 -0
  254. package/tokens/src/core/components/SelectableBox.json +9 -0
  255. package/tokens/src/core/components/Sheet.json +10 -0
  256. package/tokens/src/core/components/Spinner.json +19 -0
  257. package/tokens/src/core/components/Stack.json +7 -0
  258. package/tokens/src/core/components/Stepper.json +42 -0
  259. package/tokens/src/core/components/Sticky.json +7 -0
  260. package/tokens/src/core/components/Tab.json +19 -0
  261. package/tokens/src/core/components/Tabs.json +19 -0
  262. package/tokens/src/core/components/Toast.json +30 -0
  263. package/tokens/src/core/components/Tooltip.json +33 -0
  264. package/tokens/src/core/components/general/caret.json +13 -0
  265. package/tokens/src/core/components/general/headings.json +16 -0
  266. package/tokens/src/core/components/general/hr.json +10 -0
  267. package/tokens/src/core/components/general/input.json +51 -0
  268. package/tokens/src/core/components/general/link.json +30 -0
  269. package/tokens/src/core/components/general/list.json +26 -0
  270. package/tokens/src/core/components/general/text.json +24 -0
  271. package/tokens/src/core/global/breakpoints.json +12 -0
  272. package/tokens/src/core/global/display.json +21 -0
  273. package/tokens/src/core/global/elevation.json +19 -0
  274. package/tokens/src/core/global/other.json +4 -0
  275. package/tokens/src/core/global/spacing.json +35 -0
  276. package/tokens/src/core/global/transition.json +14 -0
  277. package/tokens/src/core/global/typography.json +91 -0
  278. package/tokens/src/core/utilities/color.json +12 -0
  279. package/tokens/src/themes/light/alias/color.json +114 -0
  280. package/tokens/src/themes/light/components/Alert.json +47 -0
  281. package/tokens/src/themes/light/components/Annotation.json +29 -0
  282. package/tokens/src/themes/light/components/Avatar.json +7 -0
  283. package/tokens/src/themes/light/components/Badge.json +186 -0
  284. package/tokens/src/themes/light/components/Breadcrumb.json +14 -0
  285. package/tokens/src/themes/light/components/Bubble.json +18 -0
  286. package/tokens/src/themes/light/components/Button/brand.json +260 -0
  287. package/tokens/src/themes/light/components/Button/core.json +24 -0
  288. package/tokens/src/themes/light/components/Button/danger.json +247 -0
  289. package/tokens/src/themes/light/components/Button/dark.json +230 -0
  290. package/tokens/src/themes/light/components/Button/info.json +238 -0
  291. package/tokens/src/themes/light/components/Button/light.json +236 -0
  292. package/tokens/src/themes/light/components/Button/primary.json +250 -0
  293. package/tokens/src/themes/light/components/Button/secondary.json +278 -0
  294. package/tokens/src/themes/light/components/Button/success.json +253 -0
  295. package/tokens/src/themes/light/components/Button/tertiary.json +109 -0
  296. package/tokens/src/themes/light/components/Button/warning.json +276 -0
  297. package/tokens/src/themes/light/components/Card.json +40 -0
  298. package/tokens/src/themes/light/components/Carousel.json +45 -0
  299. package/tokens/src/themes/light/components/Chip.json +50 -0
  300. package/tokens/src/themes/light/components/CloseButton.json +10 -0
  301. package/tokens/src/themes/light/components/Code.json +23 -0
  302. package/tokens/src/themes/light/components/DataTable.json +26 -0
  303. package/tokens/src/themes/light/components/Dropdown.json +41 -0
  304. package/tokens/src/themes/light/components/Dropzone.json +23 -0
  305. package/tokens/src/themes/light/components/Form/color.json +270 -0
  306. package/tokens/src/themes/light/components/Form/elevation.json +76 -0
  307. package/tokens/src/themes/light/components/Form/other.json +131 -0
  308. package/tokens/src/themes/light/components/IconButton.json +451 -0
  309. package/tokens/src/themes/light/components/Image.json +18 -0
  310. package/tokens/src/themes/light/components/Menu.json +30 -0
  311. package/tokens/src/themes/light/components/Modal.json +37 -0
  312. package/tokens/src/themes/light/components/Nav.json +166 -0
  313. package/tokens/src/themes/light/components/Navbar.json +136 -0
  314. package/tokens/src/themes/light/components/OverflowScroll.json +9 -0
  315. package/tokens/src/themes/light/components/PageBanner.json +24 -0
  316. package/tokens/src/themes/light/components/Pagination.json +45 -0
  317. package/tokens/src/themes/light/components/Popover.json +55 -0
  318. package/tokens/src/themes/light/components/ProductTour.json +35 -0
  319. package/tokens/src/themes/light/components/ProgressBar.json +20 -0
  320. package/tokens/src/themes/light/components/Scrollable.json +14 -0
  321. package/tokens/src/themes/light/components/SearchField.json +25 -0
  322. package/tokens/src/themes/light/components/Sheet.json +22 -0
  323. package/tokens/src/themes/light/components/Stepper.json +34 -0
  324. package/tokens/src/themes/light/components/Sticky.json +18 -0
  325. package/tokens/src/themes/light/components/Tab.json +62 -0
  326. package/tokens/src/themes/light/components/Toast.json +33 -0
  327. package/tokens/src/themes/light/components/Tooltip.json +30 -0
  328. package/tokens/src/themes/light/components/general/body.json +8 -0
  329. package/tokens/src/themes/light/components/general/headings.json +7 -0
  330. package/tokens/src/themes/light/components/general/hr.json +15 -0
  331. package/tokens/src/themes/light/components/general/input.json +18 -0
  332. package/tokens/src/themes/light/components/general/link.json +109 -0
  333. package/tokens/src/themes/light/components/general/list.json +38 -0
  334. package/tokens/src/themes/light/components/general/text.json +6 -0
  335. package/tokens/src/themes/light/global/color.json +1661 -0
  336. package/tokens/src/themes/light/global/elevation.json +201 -0
  337. package/tokens/src/themes/light/global/other.json +4 -0
  338. package/tokens/style-dictionary.js +223 -0
  339. package/tokens/utils.js +210 -0
  340. package/dist/ActionRow/_variables.scss +0 -2
  341. package/dist/Alert/_variables.scss +0 -24
  342. package/dist/Annotation/_variables.scss +0 -18
  343. package/dist/Avatar/_variables.scss +0 -10
  344. package/dist/AvatarButton/_variables.scss +0 -3
  345. package/dist/Badge/_variables.scss +0 -16
  346. package/dist/Breadcrumb/_variables.scss +0 -27
  347. package/dist/Bubble/_variables.scss +0 -8
  348. package/dist/Button/_variables.scss +0 -52
  349. package/dist/Button/deprecated/index.js +0 -149
  350. package/dist/Button/deprecated/index.js.map +0 -1
  351. package/dist/Card/_variables.scss +0 -55
  352. package/dist/Carousel/_variables.scss +0 -27
  353. package/dist/CheckBox/index.js +0 -102
  354. package/dist/CheckBox/index.js.map +0 -1
  355. package/dist/CheckBoxGroup/index.js +0 -15
  356. package/dist/CheckBoxGroup/index.js.map +0 -1
  357. package/dist/Chip/_variables.scss +0 -28
  358. package/dist/ChipCarousel/_variables.scss +0 -3
  359. package/dist/CloseButton/_variables.scss +0 -6
  360. package/dist/Code/_variables.scss +0 -17
  361. package/dist/Collapsible/_variables.scss +0 -12
  362. package/dist/ColorPicker/_variables.scss +0 -2
  363. package/dist/Container/_variables.scss +0 -5
  364. package/dist/DataTable/_variables.scss +0 -11
  365. package/dist/Dropdown/_variables.scss +0 -33
  366. package/dist/Dropdown/deprecated/DropdownButton.js +0 -44
  367. package/dist/Dropdown/deprecated/DropdownButton.js.map +0 -1
  368. package/dist/Dropdown/deprecated/DropdownItem.js +0 -33
  369. package/dist/Dropdown/deprecated/DropdownItem.js.map +0 -1
  370. package/dist/Dropdown/deprecated/DropdownMenu.js +0 -46
  371. package/dist/Dropdown/deprecated/DropdownMenu.js.map +0 -1
  372. package/dist/Dropdown/deprecated/index.js +0 -241
  373. package/dist/Dropdown/deprecated/index.js.map +0 -1
  374. package/dist/Dropzone/_variables.scss +0 -9
  375. package/dist/Fieldset/index.js +0 -117
  376. package/dist/Fieldset/index.js.map +0 -1
  377. package/dist/Fieldset/index.scss +0 -12
  378. package/dist/Form/_variables.scss +0 -267
  379. package/dist/Icon/_variables.scss +0 -7
  380. package/dist/Image/_variables.scss +0 -13
  381. package/dist/Input/index.js +0 -166
  382. package/dist/Input/index.js.map +0 -1
  383. package/dist/InputSelect/index.js +0 -105
  384. package/dist/InputSelect/index.js.map +0 -1
  385. package/dist/InputText/index.js +0 -45
  386. package/dist/InputText/index.js.map +0 -1
  387. package/dist/ListBox/index.js +0 -148
  388. package/dist/ListBox/index.js.map +0 -1
  389. package/dist/ListBoxOption/index.js +0 -94
  390. package/dist/ListBoxOption/index.js.map +0 -1
  391. package/dist/Menu/_variables.scss +0 -24
  392. package/dist/Modal/_variables.scss +0 -50
  393. package/dist/Modal/index.js +0 -292
  394. package/dist/Modal/index.js.map +0 -1
  395. package/dist/Nav/_variables.scss +0 -58
  396. package/dist/Navbar/_variables.scss +0 -40
  397. package/dist/OverflowScroll/_variables.scss +0 -5
  398. package/dist/OverflowScroll/index.scss +0 -1
  399. package/dist/Pagination/_variables.scss +0 -19
  400. package/dist/Popover/_variables.scss +0 -36
  401. package/dist/ProductTour/_variables.scss +0 -15
  402. package/dist/ProgressBar/_variables.scss +0 -23
  403. package/dist/RadioButtonGroup/index.js +0 -188
  404. package/dist/RadioButtonGroup/index.js.map +0 -1
  405. package/dist/SearchField/_variables.scss +0 -14
  406. package/dist/SelectableBox/_variables.scss +0 -5
  407. package/dist/Spinner/_variables.scss +0 -9
  408. package/dist/Stack/_variables.scss +0 -1
  409. package/dist/StatusAlert/index.js +0 -168
  410. package/dist/StatusAlert/index.js.map +0 -1
  411. package/dist/Stepper/_variables.scss +0 -18
  412. package/dist/Sticky/_variables.scss +0 -3
  413. package/dist/Table/_variables.scss +0 -34
  414. package/dist/Table/index.js +0 -267
  415. package/dist/Table/index.js.map +0 -1
  416. package/dist/Table/index.scss +0 -12
  417. package/dist/Tabs/_variables.scss +0 -24
  418. package/dist/Tabs/deprecated/Tabs.scss +0 -3
  419. package/dist/Tabs/deprecated/index.js +0 -123
  420. package/dist/Tabs/deprecated/index.js.map +0 -1
  421. package/dist/TextArea/index.js +0 -44
  422. package/dist/TextArea/index.js.map +0 -1
  423. package/dist/Toast/_variables.scss +0 -19
  424. package/dist/Tooltip/_variables.scss +0 -21
  425. package/dist/ValidationFormGroup/index.js +0 -106
  426. package/dist/ValidationFormGroup/index.js.map +0 -1
  427. package/dist/paragon.css +0 -45
  428. package/scss/core/_grid.scss +0 -21
  429. package/scss/core/_variables.scss +0 -875
  430. package/scss/core/core.scss +0 -21
  431. package/src/ActionRow/_variables.scss +0 -2
  432. package/src/Alert/_variables.scss +0 -24
  433. package/src/Annotation/_variables.scss +0 -18
  434. package/src/Avatar/_variables.scss +0 -10
  435. package/src/AvatarButton/_variables.scss +0 -3
  436. package/src/Badge/_variables.scss +0 -16
  437. package/src/Breadcrumb/_variables.scss +0 -27
  438. package/src/Bubble/_variables.scss +0 -8
  439. package/src/Button/_variables.scss +0 -52
  440. package/src/Button/deprecated/Button.test.jsx +0 -34
  441. package/src/Button/deprecated/index.jsx +0 -145
  442. package/src/Card/_variables.scss +0 -55
  443. package/src/Carousel/_variables.scss +0 -27
  444. package/src/CheckBox/CheckBox.test.jsx +0 -65
  445. package/src/CheckBox/README.md +0 -93
  446. package/src/CheckBox/index.jsx +0 -80
  447. package/src/CheckBoxGroup/CheckBoxGroup.test.jsx +0 -33
  448. package/src/CheckBoxGroup/README.md +0 -35
  449. package/src/CheckBoxGroup/index.jsx +0 -19
  450. package/src/Chip/_variables.scss +0 -28
  451. package/src/ChipCarousel/_variables.scss +0 -3
  452. package/src/CloseButton/_variables.scss +0 -6
  453. package/src/Code/_variables.scss +0 -17
  454. package/src/Collapsible/_variables.scss +0 -12
  455. package/src/ColorPicker/_variables.scss +0 -2
  456. package/src/Container/_variables.scss +0 -5
  457. package/src/DataTable/_variables.scss +0 -11
  458. package/src/Dropdown/_variables.scss +0 -33
  459. package/src/Dropdown/deprecated/Dropdown.test.jsx +0 -238
  460. package/src/Dropdown/deprecated/DropdownButton.jsx +0 -52
  461. package/src/Dropdown/deprecated/DropdownItem.jsx +0 -34
  462. package/src/Dropdown/deprecated/DropdownMenu.jsx +0 -50
  463. package/src/Dropdown/deprecated/__snapshots__/Dropdown.test.jsx.snap +0 -229
  464. package/src/Dropdown/deprecated/index.jsx +0 -222
  465. package/src/Dropzone/_variables.scss +0 -9
  466. package/src/Fieldset/Fieldset.test.jsx +0 -101
  467. package/src/Fieldset/README.md +0 -146
  468. package/src/Fieldset/index.jsx +0 -107
  469. package/src/Fieldset/index.scss +0 -12
  470. package/src/Form/_variables.scss +0 -267
  471. package/src/Icon/_variables.scss +0 -7
  472. package/src/Image/_variables.scss +0 -13
  473. package/src/Input/README.md +0 -74
  474. package/src/Input/__snapshots__/input.test.jsx.snap +0 -53
  475. package/src/Input/index.jsx +0 -151
  476. package/src/Input/input.test.jsx +0 -85
  477. package/src/InputSelect/README.md +0 -136
  478. package/src/InputSelect/index.jsx +0 -92
  479. package/src/InputText/InputText.test.jsx +0 -74
  480. package/src/InputText/README.md +0 -293
  481. package/src/InputText/index.jsx +0 -49
  482. package/src/ListBox/ListBox.test.jsx +0 -161
  483. package/src/ListBox/README.md +0 -185
  484. package/src/ListBox/index.jsx +0 -115
  485. package/src/ListBoxOption/ListBoxOption.test.jsx +0 -154
  486. package/src/ListBoxOption/index.jsx +0 -78
  487. package/src/Menu/_variables.scss +0 -24
  488. package/src/Modal/README.md +0 -148
  489. package/src/Modal/_variables.scss +0 -50
  490. package/src/Modal/index.jsx +0 -319
  491. package/src/Modal/tests/Modal.test.jsx +0 -261
  492. package/src/Nav/_variables.scss +0 -58
  493. package/src/Navbar/_variables.scss +0 -40
  494. package/src/OverflowScroll/_variables.scss +0 -5
  495. package/src/OverflowScroll/index.scss +0 -1
  496. package/src/Pagination/_variables.scss +0 -19
  497. package/src/Popover/_variables.scss +0 -36
  498. package/src/ProductTour/_variables.scss +0 -15
  499. package/src/ProgressBar/_variables.scss +0 -23
  500. package/src/RadioButtonGroup/README.md +0 -50
  501. package/src/RadioButtonGroup/RadioButtonGroup.test.jsx +0 -127
  502. package/src/RadioButtonGroup/index.jsx +0 -185
  503. package/src/SearchField/_variables.scss +0 -14
  504. package/src/SelectableBox/_variables.scss +0 -5
  505. package/src/Spinner/_variables.scss +0 -9
  506. package/src/Stack/_variables.scss +0 -1
  507. package/src/StatusAlert/README.md +0 -149
  508. package/src/StatusAlert/StatusAlert.test.jsx +0 -150
  509. package/src/StatusAlert/index.jsx +0 -144
  510. package/src/Stepper/_variables.scss +0 -18
  511. package/src/Sticky/_variables.scss +0 -3
  512. package/src/Table/README.md +0 -506
  513. package/src/Table/Table.test.jsx +0 -367
  514. package/src/Table/_variables.scss +0 -34
  515. package/src/Table/index.jsx +0 -264
  516. package/src/Table/index.scss +0 -12
  517. package/src/Tabs/_variables.scss +0 -24
  518. package/src/Tabs/deprecated/Tabs.scss +0 -3
  519. package/src/Tabs/deprecated/Tabs.test.jsx +0 -50
  520. package/src/Tabs/deprecated/index.jsx +0 -117
  521. package/src/TextArea/README.md +0 -63
  522. package/src/TextArea/index.jsx +0 -48
  523. package/src/Toast/_variables.scss +0 -19
  524. package/src/Tooltip/_variables.scss +0 -21
  525. package/src/ValidationFormGroup/README.md +0 -116
  526. package/src/ValidationFormGroup/ValidationFormGroup.test.jsx +0 -146
  527. package/src/ValidationFormGroup/__snapshots__/ValidationFormGroup.test.jsx.snap +0 -161
  528. package/src/ValidationFormGroup/index.jsx +0 -114
  529. /package/{scss → styles/scss}/core/_exports.module.scss +0 -0
  530. /package/{scss → styles/scss}/core/_typography.scss +0 -0
@@ -1,151 +0,0 @@
1
- import React from 'react';
2
- import classNames from 'classnames';
3
- import PropTypes from 'prop-types';
4
-
5
- class Input extends React.Component {
6
- componentDidMount() {
7
- if (process.env.NODE_ENV === 'development') {
8
- this.checkHasLabel();
9
- }
10
- }
11
-
12
- getHTMLTagForType() {
13
- const { type } = this.props;
14
- if (type === 'select' || type === 'textarea') { return type; }
15
- return 'input';
16
- }
17
-
18
- getClassNameForType() {
19
- switch (this.props.type) {
20
- case 'file':
21
- return 'form-control-file';
22
- case 'checkbox':
23
- case 'radio':
24
- return 'form-check-input';
25
- default:
26
- return 'form-control';
27
- }
28
- }
29
-
30
- setRef(forwardedRef) {
31
- // In production just return the optional forwardedRef
32
- if (process.env.NODE_ENV !== 'development') { return forwardedRef; }
33
-
34
- return (element) => {
35
- if (forwardedRef) { forwardedRef.current = element; } // eslint-disable-line no-param-reassign
36
- this.inputEl = element;
37
- };
38
- }
39
-
40
- checkHasLabel() {
41
- if (this.inputEl.labels.length > 0) { return; }
42
- if (this.inputEl.getAttribute('aria-label') !== null) { return; }
43
- if (this.inputEl.getAttribute('aria-labelledby') !== null) { return; }
44
-
45
- if (console) {
46
- // eslint-disable-next-line no-console
47
- console.warn('Input[a11y]: There is no associated label for this Input');
48
- }
49
- }
50
-
51
- renderOptions(options) {
52
- return options.map((option) => {
53
- const {
54
- value,
55
- label,
56
- group,
57
- ...attributes
58
- } = option;
59
-
60
- if (group) {
61
- return (
62
- <optgroup key={`optgroup-${label}`} label={label} {...attributes}>
63
- {this.renderOptions(group)}
64
- </optgroup>
65
- );
66
- }
67
- return (
68
- <option key={value} value={value} {...attributes}>
69
- {label}
70
- </option>
71
- );
72
- }, this);
73
- }
74
-
75
- render() {
76
- const {
77
- type,
78
- className,
79
- options,
80
- forwardedRef, // eslint-disable-line react/prop-types
81
- ...attributes // eslint-disable-line react/prop-types
82
- } = this.props;
83
-
84
- const htmlTag = this.getHTMLTagForType();
85
- const htmlProps = {
86
- className: classNames(this.getClassNameForType(), className),
87
- type: htmlTag === 'input' ? type : undefined,
88
- ...attributes,
89
- ref: this.setRef(forwardedRef),
90
- };
91
- const htmlChildren = type === 'select' ? this.renderOptions(options) : null;
92
-
93
- return React.createElement(htmlTag, htmlProps, htmlChildren);
94
- }
95
- }
96
-
97
- Input.propTypes = {
98
- /** specifies the type of component.
99
- * One of select, textarea, or any valid type for an html input tag. */
100
- type: PropTypes.oneOf([
101
- 'textarea',
102
- 'select',
103
- 'checkbox',
104
- 'color',
105
- 'date',
106
- 'datetime',
107
- 'datetime-local',
108
- 'email',
109
- 'file',
110
- 'hidden',
111
- 'image',
112
- 'month',
113
- 'number',
114
- 'password',
115
- 'radio',
116
- 'range',
117
- 'reset',
118
- 'search',
119
- 'submit',
120
- 'tel',
121
- 'text',
122
- 'time',
123
- 'url',
124
- 'week',
125
- ]).isRequired,
126
- /** specifies the className in addition to a bootstrap class name. */
127
- className: PropTypes.string,
128
- /** should be used to specify the options of an Input of type select */
129
- options: PropTypes.arrayOf(PropTypes.shape({
130
- label: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
131
- value: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
132
- disabled: PropTypes.bool,
133
- group: PropTypes.arrayOf(PropTypes.shape({
134
- label: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
135
- value: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
136
- disabled: PropTypes.bool,
137
- })),
138
- })),
139
- };
140
-
141
- Input.defaultProps = {
142
- className: undefined,
143
- options: [],
144
- };
145
-
146
- // eslint-disable-next-line react/no-multi-comp
147
- const InputWithRefForwarding = React.forwardRef((props, ref) => (
148
- <Input forwardedRef={ref} {...props} />
149
- ));
150
-
151
- export default InputWithRefForwarding;
@@ -1,85 +0,0 @@
1
- import React from 'react';
2
- import { render } from '@testing-library/react';
3
- import renderer from 'react-test-renderer';
4
-
5
- import Input from '.';
6
-
7
- describe('<Input />', () => {
8
- const label = 'label';
9
- const name = 'name';
10
- const className = 'input';
11
- const props = {
12
- label,
13
- name,
14
- className,
15
- };
16
- const types = [
17
- 'textarea',
18
- 'select',
19
- 'checkbox',
20
- 'color',
21
- 'date',
22
- 'datetime',
23
- 'datetime-local',
24
- 'email',
25
- 'file',
26
- 'hidden',
27
- 'image',
28
- 'month',
29
- 'number',
30
- 'password',
31
- 'radio',
32
- 'range',
33
- 'reset',
34
- 'search',
35
- 'submit',
36
- 'tel',
37
- 'text',
38
- 'time',
39
- 'url',
40
- 'week',
41
- ];
42
-
43
- const groupInput = (
44
- <Input
45
- type="select"
46
- defaultValue="Foo Bar"
47
- options={[
48
- { value: 'Foo Bar', label: 'Foo Bar' },
49
- { value: 'Foos Bar', label: 'Bar foo' },
50
- { value: 'Foo sBar', label: 'FoBaro' },
51
- { value: 'Foo ssBar', label: 'Farboo' },
52
- {
53
- label: 'But there is more',
54
- group: [
55
- { value: 'vFoo Bar', label: 'Foov Bar' },
56
- { value: 'vFoos Bar', label: 'Barv foo' },
57
- { value: 'vFoo sBar', label: 'FoBarov' },
58
- { value: 'vFoo ssBar', label: 'Farboov' },
59
- ],
60
- },
61
- ]}
62
- />
63
- );
64
-
65
- describe('rendering', () => {
66
- it('should render with forwardRef', () => {
67
- const refSpy = jest.fn();
68
- render(<Input type="text" ref={refSpy} {...props} />);
69
- expect(refSpy).toHaveBeenCalled();
70
- });
71
-
72
- it('should render each input type', () => {
73
- types.forEach((type) => {
74
- const { container } = render(<Input type={type} {...props} />);
75
- const input = container.querySelector('.input');
76
- expect(input).toBeInTheDocument();
77
- });
78
- });
79
-
80
- it('properly renders groups', () => {
81
- const tree = renderer.create(groupInput).toJSON();
82
- expect(tree).toMatchSnapshot();
83
- });
84
- });
85
- });
@@ -1,136 +0,0 @@
1
- ---
2
- title: 'InputSelect'
3
- type: 'component'
4
- components:
5
- - InputSelect
6
- categories:
7
- - Forms (deprecated)
8
- status: 'Deprecate Soon'
9
- designStatus: 'TBD'
10
- devStatus: 'To Do'
11
- notes: |
12
- Replaced by Form.Control
13
- ---
14
-
15
- ## Basic usage
16
-
17
- ```jsx live
18
- <InputSelect
19
- name="fruits"
20
- label="Fruits"
21
- value="strawberry"
22
- options={[
23
- 'apple',
24
- 'orange',
25
- 'strawberry',
26
- 'banana',
27
- ]}
28
- />
29
- ```
30
-
31
- ## Separate labels and values
32
-
33
- ```jsx live
34
- <InputSelect
35
- name="new-england-states"
36
- label="New England States"
37
- value="RI"
38
- options={[
39
- { label: 'Connecticut', value: 'CN' },
40
- { label: 'Maine', value: 'ME' },
41
- { label: 'Massachusetts', value: 'MA' },
42
- { label: 'New Hampshire', value: 'NH' },
43
- { label: 'Rhode Island', value: 'RI' },
44
- { label: 'Vermont', value: 'VT' },
45
- ]}
46
- />
47
- ```
48
-
49
- ## Separate option groups
50
-
51
- ```jsx live
52
- <InputSelect
53
- name="northeast-states"
54
- label="Northeast States"
55
- value="MD"
56
- options={[
57
- {
58
- label: 'New England States',
59
- options: [
60
- { label: 'Connecticut', value: 'CN' },
61
- { label: 'Maine', value: 'ME' },
62
- { label: 'Massachusetts', value: 'MA' },
63
- { label: 'New Hampshire', value: 'NH' },
64
- { label: 'Rhode Island', value: 'RI' },
65
- { label: 'Vermont', value: 'VT' },
66
- ],
67
- },
68
- {
69
- label: 'Mid Atlantic States',
70
- options: [
71
- { label: 'Delaware', value: 'DE' },
72
- { label: 'Maryland', value: 'MD' },
73
- { label: 'New Jersey', value: 'NJ' },
74
- { label: 'New York', value: 'NY' },
75
- { label: 'Pennsylvania', value: 'PA' },
76
- { label: 'Virginia', value: 'VA' },
77
- { label: 'Washington, DC', value: 'DC' },
78
- { label: 'West Virginia', value: 'WV' },
79
- ],
80
- },
81
- ]}
82
- />
83
- ```
84
-
85
- ## With validation
86
-
87
- ```jsx live
88
- <InputSelect
89
- name="color"
90
- label="Favorite Color"
91
- options={['', 'red', 'orange', 'yellow', 'green', 'blue', 'purple']}
92
- validator={value => {
93
- let feedback = { isValid: true };
94
- if (!value) {
95
- feedback = {
96
- isValid: false,
97
- validationMessage: 'Please make a selection.',
98
- };
99
- }
100
- return feedback;
101
- }}
102
- />
103
- ```
104
-
105
- ## Disabled usage
106
-
107
- ```jsx live
108
- <InputSelect
109
- name="fruits"
110
- label="Fruits"
111
- aria-label="Fruits"
112
- value="strawberry"
113
- options={[
114
- 'apple',
115
- 'orange',
116
- 'strawberry',
117
- 'banana',
118
- ]}
119
- disabled
120
- />
121
- ```
122
-
123
- ## With disabled option
124
-
125
- ```jsx live
126
- <InputSelect
127
- name="fruits"
128
- label="Fruits"
129
- value="strawberry"
130
- options={[
131
- { label: 'apple', value: 'apple' },
132
- { label: 'orange', value: 'orange', disabled: true },
133
- { label: 'banana', value: 'banana', disabled: true },
134
- ]}
135
- />
136
- ```
@@ -1,92 +0,0 @@
1
- import React from 'react';
2
- import PropTypes from 'prop-types';
3
-
4
- import asInput from '../asInput';
5
- import withDeprecatedProps, { DeprTypes } from '../withDeprecatedProps';
6
-
7
- class Select extends React.Component {
8
- static getOption(option, i) {
9
- const { disabled } = option;
10
- let { label, value } = option;
11
-
12
- if (typeof option === 'string') {
13
- label = option;
14
- value = option;
15
- }
16
-
17
- return (
18
- <option
19
- key={`option-${i}`}
20
- value={value}
21
- disabled={disabled}
22
- >
23
- {label}
24
- </option>
25
- );
26
- }
27
-
28
- getOptions() {
29
- return this.props.options.map((option, i) => {
30
- let section;
31
- if (option.options) {
32
- const groupOpts = option.options.map((opt, j) => Select.getOption(opt, j));
33
- section = (
34
- <optgroup label={option.label} key={option.label}>
35
- {groupOpts}
36
- </optgroup>
37
- );
38
- } else {
39
- section = Select.getOption(option, i);
40
- }
41
- return section;
42
- });
43
- }
44
-
45
- render() {
46
- const {
47
- className,
48
- inputRef,
49
- ...others
50
- } = this.props;
51
- const options = this.getOptions();
52
-
53
- return (
54
- <select
55
- {...others}
56
- className={className}
57
- type="select"
58
- ref={inputRef}
59
- >
60
- {options}
61
- </select>
62
- );
63
- }
64
- }
65
-
66
- Select.propTypes = {
67
- className: PropTypes.string,
68
- inputRef: PropTypes.oneOfType([
69
- PropTypes.func,
70
- PropTypes.shape({ current: PropTypes.instanceOf(PropTypes.element) }),
71
- ]),
72
- options: PropTypes.oneOfType([
73
- PropTypes.arrayOf(PropTypes.string),
74
- PropTypes.arrayOf(PropTypes.shape({})),
75
- ]).isRequired,
76
- };
77
-
78
- Select.defaultProps = {
79
- className: undefined,
80
- inputRef: undefined,
81
- };
82
-
83
- const InputSelect = asInput(withDeprecatedProps(Select, 'InputSelect', {
84
- className: {
85
- deprType: DeprTypes.FORMAT,
86
- expect: value => typeof value === 'string',
87
- transform: value => (Array.isArray(value) ? value.join(' ') : value),
88
- message: 'It should be a string.',
89
- },
90
- }));
91
-
92
- export default InputSelect;
@@ -1,74 +0,0 @@
1
- import React from 'react';
2
- import { render } from '@testing-library/react';
3
-
4
- import InputText from '.';
5
-
6
- describe('<InputText />', () => {
7
- const label = 'label';
8
- const name = 'name';
9
- const props = {
10
- label,
11
- name,
12
- };
13
-
14
- describe('rendering', () => {
15
- it('should render with default type when type is not defined', () => {
16
- const { container } = render(<InputText {...props} />);
17
- const input = container.querySelector('input');
18
- expect(input).toBeInTheDocument();
19
- expect(input.type).toEqual('text');
20
- });
21
-
22
- it('should render with default type when type is defined as undefined', () => {
23
- const { container } = render(<InputText {...props} type={undefined} />);
24
- const input = container.querySelector('input');
25
- expect(input).toBeInTheDocument();
26
- expect(input.type).toEqual('text');
27
- });
28
-
29
- it('should render with default type when type is defined as null', () => {
30
- const { container } = render(<InputText {...props} type={null} />);
31
- const input = container.querySelector('input');
32
- expect(input).toBeInTheDocument();
33
- expect(input.type).toEqual('text');
34
- });
35
-
36
- it('should render with specified type when type is defined', () => {
37
- const type = 'foobar';
38
- const { getByRole } = render(<InputText {...props} type={type} />);
39
- const input = getByRole('textbox', { type: 'foobar' });
40
- expect(input).toBeInTheDocument();
41
- expect(input.getAttribute('type')).toEqual(type);
42
- });
43
-
44
- it('should render with the autoComplete property if set', () => {
45
- const { container } = render(<InputText {...props} autoComplete="off" />);
46
- const input = container.querySelector('input');
47
- expect(input).toBeInTheDocument();
48
- expect(input.getAttribute('autocomplete')).toEqual('off');
49
- });
50
-
51
- it('should render with custom classNames if set', () => {
52
- const { container } = render(<InputText {...props} className={['first', 'last']} />);
53
- const input = container.querySelector('input');
54
- expect(input).toBeInTheDocument();
55
- expect(input.type).toEqual('text');
56
- expect(input.classList.contains('first')).toBe(true);
57
- expect(input.classList.contains('last')).toBe(true);
58
- });
59
-
60
- it('should not be readOnly if the readOnly property is not set', () => {
61
- const { container } = render(<InputText {...props} />);
62
- const input = container.querySelector('input');
63
- expect(input).toBeInTheDocument();
64
- expect(input.readOnly).toBe(false);
65
- });
66
-
67
- it('should render with the readOnly property if set', () => {
68
- const { container } = render(<InputText {...props} readOnly />);
69
- const input = container.querySelector('input');
70
- expect(input).toBeInTheDocument();
71
- expect(input.readOnly).toBe(true);
72
- });
73
- });
74
- });