@nypl/design-system-react-components 1.4.0-rc3 → 1.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md ADDED
@@ -0,0 +1,1806 @@
1
+ # Changelog
2
+
3
+ All notable changes to this project will be documented in this file.
4
+
5
+ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/).
6
+ Currently, this repo is in Prerelease. When it is released, this project will adhere to [Semantic Versioning](https://semver.org/spec/v2.0.0.html)
7
+ ========
8
+
9
+ ## Prerelease
10
+
11
+ ## 1.4.1 (February 9, 2023)
12
+
13
+ ### Adds
14
+
15
+ - Adds the `pattern` prop to the `TextInput` component.
16
+ - Adds documentation page "Dynamic Content" to the `Accessibility Guide`.
17
+ - Adds the `isRenderedText` prop to the `HelperErrorText` component.
18
+
19
+ ### Updates
20
+
21
+ - Adds a third radio button to the `Header` component, separating search options between the Circulating Catalog, Research Catalog, and the NYPL.org website.
22
+ - Temporarily removes the "log in" state from the `Header` component, the feature to read auth cookies, and the patron's name when logged in, and the log out link.
23
+ - Truncate breadcrumb text if beyond 40 characters then add ellipsis at the end. If the breadcrumb text is truncated, the DS `Tooltip` component is used to display the full text in a tooltip when the text is hovered.
24
+ - Updates the `SearchBar`'s `textInputProps` prop to include the following props to pass to the `TextInput` component: `isClearableCallback`, `max`, `maxLength`, `min`, and `pattern`.
25
+ - Updates how the `CheckboxGroup`, `ComponentWrapper`, `DatePicker`, and `RadioGroup` components internally render the `HelperErrorText` component. The update in the `ComponentWrapper` component affects the `AudioPlayer`, `Checkbox`, `Radio`, `SearchBar`, `Select`, `Slider`, `TextInput`, `Toggle`, and `VideoPlayer` DS components, each of which render helper or error text.
26
+ - Updates the `MultiSelect` component so it closes when the "escape" key is pressed.
27
+ - Updates where the focus is set in the `MultiSelect` "dialog" variant after the "Apply" button is clicked.
28
+ - Updates where the focus is set in the `MultiSelect` component after the selected items count button is clicked.
29
+
30
+ ## 1.4.0 (January 26, 2023)
31
+
32
+ ### Adds
33
+
34
+ - Adds the `MultiSelect`, `MultiSelectGroup`, `FilterBar` component.
35
+ - Adds the `useMultiSelect`, `useFilterBar` hook.
36
+ - Adds the `onChangeEnd` prop in the `Slider` component.
37
+ - Adds `autocomplete` attribute to `TextInput`s with type `"tel"`, `"email"`,
38
+ and `"url"`.
39
+ - Adds docs for `Links` and `Repetitive Actions` to the `Accessibility Guide`.
40
+
41
+ ### Updates
42
+
43
+ - Updates the hex value for `ui.gray.xx-dark`, `ui.gray.xxx-dark`,
44
+ `ui.gray.xxxx-dark`, `dark.ui.bg.page`, `dark.ui.bg.hover`, `dark.ui.bg.active`,
45
+ `dark.ui.disabled.secondary`, `dark.ui.error.primary`, `dark.ui.error.secondary`,
46
+ `dark.ui.focus`, `dark.ui.link.primary`, `dark.ui.link.secondary`,
47
+ `dark.ui.status.primary`, `dark.ui.status.secondary`, `dark.ui.success.primary`,
48
+ `dark.ui.success.secondary`, `dark.ui.warning.primary`
49
+ and `dark.ui.warning.secondary`.
50
+ - Updates the layout of the category `RadioGroup` to `column` for the mobile
51
+ view of the `FeedbackBox` component.
52
+ - Updates the background color for the `"iconOnly"` and `"text"` variants of
53
+ the `Button` component.
54
+ - Updates the DOM in the header of the `FeedbackBox` component to improve
55
+ accessibility.
56
+ - Updates the `Link` component to include descriptive text for screen readers
57
+ in the component's `"external"` variant.
58
+ - Updates the `HelperErrorText` component to set the `ariaLive` default value
59
+ to `"polite"`.
60
+ - Updates the `Accessibility` details for the `Notification` component.
61
+ - Better docs for the `onSubmit` prop in the `FeedbackBox` component.
62
+
63
+ ### Fixes
64
+
65
+ - Fixes spacing and alignment issues in the `FeedbackBox` component.
66
+ - Fixes the width of the Privacy Policy link in the `FeedbackBox` component.
67
+ - Fixes issue where `aria-describedby` attribute was not being added to
68
+ some `TextInput`s.
69
+
70
+ ### Removes
71
+
72
+ - Removes the `Link` component warning about the deprecated `button` variant.
73
+ This change is temporary and will be reverted once teams are able to update
74
+ their `Link`s appropriately.
75
+ - Removes the `arial-label` attribute from the `CheckboxGroup` and `RadioGroup`
76
+ components for improved accessibility. Using the attribute is redundant with
77
+ the existing "screen reader only" `<legend>` element.
78
+
79
+ ## 1.3.1 (December 15, 2022)
80
+
81
+ ### Adds
82
+
83
+ - Adds the optional `isClearableCallback` prop to the `TextInput` component. This prop works with the `isClearable` prop and the passed function is invoked when the "clear" button is clicked. This is most helpful for controlled `TextInput` component implementations.
84
+
85
+ ### Updates
86
+
87
+ - Updates the background color for the `hover` state in the `secondary` variant of the `Button` component.
88
+
89
+ ### Fixes
90
+
91
+ - Fixes the z-index value of the SVG icon in the `Select` component so it does not render above other elements on a consuming application's page.
92
+
93
+ ## 1.3.0 (December 8, 2022)
94
+
95
+ This release is exactly the same as the `1.3.0-rc` release candidate published on December 2, 2022. The `rc` release was reviewed and validated.
96
+
97
+ ## 1.3.0-rc (Release Candidate December 2, 2022)
98
+
99
+ ### Adds
100
+
101
+ - Adds additional color options to `Icon` component.
102
+ - Adds reusable iconColors and iconNames arrays/types for DRYer, easier-to-update code.
103
+ - Adds the following color options to the color theme object: `ui.bg.page`, `ui.typography.inverse.body`, `ui.typography.inverse.heading`, `dark.ui.typography.inverse.body`, and `dark.ui.typography.inverse.heading`.
104
+ - Adds the `StyledList` component.
105
+ - Adds the `FeedbackBox` component, `useFeedbackBox` component hook, and `useStateWithDependencies` helper hook.
106
+
107
+ ### Updates
108
+
109
+ - Updates the data displayed on the Colors Style Guide to expand the contrast details for the `ui` and `dark.ui` color.
110
+ - Updates the `md` breakpoint to `"37.5em"`, which is equal to `"600px"`.
111
+
112
+ ### Fixes
113
+
114
+ - Adds Node environment variable to npm script that Vercel uses to build the site. This patches an error from webpack not building correctly.
115
+
116
+ ## 1.2.2 (November 10, 2022)
117
+
118
+ ### Adds
119
+
120
+ - Adds an `isClearable` prop to the `TextInput` component. When set to `true`, a close `Button` component will render on top of the input element. Once clicked, any text value in the input field will be cleared and focus will return to the input element.
121
+ - Adds the `isClearable` property to the `textInputProps` prop object in the `SearchBar` component. This allows the `isClearable` prop to be passed to the `TextInput` component to render the close `Button` component.
122
+
123
+ ### Updates
124
+
125
+ - Updates the `Icon` and `Logo` documentation to include size values in px.
126
+ - Updates the spacing within the `tertiary` variant of the `Hero` component.
127
+ - Updates the `Buttons Style Guide` to extend the information about button sizes.
128
+ - Updates the `viewport` options in Storybook to align with the Reservoir breakpoints.
129
+
130
+ ### Fixes
131
+
132
+ - Fixes an invalid TOC link on the `Card` component Storybook page.
133
+ - Fixes the sizing of the `errorFilled` and `errorOutline` icons in the `Icon` component.
134
+ - Adds new props to Chakra's `ToolTip` to more forcefully close the DS `ToolTip`. New props include `closeDelay`, `closeOnClick`, `closeOnEsc`, and `closeOnMouseDown`.
135
+
136
+ ### Removes
137
+
138
+ - Removes the `Button` component warning about the deprecated `link` variant. This change is temporary and will be reverted once teams are able to update their `Button`s appropriately.
139
+
140
+ ## 1.2.1 (October 27, 2022)
141
+
142
+ ### Adds
143
+
144
+ - Adds the `"buttonPrimary"`, `"buttonSecondary"`, `"buttonPill"`, `"buttonCallout"`, `"buttonNoBrand"`, `"buttonDisabled"` variants for the the `Link` component, set through the `type` prop.
145
+
146
+ ### Deprecates
147
+
148
+ - Deprecates the `"button"` `type` variant for the `Link` component. Use any of the new `"buttonX"` variants instead.
149
+
150
+ ### Updates
151
+
152
+ - Updates the `AlphabetFilter` component by adding `aria-label=“Filter by letter"` attribute
153
+ and removing the `role` attribute on the `<nav>` element.
154
+ - Updates `AlphabetFilter` border color for the `active letter` indicator from
155
+ `ui.gray.medium` to `ui.gray.dark`.
156
+ - Updates background styles for `Hero` component's `primary` and `campaign` variants.
157
+ - Updates the hover styles for the `Checkbox` and `Radio` components.
158
+ - Improves `TagSet` `"filter"` type accessibility by adding an `aria-label` that includes `"click to remove filter"`, when `isDismissible` is true.
159
+
160
+ ### Fixes
161
+
162
+ - Updates Storybook npm packages to fix copying documentation and table of contents heading linking.
163
+
164
+ ## 1.2.0 (October 17, 2022)
165
+
166
+ ### Adds
167
+
168
+ - Adds a variant for `NYCDOE` to the `Logo` component.
169
+ - Adds the `TagSet` component.
170
+ - Adds the `AlphabetFilter` component.
171
+ - Adds the `AudioPlayer` component.
172
+ - Adds the `requiredLabelText` prop to the `TextInput` and `Label` component.
173
+ This allows customizing the "(Required)" text for other languages.
174
+
175
+ ### Updates
176
+
177
+ - Updates the `hamburger` SVG for the `Icon` component to allow for color assignments.
178
+ - Updates `ComponentWrapper` prop `descriptionText` type to `string | JSX.Element`.
179
+
180
+ ## 1.1.2 (September 29, 2022)
181
+
182
+ ### Adds
183
+
184
+ - Adds the `size` prop to the `Button` component. The accepted values are "small",
185
+ "medium", and "large". The default size value is "medium".
186
+ - Adds the `value` prop to the `Slider` component to programmatically update the
187
+ values of the `Slider` component.
188
+ - Adds the `value` prop to the `CheckboxGroup` component to programmatically
189
+ update the values of the `Checkbox`es within it.
190
+
191
+ ### Updates
192
+
193
+ - Updates the colors for the `secondary` and `iconOnly` variants of the `Button` component.
194
+ - Updates the `Tooltip` component to remove the dropshadow effect.
195
+ - Updates whether the content inside of an `Accordion` is always rendered through the `isAlwaysRendered` prop.
196
+ - Updates the spacing of the icon and text in the `Notification` component.
197
+ - Updates the padding and placement of the links in the `Footer` component.
198
+ - Updates how content in the `Table` component is aligned.
199
+ - Updates the `Button` styles in the `Header`, `Notification`, `SearchBar`, and
200
+ `Tabs` components based on the new `size` prop.
201
+ - Updates the `content` prop of the `Tooltip` component to accept number values.
202
+
203
+ ### Removals
204
+
205
+ - Removed the `data-testid` attribute from the `Button` component.
206
+
207
+ ## 1.1.1 (September 19, 2022)
208
+
209
+ ### Adds
210
+
211
+ - Adds the `text` variant in the `Button` component.
212
+
213
+ ### Fixes
214
+
215
+ - Fixes a bug where the `defaultValue` for a `TextInput` component was not being passed correctly to the Chakra input element.
216
+
217
+ ### Deprecates
218
+
219
+ - Deprecates the `link` variant in the `Button` component.
220
+
221
+ ## 1.1.0 (August 30, 2022)
222
+
223
+ This release is exactly the same as the `1.1.0-rc5` release candidate which was published and reviewed. Minor bug fixes, listed below, were made.
224
+
225
+ ### Fixes
226
+
227
+ - Fixes how the "footer" area is rendered in the `TemplateAppContainer`.
228
+ - Fixes ARIA labels in the `Footer`.
229
+
230
+ ## 1.1.0-rc5 (Release Candidate August 14, 2022)
231
+
232
+ ### Header Feature
233
+
234
+ - Adds static `Header` component with login dropdown (functionality to be added later).
235
+ - Implements focus lock in `Login` component in the `Header`'s internal `Login` component.
236
+ - Adds the `SkipNavigation` to the `Header` component.
237
+ - Adds the `SitewideAlerts` component used internally in the `Header` component. This component dynamically fetches and renders NYPL sitewide alerts.
238
+ - Adds login functionality, which includes reading cookie values with new package, js-cookie, making an API call for patron details, and showing a different UI to logged in users.
239
+ - Adds refresh login functionality, which is used when a cookie's accessToken has expired and the server responds to a request for patron details with a 401. It attempts to refresh the token and, if successful, refetches the patron's details.
240
+ - Adds the desktop search form to the `Header` component with the `SearchButton` and `SearchForm` components.
241
+ - Refactors `SearchButton` and `SearchForm` to implement the mobile search form.
242
+ - Adds the mobile navigation menu for the `Header` component with `MobileNav` and `MobileNavButton` components.
243
+ - Adds the mobile login menu for the `Header` component.
244
+ - Adds React context for the `Header`'s patron state data through `HeaderContext` and `HeaderProvider`.
245
+ - Better namespacing for Header-only components.
246
+ - Sets Header Auth links for production and development environments.
247
+ - Adds the `EncoreCatalogLogOutTimer` function to keep track of the patron's current site and when they should be logged out of Encore/Catalog after a timeout period.
248
+ - Uses legacy SVG icons for parity with the existing `Header` component.
249
+
250
+ ### Adds
251
+
252
+ - Adds `Tooltip` component.
253
+ - Adds the basic `Footer` React component and documentation. Uses "legacy" SVG icons in the `Footer` component for social media icons.
254
+ - Adds @chakra-ui/focus-lock packages to dependencies and peerDependencies.
255
+ - Adds the `useCloseDropDown` hook to manage closing dropdown-like components through clicks outside of it and by pressing the escape key.
256
+ - Adds the `react-ga` package to send Google Analytics events in the `Header` component.
257
+
258
+ ### Updates
259
+
260
+ - Updates the `onClick` event type for the `Pagination` links `onClick` function.
261
+ - Updates the `Link` component's `onClick` event type.
262
+ - Makes small, clarifying update to `Color Mode` story in Storybook.
263
+
264
+ ### Fixes
265
+
266
+ - Fixes the styling for the `Image` component in the `Hero` "secondary" variant.
267
+
268
+ ## 1.0.8 (August 11, 2022)
269
+
270
+ ### Adds
271
+
272
+ - Adds new color values under ui:
273
+ - `bg.default`, `bg.hover`, `bg.active`, `border.default`, `border.hover`, `typography.heading`, and `typography.body`.
274
+ - Adds new colors values under ui.gray:
275
+ - `xxxx-dark` and `xxx-dark`.
276
+ - Adds UI fills colors for dark mode in the codebase and also exported in the `useNYPLTheme` hook.
277
+ - Adds an optional `panelMaxHeight` prop to the `Accordion` component that determines the height of the panel and displays a scrollbar if content exceeds it.
278
+
279
+ ### Updates
280
+
281
+ - Updates color value for `xx-dark`.
282
+ - Updates the style of the TOC on the `Style Guide` pages to match the style of the TOC on the component pages.
283
+ - Updates the `Template` components to use CSS grid instead of flexbox.
284
+ - Updates the `Template` documentation with the new pattern for using individual `Template` components that go above the main `TemplateContent` component.
285
+ - Updates the `Placeholder` component's CSS to better display in the `Template` components.
286
+ - Updates how HTML attributes are passed down in the `Image` component to the HTML `img` element.
287
+ - Updates the `Accordion` so that its panel content only renders when the `Accordion` is open.
288
+
289
+ ## 1.0.7 (July 29, 2022)
290
+
291
+ ### Updates
292
+
293
+ - Updates border color in the `Description` variant of the `List` component.
294
+ - Updates how options are passed to the `SearchBar` component for its internal `Select` component.
295
+ - Updates how style props are passed to the `Link` component when using with third-party libraries, such as React Router.
296
+ - Updates the layout of the `Image` in the `Hero` "secondary" and "fiftyFifty" variants for mobile and desktop.
297
+
298
+ ## 1.0.6 (July 21, 2022)
299
+
300
+ ### Adds
301
+
302
+ - Adds the `isLazy` prop to the `Image` component which is set to `false` by default.
303
+
304
+ ### Updates
305
+
306
+ - Updates the following components to use React's `forwardRef` wrapper function to pass along refs to the correct DOM element. This is for third-party packages and components such as Chakra's `Tooltip` to work correctly.
307
+ - `Accordion`, `Breadcrumbs`, `Button`, `ButtonGroup`, `Card`, `ComponentWrapper`, `FieldSet`, `Form`, `SimpleGrid`, `Heading`, `HelperErrorText`, `Hero`, `HorizontalRule`, `Icon`, `Image`, `Label`, `List`, `Logo`, `Modal`, `Notification`, `Pagination`, `ProgressIndicator`, `SearchBar`, `SkeletonLoader`, `SkipNavigation`, `Slider`, `StatusBadge`, `StructuredContent`, `Table`, `Tabs`, `Template`, `TemplateAppContainer`, `Text`, `VideoPlayer`.
308
+ - Updates `padding-left` and `padding-right` style properties to `padding-start` and `padding-end`, respectively. Updates `margin-left` and `margin-right` style properties to `margin-start` and `margin-end`, respectively. These changes apply to inline CSS, shorthand Chakra style prop syntax, and Chakra theme file syntax. Note that `margin-start/end` and `padding-start/end` get converted to `margin-inline-start/end` and `padding-inline-start/end` respectively by Chakra UI.
309
+ - Updates the `Icon` component to include variants for legacy versions of `Account` (filled and unfilled), `Facebook`, `Instagram`, `Twitter` and `YouTube`.
310
+ - Updates the `Icon` component to include variants for `Warning` (filled and oultine).
311
+
312
+ ### Removes
313
+
314
+ - Removes the packages `@mdx-js/react` and `babel-loader` since they are not needed by Storybook.
315
+
316
+ ## 1.0.5 (July 7, 2022)
317
+
318
+ ### Adds
319
+
320
+ - Exports `ColorCard`.
321
+
322
+ ### Updates
323
+
324
+ - Updates the `Icon` component to include variants for `actionCheckCircleFilled`, `actionRegistration`, `decorativeEnvelope`, `decorativeLibraryCard` and `decorativeShoppingBag`.
325
+ - Updates the docs for the `Colors` Style Guide to include additional data related to contrast and WCAG compliance.
326
+ - Updates the `Checkbox` and `Radio` components to use `ui.gray.dark` for the default border color.
327
+ - Updates Storybook packages.
328
+
329
+ ### Fixes
330
+
331
+ - Fixes `useNYPLBreakpoints` hook so it internally controls its own state. This eliminates server/client rendering issues on its initial load.
332
+
333
+ ## 1.0.4 (June 23, 2022)
334
+
335
+ ### Adds
336
+
337
+ - Adds the `useNYPLBreakpoints` hook. This hook internally uses Chakra's `useMediaQuery` hook to get the current responsive media query breakpoint.
338
+ - Adds `ui.gray.xx-dark` to the color palette.
339
+ - Adds npm packages useful for lazy loading images in the `Image` component.
340
+ - Adds text case styles for `Text` component.
341
+ - Exports `ColorModeScript`, `cookieStorageManager`, `localStorageManager`, `useColorMode`, and `useColorModeValue` from Chakra UI for consuming application usage.
342
+ - Adds a "Color Mode" documentation page in Storybook.
343
+ - Adds `ui.white` as default background color to `Checkbox` and `Radio` components.
344
+ - Adds text case styles for `Heading` component
345
+
346
+ ### Updates
347
+
348
+ - Updates the `Logo` component to include a variant for `MLN Color`.
349
+ - Updates the `Icon` component to include variants for `Facebook`, `Instagram`, `Tumblr`, `Twitter` and `YouTube`.
350
+ - Updates the `Icon` component to include variants for `Building`, `Exit`, `Locator`, `Power` and `Settings`.
351
+ - Updates to Storybook version 6.5.
352
+ - Explicitly sets the default color mode value to `"light"`.
353
+ - Updates how the `styles.scss` and `resources.scss` files are organized and compiled so that they can be imported in any tech stack.
354
+ - Updates the docs for the `Table` commponent to remove the example that does not include column headers.
355
+ - Updates the `Button`, `Select` and `TextInput` components to use NYPL standard minimum height in mobile viewport.
356
+ - Updates the `SearchBar` component to change how the width of the internal `Select` component is handled.
357
+
358
+ ### Fixes
359
+
360
+ - Fixes the styles for the sub-labels in the `DatePicker` component.
361
+
362
+ ## 1.0.3 (June 9, 2022)
363
+
364
+ ### Adds
365
+
366
+ - Adds prop validation for the `TextInput` "number" type for the `min` and `max` props.
367
+ - Adds `min` and `max` prop value validation for the `Slider` component, including in the "range" mode.
368
+
369
+ ### Updates
370
+
371
+ - Updates the `TemplateAppContainer`'s responsive styles for its sidebar component.
372
+ - Updates how the `Radio`'s label is hidden when the `showLabel` prop is set to "false" to fix the "no label" accessibility issue.
373
+ - Updates the `Logo` component to include new variants for `NYPL Text Only`.
374
+ - Updates the `Card`'s full-click functionality styling for its wrapper element.
375
+ - Updates how the `Card`'s `Image` component is displayed in the mobile view; sizes and aspect ratios are maintained instead of always displaying as 100% width.
376
+ - Updates hover style to add right border color on hover for `Select` element.
377
+ - Updates the `Table` component to be responsive for a mobile viewport.
378
+ - Updates the `Table` component to make the `columnHeaders` prop required.
379
+
380
+ ### Fixes
381
+
382
+ - Fixes the border color for the `Accordion` button.
383
+ - Fixes a false warning message logged from the `Table` component.
384
+ - Fixes the background color for the `Toggle` button.
385
+
386
+ ## 1.0.2 (June 1, 2022)
387
+
388
+ ### Adds
389
+
390
+ - Adds `noSpace` prop to the `Heading` component.
391
+ - Adds validation for equal headers and data column to the `Table` component.
392
+ - Adds `className`, `helperTextStyles`, and `showHelperInvalidText` props to the `ComponentWrapper` component.
393
+
394
+ ### Updates
395
+
396
+ - Updates the `fontSize` and `padding` attributes in the single variant of the `Accordion` component.
397
+ - Updates all QA urls from Tugboat QA to Vercel.
398
+ - Updates the `Logo` component to include new variants for `Apple App Store`, `Clever Badge` and `Google Play`.
399
+ - Pins the Chakra UI "react" and "system" packages to a certain range since Chakra v2 uses React 18 and creates backwards compatibility issues.
400
+ - Updates buttons setup as icon only to get the same hover styles as `secondary` button in the `Button` component.
401
+ - Updates and refactors the `Checkbox`, `Radio`, `Select`, `Slider`, `TextInput` and `Toggle` components to use the `ComponentWrapper` component for similar DOM structure.
402
+ - Updates how `CheckboxGroup` and `RadioGroup` handle `Checkbox` and `Radio` components when `isFullWidth` is true and there is JSX as labels.
403
+
404
+ ### Fixes
405
+
406
+ - Fixes how `Image`s are rendered with a non-default `aspectRatio` value and with a `caption` value or a `credit` value or both.
407
+ - Fixes the extra margin added by the `SkipNavigation` component.
408
+ - Updates various component implementations in Storybook documentation pages to remove inadvertent console errors and warnings.
409
+ - Fixes sizing in the `Card` component for the "body" and "right" sections when the `isAlignedRightActions` prop is set to `true`.
410
+ - Allows `Button`s in the `ButtonGroup` to manage their own `isDisabled` state.
411
+ - Fixes how the `onChange` prop is set in `Checkbox` so it only gets called once per rendering.
412
+
413
+ ## 1.0.1 (May 31, 2022)
414
+
415
+ _NOTE_: This version number was previously released in 2019 and is marked as deprecated in npm. The next version bump from `1.0.0` is `1.0.2`.
416
+
417
+ ## 1.0.0 (May 12, 2022)
418
+
419
+ This is the first stable release of the NYPL Reservoir Design System! We've been looking forward to this moment for over two years.
420
+
421
+ ### Updates
422
+
423
+ - Updates all links throughout the documentation to point to the new production URLs.
424
+
425
+ ## 0.28.0 (May 9, 2022)
426
+
427
+ ### Adds
428
+
429
+ - Adds `max`, `maxLength`, `min`, and `onClick` props to the `TextInput` component.
430
+ - Adds the `SkipNavigation` component and adds this component inside the `TemplateAppContainer` component. The `SkipNavigation` component renders accessible links to the main content of a page and accessibility information on NYPL.org.
431
+ - Adds the `ButtonGroup` component for `Button` layout.
432
+
433
+ ### Updates
434
+
435
+ - Updates how styles are passed down to internal components in `Card`, `Checkbox`, `CheckboxGroup`, `ComponentWrapper`, `DatePicker`, `Hero`, `Notification`, `Pagination`, `Radio`, `RadioGroup`, `SearchBar`, and `Slider`. This is based on removing the `additionalStyles` prop and passing down styles to the `__css` prop.
436
+ - Updates how the `id` is passed in the `DatePicker`'s custom `TextInput` component.
437
+ - Updates how some prop values are passed. Instead of using a Typescript enum object, a Typescript type with the string literal values is used. This still restricts the accepted values for certain props. The enum to string literal type conversion includes the following variables: `AccordionType`, `BreadcrumbsTypes`, `ButtonTypes`, `DatePickerTypes`, `FormGaps` (deleted), `GridGaps`, `HeadingSizes`, `HeadingLevels`, `HeroTypes`, `IconAlign`, `IconTypes`, `IconRotationTypes`, `IconColors`, `IconSizes`, `IconNames`, `LinkTypes`, `ListTypes`, `LogoColors`, `LogoSizes`, `LogoNames`, `NotificationTypes`, `SelectTypes`, `LabelPositions`, `SkeletonLoaderImageRatios`, `StatusBadgeTypes`, `StructuredContentImagePosition`, `TextSizes`, `TextInputTypes`, `TextInputFormats`, `TextInputVariants`, `ToggleSizes`, `VideoPlayerTypes`, `VideoPlayerAspectRatios`, and `LayoutTypes`.
438
+ - Updates the spacing for caption and credit text from `margin-bottom` to `margin-top` in `Image` component
439
+ - Updates how the `DatePicker` and `Slider` components internally use `TextInput`.
440
+ - Updates how the `Pagination` component internally uses `Link`.
441
+ - Updates how the `Tabs` component internally uses `Button`.
442
+ - Updates how images are passed to the `Hero` component. Instead of `imageAlt` and `imageSrc` props, now an object must be passed to the `imageProps` prop.
443
+ - Updates the values for the `name` prop for the `Icon` and `Logo` components.
444
+ - Updates the `Table` component to allow JSX elements to be rendered in the data cells.
445
+
446
+ ### Removals
447
+
448
+ - Removes the `additionalStyles` attributes from the `Breadcrumbs`, `Button`, `Heading`, `HelperErrorText`, `Icon`, `Link`, `List`, `Logo`, `Select`, `TextInput`, and `Toggle` components.
449
+ - Removes `getVariant` and `getStorybookEnumValues` helper functions.
450
+ - Removes all Typescript enum objects in favor of string literal types.
451
+ - Remove the bottom margin attribute that is applied to the parent element for the `Select` component.
452
+ - Removes the `attributes` prop from: `Button`, `Link`, and `TextInput` components.
453
+
454
+ ## 0.27.0 (April 27, 2022)
455
+
456
+ ### Adds
457
+
458
+ - Adds two patterns for rendering the updated `Modal` component. This is still an ongoing work-in-progress as the `Modal` gets finalized but it is now using Chakra under-the-hood.
459
+ - Adds `@chakra-ui/storybook-addon` so stories automatically pick up the Chakra-based NYPL theme.
460
+
461
+ ### Updates
462
+
463
+ - Updates React and React DOM to version 17.
464
+ - Updates Chakra packages `@chakra-ui/react` and `@chakra-ui/system`.
465
+ - Updates the `HelperErrorText` styling to correctly display when used with a `Select` element with a `labelPosition` of inline.
466
+
467
+ ### Removals
468
+
469
+ - Removes the following packages: `@storybook/addon-queryparams` and `react-router-dom`.
470
+
471
+ ## 0.26.1 (April 22, 2022)
472
+
473
+ ### Updates
474
+
475
+ - Updates storybook URL from /reservoir/v0_26 to /reservoir/v0.]
476
+ - Updates the `Header`'s bottom navigation links to be underlined and red when hovered.
477
+
478
+ ### Fixes
479
+
480
+ - Adds updated package-lock file to fix bad installations.
481
+
482
+ ## 0.26.0 (April 22, 2022)
483
+
484
+ ### Adds
485
+
486
+ - Exports the `useCarouselStyles` and `useWindowSize` hooks and adds documentation for all hooks in Storybook.
487
+ - Adds additional semantic design tokens from `fontWeights` and `fontSizes` to the `useNYPLTheme` hook.
488
+ - Adds a warning if a required `id` prop is not passed to one of the "Form Elements": `Button`, `Checkbox`, `CheckboxGroup`, `DatePicker`, `Fieldset`, `Form`, `Label`, `ProgressIndicator`, `Radio`, `RadioGroup`, `SearchBar`, `Select`, `Slider`, `TextInput`, `Toggle`.
489
+ - Adds the `isRequired` prop to the `Label` component.
490
+ - Adds the `labelPosition` prop to the `Select` component, so that the label can be styled inline with the select input.
491
+ - Adds Chakra's "Style Props" functionality to every Reservoir component. For composed components, such as the `SearchBar` component, these style props are passed to wrapper element. This update also updates the snapshot tests for every component.
492
+ - Adds the functionality to pass all valid HTML attributes to a Reservoir component, such as `data-*` props.
493
+ - Adds semantic design tokens for `spacing` theme object.
494
+ - Adds the `isAlignedRightActions` prop to the `Card` component to render `CardActions` components to the right of the main content area. This only works for the `Card`'s row layout.
495
+ - Adds styles to target native HTML basic elements inside the `StructuredContent` component.
496
+ - Adds `Reservoir` branding to Storybook.
497
+
498
+ ### Changes
499
+
500
+ - Updates the hex color value for `ui.gray.light-cool`, `ui.disabled.primary` and `section.blogs.primary`.
501
+ - Updates the default background color used in the `Accordion` component.
502
+ - Updates the default background color used in the `Hero` component.
503
+ - Updates the background color used in the `SkeletonLoader` component.
504
+ - Updates the background color used in the `VideoPlayer` component.
505
+ - Updates the background colors used in the `Tabs` component.
506
+ - Updates the colors for "secondary" and "pill" variants of the `Button` component.
507
+ - Updates the color values used in the `disabled` state for the `Checkbox`, `Radio`, `Select`, `Slider`, `TextInput` and `Toggle` components.
508
+ - Updates the `Checkbox` component to use "3px" for the border radius.
509
+ - Makes the id prop required for all "Form Elements".
510
+ - Updates how the `Required` text in the `Label` and `Fieldset` components is displayed. Instead of floating to the right of the label and legend elements, it is now displayed inlined as `(Required)`.
511
+ - Renames the `optReqFlag` prop to `showRequiredLabel` in the `CheckboxGroup`, `Fieldset`, `RadioGroup`, and `Slider` components.
512
+ - Renames the `showOptReqLabel` prop to `showRequiredLabel` in the `DatePicker`, `Select`, and `TextInput` components.
513
+ - Uses the design token "text.caption" variable for the `Notification`'s font size.
514
+ - Updates the styling for the `HelperErrorText` to be consistent for all components that use it
515
+ - Refactors the `Checkbox`, `CheckboxGroup`, `ComponentWrapper`, `DatePicker`, `Fieldset`, `Label`, `Radio`, `RadioGroup`, `Select`, `Slider`, `TextInput`, and `Toggle` to better use the updated `HelperErrorText` styling.
516
+ - Renames the `Card`'s `center` prop to `isCentered` and `border` prop to `isBordered`.
517
+ - Renames the `SkeletonLoader` component's `border` prop to `isBordered`.
518
+ - Refactors the DS `RadioGroup` component so it internally implements Chakra's `RadioGroup` component rather than the `useRadioGroup` hook. The "uncontrolled" version of Chakra's `RadioGroup` is not working and will be investigated in the future. It is recommended to use the controlled component pattern.
519
+ - Updates the `Fieldset` component to render the "Optional"/"Required" text in the `legend` element as pseudo CSS in the `::after` rule.
520
+ - Passes the `isRequired` prop in the `RadioGroup` and `CheckboxGroup` to the `Fieldset` wrapper component.
521
+ - Updates the `focus` styles for the `Radio`, `Select` and `TextInput` components.
522
+ - Updates the references of the `<dl>` element from "Definition" to "Description", as that's the official name in HTML5. This affects the `List` element and its `ListTypes.Description` enum value.
523
+ - Updates styles for `React Datepicker`'s calendar popup in the `DatePicker` component.
524
+ - Updates storybook URL from /storybook-static/ to /reservoir/v0_26.
525
+ - Updates all references to "design system" in the Storybook documentation to include "Reservoir" in the name of the design system.
526
+ - Updates language on the `Welcome` page.
527
+
528
+ ### Removals
529
+
530
+ - Removes the default `Optional` text displayed in the `Label` and `Fieldset` components.
531
+ - Removes the `optReqFlag` prop in the `Label` component.
532
+ - Removes the default autogenerated id for all components, as well as the `uuid` package.
533
+ - Removes the `HorizontalRule`'s `height` and `width` props from its prop interface in favor of Chakra's style props; the default values are still set for `height` and `width`.
534
+
535
+ ### Fixes
536
+
537
+ - Fixes how the `Button` component gets rendered inside the `Form` and `FormField` component layout.
538
+ - Fixes how the `Select` component is controlled in the `SearchBar` component.
539
+
540
+ ## 0.25.13 (April 1, 2022)
541
+
542
+ ### Adds
543
+
544
+ - Adds a `contentId` prop to the `TemplateAppContainer` component and adds an `id` prop to the `TemplateContent` component. The default value of these `id`s are both set to "mainContent" and it will render as an attribute on the `main` HTML element. This is used as the target for the skip navigation link in consuming applications.
545
+ - Adds an `Accessibility Guide` section to Storybook with a "Skip Navigation" page.
546
+ - Adds the `isFullWidth` prop to the `CheckboxGroup` and `RadioGroup` components. This sets the wrapper element to be full width for labels that need to span its container.
547
+ - Adds an optional key – `accordionType` to the `Accordion`'s `contentData` prop, which allows users to switch the background color of the `Accordion`'s button.
548
+ - Created new `LayoutTypes` enum for row and column layouts.
549
+ - Adds the value "Default" to the `IconSizes` enum.
550
+
551
+ ### Changes
552
+
553
+ - Updates Storybook's sidebar categories and documentation.
554
+ - Updates the `Image`'s caption font size to "12px" (`text.tag`).
555
+ - Updates the `Checkbox`'s and `Radio`'s `labelText` prop to accept strings and JSX Elements.
556
+ - Updates the `Toggle`'s internal styling for the default and small sizes.
557
+ - Updates the `Accordion` button's background color when expanded, adds a border color when hovered over, and adjusts the padding.
558
+ - Updates the `CardImage`'s margin bottom in the row and column layouts for mobile to be the same.
559
+ - Updates the `CardImage` to have width 100% on mobile regardless of size.
560
+ - Updates all the console warnings with consistent NYPL branding prefix label.
561
+ - Renames the `Accordion` prop `contentData` to `accordionData`.
562
+ - Renames the `Breadcrumbs` prop `colorVariant` to `breadcrumbsType`.
563
+ - Renames the `Card` prop `center` to `isCentered`.
564
+ - Updates the `Card` prop `layout` to use the `LayoutTypes` enum instead of `CardLayouts`.
565
+ - Updates the `CheckboxGroup` prop `layout` to use the `LayoutTypes` enum instead of `CheckboxGroupLayoutTypes`.
566
+ - Renames the `Heading` prop `displaySize` to `size.
567
+ - Renames the `HeadingDisplaySizes` enum to `HeadingSizes.
568
+ - Renames the `Hero` prop `image` to `imageComponent`.
569
+ - Renames the `Image` prop `imageSize` to `size`.
570
+ - Renames the `Notification` prop `centered` to `isCentered`.
571
+ - Updates the `RadioGroup` prop `layout` to use the `LayoutTypes` enum instead of `RadioGroupLayoutTypes`.
572
+ - Internal updates to the `SearchBar` component based on updates from the `Select` and `TextInput` components.
573
+ - Renames the `Select` prop `type` to `selectType`.
574
+ - Updates the `SkeletonLoader` prop `layout` to use the `LayoutTypes` enum instead of `SkeletonLoaderLayouts`.
575
+ - Renames the `StructuredContentImage` prop `imageSize` to `size` (this component is based on the `Image` component).
576
+ - Internal updates to the `StructuredContent` component based on updates from the `Image` and `Heading` components.
577
+ - Renames the `Tabs` prop `contentData` to `tabsData`.
578
+ - Renames the `Text` prop `displaySize` to `size`.
579
+ - Renames the `TextInput` prop `variant` to `textInputType`.
580
+ - Updates the `Card` image-related props into one main prop named `imageProps`. This new prop contains the following properties: alt, aspectRatio, caption, component, credit, isAtEnd, size, and src.
581
+ - Updates the `Hero` prop `image` to `imageAlt` and `imageSrc`. Internally, an `Image` component is created.
582
+ - Renames the `Image` component props `imageAspectRatio` to `aspectRatio`, `imageCaption` to `caption`, and `imageCredit` to `credit`.
583
+ - Updates the `StructuredContent` image-related props into one main prop named `imageProps`. This new prop contains the following properties: alt, aspectRatio, caption, component, credit, position, size, and src.
584
+ - Renames the `ToggleSizes.tsx` file to `ToggleTypes.tsx`. Updates the values from `Large` and `Small` to `Default` and `Small`.
585
+ - Minor update to the logic for the `ProgressIndicator` sizing prop and styles.
586
+
587
+ ### Fixes
588
+
589
+ - Fixes bug where the Next button in `Pagination` would navigate to the previous page.
590
+ - Fixes the alignment of the first link in the `Pagination` component.
591
+ - Fixes the `Breadcrumbs`' SVG arrow icon fill color for the "Blogs" variant.
592
+ - Fixes the margin right value for list items in the `List` component for the inline style.
593
+ - Fixes bug in the `Select` component where the SVG arrow hides when the component is focused.
594
+ - Fixes the extra bottom spacing in the `HeroTypes.Campaign` `Hero` variant for the mobile view.
595
+ - Fixes the `Slider` component so it doesn't cause a stack overflow client-side issue when updating the slider thumbs through the keyboard arrows. The values are now returned through Chakra's `onChange` callback instead of the `onChangeEnd` callback.
596
+
597
+ ### Removals
598
+
599
+ - Removes the `CardLayouts`, `CheckboxGroupLayoutTypes`, `RadioGroupLayoutTypes`, and `SkeletonLoaderLayouts` enums.
600
+ - Removes the `CardTypes.tsx`,` CheckboxGroupLayoutTypes.tsx`, and `RadioGroupLayoutTypes.tsx` files.
601
+
602
+ ## 0.25.12 (March 18, 2022)
603
+
604
+ ### Adds
605
+
606
+ - Adds `Education` section colors to the color palette theme object.
607
+ - Adds a `currentPage` prop to the `Pagination` component, a value that updates the selected page programmatically without the user explicitly requesting it.
608
+
609
+ ### Changes
610
+
611
+ - Removes the margin from the global `.nypl p` CSS rule.
612
+ - Updates the top and bottom margin of the `List`'s `Unordered` and `Ordered` types.
613
+ - Updates the `Notification`'s icons to be decorative by default.
614
+ - Updates the default placeholder value for the `SearchBar`'s `TextInput` component.
615
+ - Updates the `SearchBar`'s `textInputProps` prop object to not require the `placeholder` property.
616
+ - Updates the `Logo` component to include new variants for `FirstBook` and `Open eBooks`.
617
+ - Updates the border and text styles for the `Select` component.
618
+ - Updates the `Breadcrumbs` component to inlcude an `Education` color variant.
619
+ - Updates the `Icon` component to include the `Education` color values.
620
+ - Updates the default font stack to fix a typo that was disabling `sans-serif` in the stack.
621
+ - Removes the `.nypl-ds` CSS class from the base SCSS file, from the `TemplateAppContainer` component, from the Storybook configuration, and from the entire repo.
622
+ - Moves the base styles from the SCSS global file to the Chakra theme global JS object.
623
+ - Updates the label font size for the `Radio` and `Checkbox` components to be "label.default".
624
+
625
+ ### Fixes
626
+
627
+ - Fixes the styles for the `Slider` to better accomodate the slider thumbs and the width of the container.
628
+ - Updates the alignment of the `Notifications`'s dismissible icon.
629
+ - Fixes the border and padding from the `fieldset` HTML element by removing it.
630
+ - Fixes alignment for long labels in the `Checkbox` and `Radio` components.
631
+ - Fixes the line height for long labels in the `Toggle` component.
632
+
633
+ ## 0.25.11 (March 3, 2022)
634
+
635
+ ### Updates
636
+
637
+ - Updates the `Logo` component to include new variants for `BPL`, `Clever`, `LPA`, `MLN`, `QPL`, `Schomburg`, `SimplyE` and `Treasures`.
638
+ - Updates font size to "12px" and top margin to "4px" for `HelperErrorText` component.
639
+ - Updates font size to "14px" for `TextInput` component.
640
+ - Adds an `aria-label` attribute to the `Notification` component to use with its `aside` HTML landmark element. Added an "Accessibility" section in the `Notification` Storybook page to note that this component should not be used within a `header` or `footer` HTML landmark element.
641
+ - Updates the `Notification` component to handle link color inside the content area, better styling for centering and the dismissible variation, and updated background color for the "Announcement" and "Warning" types.
642
+ - Updates a log message in the `Icon` component to be more descriptive.
643
+ - Updates the mobile styles for the image in the `StructuredContent` component.
644
+ - Updates the prop type for the "Definition" `List` type so DOM elements can be passed in the definition.
645
+
646
+ ### Fixes
647
+
648
+ - Updates the bottom margin of the `Select` in the `SearchBar` so that the helper text has standard gap between the main form components and itself.
649
+ - Updates how `TabList` and `TabPanels` are returned in the `Tabs` component so no false log messages are consoled.
650
+ - Updates `List` component styling for inline.
651
+
652
+ ## 0.25.10 (February 22, 2022)
653
+
654
+ ### Adds
655
+
656
+ - Exports Chakra's `Flex` and `Spacer` components.
657
+ - Adds `TemplateAboveHeader` component in the set of "template" components.
658
+ - Adds the `aboveHeader` prop to the `TemplateAppContainer` component to render a `TemplateAboveHeader` component immediately before the `TemplateHeader` component.
659
+ - Adds the `additionalStyles` prop to the `Select` component.
660
+
661
+ ### Breaking Changes
662
+
663
+ - Renames the `Form` component's `"spacing"` prop to `"gap"` to be consistent with the `FormRow` and `FormField` components.
664
+ - Renames the `FormSpacing` enum to `FormGaps`.
665
+
666
+ ### Changes
667
+
668
+ - Passes an `onChange` prop to the `Select` component inside the `SearchBar` through its `selectProps` prop.
669
+ - Adds snapshot tests for the `Tabs` component and better checks to warn the user that the `Tabs` is missing data if data wasn't passed as props or children.
670
+ - Updates the `Form` component to warn developers when a child component in the `FormRow` component _is not_ a `FormField`.
671
+ - Adds an `onSubmit` prop to the `Form` component.
672
+ - Adds the `renderHeaderElement` prop to the `TemplateAppContainer` component. This prop is used to control whether the `TemplateAppContainer` component should render its own `<header>` HTML element through its `header` prop, or let the user pass in their own component that renders the `<header>` HTML element.
673
+ - Updates the `Fieldset` and `RadioGroup` so the `children` prop is declared through `React.PropsWithChildren` rather than in their respective prop interfaces.
674
+ - Adds snapshot tests for the `Accordion` component, as well as `id` props to the components within the `Accordion` so snapshot tests pass.
675
+ - Passes an `id` to the `Icon` in the `Select` component.
676
+ - Adds snapshot tests for the `Select` component.
677
+
678
+ ### Fixes
679
+
680
+ - Fixes `id` propagation issues in the `SearchBar` component and its children DS components.
681
+ - Fixing `Breadcrumbs` related logging issue with a CSS pseudo-selector and setting the `aria-label` to "Breadcrumbs". Adding an accessibility test that should fail when more than one `Breadcrumbs` component is rendered on a page since that landmark should only be rendered once on a web page.
682
+ - Exports the `FullDateType` interface related to the `DatePicker` component.
683
+ - Fixes and removes bad console logs from the `Pagination` and `List` components.
684
+ - Fixes auto-generated `id`s in the `Tabs` component.
685
+ - Fixes the Figma link for the `Hero` component.
686
+ - Fixes `Card` component bug for passing styles to the `CardHeading` correctly.
687
+ - Fixes the `Table` component so that a custom header text color of white does not visually hide row headers on a white background.
688
+
689
+ ### Updates
690
+
691
+ - Updates the following packages: multiple `@storybook/...` packages, `autoprefixer`, `eslint-plugin-storybook`, `husky`, `lint-staged`, `semantic-release-slack-bot`, `storybook-addon-designs`.
692
+ - Removed the following packages: `postcss`, `pretty-quick`.
693
+ - Added `@chakra-ui/react`, `@chakra-ui/system`, `@emotion/react`, `@emotion/styled`, and `framer-motion` as "peerDependencies".
694
+ - Updates the node version in Github Action workflows from Node v12 to Node v14.
695
+ - Updates how `/dist/resources.scss` is created through gulp.
696
+
697
+ ## 0.25.9 (February 3, 2022)
698
+
699
+ ### Adds
700
+
701
+ - Adds the `Logo` component.
702
+ - Adds the `noBrandButtonType` boolean prop to the `SearchBar` component to render the `NoBrand` `Button` variant style.
703
+ - Adds element-specific design tokens for `fontSizes` and `fontWeights`.
704
+ - Adds the `StructuredContent` component.
705
+ - Adds the `additionalImageStyles` and `additionalFigureStyles` props to the `Image` component to specifically target the `img` element's style and the `figure` HTML elements.
706
+ - Adds the `Table` component.
707
+
708
+ ### Breaking Changes
709
+
710
+ - Completely removes the `CardEdition` and `Input` components and related files and references.
711
+ - Removes all references of the `BEM` CSS pattern.
712
+ - Removes all references to logos from the `Icon` component.
713
+ - Removes passing in text to the `HelperErrorText` component as children. Now, the `text` prop is used to render its text.
714
+ - Renames the `SearchBar`'s `helperErrorText` prop to `helperText` to be consistent with other components.
715
+
716
+ ### Changes
717
+
718
+ - Updates the `Form`, `HorizontalRule`, `Image` component by removing the native HTML attributes as props. This sets the props allowed to the list of props declared in their own files.
719
+ - Minor change to the `Notification`'s heading component so it adds a proper id to `NotificationHeading`.
720
+ - Updates the `Heading` component to use the DS `Link` component rather than Chakra's `Link` component.
721
+ - Updates the style of links rendered in the `Heading` component so they are styled as standard links. The only exception is for links used in the `Card` component for the _full-click functionality_ feature. Otherwise, links in `Card` headings are styled as standard links.
722
+ - Updates the `SearchBar` component to now be implemented with the `ComponentWrapper` component.
723
+ - Removes the `ButtonTypes.SearchBar` variant style for the `Button` component. The style object is now set and passed directly to the `Button` component in the `SearchBar` component through the `additionalStyles` prop.
724
+ - Renames `additionalStyles` prop to `additionalWrapperStyles` in the `Image` Component.
725
+ - Updates the label text style in the disabled state of the `Toggle` component.
726
+ - Updates the `Card` component so it gives a bottom margin to the `Image` component when the `imageAspectRatio` prop is set to `ImageRatios.Original`.
727
+ - Updates the `TextInput` component to use a white background for `static`, `error` and `focus` states.
728
+ - Updates `Select` component to use a white background for `static`, `error` and `focus` states.
729
+ - Updates the `Template` component to use `s` (16px) spacing on the left and right sides of the main content area.
730
+ - Updates the `HelperErrorText` component to allow HTML to be passed in as a string or HTML.
731
+ - Updates how the `HelperErrorText` component renders text in the following components: `Checkbox`, `CheckboxGroup`, `ComponentWrapper`, `DatePicker`, `Radio`, `RadioGroup`, `SearchBar`, `Select`, `Slider`, `TextInput`, `Toggle`, `VideoPlayer`.
732
+ - Updates the `HorizontalRule` component to use "100%" as the default value for the `width` prop.
733
+
734
+ ### Fixes
735
+
736
+ - Fixes the styling of custom anchor elements when passed as a child in the `Link` component.
737
+ - Allows the `TemplateAppContainer` and `TemplateFooter` components to use the `renderFooterElement` prop. This is `true` by default so it renders an HTML `footer` element. If a custom footer component that renders its own HTML `<footer>` must be used, then setting `renderFooterElement` to false will not render two nested `footer` elements.
738
+ - Fixes the Storybook `level` prop value for the `Heading` component so it updates the component.
739
+ - Removes wrapper divs around custom image elements used in the `Card` component. Also passes the aspect ratio as `ImageRatios.Original` when the custom image element is passed to the `Card` component.
740
+
741
+ ## 0.25.8 (January 6, 2022)
742
+
743
+ ### Adds
744
+
745
+ - Adds `embedCode` prop to `VideoPlayer` component.
746
+ - Adds export statements for `ProgressIndicatorSizes` and `ProgressIndicatorTypes` enums to `index.ts`.
747
+ - Adds `ExtraSmall` and `ExtraExtraSmall` size variants to the `Image` component.
748
+ - Adds `ExtraSmall` and `ExtraExtraSmall` size variants for `CardImage` in the `Card` component.
749
+ - Adds `AlertNotificationImportant` icon to `Icon` component.
750
+ - Adds `Toggle` component.
751
+ - Adds `xxxs` (2px) spacing option to DS design tokens.
752
+ - Adds `external` variant to `Link` component.
753
+
754
+ ### Changes
755
+
756
+ - Changes category for `Table` component from `Basic Elements` to `Page Layout`.
757
+ - Updates the background color for the `Locations` variant in the `Breadcrumbs` component from `section.locations.secondary` to `section.locations.primary`.
758
+ - Updates the `Notification` component to show the `AlertNotificationImportant` icon for the `Standard` variant.
759
+ - Reduces the bottom margin on labels and legends for form components from "16px" to "8px", or "s" to "sx" in Chakra-theme variables.
760
+ - Updates docs for Chakra `Grid` component to use theme object values rather than CSS variables.
761
+ - Updates the spacing in the `Notification` component to improve the alignment of the icon and text elements.
762
+ - Updates the `Notification` component to optionally display/hide the `Icon` in the heading or content area.
763
+ - Updates the `ComponentWrapper` component to allow the internal `HelperErrorText` component to get set in the invalid state. Also added tests for this component.
764
+
765
+ ### Fixes
766
+
767
+ - Fixes two bugs in the `Slider`: (1) unable to call the `onChange` function when it is not passed, and (2) fixing the default array value for the range slider so it mounts properly.
768
+ - Updates the `Select` component's controlled state so that an initial empty `value` prop is acceptable.
769
+
770
+ ## 0.25.7 (December 20, 2021)
771
+
772
+ ### Fixes
773
+
774
+ - Removes `<=12.22` from node engine in `package.json` to reduce installation issues.
775
+
776
+ ## 0.25.6 (December 16, 2021)
777
+
778
+ ### Adds
779
+
780
+ - Adds export statements for `ProgressIndicator` and `Slider` components to `index.ts`.
781
+ - Adds `Blogs` variant to `Breadcrumbs` component.
782
+ - Adds the `placeholder` prop to the `Select` component.
783
+
784
+ ### Changes
785
+
786
+ - Adds "(Required)" text to the placeholder in the `SearchBar` component when `isRequired` is true.
787
+
788
+ ## 0.25.5 (December 9, 2021)
789
+
790
+ ### Fixes
791
+
792
+ - Updates the Github Action for the Github Pages deployment to use node 12 instead of the default node 16. This caused issues since we now set the node engine to `<=12.22`.
793
+
794
+ ## 0.25.4 (December 9, 2021)
795
+
796
+ ### Adds
797
+
798
+ - Adds the `ProgressIndicator` component.
799
+ - Adds documentation for using `NYPL Design Tokens`.
800
+ - Adds the `ActionHelpDefault`, `ActionHelpOutline` and `ActionLaunch` icons to the `Icon` component.
801
+ - Adds the DS `Slider` component based on the Chakra `Slider` and `RangeSlider` components.
802
+ - Adds the `ButtonTypes.NoBrand` variant to the `Button` component.
803
+ - Adds the `additionalStyles` prop to the `Breadcrumbs` component.
804
+
805
+ ### Changes
806
+
807
+ - Updates the organization of SCSS files by deleting some files and combining others.
808
+ - Updates `@chakra-ui/react` to version 1.7.1 and `@chakra-ui/system` to version 1.8.1.
809
+ - Updates the `TextInput` component to now have `defaultValue` and `step` props.
810
+ - Updates `Latest Version` number for `Image`, `Notification` and `Pagination` components.
811
+ - Removes the Storybook "Knobs" addon.
812
+ - Updates the margin for labels in the `DatePicker` component when it is in the "date range" state.
813
+ - Updates the `DatePicker` component to have proper form spacing when in the "date range" state.
814
+ - Updates the `Tabs` component to comply with linting rules -- no functional or visual changes were made.
815
+ - Removes the `alignText` prop from the `Notification` component. Storybook was incorrectly displaying `alignText` as an available prop.
816
+
817
+ ### Fixes
818
+
819
+ - Exports components and variables that were initially missed when they were added: `ColorVariants`, `Fieldset`, `IconAlign`, `StatusBadgeTypes`,
820
+ - Fixes `SearchBar` by passing necessary props down to its `TextInput` through the `textInputProps` prop.
821
+ - Fixes `DatePicker` component unit tests.
822
+ - Removes the `showLabel` prop from the `SearchBar` component to prevent confusion. Labels for the `Select` and `TextInput` components are never shown but are added through the `aria-label` attribute.
823
+
824
+ ### Breaking Changes
825
+
826
+ - Updates the breakpoint CSS variable names by adding the `--nypl` prefix and the SCSS variables by adding the `$nypl` prefix. Updates references throughout the codebase.
827
+ - Changes the `Button`'s `disabled` prop to `isDisabled`.
828
+ - Updates npm packages in `package.json`. Removes `cpy-cli`, `react-uid`, `react-is`, `stylelint` and related packages, and `ts-loader` (already added through TSDX). Updates other packages such as `sass-loader`, `prettier`, `jest`, `jest-axe`, and the majority of Storybook addon packages.
829
+
830
+ ### Deprecates
831
+
832
+ - Deprecates the `Input` component. The `Input` component will be removed from the NYPL Design System React Library in the first release of January 2022.
833
+ - Deprecates the `CardEdition` component. The `CardEdition` component will be removed from the NYPL Design System React Library in the first release of January 2022.
834
+
835
+ ## 0.25.3 (November 18, 2021)
836
+
837
+ ### Adds
838
+
839
+ - Adds the `ImageRatios`, `ImageSizes`, and `ImageTypes` enums.
840
+ - Composes the DS `Fieldset` component with Chakra. This always renders a `legend` element as its first child but it can be optionally hidden from the screen.
841
+ - Adds the ability to make an entire `Card` component clickable with Chakra's `LinkBox` and `LinkOverlay` components. Links in the `CardActions` component can still be accessed in this state by clicking with the mouse or tabbing and pressing "enter".
842
+ - Adds new file type SVG files to use in the `Icon` component: Audio, Doc, GenericDoc, Image, PDF, Spreadsheet, Video.
843
+ - Adds `ActionCheckCircle` SVG file to use in the `Icon` component.
844
+
845
+ ### Changes
846
+
847
+ - Updates the Github Action for the changelog reminder.
848
+ - Updates the `Checkbox` component with an "indeterminate" state through the `isIndeterminate` prop.
849
+ - Updates the `CheckboxGroup` component story with an "indeterminate" state example.
850
+ - Updates the `CheckboxGroup` and `RadioGroup` components to use the `Fieldset` component.
851
+ - Updates the `HelperErrorText` and `TextInput` components with added `additionalStyles` prop.
852
+ - Updates the `Button` Style Guide documentation.
853
+ - Updates the `Iconography` Style Guide story documentation.
854
+ - Updates the `Button` font weight to "regular".
855
+
856
+ ### Fixes
857
+
858
+ - Fixes nondeterministic unit test in the `DatePicker` component.
859
+ - Version of latest `List` component release in its storybook page.
860
+ - Adds validation to the `height` prop in the `HorizontalRule` so percentage values are not used. If a percentage value is used, the default "2px" value is set.
861
+ - Fixes styling issues for the `Notification` dismissible button.
862
+ - Fixes `SearchBar` mobile styling for the `Select`, `TextInput`, and `Button` components.
863
+ - Fixes `SearchBar` focus flicker when the `Select` component is selected.
864
+
865
+ ### Breaking Changes
866
+
867
+ - Updates the `Notification` component to fix the custom icon alignment.
868
+ - Adds the `title` prop to the `Icon` component to render a `title` HTML element for accessible SVG icons.
869
+ - Updates the default font size of the `Button` component to `"-1"` (14px) for all variants except the `Link` variant. Removes the `bem` function from internal use and makes it clearer that the `ButtonGroup` Chakra component is exported in the Design System.
870
+ - Updates the `errorText` prop to `invalidText` for the `Checkbox` component.
871
+ - Composes the DS `Pagination` component with Chakra. Removes the BEM-related props and updates the `currentPage` prop to `initialPage`. The current selected page is now kept in state inside the `Pagination` component and returned to the user through `getPageHref` or `onPageChange`. This also adds better aria attributes to the list inside the `Pagination` component.
872
+ - Composes the DS `Image` component with Chakra styling and updates all `Image` references in other DS components. The `attributes` prop and the BEM related props `blockname` and `modifiers` have been removed. Adds the following new props: `additionalStyles`, `component`, `imageAspectRatio`, `imageSize`, `imageType`.
873
+ - Composes the DS `Card` component with Chakra. BEM related props `modifiers` and `blockname` have been removed. Replaces the `CardImageRatios` with `ImageRatios`. Removes the `CardImageSizes` enum.
874
+ - Composes the DS `DatePicker` component with Chakra. Adds more tests, documentation, and examples. This component now uses the `Fieldset` component for the date range type, and better `Form` components for layout. Prop name changes: `dateRange` is now `isDateRange` and `required` is now `isRequired`. BEM related props `modifiers` and `blockname` have been removed. The "Required"/"Optional" text in the date range legend can now be hidden with the `showOptReqLabel` prop.
875
+ - Composes the DS `SkeletonLoader` with Chakra's `Skeleton` component. BEM related prop `modifiers` has been removed. Chakra's default `Skeleton` styles have been updated with NYPL's theme.
876
+ - Removes deprecated CSS variables. Now the DS repo only uses the CSS variables exposed by Chakra that contain the `--nypl` prefix.
877
+
878
+ ## 0.25.2 (October 28, 2021)
879
+
880
+ ### Adds
881
+
882
+ - Adds custom `useCarouselStyles` hook for the `Tabs` mobile carousel functionality.
883
+ - Adds custom NYPL-theme radii values to use within Chakra, mostly for border radius values.
884
+ - Adds the `showHelperInvalidText` prop to form components to control displaying or hiding the content in the `HelperErrorText` component.
885
+ - Adds `useNYPLTheme` hook for consuming applications to use NYPL DS values.
886
+ - Adds the DS `ComponentWrapper` helper component for internal use.
887
+ - Adds `useWindowSize` hook for responsive styles and functionality.
888
+ - Adds Chakra Migration Guide for version `0.25.0` and greater.
889
+
890
+ ### Changes
891
+
892
+ - Updates the CSS vars name prefix to use `nypl`.
893
+ - Updates documentation in the README and updates the issue contribution template.
894
+ - Updates the following components to use the `showHelperInvalidText` prop: `Checkbox`, `CheckboxGroup`, `DatePicker`, `Radio`, `RadioGroup`, `SearchBar`, `Select`, `TextInput`, `VideoPlayer`.
895
+
896
+ ### Breaking Changes
897
+
898
+ - Composes the DS `Notification` component with Chakra components. Removes the `NotificationHeading` and `NotificationContent` components as exports and are only used internally in `Notification`. Instead of children component, `Notification` accepts the heading and content values through the `notificationHeading` and `notificationContent` props, respectively.
899
+ - Composes the DS `HelperErrorText` component with Chakra. BEM related props `modifiers` and `blockname` have been removed. The `isError` prop has been renamed to `isInvalid`.
900
+ - Composes the DS `VideoPlayer` component with Chakra. BEM related prop `modifiers` has been removed.
901
+ - Composes the DS `HorizontalRule` component with Chakra. BEM related prop `modifiers` has been removed, as well as the `attributes` prop.
902
+ - Composes the DS `List` component with Chakra. BEM related props `modifiers` and `blockname` have been removed. The `noStyling` prop is now used for the no list style variant style.
903
+
904
+ ## 0.25.1 (October 14, 2021)
905
+
906
+ ### Adds
907
+
908
+ - Updates the `Accordion` component to internally use Chakra components.
909
+ - Adds DS `SimpleGrid` component composed from Chakra's `Simplegrid` component.
910
+ - Adds DS `Text` component composed from Chakra's `Text` component.
911
+ - Update the NYPL Colors with updated color names and values.
912
+ - Composes the DS `TextInput` component from Chakra's `Input` and `Textarea` components.
913
+ - Composes the DS `Select` component from Chakra's `Select` component.
914
+ - Composes the DS `Hero` component from Chakra's component.
915
+ - Composes the DS `CheckboxGroup` component from Chakra's `CheckboxGroup` component.
916
+ - Composes the DS "Template" components (`Template`, `TemplateHeader`, `TemplateBreakout`, `TemplateContent`, `TemplateContentPrimary`, `TemplateContentSidebar`, `TemplateFooter`) from Chakra's `Box` component for page layouts through children components.
917
+ - Composes the DS `TemplateAppContainer` component from Chakra's `Box` component for page layouts through props.
918
+ - Composes the DS `Link` component with Chakra component and fixes the `Button` type.
919
+ - Exports Chakra's `Grid` and `GridItem` components.
920
+ - Composes the DS `Label` component with Chakra component and updates the font size.
921
+ - Composes the DS `StatusBadge` component from Chakra's component.
922
+ - Composes the DS `Forms` component using DS and Chakra components.
923
+ - Composes the DS `Icon` component with Chakra's `Icon` component. Added new props for `Icon` sizing, alignment, name, and rotation.
924
+ - Composes the DS `SearchBar` component from DS `Select`, `TextInput`, `Button`, and `HelperErrorText` components.
925
+ - Composes the DS `Breadcrumbs` component from Chakra's `Breadcumb`, `BreadcrumbItem` and `BreadcrumbLink` components.
926
+
927
+ ### Changes
928
+
929
+ - Updates spacing values to use NYPL spacing rather than "em"s.
930
+ - Updates the `SkeletonLoaderLayouts` enum values from `Horizontal` and `Vertical` to `Row` and `Column`, respectively.
931
+ - Updates the `CardLayouts` enum values from `Horizontal` and `Vertical` to `Row` and `Column`, respectively.
932
+ - Updates font size of the `legend` element used in `CheckboxGroup`, `DatePicker` and `RadioGroup`.
933
+ - Updates the radius values through Chakra's theme object.
934
+
935
+ ## 0.25.0 (September 30, 2021)
936
+
937
+ ### Breaking Changes
938
+
939
+ - Renames `HeadingDisplaySizes.tsx` to `HeadingTypes.tsx`.
940
+
941
+ ### Adds
942
+
943
+ - Integrates Chakra-UI into the codebase.
944
+ - Moved SCSS and CSS variable styles into a custom NYPL theme to extend Chakra's base theme.
945
+ - Adds `DSProvider` component to use the NYPL theme in consuming applications.
946
+ - Exports Chakra's `Box`, `Center`, `Circle`, `Square`, `Stack`, `HStack`, and `VStack` components.
947
+ - Composes the DS `Button` component from Chakra's `Button` component.
948
+ - Composes the DS `Heading` component from Chakra's `Heading` component.
949
+ - Composes the DS `Tabs` component from Chakra's `Tabs`, `TabList`, `Tab`, `TabPanels`, and `TabPanel` components.
950
+ - Composes the DS `Radio` component from Chakra's `Radio` component.
951
+ - Composes the DS `RadioGroup` component from Chakra's `RadioGroup` component.
952
+ - Composes the DS `Checkbox` component from Chakra's `Checkbox` component.
953
+ - Updates the `errorText` prop name to `invalidText`.
954
+
955
+ ### Removes
956
+
957
+ - Removes the `color-classes` SCSS mixin.
958
+
959
+ ### Changes
960
+
961
+ - Updates the development preview URL from the Netlify link to the Tugboat QA link.
962
+
963
+ ## 0.24.1
964
+
965
+ ### Adds
966
+
967
+ - Adds `FormSpacing` enum to DS exports.
968
+ - Adds `utility_account_filled`, `utility_account_unfilled`, `utility_hamburger` and `utility_search` icons to `Icon` component.
969
+
970
+ ### Changes
971
+
972
+ - Updates `General Guidelines` for `Buttons Style Guide`.
973
+
974
+ ### Fixes
975
+
976
+ - Fixes left padding on `Card` when `imageAtEnd` and `border` are both `true`.
977
+
978
+ ## 0.24.0
979
+
980
+ ### Breaking Changes
981
+
982
+ - Renames original `Card` components to be `CardEdition`.
983
+
984
+ ### Adds
985
+
986
+ - Adds the `DatePicker` component.
987
+ - Adds new `Card` component.
988
+ - Adds `spacing` prop to `Form` component to allow for spacing variations.
989
+ - Adds Style Guide `Forms`
990
+
991
+ ### Changes
992
+
993
+ - Exports `VideoPlayerAspectRatios`.
994
+ - Adds additional props for the `DatePicker` component based on its TAD Addendum section.
995
+ - Adds Tugboat QA configuration for PR preview deployments to replace Netlify.
996
+ - Updates the `DatePicker`, `TextInput`, `Select`, and `Label` components to pass an optional `showOptReqLabel` prop to conditionally render "Required"/"Optional" in the label text.
997
+
998
+ ### Fixes
999
+
1000
+ - Fixes Accordion FAQ Storybook example rendering bug.
1001
+
1002
+ ## 0.23.4
1003
+
1004
+ ### Adds
1005
+
1006
+ - Adds TSDX as the bootstrapping tool to add opinionated configurations.
1007
+ - Adds an `/example/` directory through TSDX with an small playground app.
1008
+ - Snapshot testing through `react-test-renderer` and Jest.
1009
+ - Typescript documentation file to be use as a development guide.
1010
+ - Typescript documentation for `enum` variables in the TYPESCRIPT file.
1011
+ - Adds `SkeletonLoaderLayouts` and `SkeletonLoaderImageRatios` enums to DS exports.
1012
+ - Adds heading, description and helper text to `VideoPlayer` component.
1013
+ - Adds `@storybook/addons-jest` plugin to display Jest/React Testing Library unit tests in a Storybook tab.
1014
+
1015
+ ### Changes
1016
+
1017
+ - Updates Style Guide `Spacing`.
1018
+ - Updates `Hero` component to include `Campaign` variant.
1019
+ - Updates `Hero` stories to use MDX format.
1020
+ - Updated warnings for too few or too many option children for the `Select` component.
1021
+ - Updates the README to include information on the production, development, and "preview" Storybook documentation instances.
1022
+ - Removes a custom SCSS breakpoint in `_Breadcrumbs.scss` in favor of mobile-first style rules.
1023
+ - Replaces Mocha, Chai, Sinon, and Enzyme for Jest and React Testing Library for unit testing.
1024
+ - Replaces webpack with rollup through TSDX.
1025
+ - Updates npm scripts to use TSDX for internal commands.
1026
+ - Replaces lodash with own functions.
1027
+ - Minor updates to Github Actions.
1028
+ - Adds PostCSS/autoprefixer to Rollup workflow instead of the default scss minifier.
1029
+
1030
+ ### Fixes
1031
+
1032
+ - Fixes the `bem` utility function so that it doesn't crash Storybook whenever the `modifiers` Controls prop option is empty.
1033
+
1034
+ ## 0.23.3
1035
+
1036
+ ### Fixes
1037
+
1038
+ - Removes the `storybook-static` directory from `.gitignore` so that the Github Actions deploy job can work properly.
1039
+
1040
+ ## 0.23.2
1041
+
1042
+ ### Adds
1043
+
1044
+ - Adds `Form` component.
1045
+ - Adds `Notification` component.
1046
+ - Adds Style Guide `Buttons`.
1047
+ - Adds `VideoPlayer` component.
1048
+ - Adds the ability to render a `textarea` element from the `TextInput` component.
1049
+
1050
+ ### Changes
1051
+
1052
+ - Updates stories for the `List` component to use MDX format.
1053
+ - Updates stories for the `Pagination` component to use MDX format.
1054
+ - Updates how children are rendered in the `List` component. Direct children `li`, `dt`, and `dd` elements can still be passed, but specific data structures can be passed to the `listItems` prop to render the appropriate children element.
1055
+ - Updates to the contributing documentation, pull request template, and the README.
1056
+ - Changes `DisplaySizes` to `HeadingDisplaySizes`.
1057
+ - Changes `Skeleton Loader` to be configurable via props.
1058
+ - Changes `Button` to use `16px` for left/right padding for buttons with text; icon only buttons still use `8px` left/right padding.
1059
+ - Changes `TextInput` label text to `font-weight: 500`.
1060
+
1061
+ ## 0.23.1
1062
+
1063
+ ### Adds
1064
+
1065
+ - Adds CSS vars for `font-weight`
1066
+ - Adds `displaySize` prop to `Heading`
1067
+ - Adds Style Guide `Iconography`
1068
+ - Adds new SVGs to be used with the `Icon` component. Among the new SVGs are: Error solid, Error outlined, Speaker Notes.
1069
+ - Adds ability to change the color of an SVG icon with classes such as: `ui-black` (default), `ui-white`, `brand-primary` (red), `section-research-secondary` (turquoise).
1070
+ - Adds `helperText` and `errorText` props to `Checkbox`
1071
+ - Adds `helperText` and `errorText` props to `Radio`
1072
+ - Adds `errorText`, `helperText`, `labelText`, `required` and `showLabel` props to `Select`
1073
+
1074
+ ### Changes
1075
+
1076
+ - Updates content in Style Guide `Typography`
1077
+ - Updates content in Style Guide `Breakpoints`
1078
+ - Changes `Link` story from `.tsx` to `.mdx`.
1079
+
1080
+ ### Deprecates
1081
+
1082
+ - Deprecates `ariaLabel`, `helperTextId`, `isRequired` and `labelId` props in `Select`
1083
+
1084
+ ## 0.23.0
1085
+
1086
+ ### Breaking Changes
1087
+
1088
+ - Removes `breakout` CSS from `Breadcrumbs`. To retain previous behavior, `Breadcrumbs` component should be a child of a `.content-header` element.
1089
+ - Removes `breakout` CSS from `Hero Secondary`. To retain previous behavior, `Hero` component should be a child of a `.content-header` element.
1090
+
1091
+ ### Adds
1092
+
1093
+ - Adds `HorizontalRule` component
1094
+ - Adds new `short` class for `Placeholder`
1095
+ - Adds `Style Guide` category to Storybook sidebar
1096
+
1097
+ ### Changes
1098
+
1099
+ - Changes `Breadcrumbs` story from `.tsx` to `.mdx`
1100
+ - Changes `Heading` story from `.tsx` to `.mdx`
1101
+ - Changes suggested DOM structure in `Template` Story
1102
+
1103
+ ## 0.22.2
1104
+
1105
+ ### Changes
1106
+
1107
+ - Adds documentation on layout bidirectionality
1108
+ - Changes `Pagination` to hide pagination UI when there are 0 or 1 pages.
1109
+
1110
+ ## 0.22.1
1111
+
1112
+ ### Changes
1113
+
1114
+ - Removes `color-classes` and `css-vars` mixins from `_03-mixins.scss`
1115
+ - Adds `color-classes` and `css-vars` mixins to `styles.scss`
1116
+ - Changes order of CSS `@import` rules in `styles.scss`
1117
+ - Adds quotes around `black` and `white` in `$colors` object in `_colors-utility.scss`
1118
+
1119
+ ## 0.22.0
1120
+
1121
+ ### Breaking Changes
1122
+
1123
+ - Removes `--ui-success` CSS variable and adds `--ui-success-primary` and `--ui-success-secondary`
1124
+ - Removes `checkboxId` prop from `Checkbox` component and employs `id` in its place.
1125
+ - Removes `defaultChecked` prop from `Checkbox` component.
1126
+ - Removed `labelOptions` prop from `Checkbox` component and employs `labelText` in its place.
1127
+
1128
+ ### Changes
1129
+
1130
+ - Added: Definition List component.
1131
+ - Changed: Separate Checkbox into its own component.
1132
+ - Changed: Separate Radio button into its own component.
1133
+ - Adds `Tertiary` state to Hero component
1134
+ - Changes `Brand` and `Utility` color values to match Figma main file
1135
+ - Changes `Radio` styles to use SASS vars in place of CSS vars
1136
+ - Adds `TextInput` component to handle email, hidden, number, password, text, textarea, tel and url input types
1137
+ - Adds default width and padding to `StatusBadge` component.
1138
+ - Hides pagination when there are 0 or 1 pages.
1139
+
1140
+ ### BugFixes
1141
+
1142
+ - Fixed layout bug for layouts that include a right sidebar column and DOM structure.
1143
+
1144
+ ## 0.21.2
1145
+
1146
+ ### Changes
1147
+
1148
+ - Adds `getPageHref` to `Pagination`
1149
+
1150
+ ## 0.21.1
1151
+
1152
+ ### Changes
1153
+
1154
+ - `Accordion`: Adds `fixed-height` modifier and `defaultOpen` prop
1155
+ - `List` defaults to grey bullets instead of black
1156
+ - Adds margins inside the default columns of `Card`
1157
+
1158
+ ### BugFixes
1159
+
1160
+ - Breadcrumbs now show up in light colours
1161
+ - Template reflow and breakpoints now happen at the same time
1162
+ - Fixes release github action
1163
+
1164
+ ## 0.21.0
1165
+
1166
+ ### Breaking Changes
1167
+
1168
+ - Removes `statusBadgeText` prop in StatusBadge to allow text to be inside component
1169
+
1170
+ ### Changes
1171
+
1172
+ - Add `method` and `action` to `SearchBar` `<form>`
1173
+
1174
+ ### Bugfixes
1175
+
1176
+ - Add the `attributes` property to the `SearchBar` `<form>`
1177
+ - Adds focus outline to the `Accordion` component so it appears when it is tabbed.
1178
+
1179
+ ## 0.20.2
1180
+
1181
+ ### Changes
1182
+
1183
+ - Exports mixins in a `resources.scss` file that can be used by consumers.
1184
+
1185
+ ### Bugfixes
1186
+
1187
+ - `Link` with class `button` has white text color
1188
+
1189
+ ## 0.20.1
1190
+
1191
+ ### Bugfixes
1192
+
1193
+ - Fixes `Pagination` when there are fewer than 4 pages
1194
+ - Adds `StatusBadge` component to `design-system-react-components` package
1195
+
1196
+ ## 0.20.0
1197
+
1198
+ ### Changes
1199
+
1200
+ - `Select`: selectedOption holds the selected value, instead of just the default.
1201
+ - `Hero`: `Hero.Secondary` now changes background color based on NYPL site section
1202
+ - `Hero`: All props are now optional
1203
+ - `Input`: added onChange prop to explicitly allow it to be used as a controlled component
1204
+ - Uses stricter linters and more Prettier configs.
1205
+
1206
+ ### Breaking Changes
1207
+
1208
+ - Removed `SectionTitle`
1209
+ - Scopes all element selects to the `.nypl-ds` class
1210
+
1211
+ ## 0.19.1
1212
+
1213
+ ### Breaking Changes
1214
+
1215
+ - Accordion: Accordion input styling affects only direct children
1216
+ - Checkbox: Allows checkbox to be used as a controlled component or uncontrolled component.
1217
+
1218
+ ## 0.19.0
1219
+
1220
+ ### Breaking Changes
1221
+
1222
+ - Updates `Pagination` component to match new design.
1223
+
1224
+ ## 0.18.7
1225
+
1226
+ ### Changes
1227
+
1228
+ - Adds actual `StatusBadge` component with props for setting levels [RENO-1882](https://jira.nypl.org/browse/RENO-1882)
1229
+
1230
+ ## 0.18.6
1231
+
1232
+ ### Changes
1233
+
1234
+ - Updates `Hero`'s primary option to have a larger top/bottom padding on the inner content via [Reno-1670](https://jira.nypl.org/browse/RENO-1670)
1235
+
1236
+ ## 0.18.5
1237
+
1238
+ ### Changes
1239
+
1240
+ - Converts the Accordion component to open and close through CSS rather than through Javascript.
1241
+
1242
+ ## 0.18.4
1243
+
1244
+ ### Changes
1245
+
1246
+ - Updates the `Input` component to conditionally render an `id` attribute if an `id` prop value is passed to it.
1247
+
1248
+ ## 0.18.3
1249
+
1250
+ ### Changes
1251
+
1252
+ - Add `overflow: hidden` to `.no-scroll` styling on `<body>` for modal to prevent scroll element for content behind modal being displayed
1253
+
1254
+ ## 0.18.2
1255
+
1256
+ ### Changes
1257
+
1258
+ - Updates Accordion sets so that first item in list doesn't have `-1px` top margin
1259
+
1260
+ ## 0.18.1
1261
+
1262
+ ### Breaking Changes
1263
+
1264
+ - For `Input` components that use the `.input-group` class, on mobile those input elements are now stacked on top of each other rather than side-to-side.
1265
+
1266
+ ### Updates
1267
+
1268
+ - Updates the `Input` component to allow it to render a "hidden" input type.
1269
+
1270
+ ## 0.18.0
1271
+
1272
+ ### Breaking Changes
1273
+
1274
+ - Removes type, color, and line-height declarations from `body` tags and moves them to the `.nypl-ds` namespace
1275
+
1276
+ ## 0.17.4
1277
+
1278
+ ### Changes
1279
+
1280
+ - Moves footer outside of `.nypl-ds` namespace on Template story
1281
+
1282
+ ## 0.17.3
1283
+
1284
+ ### Adds
1285
+
1286
+ - `SkeletonLoader` component for loading screens
1287
+
1288
+ ## 0.17.2
1289
+
1290
+ ### Adds
1291
+
1292
+ - `selectedOption` to `Pagination` story
1293
+
1294
+ ## 0.17.1
1295
+
1296
+ ### Adds
1297
+
1298
+ - `FiftyFifty` Hero type styling
1299
+
1300
+ ## 0.17.0
1301
+
1302
+ ### Breaking Changes
1303
+
1304
+ - Sets up the default `font-size` value in the `.nypl-ds` namespace.
1305
+
1306
+ ## 0.16.1
1307
+
1308
+ ### Adds
1309
+
1310
+ - Styling for `Accordion` sets
1311
+
1312
+ ### Changes
1313
+
1314
+ - `className`s within `Accordion` for content
1315
+ - Hover stylings for `Accordion`
1316
+
1317
+ ## 0.16.0
1318
+
1319
+ ### Breaking Changes
1320
+
1321
+ - Removes the padding on the `breakout` mixin
1322
+ - Removes the padding on the `wrapper` mixin at the `xl` breakpoint
1323
+
1324
+ ## 0.15.1
1325
+
1326
+ ### Removes
1327
+
1328
+ - `arrow_xsmall` and `search_small` icons
1329
+
1330
+ ## 0.15.0
1331
+
1332
+ ### Breaking Changes
1333
+
1334
+ - Fixes a bug in which content was not centered within `Button` when button was made larger than the text content
1335
+
1336
+ ### Removes
1337
+
1338
+ - Additional `Button` CSS that was no longer used after Button API refactor in 0.13.0
1339
+ - Deprecates `SearchResultItem`
1340
+
1341
+ ## 0.14.0
1342
+
1343
+ ### Breaking Changes
1344
+
1345
+ - `Image` now has an `alt` prop instead of an `altText` prop
1346
+ - Removes `isDecorative` property in favor of an empty `alt`
1347
+
1348
+ ### Adds
1349
+
1350
+ - Adds HTML `<img>` props to the `Image` component
1351
+
1352
+ ## 0.13.0
1353
+
1354
+ ### Breaking Changes
1355
+
1356
+ - Removes all icon props from `Button`. Button now uses `Icon` as a child
1357
+ - Removes `ButtonIconPositions`
1358
+
1359
+ ### Changes
1360
+
1361
+ - Makes `Button`'s `onClick` property optional
1362
+
1363
+ ## 0.12.0
1364
+
1365
+ ### Breaking Changes
1366
+
1367
+ - Moves box-sizing declarations to a `.nypl-ds` namespace. All future "global" CSS settings will move to exist under this namespace.
1368
+
1369
+ ### Adds
1370
+
1371
+ - Universal focus styling
1372
+
1373
+ ## 0.11.5
1374
+
1375
+ ### Changes
1376
+
1377
+ - Updates the margin on action-links from `xxs` to `xs`
1378
+
1379
+ ## 0.11.4
1380
+
1381
+ ### Changes
1382
+
1383
+ - Removes the `description` tag from the `<span>` element wrapping svg icons (#360)
1384
+
1385
+ ## 0.11.3
1386
+
1387
+ ### Changes
1388
+
1389
+ - `Icon` now accepts children for custom icons
1390
+
1391
+ ## 0.11.2
1392
+
1393
+ ### Adds
1394
+
1395
+ - Status Badge component as stories
1396
+
1397
+ ## 0.11.1
1398
+
1399
+ ### Changes
1400
+
1401
+ - DS bundle is now compiled for es5 instead of es6 to accommodate for IE11 and the arrow functions we're using in DS
1402
+
1403
+ ## 0.11.0
1404
+
1405
+ ## Breaking Changes
1406
+
1407
+ - Removes options from the `Pagination` component
1408
+
1409
+ ## 0.10.4
1410
+
1411
+ ### Changes
1412
+
1413
+ - Updates the `Link` component's `linkType` prop to `type`, implements `React.forwardRef` to use with other libraries, and updates the stories.
1414
+
1415
+ ## 0.10.3
1416
+
1417
+ ### Changes
1418
+
1419
+ - Updates the `Icon` component's `name` prop to allow for `LogoNames` enum types.
1420
+
1421
+ ### Adds
1422
+
1423
+ - Adds a "negative" NYPL logo to be used on non-white backgrounds.
1424
+
1425
+ ## 0.10.2
1426
+
1427
+ ### Changes
1428
+
1429
+ - Updates the formatting of svg file names to use underscores
1430
+
1431
+ ## 0.10.1
1432
+
1433
+ ### Changes
1434
+
1435
+ - Updates the `Input` element to allow props and attributes to be able to render input elements of type "radio".
1436
+
1437
+ ## 0.10.0
1438
+
1439
+ ### Removes
1440
+
1441
+ - Deprecates `SectionName` in favor of the stories under `Colors—Brand`
1442
+
1443
+ ## 0.9.3
1444
+
1445
+ ### Adds
1446
+
1447
+ - SVGs for NYPL full logo lockup, Queens Public Library Logo, and Brooklyn Public Library Logo
1448
+
1449
+ ## 0.9.2
1450
+
1451
+ ### Adds
1452
+
1453
+ - CSS to style [React Autosuggest](https://github.com/moroshko/react-autosuggest/)
1454
+
1455
+ ## 0.9.1
1456
+
1457
+ ### Changes
1458
+
1459
+ - `Breadcrumbs`'s background color now reflects the app's globally applied section modifier, such as `.nypl--locations`. It recognizes these for `--locations`, `--whats-on`, `--research`, and `--books-and-more`.
1460
+
1461
+ ## 0.9.0
1462
+
1463
+ ### Breaking Changes
1464
+
1465
+ - Removes `$color-spotlight`, `$color-your-interests`, `$color-support`, and `$color-help`
1466
+ - Removes all `$nypl-` prefixed Sass variables
1467
+ - `$color-success` is now `--ui-success`.
1468
+ - Breakpoint variables are now prefixed with `breakpoint`.
1469
+ - Type sizing variables are now prefixed with `font-size`.
1470
+ - Typeface variables are now prefixed with `typeface`.
1471
+ - Removes `--font-size-1p5`, which was originally added as certain designs call out `20px` for headings and others at `18px`. Figma documentation refers to `18px` only as of [0.1.1](https://www.figma.com/file/qShodlfNCJHb8n03IFyApM/Master?node-id=10975%3A16).
1472
+
1473
+ ### Adds
1474
+
1475
+ - Exposes color and typography constants as CSS variables
1476
+ - Adds Section colors for `--section-research-library-lpa`, `--section-research-library-schomburg`, and `--section-research-library-schwartzman`
1477
+
1478
+ ### Removes
1479
+
1480
+ - Letterspacing property on all body copy
1481
+
1482
+ ## 0.8.0
1483
+
1484
+ ### Removes
1485
+
1486
+ - `width: 100%` on svgs
1487
+
1488
+ ## 0.7.2
1489
+
1490
+ ### Adds
1491
+
1492
+ - Adds icons for `accessibility_full`, `accessibility_partial`, `clock`, `check`, and `close`
1493
+
1494
+ ### Changes
1495
+
1496
+ - Updates the `download` icon to Google Material Design's icon.
1497
+
1498
+ ## 0.7.1
1499
+
1500
+ ### Changes
1501
+
1502
+ - Updated the Select component to take in a ref using ForwardRef and also a `name` prop.
1503
+
1504
+ ## 0.7.0
1505
+
1506
+ ### Breaking Changes
1507
+
1508
+ - `FormDropDown` and `Dropdown` are now `Select`
1509
+ - `Textfield` has been retired in favor of `Input`
1510
+ - `Input` type is now controlled via an enum defined in `InputTypes` instead of a string
1511
+ - Changes `referenceId` to `htmlFor` on `Label`
1512
+ - Deprecates `DateRangeForm`, `BodyText`, `SearchPromo`, `Container`, and `RNHeaderWithSearch`
1513
+ - `Button` now accepts an `onClick` instead of a `callback`
1514
+ - In the `ButtonTypes` enum, `Filled` and `Outline` have been changed to `Primary` and `Secondary`, respectively
1515
+ - `Accordion` now accepts `accordionLabel` and `labelId` instead of `buttonOpts` properties
1516
+ - Removes project-specific styles for now deprecated `EditionCard`
1517
+ - Removes project-specific styles of `.search-results-list` and `.form-item--radios`
1518
+ - `UnorderedList` is now `List`, with an enum to control whether is it ordered or unordered
1519
+ - `Input` `id` is no longer prepended with `input-`
1520
+ - `Button` `id` is no longer prepended with `btn-`
1521
+ - `SearchBar` no longer has props for `selectChangeHandler`, `selectBlurHandler`, or `searchChangeHandler`.
1522
+ - `Input` offers `ariaLabel` and `ariaLabelledby` props in favor of `labelId` and `helperTextId`
1523
+ - Removes `headingAttributes?: {}` from `SectionTitle`
1524
+
1525
+ ### Adds
1526
+
1527
+ - Adds `aria-live` and `aria-atomic` to `HelperErrorText` in its errored state
1528
+ - Adds "Optional", "Required", or empty string inside `Label` for forms
1529
+ - Adds `IconNames` enum to make `allSVGs` array globally accessible
1530
+ - Adds `width: 100%` globally to SVGs
1531
+ - `Card` now constrains items in its `image` column to the column width
1532
+ - Adds the `forwardRef` implementation to the `Input` component
1533
+ - Adds `disabled` prop to `Input` and `Button` components
1534
+ - Adds `disabled` styling to `Button.Primary`
1535
+ - Adds `className?: string;` as additional props to all components
1536
+ - Adds `attributes?: { [key: string]: string }; ` to `Input`, `Button`, `Select`, `Link`, and `Image`
1537
+ - Adds `justify-content: center` for `Button` with icon to adjust for mobile
1538
+
1539
+ ### Changes
1540
+
1541
+ - Fixes bug in former `FormDropdown` (now `Select`) where the select value would not change if `selectedOption` were passed
1542
+ - `Link`'s scss now references `$ui-link-primary` instead of `$nypl-blue-regular`
1543
+ - Changes `Select`'s SCSS to use the updated styling from Filament Group
1544
+ - `Image` is wrapped in `figure` when `imageCaption` or `imageCredit` is passed to `Image`
1545
+ - Adds `viewport` properties to any SVG files that were missing it
1546
+
1547
+ ### Removes
1548
+
1549
+ - Removes `HelperErrorTextOptions`
1550
+
1551
+ ## 0.6.0
1552
+
1553
+ ### Breaking Changes
1554
+
1555
+ - Removes `RNSectionTitle`
1556
+
1557
+ ### Changes
1558
+
1559
+ - Updates `$nypl-blue-regular` from #0071ce to #0576d3
1560
+ - `$nypl-blue-regular` is now extended with `$ui-link-primary`
1561
+
1562
+ ## [0.5.0]
1563
+
1564
+ ### Breaking Changes
1565
+
1566
+ - `EditionCard` is now `Card`
1567
+ - Buttons from black by default to blue
1568
+
1569
+ ### Adds
1570
+
1571
+ - Icon for audiobook
1572
+ - Changes the line-height values on some of the heading mixins
1573
+
1574
+ ## [0.4.1]
1575
+
1576
+ ### Changes
1577
+
1578
+ - Makes all IDs optional
1579
+
1580
+ ## [0.4.0]
1581
+
1582
+ ### Breaking Changes
1583
+
1584
+ - Concatenates `BasicLink`, `UnderlineLink`, and `IconLink` into `Link` with `LinkTypes` enum
1585
+ - Moves styles into their corresponding component folders
1586
+ - Moves base styles into the react-components package
1587
+ - Deprecates `@nypl/design-system-styles`
1588
+
1589
+ ### Changes
1590
+
1591
+ - Moves tests into their corresponding component folders
1592
+ - Flattens component structure to export as one package.
1593
+ - Exports `Icon`
1594
+
1595
+ ## [0.3.7]
1596
+
1597
+ - Fixed `dist` script so it clears the folder
1598
+ - Added `viewBox` to `arrow` icon
1599
+
1600
+ ## [0.3.6]
1601
+
1602
+ - added `Template` stories
1603
+ - fixed `Accordion` buttons
1604
+ - added `viewBox` to `arrow-xsmall` icon
1605
+
1606
+ ## [0.3.5]
1607
+
1608
+ - Move `Placeholder`, `Modal`, `SectionName` and `Container` from `/00-base` into top-level `/components`
1609
+ - Fix Storybook errors for Headings with Bold and Headings with Link.
1610
+ - Move `Headings/*` from `/02-molecules` into top-level `/components`
1611
+ - Inlined icons inside `react-components`
1612
+ - No longer publishing `@nypl/design-system-icons` package
1613
+
1614
+ ## [0.3.4]
1615
+
1616
+ - Exported `searchValue` and `selectedField` in `RNHeaderWithSearch`
1617
+
1618
+ ## [0.3.3]
1619
+
1620
+ - Added `blockName` handling to `DateRangeForm`
1621
+
1622
+ ## [0.3.1]
1623
+
1624
+ - Exports `SectionName` and `Image`
1625
+
1626
+ ## [0.3.0]
1627
+
1628
+ ### Breaking Changes
1629
+
1630
+ - Edition Card no longer accepts strings for links and descriptions
1631
+
1632
+ ### Changed
1633
+
1634
+ - Added `iconName` as an optional prop in `IconLink`
1635
+
1636
+ ## [0.2.1] - 2020-04-23
1637
+
1638
+ ### Removed
1639
+
1640
+ - `HeaderWithImageRight` component and corresponding story
1641
+
1642
+ ## [0.2.0] - 2020-04-13
1643
+
1644
+ ### Changed
1645
+
1646
+ - Reworks `HeaderWithImageRight` into `Hero`, which accepts values from an enum to display different kinds of heros based on [this documentation page](https://www.figma.com/file/qShodlfNCJHb8n03IFyApM/Master?node-id=10968%3A5314)
1647
+
1648
+ ## [0.1.1]
1649
+
1650
+ ### Changed
1651
+
1652
+ - `Textfield` id is no longer duplicated
1653
+ - `Dropdown` now applies `bem` `blockName`
1654
+ - `Pagination` now passes in `blockName` into `Dropdown`
1655
+
1656
+ ## [0.1.0]
1657
+
1658
+ ### Breaking Changes
1659
+
1660
+ - Large classes now have `Opts` inteface that allows for the component to be built over multiple steps. This affects:
1661
+ - `HelperErrorText`
1662
+ - `Label`
1663
+ - `TextField`
1664
+ - `Button`
1665
+ - Deprecated `SearchResultsList`, `IconLinkList` and `EditionsList` in favor of `UnorderedList`
1666
+ - `type` in `Button` now corresponds to html button types. `buttonType` in button corresponds to the visual categories of buttons (eg: `filled`, `outline`)
1667
+ - `subtitle` in `SearchResultsItem` changed to `subtitleContent` to take a JSX
1668
+ - `Label` and `Button` only accept children when called directly
1669
+
1670
+ ### Added:
1671
+
1672
+ - `Checkbox`
1673
+ - `DateRangeForm`
1674
+ - `Input`
1675
+ - `Accordion`
1676
+ - `UnorderedList`
1677
+ - # `Modal`
1678
+
1679
+ ## [0.0.17] - 2020-03-17
1680
+
1681
+ - Changelog update
1682
+
1683
+ ## [0.0.16]
1684
+
1685
+ - `HeaderImgRight` accepts elements
1686
+
1687
+ ## [0.0.15] - 2020-03-3
1688
+
1689
+ ### Changed
1690
+
1691
+ - `Button` component accepts content to render from its `content` prop or its `children` prop.
1692
+
1693
+ ## [0.0.14] - 2020-02-18
1694
+
1695
+ ### Changed
1696
+
1697
+ - `EditionCard` `EditionInfo` fields accept elements
1698
+ - `EditionCard` `ReadOnline` and `Download` fields accept elements
1699
+
1700
+ ### [0.0.14] - 2020-02-18
1701
+
1702
+ - added `noLinkElement` to `EditionCard` to receive an element
1703
+
1704
+ ## [0.0.11] — 2020-01-23
1705
+
1706
+ ### Added
1707
+
1708
+ - `EditionsList`
1709
+
1710
+ ## [0.0.10] - 2020-01-14
1711
+
1712
+ ### Added
1713
+
1714
+ - `Dropdown` which controls `FormDropdown` and its corresponding `Label`
1715
+ - `Label`
1716
+ - `HelperErrorText`
1717
+ - `Pagination`
1718
+ - `EditionCard` component
1719
+ - `SearchResultItem` component that uses `EditionCard`
1720
+ - `RN Header With Search`
1721
+ - a story for `RN Section Title`, which is just a collection of styles
1722
+ - `SearchResultsList` component
1723
+
1724
+ ### Changed
1725
+
1726
+ - added `iconModifiers` to `Button`
1727
+ - `buttonId` in `Button` is now required
1728
+ - refactored `FormDropdown` to not include its own `label`
1729
+ - `RN Header With Search`
1730
+ - a story for `RN Section Title`, which is just a collection of styles
1731
+ - `Link` -> `BasicLink` for clarity
1732
+ - Bugfixes in `UnderlineLink` and `IconLink`
1733
+ - Added stories for `BasicLink`
1734
+ - `Link` missing URL error message
1735
+ - Consolidated `Heading` and `PageTitle`
1736
+ - `Heading` now only takes a single span
1737
+ - Added ResearchNow specific `SearchBar` error state
1738
+ - A11Y changes for `SearchBar` and `HeaderWithSearch`
1739
+ - Added stories for AT-79, AT-264 and AT-3
1740
+ - `selectedOption` added to `FormDropdown` stores selected state
1741
+
1742
+ ## [0.0.7] - 2020-01-03
1743
+
1744
+ ### Added
1745
+
1746
+ - A webpack file in order to build and distribute a compiled version of the react components. Does not replace the /lib folder usage, but the main file is now pointing to `/dist/design-system-react-components.min.js`.
1747
+
1748
+ ## [0.0.6] - 2019-12-31
1749
+
1750
+ ### Added
1751
+
1752
+ - `Image` for 2:1 ratio
1753
+ - `PageTitle`
1754
+ - `Header with Image Right`
1755
+ - `FormDropdown`
1756
+ - `SearchPromo`
1757
+
1758
+ ### Changed
1759
+
1760
+ - Moved heading-related atoms from `01-atoms/Text` into `01-atoms/Text/Heading`
1761
+ - Updated `Searchbar` component to include Parameters
1762
+ - Changed `Breadcrumb` export from `Breadcrumbs`
1763
+
1764
+ ## [0.0.5] - 2019-12-06
1765
+
1766
+ ### Changed
1767
+
1768
+ - `Icon` import
1769
+
1770
+ ## [0.0.4] - 2019-12-06
1771
+
1772
+ ### Added
1773
+
1774
+ - `Body text` component for plain-text elements
1775
+ - `UnderlineLink` and `IconLink` for links
1776
+ - `Icon` component that uses the `design-system-icons` package.
1777
+ - `SectionTitle` and `Heading` for heading components
1778
+ - `IconLink-List`for the list of subject links
1779
+ - `Button` and `TextField` for the searchbar
1780
+ - `SearchBar` component
1781
+
1782
+ ### Changed
1783
+
1784
+ - `Breadcrumb` now shows icon in mobile view
1785
+
1786
+ ## [0.0.3] - 2019-11-15
1787
+
1788
+ ### Changed
1789
+
1790
+ - Changed `Breadcrumb` to `Breadcrumbs` to match Twig
1791
+ - Changed the Breadcrumbs props to accept components
1792
+
1793
+ ## [0.0.2] - 2019-11-13
1794
+
1795
+ ### Added
1796
+
1797
+ - Started a change log
1798
+ - Added the Breadcrumb React Component
1799
+
1800
+ ### Changed
1801
+
1802
+ - Changed folder structure to match Twig
1803
+
1804
+ ## [0.0.1] - 2019-11-13
1805
+
1806
+ - Published as a test