@royaloperahouse/chord 1.7.0 → 1.7.1-a-chord-development

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 CHANGED
@@ -1,5 +1,11 @@
1
1
  # CHANGELOG
2
2
 
3
+ ## [1.7.1]
4
+ - Add imageAltText to Card component
5
+
6
+ ## [1.7.0-b] DEVELOPMENT
7
+ - SearchBar: Disable input and fix overflow
8
+
3
9
  ## [1.7.0]
4
10
  - Add Content Summary Section and individual Content Summaries
5
11
 
package/README.md CHANGED
@@ -1,67 +1,275 @@
1
- # Royal Opera House - chord
1
+ # Royal Opera House Chord - Front End Design System
2
2
 
3
- Welcome to the Royal Opera House library components `@royaloperahouse/chord`.
3
+ Welcome to the Royal Opera House Front End Design System, `@royaloperahouse/chord`
4
4
 
5
5
  This package is a library of UI components intended to be used in the ROH website.
6
6
 
7
+ It uses React, TypeScript, TSDX and Storybook.
7
8
 
8
- ## Install
9
+ The NPM packages are published at [https://www.npmjs.com/package/@royaloperahouse/chord](https://www.npmjs.com/package/@royaloperahouse/chord)
10
+
11
+ The Storybook for the latest version of the library is hosted at [chord.roh.org.uk](chord.roh.org.uk)
12
+
13
+
14
+ ## Prerequisites
15
+ ---
16
+
17
+ * Make sure the required package dependencies are installed using `yarn install`
18
+
19
+ * **To deploy the storybook publicly** you will need credentials for the **parent** 'Royal Opera House' AWS account in your `~/.aws/credentials` file.
20
+ * The deploy script expects these to be called `[parent]`.
21
+
22
+ * You can find these values at:
23
+
24
+ *AWS 'Your Applications' page -> 'Royal Opera House' -> 'Developer Access' -> 'Command line or programmatic access'*
25
+
26
+ * **To deploy a preview** for demo / QA you will need the `CHROMATIC_PROJECT_TOKEN` -- find this in 1Password
27
+
28
+
29
+ * **To publish the NPM package** you will need the ROH `NPM_TOKEN` -- find this in 1Password
30
+
31
+
32
+ ## Versioning
33
+ ---
34
+
35
+ We use [Semantic Versioning](https://semver.org/) for Chord.
36
+
37
+ Given a version number MAJOR.MINOR.PATCH, increment the:
38
+
39
+ * MAJOR version when you make incompatible library changes
40
+ * MINOR version when you add functionality in a backwards compatible manner
41
+ * PATCH version when you make backwards compatible bug fixes
42
+
43
+ When you create a new release always update the `CHANGELOG` and `package.json`
44
+
45
+ Increment your version from the latest stable version on `chord-releases`
46
+
47
+
48
+ ## Deploying the Storybook
49
+ ---
50
+
51
+ ### **1. To build and deploy locally**
52
+
53
+ You can quickly build and serve the contents of `/storybook-static` from your local machine, for development and manual testing. To do this run:
9
54
 
10
55
  ```bash
11
- npm i --save @royaloperahouse/chord
56
+ yarn storybook
12
57
  ```
58
+
59
+ By default the storybook will be accessible at
60
+ [http://localhost:6006/]()
61
+
62
+ The server will hot-reload on most changes.
63
+
64
+ ### **2. To deploy a preview version remotely**
65
+
66
+ You can deploy a release candidate, or work-in-progress to [Chromatic](https://www.chromatic.com/) for showcase or QA.
67
+
68
+ **NOTE:** you will need the `CHROMATIC_PROJECT_TOKEN` as described in *Prerequisites* above.
69
+
70
+ Either set the token as a shell variable or use a `.env` file in the chord root directory containing the token, as so:
71
+
72
+ ```
73
+ CHROMATIC_PROJECT_TOKEN=tokengoeshere
74
+ ```
75
+
76
+ Run:
77
+
78
+ ```
79
+ yarn deploy-storybook-dev
80
+ ```
81
+
82
+ to build and deploy the storybook from your repo to Chromatic.
83
+
84
+ You will find the address of your deployed storybook in the console output, looking something like this:
85
+
86
+ `→ View your Storybook at https://randomHexString-randomAlphabeticalString.chromatic.com`
87
+
88
+ ### **3. To deploy a release version**
89
+
90
+ You can deploy the contents of `./storybook-static` to S3 as a static site, which is permanently accessible at [chord.roh.org.uk](chord.roh.org.uk)
91
+
92
+ **NOTE:** To do this you will need the correct `AWS` credentials set up, as described in *Prerequisites* above.
93
+
94
+ First build the storybook using:
95
+
96
+ ```
97
+ yarn build-storybook
98
+ ```
99
+
100
+ then run:
101
+
13
102
  ```bash
14
- yarn add @royaloperahouse/chord
103
+ yarn deploy-storybook
15
104
  ```
16
105
 
17
- ## Usage
106
+ > **IMPORTANT:** This URL is intended to showcase the latest stable version of Chord, it should be kept up to date with the main `chord-releases` branch and should **only** be used for release versions. If you want to deploy a development version follow the steps above under *To deploy a preview version remotely*.
107
+
108
+
109
+ ## Releasing a New Package Version
110
+ ---
111
+
112
+ This is the procedure for releasing a new Chord NPM package.
113
+
114
+ There are two types of package:
115
+
116
+ A **snapshot** can be published to use a development version of the Chord library in our frontend staging environments, to perform integrated, manual testing.
117
+
118
+ A **stable** package is published for use in production.
119
+
120
+ **NOTE:** You will need the `NPM_TOKEN`, as described in 'Prerequisites' above.
18
121
 
19
- ```javascript
20
- import {
21
- Footer, GlobalStyles, ThemeProvider, ThemeType,
22
- } from '@royaloperahouse/chord';
122
+ ### **1. To release a snapshot version**
23
123
 
124
+ > **IMPORTANT:** Make sure you always publish your **snapshots** from `chord-development` after merging in your feature branch.
125
+
126
+ For snapshots, `RELEASE_VERSION` should be the same as the latest **stable** version of the Chord Library, as found in `chord-releases`, followed by an **unused** lowercase letter.
127
+
128
+ For example, if the latest stable release was 1.42.0, and the last snapshot published to NPM was 1.42.0-w, you would use RELEASE_VERSION `1.42.0-x`
129
+
130
+ To publish a snapshot use:
131
+
132
+ ```bash
133
+ NPM_ROH_TOKEN={NPM_TOKEN} RELEASE_VERSION={RELEASE_VERSION} yarn publish-snapshot
134
+ ```
135
+
136
+ The version published to NPM will be named, e.g. `1.42.0-a-chord-development`, use this to install the snapshot package in the frontend repos.
137
+
138
+ ### **2. To release a stable version**
139
+
140
+ > **IMPORTANT:** Make sure you always publish your **stable** packages from `chord-releases` after merging in your feature branch.
141
+
142
+ For stable releases, increment your version from the latest **stable** version found on `chord-releases`, following the rules described in *Versioning* above, and use this as `RELEASE_VERSION`. (Make sure it matches the version in your `package.json` and `CHANGELOG.md`!)
143
+
144
+ To publish a stable package use:
145
+
146
+ ```bash
147
+ NPM_ROH_TOKEN={NPM_TOKEN} RELEASE_VERSION={RELEASE_VERSION} yarn publish-release
148
+ ```
149
+
150
+
151
+ ## Using the Package
152
+ ---
153
+
154
+ The package is deployed to NPM, and can be installed using yarn or npm:
155
+
156
+ ```bash
157
+ npm i --save @royaloperahouse/chord
158
+ ```
159
+ ```bash
160
+ yarn add @royaloperahouse/chord
161
+ ```
162
+
163
+
164
+ ## Testing
165
+ ---
166
+
167
+ To **Lint** the package use:
168
+
169
+ ```bash
170
+ yarn lint
171
+ # Use the --fix option to perform automatic fixes
24
172
  ```
25
- ## Sample
26
173
 
27
- ```javascript
174
+ To run the **unit tests** (using Jest) use:
28
175
 
29
- import {
30
- Footer, GlobalStyles, ThemeProvider, ThemeType,
31
- } from '@royaloperahouse/chord';
176
+ ```bash
177
+ yarn test
32
178
 
179
+ # Use the -u option to update snapshots if needed
180
+ # Run `yarn test:watch` to re-run tests on changes
181
+ ```
33
182
 
34
- const App = ({ children }: InnerProps): React.ReactElement => (
35
- <ErrorBoundary>
36
- <ThemeProvider theme={ThemeType.Core}>
37
- <GlobalStyles />
38
- <Wrapper>
39
- <Header />
40
- <GlobalStyle />
41
- <HealthBanner />
42
- <ErrorBoundary>
43
- <Content>
44
- {children}
45
- </Content>
46
- </ErrorBoundary>
47
- <LiveChat />
48
- </Wrapper>
49
- <Footer data={footerData} />
50
- </ThemeProvider>
51
- </ErrorBoundary>
52
- );
183
+ To **run and and store the unit tests** for display in storybook use:
53
184
 
185
+ ```bash
186
+ yarn test-storybook
187
+ # Use the -u option to update snapshots if needed
54
188
  ```
55
189
 
56
- ## Components
57
190
 
58
- Accordion, Accordions, AltHeader, AnchorTabBar, AnnouncementBanner, BodyText, Card, Cards, Carousel, CinemaBadge, ContactCard, ControlledDropdown, devices, Editorial, Footer, GlobalStyles, Grid, GridItem, Header, HighlightsCarousel, HighlightsCarouselCinema, HighlightsCarouselCore, HighlightsCarouselStream, Icon, ImageWithCaption, Navigation, Overline, PageHeadingCinema, PageHeadingCore, PageHeadingImpact, PageHeadingStream, PeopleListing, PrimaryButton, PromoWithTags, PromoWithTitle, RotatorButtons, SecondaryButton, SecondaryLogo, SectionSplitter, SectionTitle, Sponsorship, StickyBar, StreamBadge, Subtitle, Tab, TabLink, Tabs, TertiaryButton, TextLink, TextOnly, Tickbox, TitleWithCTA, ThemeProvider, TypeTags, Quote
191
+ ## Development Process
192
+ ---
193
+
194
+ ### **1. Branching Model**
195
+ * The Chord project lives in the `roh-components` *monorepo*
196
+ * When working on Chord, treat the `roh-components/packages/chord` directory as your root
197
+ * The Chord **development** branch is currently `chord-development`
198
+ * The Chord **main** branch is currently `chord-releases`
199
+ * All work should be done on a correctly named **feature branch** of the format: `issueType/ticketNumber-short-description-of-feature`, e.g. `feature/RD-1234-update-chord-documentation`
200
+ * Always create your feature branch FROM, and submit pull requests TO, the **main** branch
201
+ * For **QA / UAT** of a Chord component in isolation: following review you should deploy a preview version to Chromatic straight from your **feature branch** _without_ merging to development
202
+ * For releasing an **NPM snapshot**: merge your feature branch into the **development** branch and publish the NPM snapshot from there
203
+
204
+ ### **2. Detailed Workflow**
205
+
206
+ #### **Before review:**
207
+
208
+ * Git pull the latest version of `chord-releases`
209
+ * Checkout a new, correctly-named feature branch from `chord releases`
210
+ * Do your work on this feature branch
211
+ * Run: `yarn lint`
212
+ * Run: `yarn test`
213
+ * Commit your changes
214
+ * Create a pull request from your feature branch to `chord-releases`
215
+ * Add the appropriate reviewers
216
+
217
+ #### **Before QA / UAT:**
218
+
219
+ After your PR is approved, you have two options:
220
+
221
+ **i.** For QA of a component in isolation:
222
+
223
+ * Follow the steps above in *Deploying the Storybook -> 2. Deploying a preview version remotely*
224
+ * Share the generated Chromatic URL with the appropriate people for QA / UAT
225
+
226
+ **ii.** For integrated testing of a component in the frontend staging environments:
227
+
228
+ * Check out the `chord-development` branch
229
+ * Merge your work in to `chord-development`
230
+ * Follow the steps above under *Publishing a New Package Version -> 1. To release a snapshot version*
231
+ * Git push the updated `chord-development` branch to remote
232
+ * Finally, in the frontend repo:
233
+
234
+ 1. Update the `package.json` to reference the new snapshot version
235
+ 2. Run: `yarn install`
236
+ 3. Deploy the frontend to a staging environment
237
+
238
+ #### **When ready for production:**
239
+
240
+ * Return to your chord **feature branch**
241
+ * Update the chord version in `package.json`, incrementing from the last **stable** release, found in `chord-releases`, and following the rules described in the *Versioning* section
242
+ * Update `CHANGELOG.md`, adding the new version number and a short description of your changes
243
+ * Run: `yarn lint`
244
+ * Run: `yarn test`
245
+ * Run: `yarn test-storybook -u`
246
+ * Run: `yarn build-storybook`
247
+ * Git commit, push, and update your PR for final approval
248
+ * Merge your approved PR to `chord-releases`
249
+ * Follow the steps in *Publishing a New Package Version -> 2. To release a stable version* to publish the NPM package
250
+ * Finally, follow the steps in *Deploying The Storybook -> 3. To deploy a release version*, to update the public Chord Storybook page
251
+
252
+ Once you have successfully published a new release version, you can open a ticket to update to this version in any of the frontend repos.
253
+
254
+
255
+ ## Notes
256
+ ---
257
+ ### The `storybook-static` folder
258
+
259
+ This folder contains all the HTML / JS required to deploy the Storybook as a static site. It's autogenerated whenever the Storybook is built and therefore will show up a lot of merge conflicts when you merge other branches into your feature branch. It is best to leave generating the storybook until the later part of your workflow, but in case you run into conflicts earlier, it's ok to just delete the folder and regenerate using:
260
+
261
+ ```bash
262
+ yarn build-storybook
263
+ ```
59
264
 
60
- ## Types
265
+ For the same reason changes to this folder will cause a lot of big diffs, when looking at a PR, but can mostly be skimmed over unless something looks unusual.
61
266
 
62
- AspectRatio, CarouselType, Colors, FooterData, INavigationProps, INavTopProps, TickboxMode, ThemeType
267
+ ---
268
+ ### Examples
63
269
 
270
+ There is an example implementation in the example folder. Alternatively there are also integration examples in storybook. Make sure to keep these updated so as to showcase the current components available.
64
271
 
65
- ## Documentation
272
+ ---
273
+ ### Bundle analysis
66
274
 
67
- See Storybook as a reference
275
+ Calculate the real cost of your library using [size-limit](https://github.com/ai/size-limit) with `yarn size` and visualize it with `yarn analyze`.
@@ -3725,10 +3725,10 @@ var Tabs = function Tabs(_ref) {
3725
3725
  };
3726
3726
 
3727
3727
  var _templateObject$t, _templateObject2$e, _templateObject3$7, _templateObject4$4, _templateObject5$1, _templateObject6$1;
3728
- var SearchBarContainer = /*#__PURE__*/styled__default.div(_templateObject$t || (_templateObject$t = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: row;\n column-gap: 64px;\n justify-content: space-between;\n align-items: center;\n height: 100px;\n background-color: var(--base-color-white);\n\n @media ", " {\n column-gap: 12px;\n height: 80px;\n }\n"])), devices.mobile);
3728
+ var SearchBarContainer = /*#__PURE__*/styled__default.div(_templateObject$t || (_templateObject$t = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: row;\n column-gap: 64px;\n justify-content: space-between;\n align-items: center;\n height: 100%;\n background-color: var(--base-color-white);\n\n @media ", " {\n column-gap: 12px;\n }\n"])), devices.mobile);
3729
3729
  var SvgContainerSearch = /*#__PURE__*/styled__default.div(_templateObject2$e || (_templateObject2$e = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n svg {\n width: var(--navigation-xlarge-gap);\n height: var(--navigation-xlarge-gap);\n }\n"])));
3730
3730
  var SvgContainerClose = /*#__PURE__*/styled__default.div(_templateObject3$7 || (_templateObject3$7 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n svg {\n width: var(--navigation-large-gap);\n height: var(--navigation-large-gap);\n }\n\n :hover {\n cursor: pointer;\n && svg path {\n fill: var(--base-color-navigation);\n }\n }\n"])));
3731
- var InputContainer = /*#__PURE__*/styled__default.div(_templateObject4$4 || (_templateObject4$4 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background-color: blue;\n width: 100%;\n\n input {\n font-size: var(--font-size-search);\n font-family: var(--font-family-search);\n border: none;\n border-radius: 0;\n outline: none;\n outline-color: var(--base-color-white);\n height: 48px;\n box-sizing: border-box;\n width: 100%;\n -webkit-appearance: none;\n\n &.search-input {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n\n @media ", " {\n column-gap: 24px;\n }\n }\n"])), devices.mobile);
3731
+ var InputContainer = /*#__PURE__*/styled__default.div(_templateObject4$4 || (_templateObject4$4 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background-color: blue;\n width: 100%;\n\n input {\n font-size: var(--font-size-search);\n font-family: var(--font-family-search);\n border: none;\n border-radius: 0;\n outline: none;\n outline-color: var(--base-color-white);\n height: 48px;\n box-sizing: border-box;\n width: 100%;\n -webkit-appearance: none;\n\n &.search-input {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n\n @media ", " {\n column-gap: 24px;\n }\n }\n\n input:disabled {\n background-color: var(--base-color-white);\n }\n"])), devices.mobile);
3732
3732
  var SearchLinkContainer = /*#__PURE__*/styled__default.div(_templateObject5$1 || (_templateObject5$1 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n @media ", " {\n display: none;\n }\n"])), devices.mobile);
3733
3733
  var SearchArrowContainer = /*#__PURE__*/styled__default.a(_templateObject6$1 || (_templateObject6$1 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: none;\n height: 24px;\n width: 24px;\n\n @media ", " {\n display: block;\n }\n"])), devices.mobile);
3734
3734
 
@@ -3795,14 +3795,15 @@ var SearchBar = function SearchBar(_ref) {
3795
3795
  "data-testid": "input-html",
3796
3796
  ref: inputRef,
3797
3797
  className: "search-input",
3798
- placeholder: "Search for anything ROH...",
3798
+ placeholder: "Our search tool is currently unavailable due to necessary maintenance.",
3799
3799
  type: "text",
3800
3800
  onChange: function onChange(e) {
3801
3801
  onChangeHandler(e);
3802
3802
  },
3803
3803
  onKeyPress: function onKeyPress(e) {
3804
3804
  return handleKeypress(e, searchValue);
3805
- }
3805
+ },
3806
+ disabled: true
3806
3807
  })), showSearchLink && /*#__PURE__*/React__default.createElement("span", null, /*#__PURE__*/React__default.createElement(SearchLinkContainer, {
3807
3808
  "data-testid": "search-button"
3808
3809
  }, /*#__PURE__*/React__default.createElement(TextLink, {
@@ -5206,6 +5207,7 @@ var Cards = function Cards(_ref) {
5206
5207
  }, /*#__PURE__*/React__default.createElement(Card, {
5207
5208
  size: size,
5208
5209
  image: card.image,
5210
+ imageAltText: card.imageAltText,
5209
5211
  progress: card.progress,
5210
5212
  title: card.title,
5211
5213
  subtitle: card.subtitle,
@@ -5742,7 +5744,8 @@ var PageHeadingImpact = function PageHeadingImpact(_ref) {
5742
5744
  customSponsorImage = _ref.customSponsorImage,
5743
5745
  scrollHref = _ref.scrollHref,
5744
5746
  bgUrlDesktop = _ref.bgUrlDesktop,
5745
- bgUrlDevice = _ref.bgUrlDevice;
5747
+ bgUrlDevice = _ref.bgUrlDevice,
5748
+ bgImageAltText = _ref.bgImageAltText;
5746
5749
  var truncatedText = text && text.substring(0, 75);
5747
5750
 
5748
5751
  var _ref2 = link || {},
@@ -5753,7 +5756,10 @@ var PageHeadingImpact = function PageHeadingImpact(_ref) {
5753
5756
  bgUrlDesktop: bgUrlDesktop,
5754
5757
  bgUrlDevice: bgUrlDevice,
5755
5758
  "data-testid": "impact-wrapper"
5756
- }, sponsor ? /*#__PURE__*/React__default.createElement(SponsorWrapper, {
5759
+ }, bgImageAltText && /*#__PURE__*/React__default.createElement("span", {
5760
+ role: "img",
5761
+ "aria-label": bgImageAltText
5762
+ }), sponsor ? /*#__PURE__*/React__default.createElement(SponsorWrapper, {
5757
5763
  "data-testid": "impact-sponsor"
5758
5764
  }, customSponsorImage ? /*#__PURE__*/React__default.createElement(Sponsorship, Object.assign({
5759
5765
  "data-testid": "impact-custom-sponsor"