@nypl/design-system-react-components 0.25.1 → 0.25.5

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 (307) hide show
  1. package/CHANGELOG.md +118 -1
  2. package/README.md +98 -50
  3. package/dist/components/Breadcrumbs/Breadcrumbs.d.ts +4 -0
  4. package/dist/components/Button/Button.d.ts +13 -8
  5. package/dist/components/Button/ButtonTypes.d.ts +2 -1
  6. package/dist/components/Card/Card.d.ts +36 -52
  7. package/dist/components/Card/CardTypes.d.ts +0 -15
  8. package/dist/components/Checkbox/Checkbox.d.ts +17 -13
  9. package/dist/components/CheckboxGroup/CheckboxGroup.d.ts +4 -2
  10. package/dist/components/ComponentWrapper/ComponentWrapper.d.ts +15 -0
  11. package/dist/components/DatePicker/DatePicker.d.ts +36 -34
  12. package/dist/components/Fieldset/Fieldset.d.ts +25 -0
  13. package/dist/components/Heading/Heading.d.ts +4 -4
  14. package/dist/components/HelperErrorText/HelperErrorText.d.ts +17 -14
  15. package/dist/components/HorizontalRule/HorizontalRule.d.ts +10 -9
  16. package/dist/components/Icons/Icon.d.ts +8 -0
  17. package/dist/components/Icons/IconSvgs.d.ts +11 -0
  18. package/dist/components/Icons/IconTypes.d.ts +11 -0
  19. package/dist/components/Image/Image.d.ts +19 -9
  20. package/dist/components/Image/ImageTypes.d.ts +20 -0
  21. package/dist/components/Link/Link.d.ts +4 -0
  22. package/dist/components/List/List.d.ts +19 -14
  23. package/dist/components/Notification/Notification.d.ts +37 -16
  24. package/dist/components/Pagination/Pagination.d.ts +16 -13
  25. package/dist/components/Pagination/Pagination.stories.d.ts +2 -0
  26. package/dist/components/ProgressIndicator/ProgressIndicator.d.ts +29 -0
  27. package/dist/components/ProgressIndicator/ProgressIndicatorTypes.d.ts +8 -0
  28. package/dist/components/Radio/Radio.d.ts +2 -0
  29. package/dist/components/RadioGroup/RadioGroup.d.ts +4 -2
  30. package/dist/components/SearchBar/SearchBar.d.ts +3 -3
  31. package/dist/components/Select/Select.d.ts +2 -0
  32. package/dist/components/SkeletonLoader/SkeletonLoader.d.ts +18 -14
  33. package/dist/components/Slider/Slider.d.ts +57 -0
  34. package/dist/components/StyleGuide/ColorCard.d.ts +12 -0
  35. package/dist/components/Tabs/Tabs.d.ts +1 -1
  36. package/dist/components/TextInput/TextInput.d.ts +12 -0
  37. package/dist/components/VideoPlayer/VideoPlayer.d.ts +6 -8
  38. package/dist/components/VideoPlayer/VideoPlayerTypes.d.ts +2 -2
  39. package/dist/design-system-react-components.cjs.development.js +6131 -3715
  40. package/dist/design-system-react-components.cjs.development.js.map +1 -1
  41. package/dist/design-system-react-components.cjs.production.min.js +1 -1
  42. package/dist/design-system-react-components.cjs.production.min.js.map +1 -1
  43. package/dist/design-system-react-components.esm.js +6124 -3699
  44. package/dist/design-system-react-components.esm.js.map +1 -1
  45. package/dist/hooks/tests/useCarouselStyles.test.d.ts +1 -0
  46. package/dist/hooks/useCarouselStyles.d.ts +16 -0
  47. package/dist/hooks/useNYPLTheme.d.ts +54 -0
  48. package/dist/hooks/useWindowSize.d.ts +10 -0
  49. package/dist/index.d.ts +13 -8
  50. package/dist/resources.scss +180 -170
  51. package/dist/styles.css +1 -1
  52. package/dist/theme/components/button.d.ts +22 -8
  53. package/dist/theme/components/card.d.ts +168 -0
  54. package/dist/theme/components/checkbox.d.ts +5 -1
  55. package/dist/theme/components/checkboxGroup.d.ts +12 -0
  56. package/dist/theme/components/componentWrapper.d.ts +11 -0
  57. package/dist/theme/components/datePicker.d.ts +16 -0
  58. package/dist/theme/components/fieldset.d.ts +27 -0
  59. package/dist/theme/components/global.d.ts +23 -13
  60. package/dist/theme/components/globalMixins.d.ts +9 -1
  61. package/dist/theme/components/heading.d.ts +5 -0
  62. package/dist/theme/components/helperErrorText.d.ts +10 -0
  63. package/dist/theme/components/hero.d.ts +1 -0
  64. package/dist/theme/components/horizontalRule.d.ts +14 -0
  65. package/dist/theme/components/image.d.ts +31 -0
  66. package/dist/theme/components/label.d.ts +5 -3
  67. package/dist/theme/components/link.d.ts +4 -0
  68. package/dist/theme/components/list.d.ts +89 -0
  69. package/dist/theme/components/notification.d.ts +75 -0
  70. package/dist/theme/components/pagination.d.ts +19 -0
  71. package/dist/theme/components/progressIndicator.d.ts +50 -0
  72. package/dist/theme/components/radioGroup.d.ts +12 -0
  73. package/dist/theme/components/select.d.ts +11 -2
  74. package/dist/theme/components/skeletonLoader.d.ts +98 -0
  75. package/dist/theme/components/slider.d.ts +51 -0
  76. package/dist/theme/components/tabs.d.ts +54 -3
  77. package/dist/theme/components/textInput.d.ts +8 -1
  78. package/dist/theme/components/videoPlayer.d.ts +40 -0
  79. package/dist/theme/foundations/breakpoints.d.ts +8 -8
  80. package/dist/theme/foundations/global.d.ts +6 -1
  81. package/dist/theme/foundations/radii.d.ts +5 -0
  82. package/dist/theme/foundations/spacing.d.ts +16 -16
  83. package/package.json +72 -83
  84. package/src/__tests__/setup.ts +2 -2
  85. package/src/components/Accordion/Accordion.stories.mdx +39 -44
  86. package/src/components/Autosuggest/Autosuggest.stories.mdx +3 -3
  87. package/src/components/Autosuggest/Autosuggest.stories.tsx +2 -1
  88. package/src/components/Autosuggest/_Autosuggest.scss +5 -5
  89. package/src/components/Breadcrumbs/Breadcrumbs.stories.mdx +14 -10
  90. package/src/components/Breadcrumbs/Breadcrumbs.test.tsx +23 -0
  91. package/src/components/Breadcrumbs/Breadcrumbs.tsx +5 -1
  92. package/src/components/Breadcrumbs/__snapshots__/Breadcrumbs.test.tsx.snap +199 -1
  93. package/src/components/Button/Button.stories.mdx +15 -10
  94. package/src/components/Button/Button.test.tsx +21 -7
  95. package/src/components/Button/Button.tsx +22 -34
  96. package/src/components/Button/ButtonTypes.tsx +1 -0
  97. package/src/components/Button/__snapshots__/Button.test.tsx.snap +41 -10
  98. package/src/components/Card/Card.stories.mdx +296 -259
  99. package/src/components/Card/Card.test.tsx +156 -84
  100. package/src/components/Card/Card.tsx +195 -145
  101. package/src/components/Card/CardTypes.tsx +0 -17
  102. package/src/components/Card/__snapshots__/Card.test.tsx.snap +410 -0
  103. package/src/components/CardEdition/CardEdition.stories.tsx +15 -47
  104. package/src/components/CardEdition/_CardEdition.scss +22 -23
  105. package/src/components/Chakra/Box.stories.mdx +15 -16
  106. package/src/components/Chakra/Center.stories.mdx +31 -16
  107. package/src/components/Chakra/Grid.stories.mdx +28 -15
  108. package/src/components/Chakra/Stack.stories.mdx +35 -18
  109. package/src/components/Checkbox/Checkbox.stories.mdx +33 -11
  110. package/src/components/Checkbox/Checkbox.test.tsx +47 -2
  111. package/src/components/Checkbox/Checkbox.tsx +39 -33
  112. package/src/components/Checkbox/__snapshots__/Checkbox.test.tsx.snap +90 -2
  113. package/src/components/CheckboxGroup/CheckboxGroup.stories.mdx +82 -2
  114. package/src/components/CheckboxGroup/CheckboxGroup.test.tsx +29 -2
  115. package/src/components/CheckboxGroup/CheckboxGroup.tsx +22 -18
  116. package/src/components/CheckboxGroup/__snapshots__/CheckboxGroup.test.tsx.snap +47 -81
  117. package/src/components/ComponentWrapper/ComponentWrapper.tsx +63 -0
  118. package/src/components/DatePicker/DatePicker.stories.mdx +163 -62
  119. package/src/components/DatePicker/DatePicker.test.tsx +264 -64
  120. package/src/components/DatePicker/DatePicker.tsx +159 -128
  121. package/src/components/DatePicker/_DatePicker.scss +33 -67
  122. package/src/components/DatePicker/__snapshots__/DatePicker.test.tsx.snap +818 -0
  123. package/src/components/Fieldset/Fieldset.stories.mdx +55 -0
  124. package/src/components/Fieldset/Fieldset.test.tsx +125 -0
  125. package/src/components/Fieldset/Fieldset.tsx +52 -0
  126. package/src/components/Fieldset/__snapshots__/Fieldset.test.tsx.snap +68 -0
  127. package/src/components/Form/Form.stories.mdx +24 -6
  128. package/src/components/Form/Form.test.tsx +1 -1
  129. package/src/components/Form/Form.tsx +1 -0
  130. package/src/components/Grid/SimpleGrid.stories.mdx +32 -39
  131. package/src/components/Grid/SimpleGrid.test.tsx +4 -4
  132. package/src/components/Heading/Heading.stories.mdx +3 -4
  133. package/src/components/Heading/Heading.tsx +5 -5
  134. package/src/components/HelperErrorText/HelperErrorText.stories.mdx +124 -0
  135. package/src/components/HelperErrorText/HelperErrorText.test.tsx +39 -44
  136. package/src/components/HelperErrorText/HelperErrorText.tsx +37 -39
  137. package/src/components/HelperErrorText/__snapshots__/HelperErrorText.test.tsx.snap +25 -0
  138. package/src/components/Hero/Hero.stories.mdx +12 -2
  139. package/src/components/Hero/Hero.tsx +1 -1
  140. package/src/components/Hero/HeroTypes.tsx +1 -0
  141. package/src/components/Hero/__snapshots__/Hero.test.tsx.snap +7 -7
  142. package/src/components/HorizontalRule/HorizontalRule.stories.mdx +8 -6
  143. package/src/components/HorizontalRule/HorizontalRule.test.tsx +33 -28
  144. package/src/components/HorizontalRule/HorizontalRule.tsx +27 -29
  145. package/src/components/HorizontalRule/__snapshots__/HorizontalRule.test.tsx.snap +27 -9
  146. package/src/components/Icons/Icon.stories.mdx +12 -4
  147. package/src/components/Icons/Icon.test.tsx +18 -0
  148. package/src/components/Icons/Icon.tsx +16 -1
  149. package/src/components/Icons/IconSvgs.tsx +22 -0
  150. package/src/components/Icons/IconTypes.tsx +11 -0
  151. package/src/components/Image/Image.stories.mdx +220 -0
  152. package/src/components/Image/Image.test.tsx +131 -29
  153. package/src/components/Image/Image.tsx +84 -56
  154. package/src/components/Image/ImageTypes.ts +22 -0
  155. package/src/components/Image/__snapshots__/Image.test.tsx.snap +190 -0
  156. package/src/components/Input/Input.stories.tsx +23 -67
  157. package/src/components/Input/Input.test.tsx +4 -4
  158. package/src/components/Input/_Input.scss +23 -14
  159. package/src/components/Link/Link.tsx +4 -1
  160. package/src/components/List/List.stories.mdx +124 -49
  161. package/src/components/List/List.test.tsx +142 -63
  162. package/src/components/List/List.tsx +89 -93
  163. package/src/components/List/__snapshots__/List.test.tsx.snap +109 -0
  164. package/src/components/Modal/Modal.stories.mdx +3 -3
  165. package/src/components/Modal/_Modal.scss +2 -2
  166. package/src/components/Notification/Notification.stories.mdx +109 -112
  167. package/src/components/Notification/Notification.test.tsx +99 -110
  168. package/src/components/Notification/Notification.tsx +156 -159
  169. package/src/components/Notification/__snapshots__/Notification.test.tsx.snap +159 -8
  170. package/src/components/Pagination/Pagination.stories.mdx +26 -27
  171. package/src/components/Pagination/Pagination.stories.tsx +11 -16
  172. package/src/components/Pagination/Pagination.test.tsx +276 -146
  173. package/src/components/Pagination/Pagination.tsx +174 -154
  174. package/src/components/Pagination/__snapshots__/Pagination.test.tsx.snap +285 -0
  175. package/src/components/ProgressIndicator/ProgressIndicator.stories.mdx +292 -0
  176. package/src/components/ProgressIndicator/ProgressIndicator.test.tsx +225 -0
  177. package/src/components/ProgressIndicator/ProgressIndicator.tsx +126 -0
  178. package/src/components/ProgressIndicator/ProgressIndicatorTypes.ts +8 -0
  179. package/src/components/ProgressIndicator/__snapshots__/ProgressIndicator.test.tsx.snap +357 -0
  180. package/src/components/Radio/Radio.test.tsx +20 -4
  181. package/src/components/Radio/Radio.tsx +6 -3
  182. package/src/components/Radio/__snapshots__/Radio.test.tsx.snap +3 -0
  183. package/src/components/RadioGroup/RadioGroup.stories.mdx +3 -4
  184. package/src/components/RadioGroup/RadioGroup.test.tsx +24 -1
  185. package/src/components/RadioGroup/RadioGroup.tsx +19 -19
  186. package/src/components/RadioGroup/__snapshots__/RadioGroup.test.tsx.snap +42 -72
  187. package/src/components/SearchBar/SearchBar.Test.tsx +20 -1
  188. package/src/components/SearchBar/SearchBar.stories.mdx +113 -8
  189. package/src/components/SearchBar/SearchBar.tsx +20 -10
  190. package/src/components/Select/Select.test.tsx +12 -0
  191. package/src/components/Select/Select.tsx +5 -2
  192. package/src/components/Select/SelectTypes.tsx +1 -0
  193. package/src/components/SkeletonLoader/SkeletonLoader.stories.mdx +28 -59
  194. package/src/components/SkeletonLoader/SkeletonLoader.test.tsx +97 -177
  195. package/src/components/SkeletonLoader/SkeletonLoader.tsx +74 -71
  196. package/src/components/SkeletonLoader/__snapshots__/SkeletonLoader.test.tsx.snap +739 -0
  197. package/src/components/Slider/Slider.stories.mdx +529 -0
  198. package/src/components/Slider/Slider.test.tsx +653 -0
  199. package/src/components/Slider/Slider.tsx +303 -0
  200. package/src/components/Slider/__snapshots__/Slider.test.tsx.snap +1946 -0
  201. package/src/components/StyleGuide/Bidirectionality.stories.mdx +1 -1
  202. package/src/components/StyleGuide/Breakpoints.stories.mdx +34 -10
  203. package/src/components/StyleGuide/Buttons.stories.mdx +89 -73
  204. package/src/components/StyleGuide/ColorCard.tsx +46 -0
  205. package/src/components/StyleGuide/Colors.stories.mdx +171 -311
  206. package/src/components/StyleGuide/DesignTokens.stories.mdx +170 -0
  207. package/src/components/StyleGuide/Forms.stories.mdx +9 -7
  208. package/src/components/StyleGuide/Iconography.stories.mdx +85 -91
  209. package/src/components/StyleGuide/Spacing.stories.mdx +31 -23
  210. package/src/components/StyleGuide/Typography.stories.mdx +202 -189
  211. package/src/components/StyleGuide/UIDocCard.tsx +1 -1
  212. package/src/components/Tabs/Tabs.stories.mdx +73 -11
  213. package/src/components/Tabs/Tabs.tsx +87 -64
  214. package/src/components/Template/Template.stories.mdx +25 -27
  215. package/src/components/TextInput/TextInput.stories.mdx +1 -1
  216. package/src/components/TextInput/TextInput.test.tsx +22 -2
  217. package/src/components/TextInput/TextInput.tsx +28 -8
  218. package/src/components/TextInput/TextInputTypes.tsx +2 -0
  219. package/src/components/VideoPlayer/VideoPlayer.stories.mdx +17 -4
  220. package/src/components/VideoPlayer/VideoPlayer.test.tsx +54 -53
  221. package/src/components/VideoPlayer/VideoPlayer.tsx +50 -51
  222. package/src/components/VideoPlayer/VideoPlayerTypes.tsx +2 -2
  223. package/src/components/VideoPlayer/__snapshots__/VideoPlayer.test.tsx.snap +91 -0
  224. package/src/docs/Chakra.stories.mdx +244 -63
  225. package/src/docs/Intro.stories.mdx +5 -2
  226. package/src/hooks/tests/useCarouselStyles.test.ts +140 -0
  227. package/src/hooks/tests/useNYPLTheme.test.tsx +36 -0
  228. package/src/hooks/useCarouselStyles.ts +34 -0
  229. package/src/hooks/useNYPLTheme.ts +67 -0
  230. package/src/hooks/useWindowSize.ts +40 -0
  231. package/src/index.ts +22 -19
  232. package/src/resources.scss +5 -5
  233. package/src/styles/base/{_02-breakpoints.scss → _01-breakpoints.scss} +9 -10
  234. package/src/styles/base/{_03-mixins.scss → _02-mixins.scss} +16 -5
  235. package/src/styles/base/{_04-base.scss → _03-base.scss} +7 -2
  236. package/src/styles/base/{_05-focus.scss → _04-focus.scss} +0 -15
  237. package/src/styles/base/_place-holder.scss +14 -3
  238. package/src/styles/{03-space → space}/_space-inline.scss +14 -14
  239. package/src/styles/{03-space → space}/_space-inset.scss +10 -10
  240. package/src/styles/space/_space-stack.scss +116 -0
  241. package/src/styles.scss +13 -60
  242. package/src/theme/components/button.ts +21 -15
  243. package/src/theme/components/card.ts +174 -0
  244. package/src/theme/components/checkbox.ts +8 -3
  245. package/src/theme/components/checkboxGroup.ts +8 -0
  246. package/src/theme/components/componentWrapper.ts +10 -0
  247. package/src/theme/components/datePicker.ts +17 -0
  248. package/src/theme/components/fieldset.ts +18 -0
  249. package/src/theme/components/global.ts +26 -15
  250. package/src/theme/components/globalMixins.ts +9 -1
  251. package/src/theme/components/heading.ts +10 -5
  252. package/src/theme/components/helperErrorText.ts +9 -0
  253. package/src/theme/components/hero.ts +4 -3
  254. package/src/theme/components/horizontalRule.ts +13 -0
  255. package/src/theme/components/icon.ts +9 -9
  256. package/src/theme/components/image.ts +116 -0
  257. package/src/theme/components/label.ts +3 -10
  258. package/src/theme/components/link.ts +5 -1
  259. package/src/theme/components/list.ts +73 -0
  260. package/src/theme/components/notification.ts +93 -0
  261. package/src/theme/components/pagination.ts +20 -0
  262. package/src/theme/components/progressIndicator.ts +62 -0
  263. package/src/theme/components/radio.ts +2 -2
  264. package/src/theme/components/radioGroup.ts +8 -0
  265. package/src/theme/components/select.ts +6 -3
  266. package/src/theme/components/skeletonLoader.ts +107 -0
  267. package/src/theme/components/slider.ts +79 -0
  268. package/src/theme/components/statusBadge.ts +1 -2
  269. package/src/theme/components/tabs.ts +49 -19
  270. package/src/theme/components/template.ts +8 -8
  271. package/src/theme/components/textInput.ts +5 -4
  272. package/src/theme/components/videoPlayer.ts +49 -0
  273. package/src/theme/foundations/breakpoints.ts +8 -8
  274. package/src/theme/foundations/global.ts +6 -1
  275. package/src/theme/foundations/radii.ts +6 -0
  276. package/src/theme/foundations/spacing.ts +24 -24
  277. package/src/theme/index.ts +41 -10
  278. package/src/utils/componentCategories.ts +4 -3
  279. package/dist/components/HelperErrorText/HelperErrorText.stories.d.ts +0 -16
  280. package/dist/components/Image/Image.stories.d.ts +0 -18
  281. package/dist/components/List/List.stories.d.ts +0 -7
  282. package/dist/theme/components/customCheckboxGroup.d.ts +0 -18
  283. package/dist/theme/components/customRadioGroup.d.ts +0 -18
  284. package/src/components/Button/_Button.scss +0 -32
  285. package/src/components/Card/_Card.scss +0 -308
  286. package/src/components/HelperErrorText/HelperErrorText.stories.tsx +0 -48
  287. package/src/components/HelperErrorText/_HelperErrorText.scss +0 -9
  288. package/src/components/HorizontalRule/_HorizontalRule.scss +0 -15
  289. package/src/components/Image/Image.stories.tsx +0 -54
  290. package/src/components/Image/_Image.scss +0 -38
  291. package/src/components/List/List.stories.tsx +0 -139
  292. package/src/components/List/_List.scss +0 -76
  293. package/src/components/Notification/_Notification.scss +0 -110
  294. package/src/components/Pagination/_Pagination.scss +0 -40
  295. package/src/components/SkeletonLoader/_SkeletonLoader.scss +0 -142
  296. package/src/components/VideoPlayer/_VideoPlayer.scss +0 -38
  297. package/src/styles/01-colors/_colors-brand.scss +0 -62
  298. package/src/styles/01-colors/_colors-utility.scss +0 -67
  299. package/src/styles/02-typography/_type-scale.css +0 -11
  300. package/src/styles/02-typography/_type-weight.css +0 -7
  301. package/src/styles/02-typography/_typefaces.css +0 -4
  302. package/src/styles/03-space/_space-stack.scss +0 -116
  303. package/src/styles/03-space/_space.css +0 -30
  304. package/src/styles/base/_card-grid.scss +0 -78
  305. package/src/styles/base/_typography.scss +0 -11
  306. package/src/theme/components/customCheckboxGroup.ts +0 -12
  307. package/src/theme/components/customRadioGroup.ts +0 -12
@@ -6,6 +6,7 @@ import {
6
6
  Description,
7
7
  } from "@storybook/addon-docs/blocks";
8
8
  import { withDesign } from "storybook-addon-designs";
9
+ import { Stack } from "@chakra-ui/react";
9
10
 
10
11
  import { getCategory } from "../../utils/componentCategories";
11
12
  import Icon from "../Icons/Icon";
@@ -31,71 +32,64 @@ import DSProvider from "../../theme/provider";
31
32
 
32
33
  # Iconography
33
34
 
34
- Use the NYPL Design System [Icon](https://nypl.github.io/nypl-design-system/storybook-static/?path=/docs/icon--control-props) component to render and control icons and NYPL logos as `<svg>` elements within consuming apps.
35
+ | Table of Contents |
36
+ | ---------------------------------------------- |
37
+ | 1. [General Information](#general-information) |
38
+ | 2. [Icon Examples](#icon-examples) |
39
+ | 3. [Icon Sizes](#icon-sizes) |
40
+ | 4. [Icon Colors](#icon-colors) |
41
+ | 5. [Development Notes](#development-notes) |
42
+ | 6. [Figma Reference](#figma-reference) |
35
43
 
36
- The DS utilizes the `Filled` icons available in the [Material UI Design System](https://material-ui.com/components/material-icons/).
44
+ ## General Information
37
45
 
38
- ## Style Guide Topics
46
+ Use the NYPL Design System [Icon](https://nypl.github.io/nypl-design-system/storybook-static/?path=/docs/icon--control-props)
47
+ component to render and control icons and NYPL logos as `<svg>` elements within
48
+ consuming apps.
39
49
 
40
- - [Icon Examples](#icon-examples)
41
- - [Icon Sizes](#icon-sizes)
42
- - [Icon Colors](#icon-colors)
43
- - [Development Notes](#development-notes)
44
- - [Figma Reference](#figma-reference)
50
+ The DS utilizes the `Filled` icons available in the [Material UI Design System](https://material-ui.com/components/material-icons/).
45
51
 
46
52
  ## Icon Examples
47
53
 
48
- The graphic of the `Icon` component is handled through the `IconNames` and `LogoNames` enums. To see all graphic options for `Icon`, please refer to the [Icon](https://nypl.github.io/nypl-design-system/storybook-static/?path=/docs/icon--control-props) Storybook page.
54
+ The graphic of the `Icon` component is handled through the `IconNames` and
55
+ `LogoNames` enums. To see all graphic options for `Icon`, please refer to the
56
+ [Icon](https://nypl.github.io/nypl-design-system/storybook-static/?path=/docs/icon--control-props)
57
+ Storybook page.
49
58
 
50
59
  <Canvas>
51
60
  <DSProvider>
52
- <span style={{ marginRight: "1rem" }}>
61
+ <Stack spacing="s" direction="row">
53
62
  <Icon
54
63
  decorative
55
64
  size={IconSizes.ExtraExtraExtraLarge}
56
65
  name={IconNames.Check}
57
- style={{ marginRight: "1rem" }}
58
66
  />
59
- </span>
60
- <span style={{ marginRight: "1rem" }}>
61
67
  <Icon
62
68
  decorative
63
69
  size={IconSizes.ExtraExtraExtraLarge}
64
70
  name={IconNames.Close}
65
- style={{ marginRight: "1rem" }}
66
71
  />
67
- </span>
68
- <span style={{ marginRight: "1rem" }}>
69
72
  <Icon
70
73
  decorative
71
74
  size={IconSizes.ExtraExtraExtraLarge}
72
75
  name={IconNames.ErrorOutline}
73
- style={{ marginRight: "1rem" }}
74
76
  />
75
- </span>
76
- <span style={{ marginRight: "1rem" }}>
77
77
  <Icon
78
78
  decorative
79
79
  size={IconSizes.ExtraExtraExtraLarge}
80
80
  name={IconNames.SpeakerNotes}
81
- style={{ marginRight: "1rem" }}
82
81
  />
83
- </span>
84
- <span style={{ marginRight: "1rem" }}>
85
82
  <Icon
86
83
  decorative
87
84
  size={IconSizes.ExtraExtraExtraLarge}
88
85
  name={LogoNames.LogoNypl}
89
- style={{ marginRight: "1rem" }}
90
86
  />
91
- </span>
92
- <span style={{ marginRight: "1rem" }}>
93
87
  <Icon
94
88
  decorative
95
89
  size={IconSizes.ExtraExtraExtraLarge}
96
90
  name={LogoNames.LogoBrooklyn}
97
91
  />
98
- </span>
92
+ </Stack>
99
93
  </DSProvider>
100
94
  </Canvas>
101
95
 
@@ -114,89 +108,89 @@ The size of the `Icon` component is handled through the `IconSizes` enum.
114
108
 
115
109
  <Canvas>
116
110
  <DSProvider>
117
- <div style={{ display: "flex", alignItems: "center" }}>
118
- <span style={{ marginRight: "1rem" }}>
119
- <Icon size={IconSizes.Small} name={IconNames.Check} />
120
- </span>
121
- <span style={{ marginRight: "1rem" }}>
122
- <Icon size={IconSizes.Medium} name={IconNames.Check} />
123
- </span>
124
- <span style={{ marginRight: "1rem" }}>
125
- <Icon size={IconSizes.Large} name={IconNames.Check} />
126
- </span>
127
- <span style={{ marginRight: "1rem" }}>
128
- <Icon size={IconSizes.ExtraLarge} name={IconNames.Check} />
129
- </span>
130
- <span style={{ marginRight: "1rem" }}>
131
- <Icon size={IconSizes.ExtraExtraLarge} name={IconNames.Check} />
132
- </span>
133
- <span style={{ marginRight: "1rem" }}>
134
- <Icon size={IconSizes.ExtraExtraExtraLarge} name={IconNames.Check} />
135
- </span>
136
- </div>
111
+ <Stack spacing="s" direction="row" alignItems="center">
112
+ <Icon size={IconSizes.Small} name={IconNames.Check} />
113
+ <Icon size={IconSizes.Medium} name={IconNames.Check} />
114
+ <Icon size={IconSizes.Large} name={IconNames.Check} />
115
+ <Icon size={IconSizes.ExtraLarge} name={IconNames.Check} />
116
+ <Icon size={IconSizes.ExtraExtraLarge} name={IconNames.Check} />
117
+ <Icon size={IconSizes.ExtraExtraExtraLarge} name={IconNames.Check} />
118
+ </Stack>
137
119
  </DSProvider>
138
120
  </Canvas>
139
121
 
140
- | IconSizes Enum Value | CSS Value | CSS Variable |
141
- | -------------------------------- | ----------------- | ------------- |
142
- | `IconSizes.Small` | `0.875rem` (14px) | n/a |
143
- | `IconSizes.Medium` | `1.125rem` (18px) | n/a |
144
- | `IconSizes.Large` | `1.5rem` (24px) | `--space-m` |
145
- | `IconSizes.ExtraLarge` | `2rem` (32px) | `--space-l` |
146
- | `IconSizes.ExtraExtraLarge` | `3rem` (48px) | `--space-xl` |
147
- | `IconSizes.ExtraExtraExtraLarge` | `4rem` (64px) | `--space-xxl` |
122
+ | IconSizes Enum Value | CSS Value | CSS Variable |
123
+ | -------------------------------- | ----------------- | ------------------ |
124
+ | `IconSizes.Small` | `0.875rem` (14px) | n/a |
125
+ | `IconSizes.Medium` | `1.125rem` (18px) | n/a |
126
+ | `IconSizes.Large` | `1.5rem` (24px) | `--nypl-space-m` |
127
+ | `IconSizes.ExtraLarge` | `2rem` (32px) | `--nypl-space-l` |
128
+ | `IconSizes.ExtraExtraLarge` | `3rem` (48px) | `--nypl-space-xl` |
129
+ | `IconSizes.ExtraExtraExtraLarge` | `4rem` (64px) | `--nypl-space-xxl` |
148
130
 
149
131
  ## Icon Colors
150
132
 
151
- The color of the `Icon` component is handled through the `IconColors` enum. Icons in NYPL projects should always be rendered with one color.
133
+ The color of the `Icon` component is handled through the `IconColors` enum.
134
+ Icons in NYPL projects should always be rendered with one color.
152
135
 
153
136
  <Canvas>
154
137
  <DSProvider>
155
- <Icon size={IconSizes.ExtraExtraExtraLarge} name={IconNames.Check} />
156
- <Icon
157
- name={IconNames.Check}
158
- size={IconSizes.ExtraExtraExtraLarge}
159
- color={IconColors.BrandPrimary}
160
- />
161
- <Icon
162
- name={IconNames.Check}
163
- size={IconSizes.ExtraExtraExtraLarge}
164
- color={IconColors.SectionResearchPrimary}
165
- />
166
- <Icon
167
- name={IconNames.Check}
168
- size={IconSizes.ExtraExtraExtraLarge}
169
- color={IconColors.SectionResearchLibrarySchwartzman}
170
- />
171
- <Icon
172
- name={IconNames.Check}
173
- size={IconSizes.ExtraExtraExtraLarge}
174
- color={IconColors.SectionResearchLibrarySchomburg}
175
- />
138
+ <Stack spacing="s" direction="row">
139
+ <Icon size={IconSizes.ExtraExtraExtraLarge} name={IconNames.Check} />
140
+ <Icon
141
+ name={IconNames.Check}
142
+ size={IconSizes.ExtraExtraExtraLarge}
143
+ color={IconColors.BrandPrimary}
144
+ />
145
+ <Icon
146
+ name={IconNames.Check}
147
+ size={IconSizes.ExtraExtraExtraLarge}
148
+ color={IconColors.SectionResearchPrimary}
149
+ />
150
+ <Icon
151
+ name={IconNames.Check}
152
+ size={IconSizes.ExtraExtraExtraLarge}
153
+ color={IconColors.SectionResearchLibrarySchwartzman}
154
+ />
155
+ <Icon
156
+ name={IconNames.Check}
157
+ size={IconSizes.ExtraExtraExtraLarge}
158
+ color={IconColors.SectionResearchLibrarySchomburg}
159
+ />
160
+ </Stack>
176
161
  </DSProvider>
177
162
  </Canvas>
178
163
 
179
- | IconColors Enum Value | CSS Variable |
180
- | ---------------------------------------------- | ---------------------------------------- |
181
- | `IconColors.UiBlack` | `--ui-black` |
182
- | `IconColors.UiWhite` | `--ui-white` |
183
- | `IconColors.BrandPrimary` | `--brand-primary` |
184
- | `IconColors.BrandSecondary` | `--brand-secondary` |
185
- | `IconColors.SectionWhatsOnPrimary` | `--section-whats-on-primary` |
186
- | `IconColors.SectionBooksAndMorePrimary` | `--section-books-and-more-primary` |
187
- | `IconColors.SectionResearchPrimary` | `--section-research-primary` |
188
- | `IconColors.SectionResearchSecondary` | `--section-research-secondary` |
189
- | `IconColors.SectionLocationsPrimary` | `--section-locations-primary` |
190
- | `IconColors.SectionResearchLibraryLpa` | `--section-research-library-lpa` |
191
- | `IconColors.SectionResearchLibrarySchomburg` | `--section-research-library-schomburg` |
192
- | `IconColors.SectionResearchLibrarySchwartzman` | `--section-research-library-schwartzman` |
164
+ | IconColors Enum Value | CSS Variable |
165
+ | ---------------------------------------------- | ---------------------------------------------------- |
166
+ | `IconColors.UiBlack` | `--nypl-colors-ui-black` |
167
+ | `IconColors.UiWhite` | `--nypl-colors-ui-white` |
168
+ | `IconColors.BrandPrimary` | `--nypl-colors-brand-primary` |
169
+ | `IconColors.BrandSecondary` | `--nypl-colors-brand-secondary` |
170
+ | `IconColors.SectionWhatsOnPrimary` | `--nypl-colors-section-whats-on-primary` |
171
+ | `IconColors.SectionBooksAndMorePrimary` | `--nypl-colors-section-books-and-more-primary` |
172
+ | `IconColors.SectionResearchPrimary` | `--nypl-colors-section-research-primary` |
173
+ | `IconColors.SectionResearchSecondary` | `--nypl-colors-section-research-secondary` |
174
+ | `IconColors.SectionLocationsPrimary` | `--nypl-colors-section-locations-primary` |
175
+ | `IconColors.SectionResearchLibraryLpa` | `--nypl-colors-section-research-library-lpa` |
176
+ | `IconColors.SectionResearchLibrarySchomburg` | `--nypl-colors-section-research-library-schomburg` |
177
+ | `IconColors.SectionResearchLibrarySchwartzman` | `--nypl-colors-section-research-library-schwartzman` |
193
178
 
194
179
  ## Development Notes
195
180
 
196
- Icons have been added to the Icon component as they have been needed within NYPL development project, so not all of the [NYPL icons](https://www.figma.com/file/qShodlfNCJHb8n03IFyApM/?node-id=10734%3A3945) and [NYPL Brand](https://www.figma.com/file/qShodlfNCJHb8n03IFyApM/Main?node-id=15454%3A47007) and [NYPL UI](https://www.figma.com/file/qShodlfNCJHb8n03IFyApM/Main?node-id=14989%3A37) colors are currently available through the DS Icon component. If your project requires an icon or color that is not currently available in the Icon component, please inform your project manager or reach out directly to the NYPL Design System team.
181
+ Icons have been added to the Icon component as they have been needed within NYPL
182
+ development project, so not all of the [NYPL icons](https://www.figma.com/file/qShodlfNCJHb8n03IFyApM/?node-id=10734%3A3945)
183
+ and [NYPL Brand](https://www.figma.com/file/qShodlfNCJHb8n03IFyApM/Main?node-id=15454%3A47007)
184
+ and [NYPL UI](https://www.figma.com/file/qShodlfNCJHb8n03IFyApM/Main?node-id=14989%3A37)
185
+ colors are currently available through the DS Icon component. If your project
186
+ requires an icon or color that is not currently available in the Icon component,
187
+ please inform your project manager or reach out directly to the NYPL Design
188
+ System team.
197
189
 
198
190
  ## Figma Reference
199
191
 
192
+ For additional spacing information, please refer to the Figma Main file.
193
+
200
194
  - [NYPL Icons](https://www.figma.com/file/qShodlfNCJHb8n03IFyApM/?node-id=10734%3A3945)
201
195
  - [NYPL Brand Colors](https://www.figma.com/file/qShodlfNCJHb8n03IFyApM/Main?node-id=15454%3A47007)
202
196
  - [NYPL UI Colors](https://www.figma.com/file/qShodlfNCJHb8n03IFyApM/Main?node-id=14989%3A37)
@@ -13,6 +13,7 @@ import getCSSVariable from "../../helpers/getCSSVariable";
13
13
  import Card from "../Card/Card";
14
14
  import List from "../List/List";
15
15
  import { ListTypes } from "../List/ListTypes";
16
+ import DSProvider from "../../theme/provider";
16
17
 
17
18
  <Meta
18
19
  title={getCategory("Spacing")}
@@ -28,48 +29,55 @@ import { ListTypes } from "../List/ListTypes";
28
29
 
29
30
  # Spacing
30
31
 
31
- The DS spacing values are based on a root font size of `16px` (`1rem` = `16px`).
32
+ | Table of Contents |
33
+ | ------------------------------------------------ |
34
+ | 1. [General Information](#general-information) |
35
+ | 2. [CSS Variables](#css-variables) |
36
+ | 3. [Section Spacing](#section-spacing) |
37
+ | 4. [Grid Spacing](#grid-spacing) |
38
+ | 5. [Tabular Data Spacing](#tabular-data-spacing) |
39
+ | 6. [Form Spacing](#form-spacing) |
40
+ | 7. [Figma Reference](#figma-reference) |
32
41
 
33
- ## Style Guide Topics
42
+ ## General Information
34
43
 
35
- - [CSS Variables](#css-variables)
36
- - [Section Spacing](#section-spacing)
37
- - [Grid Spacing](#grid-spacing)
38
- - [Tabular Data Spacing](#tabular-data-spacing)
39
- - [Form Spacing](#form-spacing)
40
- - [Figma Reference](#figma-reference)
44
+ The DS spacing values are based on a root font size of `16px` (`1rem` = `16px`).
41
45
 
42
46
  ## CSS Variables
43
47
 
48
+ <DSProvider>
44
49
  The following CSS variables are available through the DS.
45
50
 
46
- | Variable Name | Calculation | Pixel Equivalent | Visual Reference |
47
- | -------------- | -------------------------- | ---------------- | -------------------------------------------------------------------------------------------- |
48
- | `--space` | n/a | `16px` | <div style={{ width: "var(--space)", backgroundColor: "var(--ui-focus)" }}>&nbsp;</div> |
49
- | `--space-xxs` | `calc(var(--space) / 4)` | `4px` | <div style={{ width: "var(--space-xxs)", backgroundColor: "var(--ui-focus)" }}>&nbsp;</div> |
50
- | `--space-xs` | `calc(var(--space) / 2)` | `8px` | <div style={{ width: "var(--space-xs)", backgroundColor: "var(--ui-focus)" }}>&nbsp;</div> |
51
- | `--space-s` | `calc(var(--space) * 1)` | `16px` | <div style={{ width: "var(--space-s)", backgroundColor: "var(--ui-focus)" }}>&nbsp;</div> |
52
- | `--space-m` | `calc(var(--space) * 1.5)` | `24px` | <div style={{ width: "var(--space-m)", backgroundColor: "var(--ui-focus)" }}>&nbsp;</div> |
53
- | `--space-l` | `calc(var(--space) * 2)` | `32px` | <div style={{ width: "var(--space-l)", backgroundColor: "var(--ui-focus)" }}>&nbsp;</div> |
54
- | `--space-xl` | `calc(var(--space) * 3)` | `48px` | <div style={{ width: "var(--space-xl)", backgroundColor: "var(--ui-focus)" }}>&nbsp;</div> |
55
- | `--space-xxl` | `calc(var(--space) * 4)` | `64px` | <div style={{ width: "var(--space-xxl)", backgroundColor: "var(--ui-focus)" }}>&nbsp;</div> |
56
- | `--space-xxxl` | `calc(var(--space) * 6)` | `96px` | <div style={{ width: "var(--space-xxxl)", backgroundColor: "var(--ui-focus)" }}>&nbsp;</div> |
51
+
52
+ | Variable Name | REM Equivalent | Pixel Equivalent | Visual Reference |
53
+ | ------------------- | -------------- | ---------------- | ------------------------------------------------------------------------------------------------------------- |
54
+ | `--nypl-space-xxs` | `0.25rem` | `4px` | <div style={{ width: "var(--nypl-space-xxs)", backgroundColor: "var(--nypl-colors-ui-focus)" }}>&nbsp;</div> |
55
+ | `--nypl-space-xs` | `0.5rem` | `8px` | <div style={{ width: "var(--nypl-space-xs)", backgroundColor: "var(--nypl-colors-ui-focus)" }}>&nbsp;</div> |
56
+ | `--nypl-space-s` | `1rem` | `16px` | <div style={{ width: "var(--nypl-space-s)", backgroundColor: "var(--nypl-colors-ui-focus)" }}>&nbsp;</div> |
57
+ | `--nypl-space-m` | `1.5rem` | `24px` | <div style={{ width: "var(--nypl-space-m)", backgroundColor: "var(--nypl-colors-ui-focus)" }}>&nbsp;</div> |
58
+ | `--nypl-space-l` | `2rem` | `32px` | <div style={{ width: "var(--nypl-space-l)", backgroundColor: "var(--nypl-colors-ui-focus)" }}>&nbsp;</div> |
59
+ | `--nypl-space-xl` | `3rem` | `48px` | <div style={{ width: "var(--nypl-space-xl)", backgroundColor: "var(--nypl-colors-ui-focus)" }}>&nbsp;</div> |
60
+ | `--nypl-space-xxl` | `4rem` | `64px` | <div style={{ width: "var(--nypl-space-xxl)", backgroundColor: "var(--nypl-colors-ui-focus)" }}>&nbsp;</div> |
61
+ | `--nypl-space-xxxl` | `6rem` | `96px` | <div style={{ width: "var(--nypl-space-xxxl)", backgroundColor: "var(--nypl-colors-ui-focus)" }}>&nbsp;</div> |
62
+
63
+ </DSProvider>
64
+
57
65
 
58
66
  ## Section Spacing
59
67
 
60
- In consuming apps, the major page sections should be separated vertically by `3rem` `(--space-xl`). This includes the space after the page global `header` and the space before the global `footer`.
68
+ In consuming apps, the major page sections should be separated vertically by `3rem` `(--nypl-space-xl`). This includes the space after the page global `header` and the space before the global `footer`.
61
69
 
62
70
  ## Grid Spacing
63
71
 
64
- When elements are displayed in a grid (i.e. Cards, Images, etc.), the space between elements, both horizontal and vertical, should be `2rem` (`--space-l`).
72
+ When elements are displayed in a grid (i.e. Cards, Images, etc.), the space between elements, both horizontal and vertical, should be `2rem` (`--nypl-space-l`).
65
73
 
66
74
  ## Tabular Data Spacing
67
75
 
68
- When data is displayed in a tabular layout (i.e. rows and columns in a table, a definition list, etc.), the space between data cells in a row should be `1.5rem` (`--space-m`) and the space between rows should be `2rem` (`--space-l`).
76
+ When data is displayed in a tabular layout (i.e. rows and columns in a table, a definition list, etc.), the space between data cells in a row should be `1.5rem` (`--nypl-space-m`) and the space between rows should be `2rem` (`--nypl-space-l`).
69
77
 
70
78
  ## Form Spacing
71
79
 
72
- Form input components should have a `2rem` (`--space-l`) space between each component. This includes both vertical (column) and horizontal (row) stacking. The DS [Form](https://nypl.github.io/nypl-design-system/storybook-static/?path=/story/form-elements-form--form) component has correct spacing incorporated into its UI structure and should always be used when building forms.
80
+ Form input components should have a `2rem` (`--nypl-space-l`) space between each component. This includes both vertical (column) and horizontal (row) stacking. The DS [Form](https://nypl.github.io/nypl-design-system/storybook-static/?path=/story/form-elements-form--form) component has correct spacing incorporated into its UI structure and should always be used when building forms.
73
81
 
74
82
  ## Figma Reference
75
83