@openedx/paragon 21.7.1 → 22.0.0-alpha.15

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 (543) hide show
  1. package/README.md +36 -5
  2. package/bin/paragon-scripts.js +128 -10
  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 -358
  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 +36 -34
  21. package/dist/ChipCarousel/index.scss +1 -3
  22. package/dist/CloseButton/index.scss +31 -2
  23. package/dist/Code/index.scss +47 -2
  24. package/dist/Collapsible/index.scss +15 -15
  25. package/dist/ColorPicker/index.scss +9 -11
  26. package/dist/DataTable/CollapsibleButtonGroup.js +2 -2
  27. package/dist/DataTable/CollapsibleButtonGroup.js.map +1 -1
  28. package/dist/DataTable/ExpandRow.js +8 -3
  29. package/dist/DataTable/ExpandRow.js.map +1 -1
  30. package/dist/DataTable/filters/TextFilter.js +2 -3
  31. package/dist/DataTable/filters/TextFilter.js.map +1 -1
  32. package/dist/DataTable/index.scss +48 -50
  33. package/dist/DataTable/selection/ControlledSelect.js +7 -3
  34. package/dist/DataTable/selection/ControlledSelect.js.map +1 -1
  35. package/dist/DataTable/selection/ControlledSelectHeader.js +7 -3
  36. package/dist/DataTable/selection/ControlledSelectHeader.js.map +1 -1
  37. package/dist/DataTable/selection/ControlledSelectionStatus.js +14 -5
  38. package/dist/DataTable/selection/ControlledSelectionStatus.js.map +1 -1
  39. package/dist/Dropdown/dropdown-bootstrap.scss +181 -0
  40. package/dist/Dropdown/index.js +0 -2
  41. package/dist/Dropdown/index.js.map +1 -1
  42. package/dist/Dropdown/index.scss +11 -12
  43. package/dist/Dropzone/index.scss +12 -14
  44. package/dist/Form/_FormText.scss +8 -8
  45. package/dist/Form/_bootstrap-custom-forms.scss +551 -0
  46. package/dist/Form/_bootstrap-forms.scss +381 -0
  47. package/dist/Form/_index.scss +165 -143
  48. package/dist/Form/_input-group.scss +188 -0
  49. package/dist/Form/_mixins.scss +216 -3
  50. package/dist/Hyperlink/index.scss +1 -1
  51. package/dist/Icon/index.scss +10 -12
  52. package/dist/IconButton/_mixins.scss +4 -0
  53. package/dist/IconButton/index.js +5 -11
  54. package/dist/IconButton/index.js.map +1 -1
  55. package/dist/IconButton/index.scss +387 -74
  56. package/dist/IconButtonToggle/index.scss +1 -1
  57. package/dist/Image/index.scss +53 -2
  58. package/dist/Menu/index.scss +25 -27
  59. package/dist/Modal/_ModalDialog.scss +51 -49
  60. package/dist/Modal/index.scss +6 -73
  61. package/dist/Nav/_mixins.scss +4 -4
  62. package/dist/Nav/index.scss +70 -66
  63. package/dist/Navbar/index.scss +276 -2
  64. package/dist/OverflowScroll/data/useOverflowScrollElementAttributes.js +3 -3
  65. package/dist/Overlay/index.js +2 -3
  66. package/dist/Overlay/index.js.map +1 -1
  67. package/dist/PageBanner/index.scss +17 -21
  68. package/dist/Pagination/index.scss +51 -46
  69. package/dist/Pagination/pagination-bootstrap.scss +83 -0
  70. package/dist/Popover/index.scss +9 -10
  71. package/dist/Popover/popover-bootstrap.scss +198 -0
  72. package/dist/ProductTour/Checkpoint.scss +71 -43
  73. package/dist/ProgressBar/_mixins.scss +22 -0
  74. package/dist/ProgressBar/bootstrap-progress.scss +49 -0
  75. package/dist/ProgressBar/index.scss +28 -36
  76. package/dist/Scrollable/index.scss +2 -2
  77. package/dist/SearchField/SearchFieldInput.js +2 -2
  78. package/dist/SearchField/SearchFieldInput.js.map +1 -1
  79. package/dist/SearchField/index.scss +19 -21
  80. package/dist/SelectableBox/index.scss +11 -13
  81. package/dist/Sheet/index.scss +10 -10
  82. package/dist/Spinner/index.scss +57 -2
  83. package/dist/Stack/index.scss +1 -3
  84. package/dist/Stepper/index.scss +19 -20
  85. package/dist/Sticky/index.scss +4 -6
  86. package/dist/Tabs/index.js +0 -2
  87. package/dist/Tabs/index.js.map +1 -1
  88. package/dist/Tabs/index.scss +23 -30
  89. package/dist/Toast/ToastContainer.scss +9 -11
  90. package/dist/Toast/bootstrap-toast.scss +46 -0
  91. package/dist/Toast/index.scss +9 -10
  92. package/dist/Tooltip/index.scss +136 -10
  93. package/dist/ValidationMessage/index.scss +1 -1
  94. package/dist/core.css +16706 -0
  95. package/dist/core.css.map +1 -0
  96. package/dist/core.min.css +2 -0
  97. package/dist/index.js +0 -14
  98. package/dist/index.scss +0 -4
  99. package/dist/light.css +4083 -0
  100. package/dist/light.css.map +1 -0
  101. package/dist/light.min.css +2 -0
  102. package/dist/theme-urls.json +21 -0
  103. package/dist/utils/breakpoints.js +1 -1
  104. package/lib/build-scss.js +188 -0
  105. package/lib/build-tokens.js +119 -0
  106. package/lib/help.js +36 -23
  107. package/lib/replace-variables.js +38 -0
  108. package/lib/utils.js +9 -0
  109. package/package.json +25 -11
  110. package/src/ActionRow/_index.scss +2 -4
  111. package/src/Alert/index.scss +41 -32
  112. package/src/Annotation/_mixins.scss +104 -0
  113. package/src/Annotation/index.scss +130 -103
  114. package/src/Avatar/index.scss +18 -20
  115. package/src/AvatarButton/index.scss +3 -5
  116. package/src/Badge/index.scss +112 -2
  117. package/src/Breadcrumb/index.scss +14 -16
  118. package/src/Bubble/index.scss +25 -12
  119. package/src/Button/README.md +0 -54
  120. package/src/Button/_mixins.scss +14 -0
  121. package/src/Button/button-group.scss +126 -0
  122. package/src/Button/index.jsx +0 -3
  123. package/src/Button/index.scss +855 -358
  124. package/src/Card/card-bootstrap.scss +168 -0
  125. package/src/Card/index.scss +78 -79
  126. package/src/Carousel/index.scss +168 -2
  127. package/src/Chip/index.scss +36 -34
  128. package/src/ChipCarousel/index.scss +1 -3
  129. package/src/CloseButton/index.scss +31 -2
  130. package/src/Code/index.scss +47 -2
  131. package/src/Collapsible/index.scss +15 -15
  132. package/src/ColorPicker/index.scss +9 -11
  133. package/src/DataTable/CollapsibleButtonGroup.jsx +2 -2
  134. package/src/DataTable/ExpandRow.jsx +2 -2
  135. package/src/DataTable/filters/TextFilter.jsx +2 -3
  136. package/src/DataTable/index.scss +48 -50
  137. package/src/DataTable/selection/ControlledSelect.jsx +2 -1
  138. package/src/DataTable/selection/ControlledSelectHeader.jsx +2 -1
  139. package/src/DataTable/selection/ControlledSelectionStatus.jsx +2 -1
  140. package/src/DataTable/tests/ExpandRow.test.jsx +8 -2
  141. package/src/Dropdown/README.md +0 -93
  142. package/src/Dropdown/dropdown-bootstrap.scss +181 -0
  143. package/src/Dropdown/index.jsx +0 -2
  144. package/src/Dropdown/index.scss +11 -12
  145. package/src/Dropzone/index.scss +12 -14
  146. package/src/Form/_FormText.scss +8 -8
  147. package/src/Form/_bootstrap-custom-forms.scss +551 -0
  148. package/src/Form/_bootstrap-forms.scss +381 -0
  149. package/src/Form/_index.scss +165 -143
  150. package/src/Form/_input-group.scss +188 -0
  151. package/src/Form/_mixins.scss +216 -3
  152. package/src/Hyperlink/index.scss +1 -1
  153. package/src/Icon/index.scss +10 -12
  154. package/src/IconButton/README.md +1 -15
  155. package/src/IconButton/__snapshots__/IconButton.test.jsx.snap +5 -26
  156. package/src/IconButton/_mixins.scss +4 -0
  157. package/src/IconButton/index.jsx +6 -13
  158. package/src/IconButton/index.scss +387 -74
  159. package/src/IconButtonToggle/index.scss +1 -1
  160. package/src/Image/index.scss +53 -2
  161. package/src/Menu/index.scss +25 -27
  162. package/src/Modal/_ModalDialog.scss +51 -49
  163. package/src/Modal/index.scss +6 -73
  164. package/src/Nav/_mixins.scss +4 -4
  165. package/src/Nav/index.scss +70 -66
  166. package/src/Navbar/index.scss +276 -2
  167. package/src/OverflowScroll/data/useOverflowScrollElementAttributes.js +3 -3
  168. package/src/Overlay/index.jsx +2 -3
  169. package/src/PageBanner/index.scss +17 -21
  170. package/src/Pagination/index.scss +51 -46
  171. package/src/Pagination/pagination-bootstrap.scss +83 -0
  172. package/src/Popover/index.scss +9 -10
  173. package/src/Popover/popover-bootstrap.scss +198 -0
  174. package/src/ProductTour/Checkpoint.scss +71 -43
  175. package/src/ProgressBar/_mixins.scss +22 -0
  176. package/src/ProgressBar/bootstrap-progress.scss +49 -0
  177. package/src/ProgressBar/index.scss +28 -36
  178. package/src/Scrollable/index.scss +2 -2
  179. package/src/SearchField/SearchFieldInput.jsx +2 -2
  180. package/src/SearchField/__snapshots__/SearchField.test.jsx.snap +12 -8
  181. package/src/SearchField/index.scss +19 -21
  182. package/src/SelectableBox/index.scss +11 -13
  183. package/src/Sheet/index.scss +10 -10
  184. package/src/Spinner/index.scss +57 -2
  185. package/src/Stack/index.scss +1 -3
  186. package/src/Stepper/index.scss +19 -20
  187. package/src/Sticky/index.scss +4 -6
  188. package/src/Tabs/README.md +1 -25
  189. package/src/Tabs/index.jsx +0 -3
  190. package/src/Tabs/index.scss +23 -30
  191. package/src/Toast/ToastContainer.scss +9 -11
  192. package/src/Toast/bootstrap-toast.scss +46 -0
  193. package/src/Toast/index.scss +9 -10
  194. package/src/Tooltip/index.scss +136 -10
  195. package/src/TransitionReplace/README.md +4 -4
  196. package/src/ValidationMessage/index.scss +1 -1
  197. package/src/index.js +0 -14
  198. package/src/index.scss +0 -4
  199. package/src/utils/breakpoints.js +1 -1
  200. package/styles/css/core/custom-media-breakpoints.css +17 -0
  201. package/styles/css/core/index.css +2 -0
  202. package/styles/css/core/variables.css +608 -0
  203. package/styles/css/themes/light/index.css +2 -0
  204. package/styles/css/themes/light/utility-classes.css +2454 -0
  205. package/styles/css/themes/light/variables.css +1629 -0
  206. package/{scss → styles/scss}/core/_functions.scss +1 -1
  207. package/styles/scss/core/_grid.scss +21 -0
  208. package/{scss → styles/scss}/core/_utilities.scss +17 -11
  209. package/styles/scss/core/_variables.scss +869 -0
  210. package/styles/scss/core/bootstrap-override/_functions.scss +104 -0
  211. package/styles/scss/core/bootstrap-override/_mixins.scss +4 -0
  212. package/styles/scss/core/bootstrap-override/_utilities.scss +4 -0
  213. package/styles/scss/core/bootstrap-override/bootstrap.scss +2 -0
  214. package/styles/scss/core/bootstrap-override/mixins/_grid-framework.scss +80 -0
  215. package/styles/scss/core/bootstrap-override/mixins/_grid.scss +69 -0
  216. package/styles/scss/core/bootstrap-override/mixins/_list-group.scss +22 -0
  217. package/styles/scss/core/bootstrap-override/utilities/_background.scss +7 -0
  218. package/styles/scss/core/bootstrap-override/utilities/_borders.scss +67 -0
  219. package/styles/scss/core/bootstrap-override/utilities/_spacing.scss +70 -0
  220. package/styles/scss/core/bootstrap-override/utilities/_text.scss +68 -0
  221. package/styles/scss/core/core.scss +20 -0
  222. package/{scss → styles/scss}/core/utilities-only.scss +1 -0
  223. package/tokens/README.md +158 -0
  224. package/tokens/css-utilities.js +56 -0
  225. package/tokens/map-scss-to-css.js +24 -0
  226. package/tokens/replace-variables.js +32 -0
  227. package/tokens/sass-helpers.js +98 -0
  228. package/tokens/src/core/alias/size.json +15 -0
  229. package/tokens/src/core/components/ActionRow.json +10 -0
  230. package/tokens/src/core/components/Alert.json +30 -0
  231. package/tokens/src/core/components/Annotation.json +25 -0
  232. package/tokens/src/core/components/Avatar.json +17 -0
  233. package/tokens/src/core/components/AvatarButton.json +11 -0
  234. package/tokens/src/core/components/Badge.json +33 -0
  235. package/tokens/src/core/components/Breadcrumb.json +37 -0
  236. package/tokens/src/core/components/Bubble.json +10 -0
  237. package/tokens/src/core/components/Button/core.json +101 -0
  238. package/tokens/src/core/components/Card.json +91 -0
  239. package/tokens/src/core/components/Carousel.json +37 -0
  240. package/tokens/src/core/components/Chip.json +19 -0
  241. package/tokens/src/core/components/ChipCarousel.json +9 -0
  242. package/tokens/src/core/components/CloseButton.json +14 -0
  243. package/tokens/src/core/components/Code.json +34 -0
  244. package/tokens/src/core/components/Collapsible.json +29 -0
  245. package/tokens/src/core/components/ColorPicker.json +8 -0
  246. package/tokens/src/core/components/Container.json +13 -0
  247. package/tokens/src/core/components/DataTable.json +27 -0
  248. package/tokens/src/core/components/Dropdown.json +67 -0
  249. package/tokens/src/core/components/Dropzone.json +25 -0
  250. package/tokens/src/core/components/Form/other.json +14 -0
  251. package/tokens/src/core/components/Form/size.json +233 -0
  252. package/tokens/src/core/components/Form/spacing.json +155 -0
  253. package/tokens/src/core/components/Form/transition.json +16 -0
  254. package/tokens/src/core/components/Form/typography.json +122 -0
  255. package/tokens/src/core/components/Icon.json +11 -0
  256. package/tokens/src/core/components/IconButton.json +15 -0
  257. package/tokens/src/core/components/Image.json +28 -0
  258. package/tokens/src/core/components/Menu.json +48 -0
  259. package/tokens/src/core/components/Modal.json +47 -0
  260. package/tokens/src/core/components/Nav.json +55 -0
  261. package/tokens/src/core/components/Navbar.json +70 -0
  262. package/tokens/src/core/components/Pagination.json +70 -0
  263. package/tokens/src/core/components/Popover.json +48 -0
  264. package/tokens/src/core/components/ProductTour.json +37 -0
  265. package/tokens/src/core/components/ProgressBar.json +44 -0
  266. package/tokens/src/core/components/SearchField.json +23 -0
  267. package/tokens/src/core/components/SelectableBox.json +9 -0
  268. package/tokens/src/core/components/Sheet.json +10 -0
  269. package/tokens/src/core/components/Spinner.json +19 -0
  270. package/tokens/src/core/components/Stack.json +7 -0
  271. package/tokens/src/core/components/Stepper.json +42 -0
  272. package/tokens/src/core/components/Sticky.json +7 -0
  273. package/tokens/src/core/components/Tab.json +18 -0
  274. package/tokens/src/core/components/Tabs.json +19 -0
  275. package/tokens/src/core/components/Toast.json +30 -0
  276. package/tokens/src/core/components/Tooltip.json +33 -0
  277. package/tokens/src/core/components/general/caret.json +13 -0
  278. package/tokens/src/core/components/general/headings.json +16 -0
  279. package/tokens/src/core/components/general/hr.json +10 -0
  280. package/tokens/src/core/components/general/input.json +51 -0
  281. package/tokens/src/core/components/general/link.json +30 -0
  282. package/tokens/src/core/components/general/list.json +26 -0
  283. package/tokens/src/core/components/general/text.json +24 -0
  284. package/tokens/src/core/global/breakpoints.json +12 -0
  285. package/tokens/src/core/global/display.json +21 -0
  286. package/tokens/src/core/global/elevation.json +19 -0
  287. package/tokens/src/core/global/other.json +4 -0
  288. package/tokens/src/core/global/spacing.json +35 -0
  289. package/tokens/src/core/global/transition.json +14 -0
  290. package/tokens/src/core/global/typography.json +91 -0
  291. package/tokens/src/core/utilities/color.json +12 -0
  292. package/tokens/src/themes/light/alias/color.json +114 -0
  293. package/tokens/src/themes/light/components/Alert.json +47 -0
  294. package/tokens/src/themes/light/components/Annotation.json +29 -0
  295. package/tokens/src/themes/light/components/Avatar.json +7 -0
  296. package/tokens/src/themes/light/components/Badge.json +186 -0
  297. package/tokens/src/themes/light/components/Breadcrumb.json +15 -0
  298. package/tokens/src/themes/light/components/Bubble.json +18 -0
  299. package/tokens/src/themes/light/components/Button/brand.json +260 -0
  300. package/tokens/src/themes/light/components/Button/core.json +24 -0
  301. package/tokens/src/themes/light/components/Button/danger.json +247 -0
  302. package/tokens/src/themes/light/components/Button/dark.json +230 -0
  303. package/tokens/src/themes/light/components/Button/info.json +238 -0
  304. package/tokens/src/themes/light/components/Button/light.json +236 -0
  305. package/tokens/src/themes/light/components/Button/primary.json +250 -0
  306. package/tokens/src/themes/light/components/Button/secondary.json +278 -0
  307. package/tokens/src/themes/light/components/Button/success.json +253 -0
  308. package/tokens/src/themes/light/components/Button/tertiary.json +109 -0
  309. package/tokens/src/themes/light/components/Button/warning.json +276 -0
  310. package/tokens/src/themes/light/components/Card.json +40 -0
  311. package/tokens/src/themes/light/components/Carousel.json +45 -0
  312. package/tokens/src/themes/light/components/Chip.json +19 -0
  313. package/tokens/src/themes/light/components/CloseButton.json +10 -0
  314. package/tokens/src/themes/light/components/Code.json +23 -0
  315. package/tokens/src/themes/light/components/DataTable.json +26 -0
  316. package/tokens/src/themes/light/components/Dropdown.json +36 -0
  317. package/tokens/src/themes/light/components/Dropzone.json +19 -0
  318. package/tokens/src/themes/light/components/Form/color.json +270 -0
  319. package/tokens/src/themes/light/components/Form/elevation.json +76 -0
  320. package/tokens/src/themes/light/components/Form/other.json +131 -0
  321. package/tokens/src/themes/light/components/IconButton.json +451 -0
  322. package/tokens/src/themes/light/components/Image.json +18 -0
  323. package/tokens/src/themes/light/components/Menu.json +30 -0
  324. package/tokens/src/themes/light/components/Modal.json +37 -0
  325. package/tokens/src/themes/light/components/Nav.json +145 -0
  326. package/tokens/src/themes/light/components/Navbar.json +136 -0
  327. package/tokens/src/themes/light/components/OverflowScroll.json +9 -0
  328. package/tokens/src/themes/light/components/PageBanner.json +24 -0
  329. package/tokens/src/themes/light/components/Pagination.json +40 -0
  330. package/tokens/src/themes/light/components/Popover.json +55 -0
  331. package/tokens/src/themes/light/components/ProductTour.json +35 -0
  332. package/tokens/src/themes/light/components/ProgressBar.json +20 -0
  333. package/tokens/src/themes/light/components/Scrollable.json +14 -0
  334. package/tokens/src/themes/light/components/SearchField.json +25 -0
  335. package/tokens/src/themes/light/components/Sheet.json +22 -0
  336. package/tokens/src/themes/light/components/Stepper.json +34 -0
  337. package/tokens/src/themes/light/components/Sticky.json +18 -0
  338. package/tokens/src/themes/light/components/Tab.json +55 -0
  339. package/tokens/src/themes/light/components/Toast.json +33 -0
  340. package/tokens/src/themes/light/components/Tooltip.json +30 -0
  341. package/tokens/src/themes/light/components/general/body.json +8 -0
  342. package/tokens/src/themes/light/components/general/headings.json +7 -0
  343. package/tokens/src/themes/light/components/general/hr.json +15 -0
  344. package/tokens/src/themes/light/components/general/input.json +18 -0
  345. package/tokens/src/themes/light/components/general/link.json +109 -0
  346. package/tokens/src/themes/light/components/general/list.json +38 -0
  347. package/tokens/src/themes/light/components/general/text.json +6 -0
  348. package/tokens/src/themes/light/global/color.json +1661 -0
  349. package/tokens/src/themes/light/global/elevation.json +201 -0
  350. package/tokens/src/themes/light/global/other.json +4 -0
  351. package/tokens/style-dictionary.js +223 -0
  352. package/tokens/utils.js +210 -0
  353. package/dist/ActionRow/_variables.scss +0 -2
  354. package/dist/Alert/_variables.scss +0 -24
  355. package/dist/Annotation/_variables.scss +0 -18
  356. package/dist/Avatar/_variables.scss +0 -10
  357. package/dist/AvatarButton/_variables.scss +0 -3
  358. package/dist/Badge/_variables.scss +0 -16
  359. package/dist/Breadcrumb/_variables.scss +0 -27
  360. package/dist/Bubble/_variables.scss +0 -8
  361. package/dist/Button/_variables.scss +0 -50
  362. package/dist/Button/deprecated/index.js +0 -128
  363. package/dist/Button/deprecated/index.js.map +0 -1
  364. package/dist/Card/_variables.scss +0 -56
  365. package/dist/Carousel/_variables.scss +0 -27
  366. package/dist/CheckBox/index.js +0 -72
  367. package/dist/CheckBox/index.js.map +0 -1
  368. package/dist/CheckBoxGroup/index.js +0 -15
  369. package/dist/CheckBoxGroup/index.js.map +0 -1
  370. package/dist/Chip/_variables.scss +0 -19
  371. package/dist/ChipCarousel/_variables.scss +0 -1
  372. package/dist/CloseButton/_variables.scss +0 -6
  373. package/dist/Code/_variables.scss +0 -17
  374. package/dist/Collapsible/_variables.scss +0 -12
  375. package/dist/ColorPicker/_variables.scss +0 -2
  376. package/dist/Container/_variables.scss +0 -5
  377. package/dist/DataTable/_variables.scss +0 -11
  378. package/dist/Dropdown/_variables.scss +0 -33
  379. package/dist/Dropdown/deprecated/DropdownButton.js +0 -48
  380. package/dist/Dropdown/deprecated/DropdownButton.js.map +0 -1
  381. package/dist/Dropdown/deprecated/DropdownItem.js +0 -34
  382. package/dist/Dropdown/deprecated/DropdownItem.js.map +0 -1
  383. package/dist/Dropdown/deprecated/DropdownMenu.js +0 -50
  384. package/dist/Dropdown/deprecated/DropdownMenu.js.map +0 -1
  385. package/dist/Dropdown/deprecated/index.js +0 -209
  386. package/dist/Dropdown/deprecated/index.js.map +0 -1
  387. package/dist/Dropzone/_variables.scss +0 -9
  388. package/dist/Fieldset/index.js +0 -92
  389. package/dist/Fieldset/index.js.map +0 -1
  390. package/dist/Fieldset/index.scss +0 -12
  391. package/dist/Form/_variables.scss +0 -267
  392. package/dist/Icon/_variables.scss +0 -7
  393. package/dist/Image/_variables.scss +0 -13
  394. package/dist/Input/index.js +0 -136
  395. package/dist/Input/index.js.map +0 -1
  396. package/dist/InputSelect/index.js +0 -78
  397. package/dist/InputSelect/index.js.map +0 -1
  398. package/dist/InputText/index.js +0 -43
  399. package/dist/InputText/index.js.map +0 -1
  400. package/dist/ListBox/index.js +0 -116
  401. package/dist/ListBox/index.js.map +0 -1
  402. package/dist/ListBoxOption/index.js +0 -71
  403. package/dist/ListBoxOption/index.js.map +0 -1
  404. package/dist/Menu/_variables.scss +0 -24
  405. package/dist/Modal/_variables.scss +0 -50
  406. package/dist/Modal/index.js +0 -260
  407. package/dist/Modal/index.js.map +0 -1
  408. package/dist/Nav/_variables.scss +0 -59
  409. package/dist/Navbar/_variables.scss +0 -40
  410. package/dist/OverflowScroll/_variables.scss +0 -5
  411. package/dist/OverflowScroll/index.scss +0 -1
  412. package/dist/Pagination/_variables.scss +0 -52
  413. package/dist/Popover/_variables.scss +0 -36
  414. package/dist/ProductTour/_variables.scss +0 -15
  415. package/dist/ProgressBar/_variables.scss +0 -23
  416. package/dist/RadioButtonGroup/index.js +0 -157
  417. package/dist/RadioButtonGroup/index.js.map +0 -1
  418. package/dist/SearchField/_variables.scss +0 -16
  419. package/dist/SelectableBox/_variables.scss +0 -5
  420. package/dist/Spinner/_variables.scss +0 -9
  421. package/dist/Stack/_variables.scss +0 -1
  422. package/dist/StatusAlert/index.js +0 -130
  423. package/dist/StatusAlert/index.js.map +0 -1
  424. package/dist/Stepper/_variables.scss +0 -18
  425. package/dist/Sticky/_variables.scss +0 -3
  426. package/dist/Table/_variables.scss +0 -34
  427. package/dist/Table/index.js +0 -198
  428. package/dist/Table/index.js.map +0 -1
  429. package/dist/Table/index.scss +0 -12
  430. package/dist/Tabs/_variables.scss +0 -24
  431. package/dist/Tabs/deprecated/Tabs.scss +0 -3
  432. package/dist/Tabs/deprecated/index.js +0 -90
  433. package/dist/Tabs/deprecated/index.js.map +0 -1
  434. package/dist/TextArea/index.js +0 -42
  435. package/dist/TextArea/index.js.map +0 -1
  436. package/dist/Toast/_variables.scss +0 -19
  437. package/dist/Tooltip/_variables.scss +0 -21
  438. package/dist/ValidationFormGroup/index.js +0 -105
  439. package/dist/ValidationFormGroup/index.js.map +0 -1
  440. package/dist/paragon.css +0 -39
  441. package/scss/core/_grid.scss +0 -21
  442. package/scss/core/_variables.scss +0 -875
  443. package/scss/core/core.scss +0 -21
  444. package/src/ActionRow/_variables.scss +0 -2
  445. package/src/Alert/_variables.scss +0 -24
  446. package/src/Annotation/_variables.scss +0 -18
  447. package/src/Avatar/_variables.scss +0 -10
  448. package/src/AvatarButton/_variables.scss +0 -3
  449. package/src/Badge/_variables.scss +0 -16
  450. package/src/Breadcrumb/_variables.scss +0 -27
  451. package/src/Bubble/_variables.scss +0 -8
  452. package/src/Button/_variables.scss +0 -50
  453. package/src/Button/deprecated/Button.test.jsx +0 -34
  454. package/src/Button/deprecated/index.jsx +0 -145
  455. package/src/Card/_variables.scss +0 -56
  456. package/src/Carousel/_variables.scss +0 -27
  457. package/src/CheckBox/CheckBox.test.jsx +0 -65
  458. package/src/CheckBox/README.md +0 -93
  459. package/src/CheckBox/index.jsx +0 -80
  460. package/src/CheckBoxGroup/CheckBoxGroup.test.jsx +0 -33
  461. package/src/CheckBoxGroup/README.md +0 -35
  462. package/src/CheckBoxGroup/index.jsx +0 -19
  463. package/src/Chip/_variables.scss +0 -19
  464. package/src/ChipCarousel/_variables.scss +0 -1
  465. package/src/CloseButton/_variables.scss +0 -6
  466. package/src/Code/_variables.scss +0 -17
  467. package/src/Collapsible/_variables.scss +0 -12
  468. package/src/ColorPicker/_variables.scss +0 -2
  469. package/src/Container/_variables.scss +0 -5
  470. package/src/DataTable/_variables.scss +0 -11
  471. package/src/Dropdown/_variables.scss +0 -33
  472. package/src/Dropdown/deprecated/Dropdown.test.jsx +0 -238
  473. package/src/Dropdown/deprecated/DropdownButton.jsx +0 -52
  474. package/src/Dropdown/deprecated/DropdownItem.jsx +0 -34
  475. package/src/Dropdown/deprecated/DropdownMenu.jsx +0 -50
  476. package/src/Dropdown/deprecated/__snapshots__/Dropdown.test.jsx.snap +0 -229
  477. package/src/Dropdown/deprecated/index.jsx +0 -222
  478. package/src/Dropzone/_variables.scss +0 -9
  479. package/src/Fieldset/Fieldset.test.jsx +0 -101
  480. package/src/Fieldset/README.md +0 -146
  481. package/src/Fieldset/index.jsx +0 -107
  482. package/src/Fieldset/index.scss +0 -12
  483. package/src/Form/_variables.scss +0 -267
  484. package/src/Icon/_variables.scss +0 -7
  485. package/src/Image/_variables.scss +0 -13
  486. package/src/Input/README.md +0 -74
  487. package/src/Input/__snapshots__/input.test.jsx.snap +0 -53
  488. package/src/Input/index.jsx +0 -151
  489. package/src/Input/input.test.jsx +0 -85
  490. package/src/InputSelect/README.md +0 -136
  491. package/src/InputSelect/index.jsx +0 -92
  492. package/src/InputText/InputText.test.jsx +0 -74
  493. package/src/InputText/README.md +0 -293
  494. package/src/InputText/index.jsx +0 -49
  495. package/src/ListBox/ListBox.test.jsx +0 -161
  496. package/src/ListBox/README.md +0 -185
  497. package/src/ListBox/index.jsx +0 -115
  498. package/src/ListBoxOption/ListBoxOption.test.jsx +0 -154
  499. package/src/ListBoxOption/index.jsx +0 -78
  500. package/src/Menu/_variables.scss +0 -24
  501. package/src/Modal/README.md +0 -148
  502. package/src/Modal/_variables.scss +0 -50
  503. package/src/Modal/index.jsx +0 -314
  504. package/src/Modal/tests/Modal.test.jsx +0 -261
  505. package/src/Nav/_variables.scss +0 -59
  506. package/src/Navbar/_variables.scss +0 -40
  507. package/src/OverflowScroll/_variables.scss +0 -5
  508. package/src/OverflowScroll/index.scss +0 -1
  509. package/src/Pagination/_variables.scss +0 -52
  510. package/src/Popover/_variables.scss +0 -36
  511. package/src/ProductTour/_variables.scss +0 -15
  512. package/src/ProgressBar/_variables.scss +0 -23
  513. package/src/RadioButtonGroup/README.md +0 -50
  514. package/src/RadioButtonGroup/RadioButtonGroup.test.jsx +0 -127
  515. package/src/RadioButtonGroup/index.jsx +0 -185
  516. package/src/SearchField/_variables.scss +0 -16
  517. package/src/SelectableBox/_variables.scss +0 -5
  518. package/src/Spinner/_variables.scss +0 -9
  519. package/src/Stack/_variables.scss +0 -1
  520. package/src/StatusAlert/README.md +0 -149
  521. package/src/StatusAlert/StatusAlert.test.jsx +0 -150
  522. package/src/StatusAlert/index.jsx +0 -144
  523. package/src/Stepper/_variables.scss +0 -18
  524. package/src/Sticky/_variables.scss +0 -3
  525. package/src/Table/README.md +0 -506
  526. package/src/Table/Table.test.jsx +0 -367
  527. package/src/Table/_variables.scss +0 -34
  528. package/src/Table/index.jsx +0 -264
  529. package/src/Table/index.scss +0 -12
  530. package/src/Tabs/_variables.scss +0 -24
  531. package/src/Tabs/deprecated/Tabs.scss +0 -3
  532. package/src/Tabs/deprecated/Tabs.test.jsx +0 -50
  533. package/src/Tabs/deprecated/index.jsx +0 -117
  534. package/src/TextArea/README.md +0 -63
  535. package/src/TextArea/index.jsx +0 -48
  536. package/src/Toast/_variables.scss +0 -19
  537. package/src/Tooltip/_variables.scss +0 -21
  538. package/src/ValidationFormGroup/README.md +0 -116
  539. package/src/ValidationFormGroup/ValidationFormGroup.test.jsx +0 -146
  540. package/src/ValidationFormGroup/__snapshots__/ValidationFormGroup.test.jsx.snap +0 -161
  541. package/src/ValidationFormGroup/index.jsx +0 -114
  542. /package/{scss → styles/scss}/core/_exports.module.scss +0 -0
  543. /package/{scss → styles/scss}/core/_typography.scss +0 -0
@@ -1,314 +0,0 @@
1
- /* eslint-disable max-len */
2
- import React from 'react';
3
- import ReactDOM from 'react-dom';
4
- import classNames from 'classnames';
5
- import PropTypes from 'prop-types';
6
- import { FocusOn } from 'react-focus-on';
7
- import { tabbable } from 'tabbable';
8
-
9
- import { Close } from '../../icons';
10
- import Button from '../Button';
11
- import Icon from '../Icon';
12
- import newId from '../utils/newId';
13
- import Variant from '../utils/constants';
14
-
15
- class Modal extends React.Component {
16
- constructor(props) {
17
- super(props);
18
-
19
- this.close = this.close.bind(this);
20
-
21
- this.headerId = newId();
22
- this.modalBodyRef = React.createRef();
23
-
24
- if (typeof document !== 'undefined') {
25
- this.el = document.createElement('div');
26
- // Sets true for IE11, false otherwise: https://stackoverflow.com/a/22082397/6620612
27
- this.isIE11 = !!global.MSInputMethodContext && !!document.documentMode;
28
- }
29
-
30
- this.state = {
31
- open: props.open,
32
- };
33
- }
34
-
35
- componentDidMount() {
36
- const { parentSelector } = this.props;
37
- this.parentElement = document.querySelector(parentSelector);
38
- if (this.parentElement === null) {
39
- throw new Error(`Modal received invalid parentSelector: ${parentSelector}, no matching element found`);
40
- }
41
- this.parentElement.appendChild(this.el);
42
- }
43
-
44
- componentDidUpdate(prevProps, prevState) {
45
- const { open } = this.props;
46
- if (open !== prevProps.open || open !== prevState.open) {
47
- // eslint-disable-next-line react/no-did-update-set-state
48
- this.setState({ open });
49
- }
50
- }
51
-
52
- componentWillUnmount() {
53
- if (this.parentElement) {
54
- ReactDOM.unmountComponentAtNode(this.parentElement);
55
- }
56
- }
57
-
58
- getVariantIconClassName() {
59
- const { variant } = this.props;
60
- let variantIconClassName;
61
-
62
- switch (variant.status) {
63
- case Variant.status.WARNING:
64
- variantIconClassName = classNames(
65
- 'fa',
66
- 'fa-exclamation-triangle',
67
- 'fa-3x',
68
- `text-${variant.status.toLowerCase()}`,
69
- );
70
- break;
71
- default:
72
- break;
73
- }
74
-
75
- return variantIconClassName;
76
- }
77
-
78
- getVariantGridBody(body) {
79
- const { variant } = this.props;
80
-
81
- return (
82
- <div className="container-fluid">
83
- <div className="row">
84
- <div className="col-md-10">
85
- <div>
86
- {body}
87
- </div>
88
- </div>
89
- <div className="col-md-2" data-testid="modal-icon">
90
- <Icon
91
- id={newId(`Modal-${variant.status}`)}
92
- className={this.getVariantIconClassName()}
93
- />
94
- </div>
95
- </div>
96
- </div>
97
- );
98
- }
99
-
100
- getTabbableBodyElements() {
101
- if (this.modalBodyRef?.current) {
102
- return tabbable(this.modalBodyRef.current);
103
- }
104
- return [];
105
- }
106
-
107
- isValidVariantStatus() {
108
- const { variant } = this.props;
109
- return Object.values(Variant.status).includes(variant.status);
110
- }
111
-
112
- close(e) {
113
- if (e) {
114
- e.stopPropagation();
115
- }
116
-
117
- this.setState({ open: false });
118
- this.props.onClose();
119
- }
120
-
121
- renderButtons() {
122
- return this.props.buttons.map((button) => {
123
- // button is either a React component that we want clone or a set of props
124
- if (React.isValidElement(button)) {
125
- return React.cloneElement(button, {
126
- key: button.props.children,
127
- });
128
- }
129
-
130
- const { label, ...buttonProps } = button;
131
-
132
- return (
133
- <Button.Deprecated
134
- {...buttonProps}
135
- key={label}
136
- >
137
- {label}
138
- </Button.Deprecated>
139
- );
140
- });
141
- }
142
-
143
- renderBody() {
144
- let { body } = this.props;
145
-
146
- if (typeof body === 'string') {
147
- body = <p>{body}</p>;
148
- }
149
-
150
- if (this.isValidVariantStatus()) {
151
- body = this.getVariantGridBody(body);
152
- }
153
-
154
- return body;
155
- }
156
-
157
- renderModal() {
158
- const { open } = this.state;
159
- const {
160
- dialogClassName,
161
- renderDefaultCloseButton,
162
- renderHeaderCloseButton,
163
- buttons,
164
- closeText,
165
- title,
166
- } = this.props;
167
-
168
- const hasTabbableElements = (
169
- renderDefaultCloseButton
170
- || renderHeaderCloseButton
171
- || buttons.length > 0
172
- || this.getTabbableBodyElements().length > 0
173
- );
174
- const renderModalFooter = renderDefaultCloseButton || buttons.length > 0;
175
-
176
- return (
177
- <>
178
- <div
179
- className={classNames({
180
- 'modal-backdrop': open,
181
- show: open,
182
- fade: !open,
183
- })}
184
- role="presentation"
185
- data-testid="modal-backdrop"
186
- />
187
- <div
188
- className={classNames(
189
- 'modal',
190
- {
191
- show: open,
192
- fade: !open,
193
- 'd-block': open,
194
- 'is-ie11': this.isIE11,
195
- },
196
- )}
197
- role="presentation"
198
- data-testid="modal"
199
- >
200
- <div
201
- className={classNames(
202
- {
203
- 'modal-dialog': open,
204
- },
205
- dialogClassName,
206
- )}
207
- role="dialog"
208
- aria-modal
209
- aria-labelledby={this.headerId}
210
- >
211
- <FocusOn
212
- enabled={open}
213
- onClickOutside={this.close}
214
- onEscapeKey={this.close}
215
- >
216
- <div
217
- className="modal-content"
218
- data-testid="modal-content"
219
- // if the modal doesn't contain any tabbable elements, make this element programmatically focusable.
220
- {...(!hasTabbableElements ? { tabIndex: -1 } : {})}
221
- >
222
- <div className="modal-header">
223
- <h2 className="modal-title" id={this.headerId}>{title}</h2>
224
- {renderHeaderCloseButton && (
225
- <Button.Deprecated
226
- className="p-1"
227
- onClick={this.close}
228
- data-testid="modal-header-btn"
229
- >
230
- <Icon src={Close} screenReaderText={closeText} />
231
- </Button.Deprecated>
232
- )}
233
- </div>
234
- <div className="modal-body" ref={this.modalBodyRef} data-testid="modal-body">
235
- {this.renderBody()}
236
- </div>
237
- {renderModalFooter && (
238
- <div className="modal-footer">
239
- {renderDefaultCloseButton && (
240
- <Button
241
- variant="link"
242
- onClick={this.close}
243
- data-testid="modal-footer-btn"
244
- >
245
- {closeText}
246
- </Button>
247
- )}
248
- {this.renderButtons()}
249
- </div>
250
- )}
251
- </div>
252
- </FocusOn>
253
- </div>
254
- </div>
255
- </>
256
- );
257
- }
258
-
259
- render() {
260
- if (!this.el) {
261
- return null;
262
- }
263
-
264
- return ReactDOM.createPortal(
265
- this.renderModal(),
266
- this.el,
267
- );
268
- }
269
- }
270
-
271
- Modal.propTypes = {
272
- /** specifies whether the modal renders open or closed on the initial render. It defaults to false. */
273
- open: PropTypes.bool,
274
- /** is the selector for an element in the dom which the modal should be rendered under. It uses querySelector to find the first element that matches that selector, and then creates a react portal to a div underneath the parent element.
275
- */
276
- parentSelector: PropTypes.string,
277
- /** a string or an element that is rendered inside of the modal title, above the modal body. */
278
- title: PropTypes.oneOfType([PropTypes.string, PropTypes.element]).isRequired,
279
- /** a string or an element that is rendered inside of the modal body, between the title and the footer. */
280
- body: PropTypes.oneOfType([PropTypes.string, PropTypes.element]).isRequired,
281
- /** an array of either elements or shapes that take the form of the buttonPropTypes. See the [buttonPropTypes](https://github.com/openedx/paragon/blob/master/src/Button/index.jsx#L40) for a list of acceptable props to pass as part of a button. */
282
- buttons: PropTypes.arrayOf(PropTypes.oneOfType([
283
- PropTypes.element,
284
- PropTypes.shape({}), // TODO: Only accept nodes in the future
285
- ])),
286
- /** specifies the display text of the default Close button. It defaults to "Close". */
287
- closeText: PropTypes.oneOfType([PropTypes.string, PropTypes.element]),
288
- /** a function that is called on close. It can be used to perform actions upon closing of the modal, such as restoring focus to the previous logical focusable element. */
289
- onClose: PropTypes.func.isRequired,
290
- variant: PropTypes.shape({
291
- status: PropTypes.string,
292
- }),
293
- /** specifies whether the default close button is rendered in the footer. It defaults to true. */
294
- renderDefaultCloseButton: PropTypes.bool,
295
- /** specifies whether a close button is rendered in the modal header. It defaults to true. */
296
- renderHeaderCloseButton: PropTypes.bool,
297
- /**
298
- * Specifies optional classes to add to the element with the '.modal-dialog' class. See Bootstrap documentation for possible classes. Some options: modal-lg, modal-sm, modal-dialog-centered
299
- */
300
- dialogClassName: PropTypes.string,
301
- };
302
-
303
- Modal.defaultProps = {
304
- open: false,
305
- parentSelector: 'body',
306
- buttons: [],
307
- closeText: 'Close',
308
- variant: {},
309
- renderDefaultCloseButton: true,
310
- renderHeaderCloseButton: true,
311
- dialogClassName: undefined,
312
- };
313
-
314
- export default Modal;
@@ -1,261 +0,0 @@
1
- import React from 'react';
2
- import { render, screen } from '@testing-library/react';
3
- import userEvent from '@testing-library/user-event';
4
-
5
- import Modal from '..';
6
- import { Button } from '../..';
7
- import Variant from '../../utils/constants';
8
-
9
- const modalOpen = (isOpen, container) => {
10
- if (!isOpen) {
11
- expect(container.getByTestId('modal').classList).not.toContain('d-block');
12
- expect(container.getByTestId('modal').classList).not.toContain('show');
13
- expect(container.getByTestId('modal').classList).toContain('fade');
14
- expect(container.queryByTestId('modal-backdrop').classList).not.toContain('modal-backdrop');
15
- } else {
16
- expect(container.getByTestId('modal').classList).toContain('d-block');
17
- expect(container.getByTestId('modal').classList).toContain('show');
18
- expect(container.queryByTestId('modal').classList).not.toContain('fade');
19
- expect(container.queryByTestId('modal-backdrop').classList).toContain('modal-backdrop');
20
- }
21
- };
22
-
23
- const title = 'Modal title';
24
- const body = 'Modal body';
25
- const defaultProps = {
26
- title,
27
- body,
28
- open: true,
29
- onClose: () => { },
30
- };
31
- const closeText = 'GO AWAY!';
32
-
33
- describe('<Modal />', () => {
34
- describe('correct rendering', () => {
35
- const buttons = [
36
- <Button.Deprecated buttonType="primary">Blue button!</Button.Deprecated>,
37
- {
38
- label: 'Red button!',
39
- buttonType: 'danger',
40
- },
41
- <Button.Deprecated buttonType="success">Green button!</Button.Deprecated>,
42
- ];
43
-
44
- it('renders default buttons', () => {
45
- render(<Modal {...defaultProps} />);
46
- const modalTitle = screen.getByText(title);
47
- const modalBody = screen.getByText(body);
48
-
49
- expect(modalTitle).toBeInTheDocument();
50
- expect(modalBody).toBeInTheDocument();
51
- expect(screen.queryAllByRole('button')).toHaveLength(2);
52
- });
53
-
54
- it('renders custom buttons', () => {
55
- render(<Modal {...defaultProps} buttons={buttons} />);
56
- expect(screen.queryAllByRole('button')).toHaveLength(buttons.length + 2);
57
- });
58
-
59
- it('renders Warning Variant', () => {
60
- render(
61
- <Modal {...defaultProps} variant={{ status: Variant.status.WARNING }} />,
62
- );
63
-
64
- const modalBody = screen.getByTestId('modal-body');
65
-
66
- expect(modalBody.firstChild.classList).toContain('container-fluid');
67
- expect(screen.getByText(body)).toBeInTheDocument();
68
-
69
- const icon = screen.getByTestId('modal-icon').firstChild;
70
- expect(icon.classList).toContain('fa-exclamation-triangle');
71
- expect(icon.classList).toContain('fa-3x');
72
- expect(icon.classList).toContain('text-warning');
73
- });
74
-
75
- it('renders invalid Variant properly', () => {
76
- render(<Modal {...defaultProps} variant={{ status: 'foo' }} />);
77
- const modalTitle = screen.getByText(title);
78
- const modalBody = screen.getByText(body);
79
-
80
- expect(modalTitle).toBeInTheDocument();
81
- expect(modalBody).toBeInTheDocument();
82
- expect(screen.queryAllByRole('button')).toHaveLength(2);
83
- });
84
-
85
- it('render of the header close button is optional', () => {
86
- render(<Modal {...defaultProps} renderHeaderCloseButton={false} />);
87
- const modalHeaderBtn = screen.queryByTestId('modal-header-btn');
88
- const modalFooterBtn = screen.getByTestId('modal-footer-btn');
89
-
90
- expect(modalHeaderBtn).not.toBeInTheDocument();
91
- expect(modalFooterBtn).toBeInTheDocument();
92
- });
93
-
94
- it('render of the default footer close button is optional', () => {
95
- render(<Modal {...defaultProps} renderDefaultCloseButton={false} />);
96
- const modalHeaderBtn = screen.getByTestId('modal-header-btn');
97
- const modalFooterBtn = screen.queryByTestId('modal-footer-btn');
98
-
99
- expect(modalHeaderBtn).toBeInTheDocument();
100
- expect(modalFooterBtn).not.toBeInTheDocument();
101
- });
102
-
103
- it('renders custom close button string', () => {
104
- render(<Modal {...defaultProps} closeText={closeText} />);
105
- const modalFooterBtn = screen.getByTestId('modal-footer-btn');
106
- expect(modalFooterBtn).toBeInTheDocument();
107
- expect(modalFooterBtn).toHaveTextContent(closeText);
108
- });
109
-
110
- it('renders custom close button element', () => {
111
- const closeElem = <span className="is-close-text">{closeText}</span>;
112
- render(<Modal {...defaultProps} closeText={closeElem} />);
113
- const modalFooterBtn = screen.getByTestId('modal-footer-btn');
114
-
115
- expect(modalFooterBtn).toBeInTheDocument();
116
- expect(modalFooterBtn.firstChild.classList).toContain('is-close-text');
117
- expect(modalFooterBtn.firstChild).toHaveTextContent(closeText);
118
- });
119
-
120
- it('renders with IE11-specific styling when IE11 is detected', () => {
121
- const { MSInputMethodContext } = global;
122
- const { documentMode } = global.document;
123
-
124
- // mimic IE11
125
- global.MSInputMethodContext = true;
126
- global.document.documentMode = true;
127
- render(<Modal {...defaultProps} />);
128
- const modal = screen.queryByTestId('modal');
129
- expect(modal.classList).toContain('is-ie11');
130
-
131
- global.MSInputMethodContext = MSInputMethodContext;
132
- global.document.documentMode = documentMode;
133
- });
134
-
135
- it('renders without IE11-specific styling when IE11 is not detected', () => {
136
- const { MSInputMethodContext } = global;
137
- const { documentMode } = global.document;
138
-
139
- // mimic non-IE11 browser
140
- global.MSInputMethodContext = false;
141
- global.document.documentMode = false;
142
- render(<Modal {...defaultProps} />);
143
- const modal = screen.queryByTestId('modal');
144
- expect(modal).not.toContain('is-ie11');
145
-
146
- global.MSInputMethodContext = MSInputMethodContext;
147
- global.document.documentMode = documentMode;
148
- });
149
- });
150
-
151
- describe('props received correctly', () => {
152
- it('component receives props', () => {
153
- const { rerender } = render(<Modal {...defaultProps} open={false} />);
154
-
155
- modalOpen(false, screen);
156
- rerender(<Modal {...defaultProps} open />);
157
- modalOpen(true, screen);
158
- });
159
-
160
- it('component receives props and ignores prop change', () => {
161
- const { rerender } = render(<Modal {...defaultProps} />);
162
-
163
- modalOpen(true, screen);
164
- rerender(<Modal {...defaultProps} title="Changed modal title" />);
165
- modalOpen(true, screen);
166
- });
167
-
168
- it('throws an error when an invalid parentSelector prop is passed', () => {
169
- expect(() => render(
170
- <Modal
171
- {...defaultProps}
172
- parentSelector=".this-selector-does-not-exist"
173
- />,
174
- )).toThrow('Modal received invalid parentSelector: .this-selector-does-not-exist, no matching element found');
175
- });
176
- });
177
-
178
- describe('close functions properly', () => {
179
- it('closes when x button pressed', async () => {
180
- render(<Modal {...defaultProps} />);
181
-
182
- modalOpen(true, screen);
183
- await userEvent.click(screen.queryAllByRole('button')[0]);
184
- modalOpen(false, screen);
185
- });
186
-
187
- it('closes when Close button pressed', async () => {
188
- render(<Modal {...defaultProps} />);
189
-
190
- modalOpen(true, screen);
191
- await userEvent.click(screen.queryAllByRole('button')[1]);
192
- modalOpen(false, screen);
193
- });
194
-
195
- it('calls callback function on close', async () => {
196
- const spy = jest.fn();
197
- render(<Modal {...defaultProps} onClose={spy} />);
198
-
199
- expect(spy).toHaveBeenCalledTimes(0);
200
-
201
- // press X button
202
- await userEvent.click(screen.queryAllByRole('button')[0]);
203
- expect(spy).toHaveBeenCalledTimes(1);
204
- });
205
-
206
- it('reopens after closed', async () => {
207
- const { rerender } = render(<Modal {...defaultProps} />);
208
-
209
- modalOpen(true, screen);
210
- await userEvent.click(screen.queryAllByRole('button')[0]);
211
- modalOpen(false, screen);
212
- rerender(<Modal {...defaultProps} open />);
213
- modalOpen(true, screen);
214
- });
215
- });
216
-
217
- describe('focus changes correctly', () => {
218
- it('has correct initial focus', () => {
219
- render(<Modal {...defaultProps} />);
220
- const buttons = screen.queryAllByRole('button');
221
- expect(buttons[0]).toHaveFocus();
222
- });
223
-
224
- it('has reset focus after close and reopen', () => {
225
- const { rerender } = render(<Modal {...defaultProps} />);
226
- const buttons = screen.queryAllByRole('button');
227
- expect(buttons[0]).toHaveFocus();
228
- rerender(<Modal {...defaultProps} open={false} />);
229
- modalOpen(false, screen);
230
- rerender(<Modal {...defaultProps} open />);
231
- modalOpen(true, screen);
232
- expect(buttons[0]).toHaveFocus();
233
- });
234
-
235
- it('has focus on input in modal body', () => {
236
- const { getByTestId } = render(
237
- <Modal
238
- {...defaultProps}
239
- open
240
- renderDefaultCloseButton={false}
241
- renderHeaderCloseButton={false}
242
- body={<div><input data-testid="modal-input" /></div>}
243
- />,
244
- );
245
- const input = getByTestId('modal-input');
246
- expect(input).toHaveFocus();
247
- });
248
-
249
- it('has focus on `.modal-content` when nothing else is tabbable', () => {
250
- const { getByTestId } = render(
251
- <Modal
252
- {...defaultProps}
253
- renderDefaultCloseButton={false}
254
- renderHeaderCloseButton={false}
255
- />,
256
- );
257
- const modalContent = getByTestId('modal-content');
258
- expect(modalContent).toHaveFocus();
259
- });
260
- });
261
- });
@@ -1,59 +0,0 @@
1
- // Navs
2
-
3
- $nav-link-padding-y: .5rem !default;
4
- $nav-link-padding-x: 1rem !default;
5
- $nav-link-color: $gray-700 !default;
6
- $nav-link-disabled-color: $gray-300 !default;
7
- $nav-link-font-weight: 500 !default;
8
-
9
- $nav-tabs-border-color: $light-400 !default;
10
- $nav-tabs-border-width: 2px !default;
11
- $nav-tabs-border-radius: 0 !default;
12
- $nav-tabs-hover-bg: transparent !default;
13
- $nav-tabs-focus-border-color: $nav-tabs-hover-bg !default;
14
- $nav-tabs-disabled-bg: $nav-tabs-hover-bg !default;
15
- $nav-tabs-link-hover-border-color: transparent transparent $nav-tabs-border-color !default;
16
- $nav-tabs-link-hover-bg: $light-400 !default;
17
- $nav-tabs-link-active-color: $primary-500 !default;
18
- $nav-tabs-link-active-border-color: $nav-tabs-link-active-color !default;
19
- $nav-tabs-link-active-bg: transparent !default;
20
- $nav-tabs-link-focus-border-color: $nav-tabs-link-active-color !default;
21
- $nav-tabs-link-distance-to-border: 4px !default;
22
- $nav-tabs-link-border-color: transparent !default;
23
- $nav-tabs-link-disabled-border-color: $nav-tabs-link-border-color !default;
24
-
25
- $nav-pills-border-radius: $border-radius !default;
26
- $nav-pills-link-active-color: $component-active-color !default;
27
- $nav-pills-link-active-bg: $component-active-bg !default;
28
- $nav-pills-link-active-border-color: $white !default;
29
- $nav-pills-link-border-color: $nav-tabs-border-color !default;
30
- $nav-pills-link-border-width: 1px !default;
31
-
32
- $nav-inverse-pills-link-color: $white !default;
33
- $nav-inverse-pills-link-border-color: $dark-300 !default;
34
- $nav-inverse-pills-link-hover-bg: $nav-inverse-pills-link-border-color !default;
35
- $nav-inverse-pills-link-focus-color: $nav-inverse-pills-link-color !default;
36
- $nav-inverse-pills-link-active-bg: $nav-inverse-pills-link-color !default;
37
- $nav-inverse-pills-link-active-color: $primary-500 !default;
38
- $nav-inverse-pills-link-active-border-color: $nav-inverse-pills-link-color !default;
39
- $nav-inverse-pills-link-active-hover-bg: $nav-inverse-pills-link-border-color !default;
40
- $nav-inverse-pills-link-active-hover-color: $nav-inverse-pills-link-color !default;
41
- $nav-inverse-pills-link-active-hover-border-color: $nav-inverse-pills-link-border-color !default;
42
- $nav-inverse-pills-link-active-focus-hover-bg: $nav-inverse-pills-link-color !default;
43
- $nav-inverse-pills-link-active-focus-color: $nav-inverse-pills-link-active-color !default;
44
- $nav-inverse-pills-link-active-focus-border-color: $primary !default;
45
- $nav-inverse-pills-link-active-focus-hover-border-color: $nav-inverse-pills-link-active-focus-border-color !default;
46
- $nav-inverse-pills-link-border-width: $nav-pills-link-border-width !default;
47
- $nav-inverse-pills-tab-content-color: $nav-inverse-pills-link-color !default;
48
-
49
- $nav-inverse-tabs-link-color: $white !default;
50
- $nav-inverse-tabs-link-border-bottom-color: $dark-300 !default;
51
- $nav-inverse-tabs-link-hover-bg: $nav-inverse-tabs-link-border-bottom-color !default;
52
- $nav-inverse-tabs-link-active-hover-bg: transparent !default;
53
- $nav-inverse-tabs-link-focus-bg: $nav-inverse-tabs-link-color !default;
54
- $nav-inverse-tabs-link-active-border-color: $nav-inverse-tabs-link-color !default;
55
- $nav-inverse-tabs-link-active-bg: $nav-inverse-tabs-link-hover-bg !default;
56
- $nav-inverse-tabs-link-active-border-bottom-width: $nav-tabs-border-width !default;
57
- $nav-inverse-tabs-tab-content-color: $nav-inverse-tabs-link-color !default;
58
- $nav-inverse-tabs-dropdown-border-color: $nav-inverse-tabs-link-active-hover-bg !default;
59
- $nav-inverse-tabs-dropdown-bottom-gap: .4375rem !default;
@@ -1,40 +0,0 @@
1
- // Navbar
2
-
3
- $navbar-padding-y: calc($spacer / 2) !default;
4
- $navbar-padding-x: $spacer !default;
5
-
6
- $navbar-nav-link-padding-x: .5rem !default;
7
-
8
- $navbar-brand-font-size: $font-size-lg !default;
9
-
10
- // Compute the navbar-brand padding-y so the navbar-brand will have the same height as navbar-text and nav-link
11
- // The default for $nav-link-padding-y is .5rem. Copied here for modularization
12
- $nav-link-height: $font-size-base * $line-height-base + .5rem * 2 !default;
13
- $navbar-brand-height: $navbar-brand-font-size * $line-height-base !default;
14
- $navbar-brand-padding-y: calc(($nav-link-height - $navbar-brand-height) / 2) !default;
15
-
16
- $navbar-toggler-padding-y: .25rem !default;
17
- $navbar-toggler-padding-x: .75rem !default;
18
- $navbar-toggler-font-size: $font-size-lg !default;
19
- $navbar-toggler-border-radius: $btn-border-radius !default;
20
-
21
- $navbar-nav-scroll-max-height: 75vh !default;
22
-
23
- $navbar-dark-color: rgba($white, .5) !default;
24
- $navbar-dark-hover-color: rgba($white, .75) !default;
25
- $navbar-dark-active-color: $white !default;
26
- $navbar-dark-disabled-color: rgba($white, .25) !default;
27
- $navbar-dark-toggler-icon-bg: str-replace(url("data:image/svg+xml,%3csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3e%3cpath stroke='#{$navbar-dark-color}' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e"), "#", "%23") !default;
28
- $navbar-dark-toggler-border-color: rgba($white, .1) !default;
29
-
30
- $navbar-light-color: rgba($black, .5) !default;
31
- $navbar-light-hover-color: rgba($black, .7) !default;
32
- $navbar-light-active-color: rgba($black, .9) !default;
33
- $navbar-light-disabled-color: rgba($black, .3) !default;
34
- $navbar-light-toggler-icon-bg: str-replace(url("data:image/svg+xml,%3csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3e%3cpath stroke='#{$navbar-light-color}' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e"), "#", "%23") !default;
35
- $navbar-light-toggler-border-color: rgba($black, .1) !default;
36
-
37
- $navbar-light-brand-color: $navbar-light-active-color !default;
38
- $navbar-light-brand-hover-color: $navbar-light-active-color !default;
39
- $navbar-dark-brand-color: $navbar-dark-active-color !default;
40
- $navbar-dark-brand-hover-color: $navbar-dark-active-color !default;
@@ -1,5 +0,0 @@
1
- .pgn__overflow-scroll-overflow-container {
2
- --pgn-overflow-scroll-opacity-mask-transparent: rgba(0, 0, 0, .4);
3
- }
4
-
5
- $overflow-scroll-opacity-mask-transparent: var(--pgn-overflow-scroll-opacity-mask-transparent) !default;
@@ -1 +0,0 @@
1
- @import "variables";