@openedx/paragon 22.6.0 → 23.0.0-alpha.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (564) hide show
  1. package/README.md +61 -21
  2. package/bin/paragon-scripts.js +128 -9
  3. package/dist/ActionRow/_index.scss +2 -4
  4. package/dist/Alert/index.scss +41 -32
  5. package/dist/Annotation/_mixins.scss +104 -0
  6. package/dist/Annotation/index.scss +130 -103
  7. package/dist/Avatar/index.scss +18 -20
  8. package/dist/AvatarButton/index.scss +3 -5
  9. package/dist/Badge/index.scss +112 -2
  10. package/dist/Breadcrumb/index.scss +14 -16
  11. package/dist/Bubble/index.scss +25 -12
  12. package/dist/Button/_mixins.scss +14 -0
  13. package/dist/Button/button-group.scss +126 -0
  14. package/dist/Button/index.js +15 -40
  15. package/dist/Button/index.js.map +1 -1
  16. package/dist/Button/index.scss +855 -372
  17. package/dist/Card/card-bootstrap.scss +168 -0
  18. package/dist/Card/index.scss +78 -79
  19. package/dist/Carousel/index.scss +168 -2
  20. package/dist/Chip/ChipIcon.d.ts +2 -2
  21. package/dist/Chip/ChipIcon.js.map +1 -1
  22. package/dist/Chip/index.d.ts +2 -2
  23. package/dist/Chip/index.js +2 -2
  24. package/dist/Chip/index.js.map +1 -1
  25. package/dist/Chip/index.scss +48 -38
  26. package/dist/Chip/mixins.scss +8 -3
  27. package/dist/ChipCarousel/index.scss +4 -4
  28. package/dist/CloseButton/index.scss +31 -2
  29. package/dist/Code/index.scss +47 -2
  30. package/dist/Collapsible/index.scss +15 -15
  31. package/dist/ColorPicker/index.scss +9 -11
  32. package/dist/DataTable/CollapsibleButtonGroup.js +2 -2
  33. package/dist/DataTable/CollapsibleButtonGroup.js.map +1 -1
  34. package/dist/DataTable/index.scss +48 -50
  35. package/dist/Dropdown/dropdown-bootstrap.scss +181 -0
  36. package/dist/Dropdown/index.js +0 -2
  37. package/dist/Dropdown/index.js.map +1 -1
  38. package/dist/Dropdown/index.scss +11 -12
  39. package/dist/Dropzone/index.scss +12 -14
  40. package/dist/Form/_FormText.scss +8 -8
  41. package/dist/Form/_bootstrap-custom-forms.scss +551 -0
  42. package/dist/Form/_bootstrap-forms.scss +381 -0
  43. package/dist/Form/_index.scss +168 -146
  44. package/dist/Form/_input-group.scss +188 -0
  45. package/dist/Form/_mixins.scss +216 -3
  46. package/dist/Hyperlink/index.js +32 -20
  47. package/dist/Hyperlink/index.js.map +1 -1
  48. package/dist/Hyperlink/index.scss +1 -1
  49. package/dist/Icon/index.d.ts +2 -4
  50. package/dist/Icon/index.js +1 -1
  51. package/dist/Icon/index.js.map +1 -1
  52. package/dist/Icon/index.scss +10 -12
  53. package/dist/IconButton/_mixins.scss +4 -0
  54. package/dist/IconButton/index.js +5 -11
  55. package/dist/IconButton/index.js.map +1 -1
  56. package/dist/IconButton/index.scss +387 -74
  57. package/dist/IconButtonToggle/index.scss +1 -1
  58. package/dist/Image/index.scss +53 -2
  59. package/dist/Menu/index.scss +25 -27
  60. package/dist/Modal/_ModalDialog.scss +52 -54
  61. package/dist/Modal/index.scss +6 -73
  62. package/dist/Nav/_mixins.scss +4 -4
  63. package/dist/Nav/index.scss +70 -66
  64. package/dist/Navbar/index.scss +276 -2
  65. package/dist/OverflowScroll/data/useOverflowScrollElementAttributes.js +3 -3
  66. package/dist/Overlay/index.js +2 -3
  67. package/dist/Overlay/index.js.map +1 -1
  68. package/dist/PageBanner/index.scss +17 -21
  69. package/dist/Pagination/index.scss +32 -34
  70. package/dist/Pagination/pagination-bootstrap.scss +83 -0
  71. package/dist/Popover/index.scss +9 -10
  72. package/dist/Popover/popover-bootstrap.scss +198 -0
  73. package/dist/ProductTour/Checkpoint.scss +71 -43
  74. package/dist/ProgressBar/_mixins.scss +22 -0
  75. package/dist/ProgressBar/bootstrap-progress.scss +49 -0
  76. package/dist/ProgressBar/index.scss +28 -36
  77. package/dist/Scrollable/index.scss +2 -2
  78. package/dist/SearchField/SearchFieldInput.js +2 -2
  79. package/dist/SearchField/SearchFieldInput.js.map +1 -1
  80. package/dist/SearchField/index.scss +15 -17
  81. package/dist/SelectableBox/index.scss +11 -13
  82. package/dist/Sheet/index.scss +10 -10
  83. package/dist/Spinner/index.scss +57 -2
  84. package/dist/Stack/index.scss +1 -3
  85. package/dist/Stepper/index.scss +20 -20
  86. package/dist/Sticky/index.scss +4 -6
  87. package/dist/Tabs/index.js +0 -2
  88. package/dist/Tabs/index.js.map +1 -1
  89. package/dist/Tabs/index.scss +29 -25
  90. package/dist/Toast/ToastContainer.scss +9 -11
  91. package/dist/Toast/bootstrap-toast.scss +46 -0
  92. package/dist/Toast/index.scss +9 -10
  93. package/dist/Tooltip/index.scss +136 -10
  94. package/dist/ValidationMessage/index.scss +1 -1
  95. package/dist/core.css +16777 -0
  96. package/dist/core.css.map +1 -0
  97. package/dist/core.min.css +2 -0
  98. package/dist/index.d.ts +2 -2
  99. package/dist/index.js +4 -18
  100. package/dist/index.scss +0 -4
  101. package/dist/light.css +4098 -0
  102. package/dist/light.css.map +1 -0
  103. package/dist/light.min.css +2 -0
  104. package/dist/theme-urls.json +21 -0
  105. package/dist/utils/breakpoints.js +1 -1
  106. package/lib/build-scss.js +188 -0
  107. package/lib/build-tokens.js +133 -0
  108. package/lib/help.js +36 -23
  109. package/lib/replace-variables.js +38 -0
  110. package/lib/utils.js +30 -0
  111. package/package.json +30 -14
  112. package/src/ActionRow/_index.scss +2 -4
  113. package/src/Alert/index.scss +41 -32
  114. package/src/Annotation/_mixins.scss +104 -0
  115. package/src/Annotation/index.scss +130 -103
  116. package/src/Avatar/index.scss +18 -20
  117. package/src/AvatarButton/index.scss +3 -5
  118. package/src/Badge/index.scss +112 -2
  119. package/src/Breadcrumb/index.scss +14 -16
  120. package/src/Bubble/index.scss +25 -12
  121. package/src/Button/{Button.test.tsx → Button.test.jsx} +2 -14
  122. package/src/Button/README.md +0 -84
  123. package/src/Button/__snapshots__/{Button.test.tsx.snap → Button.test.jsx.snap} +2 -19
  124. package/src/Button/_mixins.scss +14 -0
  125. package/src/Button/button-group.scss +126 -0
  126. package/src/Button/index.jsx +113 -0
  127. package/src/Button/index.scss +855 -372
  128. package/src/Card/card-bootstrap.scss +168 -0
  129. package/src/Card/index.scss +78 -79
  130. package/src/Carousel/index.scss +168 -2
  131. package/src/Chip/ChipIcon.tsx +1 -1
  132. package/src/Chip/index.scss +48 -38
  133. package/src/Chip/index.tsx +5 -5
  134. package/src/Chip/mixins.scss +8 -3
  135. package/src/ChipCarousel/index.scss +4 -4
  136. package/src/CloseButton/index.scss +31 -2
  137. package/src/Code/index.scss +47 -2
  138. package/src/Collapsible/index.scss +15 -15
  139. package/src/ColorPicker/index.scss +9 -11
  140. package/src/DataTable/CollapsibleButtonGroup.jsx +2 -2
  141. package/src/DataTable/index.scss +48 -50
  142. package/src/Dropdown/README.md +0 -93
  143. package/src/Dropdown/dropdown-bootstrap.scss +181 -0
  144. package/src/Dropdown/index.jsx +0 -2
  145. package/src/Dropdown/index.scss +11 -12
  146. package/src/Dropzone/index.scss +12 -14
  147. package/src/Form/_FormText.scss +8 -8
  148. package/src/Form/_bootstrap-custom-forms.scss +551 -0
  149. package/src/Form/_bootstrap-forms.scss +381 -0
  150. package/src/Form/_index.scss +168 -146
  151. package/src/Form/_input-group.scss +188 -0
  152. package/src/Form/_mixins.scss +216 -3
  153. package/src/Hyperlink/{Hyperlink.test.tsx → Hyperlink.test.jsx} +10 -21
  154. package/src/Hyperlink/{index.tsx → index.jsx} +37 -41
  155. package/src/Hyperlink/index.scss +1 -1
  156. package/src/Icon/index.d.ts +2 -4
  157. package/src/Icon/index.jsx +1 -1
  158. package/src/Icon/index.scss +10 -12
  159. package/src/IconButton/README.md +1 -15
  160. package/src/IconButton/__snapshots__/IconButton.test.jsx.snap +5 -28
  161. package/src/IconButton/_mixins.scss +4 -0
  162. package/src/IconButton/index.jsx +6 -13
  163. package/src/IconButton/index.scss +387 -74
  164. package/src/IconButtonToggle/index.scss +1 -1
  165. package/src/Image/index.scss +53 -2
  166. package/src/Menu/index.scss +25 -27
  167. package/src/Modal/_ModalDialog.scss +52 -54
  168. package/src/Modal/index.scss +6 -73
  169. package/src/Nav/_mixins.scss +4 -4
  170. package/src/Nav/index.scss +70 -66
  171. package/src/Navbar/index.scss +276 -2
  172. package/src/OverflowScroll/data/useOverflowScrollElementAttributes.js +3 -3
  173. package/src/Overlay/index.jsx +2 -3
  174. package/src/PageBanner/index.scss +17 -21
  175. package/src/Pagination/index.scss +32 -34
  176. package/src/Pagination/pagination-bootstrap.scss +83 -0
  177. package/src/Popover/index.scss +9 -10
  178. package/src/Popover/popover-bootstrap.scss +198 -0
  179. package/src/ProductTour/Checkpoint.scss +71 -43
  180. package/src/ProgressBar/_mixins.scss +22 -0
  181. package/src/ProgressBar/bootstrap-progress.scss +49 -0
  182. package/src/ProgressBar/index.scss +28 -36
  183. package/src/Scrollable/index.scss +2 -2
  184. package/src/SearchField/SearchFieldInput.jsx +2 -2
  185. package/src/SearchField/__snapshots__/SearchField.test.jsx.snap +12 -8
  186. package/src/SearchField/index.scss +15 -17
  187. package/src/SelectableBox/index.scss +11 -13
  188. package/src/Sheet/index.scss +10 -10
  189. package/src/Spinner/index.scss +57 -2
  190. package/src/Stack/index.scss +1 -3
  191. package/src/Stepper/index.scss +20 -20
  192. package/src/Sticky/index.scss +4 -6
  193. package/src/Tabs/README.md +1 -23
  194. package/src/Tabs/index.jsx +0 -3
  195. package/src/Tabs/index.scss +29 -25
  196. package/src/Toast/ToastContainer.scss +9 -11
  197. package/src/Toast/bootstrap-toast.scss +46 -0
  198. package/src/Toast/index.scss +9 -10
  199. package/src/Tooltip/index.scss +136 -10
  200. package/src/TransitionReplace/README.md +4 -4
  201. package/src/ValidationMessage/index.scss +1 -1
  202. package/src/index.d.ts +2 -2
  203. package/src/index.js +4 -18
  204. package/src/index.scss +0 -4
  205. package/src/{setupTest.ts → setupTest.js} +0 -7
  206. package/src/utils/breakpoints.js +1 -1
  207. package/styles/css/core/custom-media-breakpoints.css +17 -0
  208. package/styles/css/core/index.css +2 -0
  209. package/styles/css/core/variables.css +603 -0
  210. package/styles/css/themes/light/index.css +2 -0
  211. package/styles/css/themes/light/utility-classes.css +2454 -0
  212. package/styles/css/themes/light/variables.css +1644 -0
  213. package/{scss → styles/scss}/core/_functions.scss +1 -1
  214. package/styles/scss/core/_grid.scss +21 -0
  215. package/{scss → styles/scss}/core/_utilities.scss +17 -11
  216. package/styles/scss/core/_variables.scss +868 -0
  217. package/styles/scss/core/bootstrap-override/_functions.scss +104 -0
  218. package/styles/scss/core/bootstrap-override/_mixins.scss +4 -0
  219. package/styles/scss/core/bootstrap-override/_utilities.scss +4 -0
  220. package/styles/scss/core/bootstrap-override/bootstrap.scss +2 -0
  221. package/styles/scss/core/bootstrap-override/mixins/_grid-framework.scss +80 -0
  222. package/styles/scss/core/bootstrap-override/mixins/_grid.scss +69 -0
  223. package/styles/scss/core/bootstrap-override/mixins/_list-group.scss +22 -0
  224. package/styles/scss/core/bootstrap-override/utilities/_background.scss +7 -0
  225. package/styles/scss/core/bootstrap-override/utilities/_borders.scss +67 -0
  226. package/styles/scss/core/bootstrap-override/utilities/_spacing.scss +70 -0
  227. package/styles/scss/core/bootstrap-override/utilities/_text.scss +68 -0
  228. package/styles/scss/core/core.scss +21 -0
  229. package/{scss → styles/scss}/core/utilities-only.scss +1 -0
  230. package/tokens/README.md +157 -0
  231. package/tokens/css-utilities.js +56 -0
  232. package/tokens/map-scss-to-css.js +24 -0
  233. package/tokens/replace-variables.js +32 -0
  234. package/tokens/sass-helpers.js +98 -0
  235. package/tokens/src/core/alias/size.json +15 -0
  236. package/tokens/src/core/components/ActionRow.json +10 -0
  237. package/tokens/src/core/components/Alert.json +30 -0
  238. package/tokens/src/core/components/Annotation.json +25 -0
  239. package/tokens/src/core/components/Avatar.json +17 -0
  240. package/tokens/src/core/components/AvatarButton.json +11 -0
  241. package/tokens/src/core/components/Badge.json +33 -0
  242. package/tokens/src/core/components/Breadcrumb.json +23 -0
  243. package/tokens/src/core/components/Bubble.json +10 -0
  244. package/tokens/src/core/components/Button/core.json +105 -0
  245. package/tokens/src/core/components/Card.json +96 -0
  246. package/tokens/src/core/components/Carousel.json +37 -0
  247. package/tokens/src/core/components/Chip.json +41 -0
  248. package/tokens/src/core/components/ChipCarousel.json +15 -0
  249. package/tokens/src/core/components/CloseButton.json +14 -0
  250. package/tokens/src/core/components/Code.json +34 -0
  251. package/tokens/src/core/components/Collapsible.json +29 -0
  252. package/tokens/src/core/components/ColorPicker.json +8 -0
  253. package/tokens/src/core/components/Container.json +13 -0
  254. package/tokens/src/core/components/DataTable.json +27 -0
  255. package/tokens/src/core/components/Dropdown.json +67 -0
  256. package/tokens/src/core/components/Dropzone.json +21 -0
  257. package/tokens/src/core/components/Form/other.json +14 -0
  258. package/tokens/src/core/components/Form/size.json +229 -0
  259. package/tokens/src/core/components/Form/spacing.json +155 -0
  260. package/tokens/src/core/components/Form/transition.json +16 -0
  261. package/tokens/src/core/components/Form/typography.json +122 -0
  262. package/tokens/src/core/components/Icon.json +11 -0
  263. package/tokens/src/core/components/IconButton.json +15 -0
  264. package/tokens/src/core/components/Image.json +28 -0
  265. package/tokens/src/core/components/Menu.json +48 -0
  266. package/tokens/src/core/components/Modal.json +47 -0
  267. package/tokens/src/core/components/Nav.json +52 -0
  268. package/tokens/src/core/components/Navbar.json +70 -0
  269. package/tokens/src/core/components/Pagination.json +66 -0
  270. package/tokens/src/core/components/Popover.json +48 -0
  271. package/tokens/src/core/components/ProductTour.json +32 -0
  272. package/tokens/src/core/components/ProgressBar.json +39 -0
  273. package/tokens/src/core/components/SearchField.json +23 -0
  274. package/tokens/src/core/components/SelectableBox.json +9 -0
  275. package/tokens/src/core/components/Sheet.json +10 -0
  276. package/tokens/src/core/components/Spinner.json +19 -0
  277. package/tokens/src/core/components/Stack.json +7 -0
  278. package/tokens/src/core/components/Stepper.json +42 -0
  279. package/tokens/src/core/components/Sticky.json +7 -0
  280. package/tokens/src/core/components/Tab.json +19 -0
  281. package/tokens/src/core/components/Tabs.json +19 -0
  282. package/tokens/src/core/components/Toast.json +30 -0
  283. package/tokens/src/core/components/Tooltip.json +33 -0
  284. package/tokens/src/core/components/general/caret.json +13 -0
  285. package/tokens/src/core/components/general/headings.json +16 -0
  286. package/tokens/src/core/components/general/hr.json +10 -0
  287. package/tokens/src/core/components/general/input.json +51 -0
  288. package/tokens/src/core/components/general/link.json +30 -0
  289. package/tokens/src/core/components/general/list.json +26 -0
  290. package/tokens/src/core/components/general/text.json +24 -0
  291. package/tokens/src/core/global/breakpoints.json +12 -0
  292. package/tokens/src/core/global/display.json +22 -0
  293. package/tokens/src/core/global/elevation.json +19 -0
  294. package/tokens/src/core/global/other.json +4 -0
  295. package/tokens/src/core/global/spacing.json +37 -0
  296. package/tokens/src/core/global/transition.json +14 -0
  297. package/tokens/src/core/global/typography.json +91 -0
  298. package/tokens/src/core/utilities/color.json +12 -0
  299. package/tokens/src/themes/light/alias/color.json +114 -0
  300. package/tokens/src/themes/light/components/Alert.json +38 -0
  301. package/tokens/src/themes/light/components/Annotation.json +29 -0
  302. package/tokens/src/themes/light/components/Avatar.json +7 -0
  303. package/tokens/src/themes/light/components/Badge.json +186 -0
  304. package/tokens/src/themes/light/components/Breadcrumb.json +13 -0
  305. package/tokens/src/themes/light/components/Bubble.json +18 -0
  306. package/tokens/src/themes/light/components/Button/brand.json +260 -0
  307. package/tokens/src/themes/light/components/Button/core.json +24 -0
  308. package/tokens/src/themes/light/components/Button/danger.json +247 -0
  309. package/tokens/src/themes/light/components/Button/dark.json +230 -0
  310. package/tokens/src/themes/light/components/Button/info.json +238 -0
  311. package/tokens/src/themes/light/components/Button/light.json +236 -0
  312. package/tokens/src/themes/light/components/Button/primary.json +250 -0
  313. package/tokens/src/themes/light/components/Button/secondary.json +278 -0
  314. package/tokens/src/themes/light/components/Button/success.json +253 -0
  315. package/tokens/src/themes/light/components/Button/tertiary.json +109 -0
  316. package/tokens/src/themes/light/components/Button/warning.json +276 -0
  317. package/tokens/src/themes/light/components/Card.json +36 -0
  318. package/tokens/src/themes/light/components/Carousel.json +45 -0
  319. package/tokens/src/themes/light/components/Chip.json +50 -0
  320. package/tokens/src/themes/light/components/CloseButton.json +10 -0
  321. package/tokens/src/themes/light/components/Code.json +23 -0
  322. package/tokens/src/themes/light/components/DataTable.json +26 -0
  323. package/tokens/src/themes/light/components/Dropdown.json +41 -0
  324. package/tokens/src/themes/light/components/Dropzone.json +23 -0
  325. package/tokens/src/themes/light/components/Form/color.json +270 -0
  326. package/tokens/src/themes/light/components/Form/elevation.json +76 -0
  327. package/tokens/src/themes/light/components/Form/other.json +131 -0
  328. package/tokens/src/themes/light/components/IconButton.json +451 -0
  329. package/tokens/src/themes/light/components/Image.json +18 -0
  330. package/tokens/src/themes/light/components/Menu.json +30 -0
  331. package/tokens/src/themes/light/components/Modal.json +37 -0
  332. package/tokens/src/themes/light/components/Nav.json +166 -0
  333. package/tokens/src/themes/light/components/Navbar.json +136 -0
  334. package/tokens/src/themes/light/components/OverflowScroll.json +9 -0
  335. package/tokens/src/themes/light/components/PageBanner.json +24 -0
  336. package/tokens/src/themes/light/components/Pagination.json +45 -0
  337. package/tokens/src/themes/light/components/Popover.json +55 -0
  338. package/tokens/src/themes/light/components/ProductTour.json +35 -0
  339. package/tokens/src/themes/light/components/ProgressBar.json +20 -0
  340. package/tokens/src/themes/light/components/Scrollable.json +14 -0
  341. package/tokens/src/themes/light/components/SearchField.json +25 -0
  342. package/tokens/src/themes/light/components/Sheet.json +22 -0
  343. package/tokens/src/themes/light/components/Stepper.json +34 -0
  344. package/tokens/src/themes/light/components/Sticky.json +18 -0
  345. package/tokens/src/themes/light/components/Tab.json +62 -0
  346. package/tokens/src/themes/light/components/Toast.json +33 -0
  347. package/tokens/src/themes/light/components/Tooltip.json +30 -0
  348. package/tokens/src/themes/light/components/general/body.json +8 -0
  349. package/tokens/src/themes/light/components/general/headings.json +7 -0
  350. package/tokens/src/themes/light/components/general/hr.json +15 -0
  351. package/tokens/src/themes/light/components/general/input.json +18 -0
  352. package/tokens/src/themes/light/components/general/link.json +109 -0
  353. package/tokens/src/themes/light/components/general/list.json +38 -0
  354. package/tokens/src/themes/light/components/general/text.json +12 -0
  355. package/tokens/src/themes/light/global/color.json +1661 -0
  356. package/tokens/src/themes/light/global/elevation.json +201 -0
  357. package/tokens/src/themes/light/global/other.json +4 -0
  358. package/tokens/style-dictionary.js +229 -0
  359. package/tokens/utils.js +210 -0
  360. package/dist/ActionRow/_variables.scss +0 -2
  361. package/dist/Alert/_variables.scss +0 -24
  362. package/dist/Annotation/_variables.scss +0 -18
  363. package/dist/Avatar/_variables.scss +0 -10
  364. package/dist/AvatarButton/_variables.scss +0 -3
  365. package/dist/Badge/_variables.scss +0 -16
  366. package/dist/Breadcrumb/_variables.scss +0 -27
  367. package/dist/Bubble/_variables.scss +0 -8
  368. package/dist/Button/_variables.scss +0 -52
  369. package/dist/Button/deprecated/index.js +0 -149
  370. package/dist/Button/deprecated/index.js.map +0 -1
  371. package/dist/Button/index.d.ts +0 -35
  372. package/dist/Card/_variables.scss +0 -55
  373. package/dist/Carousel/_variables.scss +0 -27
  374. package/dist/CheckBox/index.js +0 -102
  375. package/dist/CheckBox/index.js.map +0 -1
  376. package/dist/CheckBoxGroup/index.js +0 -15
  377. package/dist/CheckBoxGroup/index.js.map +0 -1
  378. package/dist/Chip/_variables.scss +0 -28
  379. package/dist/ChipCarousel/_variables.scss +0 -3
  380. package/dist/CloseButton/_variables.scss +0 -6
  381. package/dist/Code/_variables.scss +0 -17
  382. package/dist/Collapsible/_variables.scss +0 -12
  383. package/dist/ColorPicker/_variables.scss +0 -2
  384. package/dist/Container/_variables.scss +0 -5
  385. package/dist/DataTable/_variables.scss +0 -11
  386. package/dist/Dropdown/_variables.scss +0 -33
  387. package/dist/Dropdown/deprecated/DropdownButton.js +0 -44
  388. package/dist/Dropdown/deprecated/DropdownButton.js.map +0 -1
  389. package/dist/Dropdown/deprecated/DropdownItem.js +0 -33
  390. package/dist/Dropdown/deprecated/DropdownItem.js.map +0 -1
  391. package/dist/Dropdown/deprecated/DropdownMenu.js +0 -46
  392. package/dist/Dropdown/deprecated/DropdownMenu.js.map +0 -1
  393. package/dist/Dropdown/deprecated/index.js +0 -241
  394. package/dist/Dropdown/deprecated/index.js.map +0 -1
  395. package/dist/Dropzone/_variables.scss +0 -9
  396. package/dist/Fieldset/index.js +0 -117
  397. package/dist/Fieldset/index.js.map +0 -1
  398. package/dist/Fieldset/index.scss +0 -12
  399. package/dist/Form/_variables.scss +0 -267
  400. package/dist/Hyperlink/index.d.ts +0 -24
  401. package/dist/Icon/_variables.scss +0 -7
  402. package/dist/Image/_variables.scss +0 -13
  403. package/dist/Input/index.js +0 -166
  404. package/dist/Input/index.js.map +0 -1
  405. package/dist/InputSelect/index.js +0 -105
  406. package/dist/InputSelect/index.js.map +0 -1
  407. package/dist/InputText/index.js +0 -45
  408. package/dist/InputText/index.js.map +0 -1
  409. package/dist/ListBox/index.js +0 -148
  410. package/dist/ListBox/index.js.map +0 -1
  411. package/dist/ListBoxOption/index.js +0 -94
  412. package/dist/ListBoxOption/index.js.map +0 -1
  413. package/dist/Menu/_variables.scss +0 -24
  414. package/dist/Modal/_variables.scss +0 -50
  415. package/dist/Modal/index.js +0 -292
  416. package/dist/Modal/index.js.map +0 -1
  417. package/dist/Nav/_variables.scss +0 -58
  418. package/dist/Navbar/_variables.scss +0 -40
  419. package/dist/OverflowScroll/_variables.scss +0 -5
  420. package/dist/OverflowScroll/index.scss +0 -1
  421. package/dist/Pagination/_variables.scss +0 -19
  422. package/dist/Popover/_variables.scss +0 -36
  423. package/dist/ProductTour/_variables.scss +0 -15
  424. package/dist/ProgressBar/_variables.scss +0 -23
  425. package/dist/RadioButtonGroup/index.js +0 -188
  426. package/dist/RadioButtonGroup/index.js.map +0 -1
  427. package/dist/SearchField/_variables.scss +0 -14
  428. package/dist/SelectableBox/_variables.scss +0 -5
  429. package/dist/Spinner/_variables.scss +0 -9
  430. package/dist/Stack/_variables.scss +0 -1
  431. package/dist/StatusAlert/index.js +0 -168
  432. package/dist/StatusAlert/index.js.map +0 -1
  433. package/dist/Stepper/_variables.scss +0 -18
  434. package/dist/Sticky/_variables.scss +0 -3
  435. package/dist/Table/_variables.scss +0 -34
  436. package/dist/Table/index.js +0 -267
  437. package/dist/Table/index.js.map +0 -1
  438. package/dist/Table/index.scss +0 -12
  439. package/dist/Tabs/_variables.scss +0 -24
  440. package/dist/Tabs/deprecated/Tabs.scss +0 -3
  441. package/dist/Tabs/deprecated/index.js +0 -123
  442. package/dist/Tabs/deprecated/index.js.map +0 -1
  443. package/dist/TextArea/index.js +0 -44
  444. package/dist/TextArea/index.js.map +0 -1
  445. package/dist/Toast/_variables.scss +0 -19
  446. package/dist/Tooltip/_variables.scss +0 -21
  447. package/dist/ValidationFormGroup/index.js +0 -106
  448. package/dist/ValidationFormGroup/index.js.map +0 -1
  449. package/dist/paragon.css +0 -45
  450. package/dist/setupTest.d.ts +0 -2
  451. package/dist/setupTest.js.map +0 -1
  452. package/dist/utils/types/bootstrap.d.ts +0 -39
  453. package/dist/utils/types/bootstrap.js +0 -2
  454. package/dist/utils/types/bootstrap.js.map +0 -1
  455. package/scss/core/_grid.scss +0 -21
  456. package/scss/core/_variables.scss +0 -875
  457. package/scss/core/core.scss +0 -21
  458. package/src/ActionRow/_variables.scss +0 -2
  459. package/src/Alert/_variables.scss +0 -24
  460. package/src/Annotation/_variables.scss +0 -18
  461. package/src/Avatar/_variables.scss +0 -10
  462. package/src/AvatarButton/_variables.scss +0 -3
  463. package/src/Badge/_variables.scss +0 -16
  464. package/src/Breadcrumb/_variables.scss +0 -27
  465. package/src/Bubble/_variables.scss +0 -8
  466. package/src/Button/_variables.scss +0 -52
  467. package/src/Button/deprecated/Button.test.jsx +0 -34
  468. package/src/Button/deprecated/index.jsx +0 -145
  469. package/src/Button/index.tsx +0 -159
  470. package/src/Card/_variables.scss +0 -55
  471. package/src/Carousel/_variables.scss +0 -27
  472. package/src/CheckBox/CheckBox.test.jsx +0 -65
  473. package/src/CheckBox/README.md +0 -93
  474. package/src/CheckBox/index.jsx +0 -80
  475. package/src/CheckBoxGroup/CheckBoxGroup.test.jsx +0 -33
  476. package/src/CheckBoxGroup/README.md +0 -35
  477. package/src/CheckBoxGroup/index.jsx +0 -19
  478. package/src/Chip/_variables.scss +0 -28
  479. package/src/ChipCarousel/_variables.scss +0 -3
  480. package/src/CloseButton/_variables.scss +0 -6
  481. package/src/Code/_variables.scss +0 -17
  482. package/src/Collapsible/_variables.scss +0 -12
  483. package/src/ColorPicker/_variables.scss +0 -2
  484. package/src/Container/_variables.scss +0 -5
  485. package/src/DataTable/_variables.scss +0 -11
  486. package/src/Dropdown/_variables.scss +0 -33
  487. package/src/Dropdown/deprecated/Dropdown.test.jsx +0 -238
  488. package/src/Dropdown/deprecated/DropdownButton.jsx +0 -52
  489. package/src/Dropdown/deprecated/DropdownItem.jsx +0 -34
  490. package/src/Dropdown/deprecated/DropdownMenu.jsx +0 -50
  491. package/src/Dropdown/deprecated/__snapshots__/Dropdown.test.jsx.snap +0 -229
  492. package/src/Dropdown/deprecated/index.jsx +0 -222
  493. package/src/Dropzone/_variables.scss +0 -9
  494. package/src/Fieldset/Fieldset.test.jsx +0 -101
  495. package/src/Fieldset/README.md +0 -146
  496. package/src/Fieldset/index.jsx +0 -107
  497. package/src/Fieldset/index.scss +0 -12
  498. package/src/Form/_variables.scss +0 -267
  499. package/src/Icon/_variables.scss +0 -7
  500. package/src/Image/_variables.scss +0 -13
  501. package/src/Input/README.md +0 -74
  502. package/src/Input/__snapshots__/input.test.jsx.snap +0 -53
  503. package/src/Input/index.jsx +0 -151
  504. package/src/Input/input.test.jsx +0 -85
  505. package/src/InputSelect/README.md +0 -136
  506. package/src/InputSelect/index.jsx +0 -92
  507. package/src/InputText/InputText.test.jsx +0 -74
  508. package/src/InputText/README.md +0 -293
  509. package/src/InputText/index.jsx +0 -49
  510. package/src/ListBox/ListBox.test.jsx +0 -161
  511. package/src/ListBox/README.md +0 -185
  512. package/src/ListBox/index.jsx +0 -115
  513. package/src/ListBoxOption/ListBoxOption.test.jsx +0 -154
  514. package/src/ListBoxOption/index.jsx +0 -78
  515. package/src/Menu/_variables.scss +0 -24
  516. package/src/Modal/README.md +0 -148
  517. package/src/Modal/_variables.scss +0 -50
  518. package/src/Modal/index.jsx +0 -319
  519. package/src/Modal/tests/Modal.test.jsx +0 -261
  520. package/src/Nav/_variables.scss +0 -58
  521. package/src/Navbar/_variables.scss +0 -40
  522. package/src/OverflowScroll/_variables.scss +0 -5
  523. package/src/OverflowScroll/index.scss +0 -1
  524. package/src/Pagination/_variables.scss +0 -19
  525. package/src/Popover/_variables.scss +0 -36
  526. package/src/ProductTour/_variables.scss +0 -15
  527. package/src/ProgressBar/_variables.scss +0 -23
  528. package/src/RadioButtonGroup/README.md +0 -50
  529. package/src/RadioButtonGroup/RadioButtonGroup.test.jsx +0 -127
  530. package/src/RadioButtonGroup/index.jsx +0 -185
  531. package/src/SearchField/_variables.scss +0 -14
  532. package/src/SelectableBox/_variables.scss +0 -5
  533. package/src/Spinner/_variables.scss +0 -9
  534. package/src/Stack/_variables.scss +0 -1
  535. package/src/StatusAlert/README.md +0 -149
  536. package/src/StatusAlert/StatusAlert.test.jsx +0 -150
  537. package/src/StatusAlert/index.jsx +0 -144
  538. package/src/Stepper/_variables.scss +0 -18
  539. package/src/Sticky/_variables.scss +0 -3
  540. package/src/Table/README.md +0 -506
  541. package/src/Table/Table.test.jsx +0 -367
  542. package/src/Table/_variables.scss +0 -34
  543. package/src/Table/index.jsx +0 -264
  544. package/src/Table/index.scss +0 -12
  545. package/src/Tabs/_variables.scss +0 -24
  546. package/src/Tabs/deprecated/Tabs.scss +0 -3
  547. package/src/Tabs/deprecated/Tabs.test.jsx +0 -50
  548. package/src/Tabs/deprecated/index.jsx +0 -117
  549. package/src/TextArea/README.md +0 -63
  550. package/src/TextArea/index.jsx +0 -48
  551. package/src/Toast/_variables.scss +0 -19
  552. package/src/Tooltip/_variables.scss +0 -21
  553. package/src/ValidationFormGroup/README.md +0 -116
  554. package/src/ValidationFormGroup/ValidationFormGroup.test.jsx +0 -146
  555. package/src/ValidationFormGroup/__snapshots__/ValidationFormGroup.test.jsx.snap +0 -161
  556. package/src/ValidationFormGroup/index.jsx +0 -114
  557. package/src/utils/types/bootstrap.test.tsx +0 -86
  558. package/src/utils/types/bootstrap.ts +0 -43
  559. /package/src/Button/{ButtonGroup.test.tsx → ButtonGroup.test.jsx} +0 -0
  560. /package/src/Button/{ButtonToolbar.test.tsx → ButtonToolbar.test.jsx} +0 -0
  561. /package/src/Button/__snapshots__/{ButtonGroup.test.tsx.snap → ButtonGroup.test.jsx.snap} +0 -0
  562. /package/src/Button/__snapshots__/{ButtonToolbar.test.tsx.snap → ButtonToolbar.test.jsx.snap} +0 -0
  563. /package/{scss → styles/scss}/core/_exports.module.scss +0 -0
  564. /package/{scss → styles/scss}/core/_typography.scss +0 -0
@@ -0,0 +1,133 @@
1
+ const path = require('path');
2
+ const minimist = require('minimist');
3
+ const { StyleDictionary, colorTransform, createCustomCSSVariables } = require('../tokens/style-dictionary');
4
+ const { createIndexCssFile } = require('../tokens/utils');
5
+
6
+ /**
7
+ * Builds tokens for CSS styles from JSON source files.
8
+ *
9
+ * @param {string[]} commandArgs - Command line arguments for building tokens.
10
+ * @param {string} [commandArgs.build-dir='./build/'] - The directory where the build output will be placed.
11
+ * @param {string} [commandArgs.source] - The source directory containing JSON token files.
12
+ * @param {boolean} [commandArgs.source-tokens-only=false] - Indicates whether to include only source tokens.
13
+ * @param {string|string[]} [commandArgs.themes=['light']] - The themes (variants) for which to build tokens.
14
+ */
15
+ async function buildTokensCommand(commandArgs) {
16
+ const defaultParams = {
17
+ themes: ['light'],
18
+ 'build-dir': './build/',
19
+ };
20
+
21
+ const alias = {
22
+ 'build-dir': 'b',
23
+ themes: 't',
24
+ };
25
+
26
+ const {
27
+ 'build-dir': buildDir,
28
+ source: tokensSource,
29
+ 'source-tokens-only': hasSourceTokensOnly,
30
+ themes,
31
+ } = minimist(commandArgs, { alias, default: defaultParams, boolean: 'source-tokens-only' });
32
+
33
+ const coreConfig = {
34
+ include: [
35
+ path.resolve(__dirname, '../tokens/src/core/**/*.json'),
36
+ path.resolve(__dirname, '../tokens/src/core/**/*.toml'),
37
+ ],
38
+ source: tokensSource
39
+ ? [`${tokensSource}/core/**/*.json`, `${tokensSource}/core/**/*.toml`]
40
+ : [],
41
+ platforms: {
42
+ css: {
43
+ prefix: 'pgn',
44
+ transformGroup: 'css',
45
+ // NOTE: buildPath must end with a slash
46
+ buildPath: buildDir.slice(-1) === '/' ? buildDir : `${buildDir}/`,
47
+ files: [
48
+ {
49
+ format: 'css/custom-variables',
50
+ destination: 'core/variables.css',
51
+ filter: hasSourceTokensOnly ? 'isSource' : undefined,
52
+ options: {
53
+ outputReferences: !hasSourceTokensOnly,
54
+ },
55
+ },
56
+ {
57
+ format: 'css/custom-media-breakpoints',
58
+ destination: 'core/custom-media-breakpoints.css',
59
+ filter: hasSourceTokensOnly ? 'isSource' : undefined,
60
+ options: {
61
+ outputReferences: !hasSourceTokensOnly,
62
+ },
63
+ },
64
+ ],
65
+ transforms: StyleDictionary.transformGroup.css.filter(item => item !== 'size/rem').concat('color/sass-color-functions', 'str-replace'),
66
+ options: {
67
+ fileHeader: 'customFileHeader',
68
+ },
69
+ },
70
+ },
71
+ };
72
+
73
+ const getStyleDictionaryConfig = (themeVariant) => ({
74
+ ...coreConfig,
75
+ include: [
76
+ ...coreConfig.include,
77
+ path.resolve(__dirname, `../tokens/src/themes/${themeVariant}/**/*.json`),
78
+ path.resolve(__dirname, `../tokens/src/themes/${themeVariant}/**/*.toml`),
79
+ ],
80
+ source: tokensSource
81
+ ? [
82
+ `${tokensSource}/themes/${themeVariant}/**/*.json`,
83
+ `${tokensSource}/themes/${themeVariant}/**/*.toml`,
84
+ ]
85
+ : [],
86
+ transform: {
87
+ 'color/sass-color-functions': {
88
+ ...StyleDictionary.transform['color/sass-color-functions'],
89
+ transformer: (token) => colorTransform(token, themeVariant),
90
+ },
91
+ },
92
+ format: {
93
+ 'css/custom-variables': formatterArgs => createCustomCSSVariables({
94
+ formatterArgs,
95
+ themeVariant,
96
+ }),
97
+ },
98
+ platforms: {
99
+ css: {
100
+ ...coreConfig.platforms.css,
101
+ files: [
102
+ {
103
+ format: 'css/custom-variables',
104
+ destination: `themes/${themeVariant}/variables.css`,
105
+ filter: hasSourceTokensOnly ? 'isSource' : undefined,
106
+ options: {
107
+ outputReferences: !hasSourceTokensOnly,
108
+ },
109
+ },
110
+ {
111
+ format: 'css/utility-classes',
112
+ destination: `themes/${themeVariant}/utility-classes.css`,
113
+ filter: hasSourceTokensOnly ? 'isSource' : undefined,
114
+ options: {
115
+ outputReferences: !hasSourceTokensOnly,
116
+ },
117
+ },
118
+ ],
119
+ },
120
+ },
121
+ });
122
+
123
+ StyleDictionary.extend(coreConfig).buildAllPlatforms();
124
+ createIndexCssFile({ buildDir, isTheme: false });
125
+
126
+ themes.forEach((themeVariant) => {
127
+ const config = getStyleDictionaryConfig(themeVariant);
128
+ StyleDictionary.extend(config).buildAllPlatforms();
129
+ createIndexCssFile({ buildDir, isTheme: true, themeVariant });
130
+ });
131
+ }
132
+
133
+ module.exports = buildTokensCommand;
package/lib/help.js CHANGED
@@ -1,52 +1,65 @@
1
1
  /* eslint-disable no-console */
2
2
  const chalk = require('chalk');
3
3
 
4
- const DESCRIPTION_PAD = 20;
5
-
6
4
  /**
7
- * Pads a description string to align with a specified offset string.
5
+ * Finds a command based on the given name in the commands object.
8
6
  *
9
- * @param {string} description - The description to pad.
10
- * @param {string} offsetString - The offset string that the description should align with.
11
- * @returns {string} - The padded description.
7
+ * @param {Array} commandName - The name to find the command.
8
+ * @param {Object} commands - The object containing commands to search in.
9
+ * @returns {Object|null} - The found command or null if the command is not found.
12
10
  */
13
- function padLeft(description, offsetString) {
14
- // Calculate the necessary padding based on the offsetString length
15
- const padding = ' '.repeat(Math.max(0, DESCRIPTION_PAD - offsetString.length));
16
- return `${padding}${description}`;
17
- }
11
+ const findCommandByName = (commandName, commands) => ((commandName in commands)
12
+ ? { [commandName]: commands[commandName] } : null);
18
13
 
19
14
  /**
20
15
  * Displays a help message for available commands, including descriptions, parameters, and options.
21
16
  *
22
17
  * @param {Object} commands - An object containing information about available commands.
18
+ * @param {Array} commandArgs - An array containing the command name.
23
19
  */
24
- function helpCommand(commands) {
20
+ function helpCommand(commands, commandArgs) {
21
+ const retrievedCommands = commandArgs.length ? findCommandByName(commandArgs, commands) : commands;
22
+ if (!retrievedCommands) {
23
+ console.error(chalk.red.bold('Unknown command. Usage: paragon help <command>.'));
24
+ return;
25
+ }
26
+
25
27
  console.log(chalk.yellow.bold('Paragon Help'));
26
28
  console.log();
27
- console.log('Available commands:');
29
+
30
+ if (!commandArgs.length) {
31
+ console.log('Available commands:');
32
+ }
33
+
28
34
  console.log();
29
35
 
30
- Object.entries(commands).forEach(([command, { parameters, description, options }]) => {
31
- console.log(` ${chalk.green.bold(command)}`);
36
+ Object.entries(retrievedCommands).forEach(([command, { parameters, description, options }]) => {
37
+ console.log(` ${chalk.green.underline.bold(command)}`);
32
38
  if (description) {
33
- console.log(` ${description}`);
39
+ console.log(` ${description}`);
34
40
  }
35
41
 
36
42
  if (parameters && parameters.length > 0) {
37
- console.log(` ${chalk.cyan('Parameters: ')}`);
43
+ console.log('');
44
+ console.log(` ${chalk.bold.cyan('Parameters: ')}`);
38
45
  parameters.forEach(parameter => {
39
- const requiredStatus = parameter.required ? 'Required' : 'Optional';
40
- const formattedDescription = padLeft(parameter.description, parameter.name);
41
- console.log(` ${parameter.name}${formattedDescription} (${requiredStatus}, Default: ${parameter.defaultValue || 'None'})`);
46
+ console.log(` ${chalk.yellow.bold(parameter.name)} ${chalk.grey(parameter.choices ? `${parameter.choices}, Default: ${parameter.defaultValue || 'None'}` : `Default: ${parameter.defaultValue || 'None'}`)}`);
47
+ if (parameter.description) {
48
+ console.log(` ${parameter.description}`);
49
+ }
50
+ console.log('');
42
51
  });
43
52
  }
44
53
 
45
54
  if (options && options.length > 0) {
46
- console.log(` ${chalk.cyan('Options: ')}`);
55
+ console.log('');
56
+ console.log(` ${chalk.bold.cyan('Options: ')}`);
47
57
  options.forEach(option => {
48
- const formattedDescription = padLeft(option.description, option.name);
49
- console.log(` ${option.name}${formattedDescription}`);
58
+ console.log(` ${chalk.yellow.bold(option.name)} ${chalk.grey(option.choices ? `${option.choices}, Default: ${option.defaultValue || 'None'}` : `Default: ${option.defaultValue}`)}`);
59
+ if (option.description) {
60
+ console.log(` ${option.description}`);
61
+ }
62
+ console.log('');
50
63
  });
51
64
  }
52
65
 
@@ -0,0 +1,38 @@
1
+ const minimist = require('minimist');
2
+ const { transformInPath } = require('../tokens/utils');
3
+ const mapSCSStoCSS = require('../tokens/map-scss-to-css');
4
+
5
+ /**
6
+ * Replaces CSS or SASS variables in a file with their corresponding values.
7
+ *
8
+ * @param {string[]} commandArgs - Command line arguments for replacing variables.
9
+ * @param {string} [commandArgs.filePath] - The path to the file in which variables should be replaced.
10
+ * @param {string} [commandArgs.source] - The path to the source directory containing variable mappings.
11
+ * @param {string} [commandArgs.replacementType] - The type of replacement ('usage' or 'all').
12
+ * @param {string} [commandArgs.direction] - The direction of replacement ('forward' or 'backward').
13
+ */
14
+ async function replaceVariablesCommand(commandArgs) {
15
+ const alias = {
16
+ filePath: 'p',
17
+ source: 's',
18
+ replacementType: 't',
19
+ direction: 'd',
20
+ };
21
+
22
+ const {
23
+ filePath,
24
+ source: sourcePath,
25
+ replacementType,
26
+ direction,
27
+ } = minimist(commandArgs, { alias });
28
+
29
+ const variablesMap = mapSCSStoCSS(sourcePath);
30
+
31
+ if (replacementType === 'usage') {
32
+ await transformInPath(filePath, variablesMap, 'usage', [], direction);
33
+ } else {
34
+ await transformInPath(filePath, variablesMap);
35
+ }
36
+ }
37
+
38
+ module.exports = replaceVariablesCommand;
package/lib/utils.js ADDED
@@ -0,0 +1,30 @@
1
+ const axios = require('axios');
2
+
3
+ /**
4
+ * Sends request to the Netlify function to inform about specified event.
5
+ * @param {string} eventId - tracking event id
6
+ * @param {object} properties - tracking properties
7
+ */
8
+ function sendTrackInfo(eventId, properties) {
9
+ const { BASE_URL, TRACK_ANONYMOUS_ANALYTICS } = process.env;
10
+ if (TRACK_ANONYMOUS_ANALYTICS) {
11
+ const url = `${BASE_URL}/.netlify/functions/sendTrackData`;
12
+ axios.post(url, { eventId, properties })
13
+ .then(result => {
14
+ // eslint-disable-next-line no-console
15
+ console.log(`Track info is successfully sent (status ${result.status})`);
16
+ }).catch(error => {
17
+ // eslint-disable-next-line no-console
18
+ console.log(`Track info request failed (${error})`);
19
+ });
20
+ }
21
+ }
22
+
23
+ function capitalize(str) {
24
+ if (typeof str !== 'string' || str.length === 0) {
25
+ return '';
26
+ }
27
+ return str.charAt(0).toUpperCase() + str.slice(1);
28
+ }
29
+
30
+ module.exports = { sendTrackInfo, capitalize };
package/package.json CHANGED
@@ -1,17 +1,17 @@
1
1
  {
2
2
  "name": "@openedx/paragon",
3
- "version": "22.6.0",
3
+ "version": "23.0.0-alpha.2",
4
4
  "description": "Accessible, responsive UI component library based on Bootstrap.",
5
5
  "main": "dist/index.js",
6
6
  "module": "dist/index.js",
7
7
  "types": "dist/index.d.ts",
8
8
  "license": "Apache-2.0",
9
- "publishConfig": {
10
- "access": "public"
11
- },
12
9
  "bin": {
13
10
  "paragon": "./bin/paragon-scripts.js"
14
11
  },
12
+ "publishConfig": {
13
+ "access": "public"
14
+ },
15
15
  "repository": {
16
16
  "type": "git",
17
17
  "url": "https://github.com/openedx/paragon.git"
@@ -20,7 +20,8 @@
20
20
  "/dist",
21
21
  "/icons",
22
22
  "/src",
23
- "/scss",
23
+ "/styles",
24
+ "/tokens",
24
25
  "/lib"
25
26
  ],
26
27
  "sideEffects": false,
@@ -48,23 +49,37 @@
48
49
  "build-types": "tsc --emitDeclarationOnly",
49
50
  "playroom:start": "npm run playroom:start --workspace=www",
50
51
  "playroom:build": "npm run playroom:build --workspace=www",
51
- "prepare": "husky || true"
52
+ "prepare": "husky || true",
53
+ "build-tokens": "./bin/paragon-scripts.js build-tokens --build-dir ./styles/css",
54
+ "replace-variables-usage-with-css": "./bin/paragon-scripts.js replace-variables -p src -t usage",
55
+ "replace-variables-definition-with-css": "./bin/paragon-scripts.js replace-variables -p src -t definition"
52
56
  },
53
57
  "dependencies": {
54
- "@fortawesome/fontawesome-svg-core": "^6.1.1",
55
- "@fortawesome/react-fontawesome": "^0.1.18",
56
58
  "@popperjs/core": "^2.11.4",
59
+ "axios": "^0.27.2",
57
60
  "bootstrap": "^4.6.2",
58
61
  "chalk": "^4.1.2",
59
62
  "child_process": "^1.0.2",
63
+ "chroma-js": "^2.4.2",
60
64
  "classnames": "^2.3.1",
65
+ "cli-progress": "^3.12.0",
66
+ "commander": "^9.4.1",
61
67
  "email-prop-type": "^3.0.0",
62
68
  "file-selector": "^0.6.0",
63
- "font-awesome": "^4.7.0",
64
69
  "glob": "^8.0.3",
65
70
  "inquirer": "^8.2.5",
71
+ "js-toml": "^1.0.0",
66
72
  "lodash.uniqby": "^4.7.0",
73
+ "log-update": "^4.0.0",
67
74
  "mailto-link": "^2.0.0",
75
+ "minimist": "^1.2.8",
76
+ "ora": "^5.4.1",
77
+ "postcss": "^8.4.21",
78
+ "postcss-combine-duplicated-selectors": "^10.0.3",
79
+ "postcss-custom-media": "^9.1.2",
80
+ "postcss-import": "^15.1.0",
81
+ "postcss-map": "^0.11.0",
82
+ "postcss-minify": "^1.1.0",
68
83
  "prop-types": "^15.8.1",
69
84
  "react-bootstrap": "^1.6.5",
70
85
  "react-colorful": "^5.6.1",
@@ -77,6 +92,8 @@
77
92
  "react-responsive": "^8.2.0",
78
93
  "react-table": "^7.7.0",
79
94
  "react-transition-group": "^4.4.2",
95
+ "sass": "^1.58.3",
96
+ "style-dictionary": "^3.7.1",
80
97
  "tabbable": "^5.3.3",
81
98
  "uncontrollable": "^7.2.1",
82
99
  "uuid": "^9.0.0"
@@ -106,8 +123,8 @@
106
123
  "@testing-library/react-hooks": "^8.0.1",
107
124
  "@testing-library/user-event": "^13.5.0",
108
125
  "@types/jest": "^29.5.10",
109
- "@types/react": "^17.0.80",
110
- "@types/react-dom": "^17.0.11",
126
+ "@types/react": "17.0.0",
127
+ "@types/react-dom": "17.0.11",
111
128
  "@types/react-responsive": "^8.0.8",
112
129
  "@types/react-table": "^7.7.19",
113
130
  "@types/react-test-renderer": "^18.0.0",
@@ -137,7 +154,6 @@
137
154
  "react-dom": "^17.0.0",
138
155
  "react-test-renderer": "^17.0.0",
139
156
  "regenerator-runtime": "^0.13.9",
140
- "sass": "^1.32.13",
141
157
  "semantic-release": "^20.1.3",
142
158
  "stylelint": "^14.7.1",
143
159
  "stylelint-config-standard-scss": "^4.0.0",
@@ -153,7 +169,7 @@
153
169
  "^.+\\.tsx?$": "ts-jest"
154
170
  },
155
171
  "setupFilesAfterEnv": [
156
- "./src/setupTest.ts"
172
+ "./src/setupTest.js"
157
173
  ],
158
174
  "moduleNameMapper": {
159
175
  "\\.(jpg|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$": "<rootDir>/__mocks__/fileMock.js",
@@ -164,7 +180,7 @@
164
180
  ],
165
181
  "coveragePathIgnorePatterns": [
166
182
  "/node_modules/",
167
- "src/setupTest.ts",
183
+ "src/setupTest.js",
168
184
  "src/index.js",
169
185
  "/tests/",
170
186
  "/www/",
@@ -1,5 +1,3 @@
1
- @import "variables";
2
-
3
1
  .pgn__action-row {
4
2
  display: flex;
5
3
  flex-grow: 1;
@@ -11,7 +9,7 @@
11
9
  }
12
10
 
13
11
  & > * + * {
14
- margin-inline-start: $action-row-gap-x;
12
+ margin-inline-start: var(--pgn-spacing-action-row-gap-x);
15
13
  }
16
14
  }
17
15
 
@@ -27,7 +25,7 @@
27
25
  }
28
26
 
29
27
  & > * + * {
30
- margin-bottom: $action-row-gap-y;
28
+ margin-bottom: var(--pgn-spacing-action-row-gap-y);
31
29
  }
32
30
  }
33
31
 
@@ -1,5 +1,3 @@
1
- @import "variables";
2
-
3
1
  //
4
2
  // Override Bootstrap's alert definition.
5
3
  // We do this to get more control over colors
@@ -12,11 +10,13 @@
12
10
 
13
11
  .alert {
14
12
  position: relative;
15
- padding: $alert-padding-y $alert-padding-x;
16
- margin-bottom: $alert-margin-bottom;
17
- border: $alert-border-width solid transparent;
13
+ padding: var(--pgn-spacing-alert-padding-y) var(--pgn-spacing-alert-padding-x);
14
+ margin-bottom: var(--pgn-spacing-alert-margin-bottom);
15
+ border: var(--pgn-size-alert-border-width) solid var(--pgn-alert-border-color, transparent);
16
+ color: inherit;
17
+ background-color: var(--pgn-alert-bg, transparent);
18
18
 
19
- @include border-radius($alert-border-radius);
19
+ @include border-radius(var(--pgn-size-alert-border-radius));
20
20
  @include pgn-box-shadow(1, "down");
21
21
 
22
22
  .alert-message-content > :last-child {
@@ -24,8 +24,9 @@
24
24
  }
25
25
 
26
26
  .alert-icon {
27
+ color: var(--pgn-alert-icon-color, inherit);
27
28
  float: left;
28
- margin-inline-end: $alert-icon-space;
29
+ margin-inline-end: var(--pgn-spacing-alert-icon-space);
29
30
  width: 1.5rem;
30
31
  height: 1.5rem;
31
32
  flex-shrink: 0;
@@ -34,17 +35,17 @@
34
35
 
35
36
  // Headings for larger alerts
36
37
  .alert-heading {
37
- // Specified to prevent conflicts of changing $headings-color
38
- color: $alert-title-color;
38
+ // Specified to prevent conflicts of changing var(--pgn-color-headings-base)
39
+ color: var(--pgn-color-alert-title);
39
40
  display: flex;
40
41
  }
41
42
 
42
43
  // added to align content and icon
43
44
  .alert-content {
44
45
  display: flex;
45
- font-size: $alert-font-size;
46
- line-height: $alert-line-height;
47
- color: $alert-content-color;
46
+ font-size: var(--pgn-typography-alert-font-size);
47
+ line-height: var(--pgn-typography-alert-line-height);
48
+ color: var(--pgn-color-alert-content);
48
49
  text-align: start;
49
50
 
50
51
  div {
@@ -54,7 +55,7 @@
54
55
 
55
56
  // Provide class for links that match alerts
56
57
  .alert-link {
57
- font-weight: $alert-link-font-weight;
58
+ font-weight: var(--pgn-typography-alert-font-weight-link);
58
59
  text-decoration: underline;
59
60
 
60
61
  &:hover {
@@ -66,16 +67,16 @@
66
67
  //
67
68
  // Expand the right padding and account for the close button's positioning.
68
69
 
69
- // Baking in $close-font-size: $font-size-base * 1.5 !default; to avoid any dependency
70
+ // Baking in $close-font-size: var(--pgn-typography-font-size-base) * 1.5 !default; to avoid any dependency
70
71
  .alert-dismissible {
71
- padding-right: ($font-size-base * 1.5) + $alert-padding-x * 2;
72
+ padding-right: calc((var(--pgn-typography-font-size-base) * 1.5) + (var(--pgn-spacing-alert-padding-x) * 2));
72
73
 
73
74
  // Adjust close link position
74
75
  .close {
75
76
  position: absolute;
76
77
  top: 0;
77
78
  right: 0;
78
- padding: $alert-padding-y $alert-padding-x;
79
+ padding: var(--pgn-spacing-alert-padding-y) var(--pgn-spacing-alert-padding-x);
79
80
  color: inherit;
80
81
  }
81
82
  }
@@ -85,28 +86,36 @@
85
86
  align-items: center;
86
87
 
87
88
  .pgn__alert-actions {
88
- margin-inline-start: $alert-actions-gap;
89
+ margin-inline-start: var(--pgn-spacing-alert-actions-gap);
89
90
  }
90
91
  }
91
92
 
92
- .pgn__alert-message-wrapper-stacked {
93
- .pgn__alert-actions {
94
- margin-top: $alert-actions-gap;
95
- }
93
+ .pgn__alert-message-wrapper-stacked .pgn__alert-actions {
94
+ margin-top: var(--pgn-spacing-alert-actions-gap);
96
95
  }
97
96
 
98
97
  // Alternate styles
99
- //
100
- // Generate contextual modifier classes for coloring the alert.
101
98
 
102
- @each $color, $value in $theme-colors {
103
- .alert-#{$color} {
104
- color: inherit;
105
- background-color: theme-color($color, "background");
106
- border-color: theme-color($color, "border");
99
+ .alert-success {
100
+ --pgn-alert-bg: var(--pgn-color-alert-bg-success);
101
+ --pgn-alert-border-color: var(--pgn-color-alert-border-success);
102
+ --pgn-alert-icon-color: var(--pgn-color-alert-icon-success);
103
+ }
107
104
 
108
- .alert-icon {
109
- color: theme-color($color, "default");
110
- }
111
- }
105
+ .alert-info {
106
+ --pgn-alert-bg: var(--pgn-color-alert-bg-info);
107
+ --pgn-alert-border-color: var(--pgn-color-alert-border-info);
108
+ --pgn-alert-icon-color: var(--pgn-color-alert-icon-info);
109
+ }
110
+
111
+ .alert-danger {
112
+ --pgn-alert-bg: var(--pgn-color-alert-bg-danger);
113
+ --pgn-alert-border-color: var(--pgn-color-alert-border-danger);
114
+ --pgn-alert-icon-color: var(--pgn-color-alert-icon-danger);
115
+ }
116
+
117
+ .alert-warning {
118
+ --pgn-alert-bg: var(--pgn-color-alert-bg-warning);
119
+ --pgn-alert-border-color: var(--pgn-color-alert-border-warning);
120
+ --pgn-alert-icon-color: var(--pgn-color-alert-icon-warning);
112
121
  }
@@ -0,0 +1,104 @@
1
+ @mixin annotation-triangle($triangle-color, $triangle-direction) {
2
+ content: "";
3
+ height: 0;
4
+ width: 0;
5
+ position: absolute;
6
+ border: solid transparent;
7
+
8
+ @if $triangle-direction == top {
9
+ border-bottom-color: $triangle-color;
10
+ border-width: 0 var(--pgn-size-annotation-arrow-border-width) var(--pgn-size-annotation-arrow-border-width);
11
+ right: 0;
12
+ left: 0;
13
+ top: calc(var(--pgn-size-annotation-arrow-border-width) * -1);
14
+ margin: 0 auto;
15
+ }
16
+
17
+ @else if $triangle-direction == right {
18
+ border-left-color: $triangle-color;
19
+ border-width:
20
+ var(--pgn-size-annotation-arrow-border-width) 0 var(--pgn-size-annotation-arrow-border-width)
21
+ var(--pgn-size-annotation-arrow-border-width);
22
+ top: 0;
23
+ bottom: 0;
24
+ right: calc(var(--pgn-size-annotation-arrow-border-width) * -1);
25
+ margin: auto 0;
26
+ }
27
+
28
+ @else if $triangle-direction == bottom {
29
+ border-top-color: $triangle-color;
30
+ border-width: var(--pgn-size-annotation-arrow-border-width) var(--pgn-size-annotation-arrow-border-width) 0;
31
+ right: 0;
32
+ left: 0;
33
+ bottom: calc(var(--pgn-size-annotation-arrow-border-width) * -1);
34
+ margin: 0 auto;
35
+ }
36
+
37
+ @else if $triangle-direction == left {
38
+ border-right-color: $triangle-color;
39
+ border-width:
40
+ var(--pgn-size-annotation-arrow-border-width) var(--pgn-size-annotation-arrow-border-width)
41
+ var(--pgn-size-annotation-arrow-border-width) 0;
42
+ top: 0;
43
+ bottom: 0;
44
+ left: calc(var(--pgn-size-annotation-arrow-border-width) * -1);
45
+ margin: auto 0;
46
+ }
47
+
48
+ @else {
49
+ @error "Unknown direction #{$triangle-direction}.";
50
+ }
51
+ }
52
+
53
+ @mixin annotation-variant($bg-color, $text-color, $direction) {
54
+ background-color: $bg-color;
55
+ color: $text-color;
56
+
57
+ // set additional margin to arrow side of the Annotation
58
+ margin-#{$direction}:
59
+ calc(
60
+ var(--pgn-size-annotation-arrow-border-width) + var(--pgn-spacing-annotation-arrow-side-margin)
61
+ );
62
+
63
+ [dir="rtl"] & {
64
+ @if $direction == left {
65
+ margin-left: 0;
66
+ margin-right:
67
+ calc(
68
+ var(--pgn-size-annotation-arrow-border-width) + var(--pgn-spacing-annotation-arrow-side-margin)
69
+ );
70
+ }
71
+
72
+ @else if $direction == right {
73
+ margin-right: 0;
74
+ margin-left:
75
+ calc(
76
+ var(--pgn-size-annotation-arrow-border-width) + var(--pgn-spacing-annotation-arrow-side-margin)
77
+ );
78
+ }
79
+ }
80
+
81
+ &::after {
82
+ @include annotation-triangle($bg-color, $direction);
83
+
84
+ [dir="rtl"] & {
85
+ @if $direction == left {
86
+ left: initial;
87
+ right: calc(var(--pgn-size-annotation-arrow-border-width) * -1);
88
+ border-width:
89
+ var(--pgn-size-annotation-arrow-border-width) 0 var(--pgn-size-annotation-arrow-border-width)
90
+ var(--pgn-size-annotation-arrow-border-width);
91
+ border-left-color: $bg-color;
92
+ }
93
+
94
+ @else if $direction == right {
95
+ right: initial;
96
+ left: calc(var(--pgn-size-annotation-arrow-border-width) * -1);
97
+ border-width:
98
+ var(--pgn-size-annotation-arrow-border-width) var(--pgn-size-annotation-arrow-border-width)
99
+ var(--pgn-size-annotation-arrow-border-width) 0;
100
+ border-right-color: $bg-color;
101
+ }
102
+ }
103
+ }
104
+ }