@royaloperahouse/chord 1.24.1 → 1.24.2-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,3 +1,6 @@
1
+ ## [1.24.2]
2
+ - Increase Upsell Card Flag character limit to 30
3
+
1
4
  ## [1.24.1]
2
5
  - Include link field to Upsell Cards
3
6
 
@@ -18,12 +21,15 @@
18
21
  - TickBox: Added disabled and error states
19
22
 
20
23
  ## [1.21.1]
21
- - Made select state reset behaviour opt-in
24
+ - Compact PageHeading: Refactored to support iOS devices
22
25
 
23
26
  ## [1.21.0]
24
27
  - TextLogo: add new component
25
28
  - Compact PageHeading: swap logo with TextLogo to fix iOS issues
26
29
 
30
+ ## [1.20.2-a]
31
+ - Made select state reset behaviour opt-in
32
+
27
33
  ## [1.20.2]
28
34
  - Card: change cursor to default for cards without buttons
29
35
  - HighlightsCarousel: hide button in case there are no text for them
@@ -59,7 +65,7 @@
59
65
  - Change to pagination component to align page numbers with URL numbers.
60
66
 
61
67
  ## [1.15.0]
62
- - Implemented a new Select component
68
+ - Add Compact PageHeading component
63
69
 
64
70
  ## [1.14.0]
65
71
  - Added standfirst functionality to Accordion/ Accordions component and theme for Schools Platform
@@ -79,21 +85,55 @@
79
85
  ## [1.12.0]
80
86
  - Search: Extend ContentSummary and SearchBar components to support new search results
81
87
 
88
+ ## [1.11.0-a]
89
+ - Pagination: add new component
90
+
82
91
  ## [1.11.0]
83
92
  - Carousels: Rewrite logic that cuts description, to support older browsers
84
93
 
94
+ ## [1.10.0-a]
95
+ - ContentSummary: make image clickable
96
+
85
97
  ## [1.10.0]
86
98
  - PageHeadingImpact: Replace CSS background-image with HTML image element
87
99
 
88
100
  ## [1.9.0]
89
101
  - Card: Add a new prop for the hover line color
102
+ ## [1.9.0-c]
103
+ - ContentSummary: make image clickable
104
+
105
+ ## [1.9.0-b]
106
+ - ContentSummary: change image size
107
+ - SearchBar: Export component
108
+
109
+ ## [1.9.0-a]
110
+ - ContentSummary: change image props
111
+
112
+ ## [1.9.0]
113
+ - Card: Add a new prop for the hover line color
114
+
115
+ ## [1.8.1-h]
116
+ - ContentSummary: add exports
117
+
118
+ ## [1.8.1-g]
119
+ - ContentSummary: refactor
120
+
121
+ ## [1.8.1-f]
122
+ - ContentSummary: update conditional rendering
123
+
124
+ ## [1.8.1-c]
125
+ - ContentSummary: update for Search results
126
+ - ContentSummarySection: remove
127
+
128
+ ## [1.8.1-b]
129
+ - Card: add new prop for the line color on hover
90
130
 
91
131
  ## [1.8.0]
92
132
  - SearchBar: Disable
93
133
 
94
134
  ## [1.7.2]
95
135
  - Add imageAltText to Card component
96
-
136
+
97
137
  ## [1.7.0]
98
138
  - Add new ContentSummary component
99
139
  - Add new ContentSummarySection component
package/README.md CHANGED
@@ -1,67 +1,277 @@
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
+ * If this is the first time you are working on Chord, make sure to run `yarn build` to build all the modules.
20
+
21
+ * **To deploy the storybook publicly** you will need credentials for the **parent** 'Royal Opera House' AWS account in your `~/.aws/credentials` file.
22
+ * The deploy script expects these to be called `[parent]`.
23
+
24
+ * You can find these values at:
25
+
26
+ *AWS 'Your Applications' page -> 'Royal Opera House' -> 'Developer Access' -> 'Command line or programmatic access'*
27
+
28
+ * **To deploy a preview** for demo / QA you will need the `CHROMATIC_PROJECT_TOKEN` -- find this in 1Password
29
+
30
+
31
+ * **To publish the NPM package** you will need the ROH `NPM_TOKEN` -- find this in 1Password
32
+
33
+
34
+ ## Versioning
35
+ ---
36
+
37
+ We use [Semantic Versioning](https://semver.org/) for Chord.
38
+
39
+ Given a version number MAJOR.MINOR.PATCH, increment the:
40
+
41
+ * MAJOR version when you make incompatible library changes
42
+ * MINOR version when you add functionality in a backwards compatible manner
43
+ * PATCH version when you make backwards compatible bug fixes
44
+
45
+ When you create a new release always update the `CHANGELOG` and `package.json`
46
+
47
+ Increment your version from the latest stable version on `chord-releases`
48
+
49
+
50
+ ## Deploying the Storybook
51
+ ---
52
+
53
+ ### **1. To build and deploy locally**
54
+
55
+ You can quickly build and serve the contents of `/storybook-static` from your local machine, for development and manual testing. To do this run:
56
+
57
+ ```bash
58
+ yarn storybook
59
+ ```
60
+
61
+ By default the storybook will be accessible at
62
+ [http://localhost:6006/]()
63
+
64
+ The server will hot-reload on most changes.
65
+
66
+ ### **2. To deploy a preview version remotely**
67
+
68
+ You can deploy a release candidate, or work-in-progress to [Chromatic](https://www.chromatic.com/) for showcase or QA.
69
+
70
+ **NOTE:** you will need the `CHROMATIC_PROJECT_TOKEN` as described in *Prerequisites* above.
71
+
72
+ Either set the token as a shell variable or use a `.env` file in the chord root directory containing the token, as so:
73
+
74
+ ```
75
+ CHROMATIC_PROJECT_TOKEN=tokengoeshere
76
+ ```
77
+
78
+ Run:
79
+
80
+ ```
81
+ yarn deploy-storybook-dev
82
+ ```
83
+
84
+ to build and deploy the storybook from your repo to Chromatic.
85
+
86
+ You will find the address of your deployed storybook in the console output, looking something like this:
87
+
88
+ `→ View your Storybook at https://randomHexString-randomAlphabeticalString.chromatic.com`
89
+
90
+ ### **3. To deploy a release version**
91
+
92
+ 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)
93
+
94
+ **NOTE:** To do this you will need the correct `AWS` credentials set up, as described in *Prerequisites* above.
95
+
96
+ First build the storybook using:
97
+
98
+ ```
99
+ yarn build-storybook
100
+ ```
101
+
102
+ then run:
103
+
104
+ ```bash
105
+ yarn deploy-storybook
106
+ ```
107
+
108
+ > **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*.
109
+
110
+
111
+ ## Releasing a New Package Version
112
+ ---
113
+
114
+ This is the procedure for releasing a new Chord NPM package.
115
+
116
+ There are two types of package:
117
+
118
+ A **snapshot** can be published to use a development version of the Chord library in our frontend staging environments, to perform integrated, manual testing.
119
+
120
+ A **stable** package is published for use in production.
121
+
122
+ **NOTE:** You will need the `NPM_TOKEN`, as described in 'Prerequisites' above.
123
+
124
+ ### **1. To release a snapshot version**
125
+
126
+ > **IMPORTANT:** Make sure you always publish your **snapshots** from `chord-development` after merging in your feature branch.
127
+
128
+ 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.
129
+
130
+ 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`
131
+
132
+ To publish a snapshot use:
9
133
 
10
134
  ```bash
11
- npm i --save @royaloperahouse/chord
135
+ NPM_ROH_TOKEN={NPM_TOKEN} RELEASE_VERSION={RELEASE_VERSION} yarn publish-snapshot
12
136
  ```
137
+
138
+ 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.
139
+
140
+ ### **2. To release a stable version**
141
+
142
+ > **IMPORTANT:** Make sure you always publish your **stable** packages from `chord-releases` after merging in your feature branch.
143
+
144
+ 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`!)
145
+
146
+ To publish a stable package use:
147
+
13
148
  ```bash
14
- yarn add @royaloperahouse/chord
149
+ NPM_ROH_TOKEN={NPM_TOKEN} RELEASE_VERSION={RELEASE_VERSION} yarn publish-release
15
150
  ```
16
151
 
17
- ## Usage
18
152
 
19
- ```javascript
20
- import {
21
- Footer, GlobalStyles, ThemeProvider, ThemeType,
22
- } from '@royaloperahouse/chord';
153
+ ## Using the Package
154
+ ---
155
+
156
+ The package is deployed to NPM, and can be installed using yarn or npm:
23
157
 
158
+ ```bash
159
+ npm i --save @royaloperahouse/chord
24
160
  ```
25
- ## Sample
161
+ ```bash
162
+ yarn add @royaloperahouse/chord
163
+ ```
164
+
26
165
 
27
- ```javascript
166
+ ## Testing
167
+ ---
28
168
 
29
- import {
30
- Footer, GlobalStyles, ThemeProvider, ThemeType,
31
- } from '@royaloperahouse/chord';
169
+ To **Lint** the package use:
32
170
 
171
+ ```bash
172
+ yarn lint
173
+ # Use the --fix option to perform automatic fixes
174
+ ```
33
175
 
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
- );
176
+ To run the **unit tests** (using Jest) use:
53
177
 
178
+ ```bash
179
+ yarn test
180
+
181
+ # Use the -u option to update snapshots if needed
182
+ # Run `yarn test:watch` to re-run tests on changes
54
183
  ```
55
184
 
56
- ## Components
185
+ To **run and and store the unit tests** for display in storybook use:
186
+
187
+ ```bash
188
+ yarn test-storybook
189
+ # Use the -u option to update snapshots if needed
190
+ ```
191
+
192
+
193
+ ## Development Process
194
+ ---
195
+
196
+ ### **1. Branching Model**
197
+ * The Chord project lives in the `roh-components` *monorepo*
198
+ * When working on Chord, treat the `roh-components/packages/chord` directory as your root
199
+ * The Chord **development** branch is currently `chord-development`
200
+ * The Chord **main** branch is currently `chord-releases`
201
+ * 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`
202
+ * Always create your feature branch FROM, and submit pull requests TO, the **main** branch
203
+ * 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
204
+ * For releasing an **NPM snapshot**: merge your feature branch into the **development** branch and publish the NPM snapshot from there
205
+
206
+ ### **2. Detailed Workflow**
207
+
208
+ #### **Before review:**
209
+
210
+ * Git pull the latest version of `chord-releases`
211
+ * Checkout a new, correctly-named feature branch from `chord releases`
212
+ * Do your work on this feature branch
213
+ * Run: `yarn lint`
214
+ * Run: `yarn test`
215
+ * Commit your changes
216
+ * Create a pull request from your feature branch to `chord-releases`
217
+ * Add the appropriate reviewers
218
+
219
+ #### **Before QA / UAT:**
220
+
221
+ After your PR is approved, you have two options:
222
+
223
+ **i.** For QA of a component in isolation:
57
224
 
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
225
+ * Follow the steps above in *Deploying the Storybook -> 2. Deploying a preview version remotely*
226
+ * Share the generated Chromatic URL with the appropriate people for QA / UAT
227
+
228
+ **ii.** For integrated testing of a component in the frontend staging environments:
229
+
230
+ * Check out the `chord-development` branch
231
+ * Merge your work in to `chord-development`
232
+ * Follow the steps above under *Publishing a New Package Version -> 1. To release a snapshot version*
233
+ * Git push the updated `chord-development` branch to remote
234
+ * Finally, in the frontend repo:
235
+
236
+ 1. Update the `package.json` to reference the new snapshot version
237
+ 2. Run: `yarn install`
238
+ 3. Deploy the frontend to a staging environment
239
+
240
+ #### **When ready for production:**
241
+
242
+ * Return to your chord **feature branch**
243
+ * 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
244
+ * Update `CHANGELOG.md`, adding the new version number and a short description of your changes
245
+ * Run: `yarn lint`
246
+ * Run: `yarn test`
247
+ * Run: `yarn test-storybook -u`
248
+ * Run: `yarn build-storybook`
249
+ * Git commit, push, and update your PR for final approval
250
+ * Merge your approved PR to `chord-releases`
251
+ * Follow the steps in *Publishing a New Package Version -> 2. To release a stable version* to publish the NPM package
252
+ * Finally, follow the steps in *Deploying The Storybook -> 3. To deploy a release version*, to update the public Chord Storybook page
253
+
254
+ 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.
255
+
256
+
257
+ ## Notes
258
+ ---
259
+ ### The `storybook-static` folder
260
+
261
+ 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:
262
+
263
+ ```bash
264
+ yarn build-storybook
265
+ ```
59
266
 
60
- ## Types
267
+ 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
268
 
62
- AspectRatio, CarouselType, Colors, FooterData, INavigationProps, INavTopProps, TickboxMode, ThemeType
269
+ ---
270
+ ### Examples
63
271
 
272
+ 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
273
 
65
- ## Documentation
274
+ ---
275
+ ### Bundle analysis
66
276
 
67
- See Storybook as a reference
277
+ 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`.
@@ -5658,7 +5658,7 @@ var TitleWithCTA = function TitleWithCTA(_ref) {
5658
5658
  };
5659
5659
 
5660
5660
  var _templateObject$H, _templateObject2$s, _templateObject3$l, _templateObject4$g, _templateObject5$a, _templateObject6$9, _templateObject7$7, _templateObject8$5;
5661
- var Wrapper$2 = /*#__PURE__*/styled__default.div(_templateObject$H || (_templateObject$H = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background-color: var(--base-color-lightgrey);\n padding: 40px;\n\n display: block;\n position: relative;\n\n @media ", " {\n margin-top: 0;\n padding: 40px 20px;\n }\n\n"])), devices.tablet);
5661
+ var Wrapper$2 = /*#__PURE__*/styled__default.div(_templateObject$H || (_templateObject$H = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background-color: var(--base-color-lightgrey);\n padding: 40px;\n\n display: block;\n position: relative;\n\n @media ", " {\n margin-top: 0;\n padding: 40px 20px;\n }\n"])), devices.tablet);
5662
5662
  var PromoLabelWrapper = /*#__PURE__*/styled__default.div(_templateObject2$s || (_templateObject2$s = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: row;\n justify-content: flex-end;\n align-self: flex-end;\n height: 15px;\n"])));
5663
5663
  var PromoLabel = /*#__PURE__*/styled__default.div(_templateObject3$l || (_templateObject3$l = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background: ", ";\n color: ", ";\n padding: 6px 8px;\n width: fit-content;\n display: flex;\n justify-content: center;\n align-items: center;\n position: absolute;\n right: 20px;\n top: 0;\n width: auto;\n margin: auto;\n font-family: var(--font-family-header);\n font-feature-settings: 'tnum' on, 'lnum' on, 'liga' off, 'calt' off;\n font-size: var(--font-size-overline-2);\n line-height: 12px;\n text-align: center;\n letter-spacing: 1px;\n text-transform: uppercase;\n"])), function (_ref) {
5664
5664
  var theme = _ref.theme;
@@ -5697,6 +5697,7 @@ var formatPrice = function formatPrice(value) {
5697
5697
 
5698
5698
  var LENGTH_SMALL_TEXT = 19;
5699
5699
  var OFFER_TEXTS_LIMIT = 3;
5700
+ var FLAG_CHAR_LIMIT = 30;
5700
5701
 
5701
5702
  var UpsellCard = function UpsellCard(_ref) {
5702
5703
  var _ref$title = _ref.title,
@@ -5717,7 +5718,7 @@ var UpsellCard = function UpsellCard(_ref) {
5717
5718
  var reducedOfferTexts = offerTexts == null ? void 0 : offerTexts.slice(0, OFFER_TEXTS_LIMIT);
5718
5719
  return /*#__PURE__*/React__default.createElement(Theme, {
5719
5720
  theme: theme
5720
- }, /*#__PURE__*/React__default.createElement(Wrapper$2, null, flag && /*#__PURE__*/React__default.createElement(PromoLabelWrapper, null, /*#__PURE__*/React__default.createElement(PromoLabel, null, setMaxCharLength(flag, 15))), /*#__PURE__*/React__default.createElement(TitleContainer$1, null, /*#__PURE__*/React__default.createElement(Subtitle, {
5721
+ }, /*#__PURE__*/React__default.createElement(Wrapper$2, null, flag && /*#__PURE__*/React__default.createElement(PromoLabelWrapper, null, /*#__PURE__*/React__default.createElement(PromoLabel, null, setMaxCharLength(flag, FLAG_CHAR_LIMIT))), /*#__PURE__*/React__default.createElement(TitleContainer$1, null, /*#__PURE__*/React__default.createElement(Subtitle, {
5721
5722
  semanticLevel: 2,
5722
5723
  level: 1
5723
5724
  }, title), subTitle && /*#__PURE__*/React__default.createElement(Overline, {
@@ -6889,7 +6890,7 @@ var BrandingTextBlock = /*#__PURE__*/styled__default.div(_templateObject$Y || (_
6889
6890
  var BrandingTextBody = /*#__PURE__*/styled__default.p(_templateObject2$G || (_templateObject2$G = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n font-family: var(--font-family-body);\n font-size: var(--font-size-heading-6);\n line-height: var(--line-height-heading-6);\n"])));
6890
6891
  var ComapctHeaderWrapper = /*#__PURE__*/styled__default.div(_templateObject3$y || (_templateObject3$y = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n position: relative;\n display: block;\n"])));
6891
6892
  var CompactHeaderAssetWrapper = /*#__PURE__*/styled__default.div(_templateObject5$k || (_templateObject5$k = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n height: 37.5vw;\n width: 100%;\n position: relative;\n overflow: hidden;\n background-color: #000;\n img {\n position: relative;\n height: 100%;\n width: 100%;\n object-fit: cover;\n }\n video {\n position: absolute;\n top: 0;\n left: 0;\n height: 100%;\n width: 100%;\n object-fit: contain;\n @media ", " {\n position: absolute;\n top: 0;\n left: 0;\n bottom: 0;\n margin: auto;\n height: auto;\n max-height: 100vh;\n width: 100%;\n object-fit: contain;\n }\n }\n @media ", " {\n height: 85vw;\n max-height: 100vh;\n }\n"])), devices.mobile, devices.mobile);
6892
- var CompactHeaderCopyWrapper = /*#__PURE__*/styled__default(Grid)(_templateObject6$e || (_templateObject6$e = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n position: relative;\n height: 160px;\n grid-template-rows: min-content min-content;\n grid-template-rows: min-content min-content;\n grid-template-columns: [logo] 1fr [title] 3fr [cta] 1fr;\n align-content: center;\n gap: 0;\n background-color: ", ";\n color: ", ";\n svg {\n max-width: 155px;\n fill: ", ";\n }\n @media ", " {\n display: flex;\n flex-direction: column;\n height: auto;\n padding: 32px 20px;\n }\n"])), function (_ref) {
6893
+ var CompactHeaderCopyWrapper = /*#__PURE__*/styled__default(Grid)(_templateObject6$e || (_templateObject6$e = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n position: relative;\n height: 160px;\n grid-template-rows: min-content min-content;\n grid-template-rows: min-content min-content;\n grid-template-columns: [logo] 1fr [title] 3fr [cta] 1fr;\n align-content: center;\n gap: 0;\n background-color: ", ";\n color: ", ";\n\n svg {\n max-width: 155px;\n fill: ", ";\n }\n\n h1::selection,\n div::selection {\n ", ";\n }\n\n @media ", " {\n display: flex;\n flex-direction: column;\n height: auto;\n padding: 32px 20px;\n }\n"])), function (_ref) {
6893
6894
  var invert = _ref.invert,
6894
6895
  theme = _ref.theme;
6895
6896
  return invert ? theme.colors.white : theme.colors.primary;
@@ -6901,18 +6902,17 @@ var CompactHeaderCopyWrapper = /*#__PURE__*/styled__default(Grid)(_templateObjec
6901
6902
  var invert = _ref3.invert,
6902
6903
  theme = _ref3.theme;
6903
6904
  return invert ? theme.colors.black : theme.colors.white;
6905
+ }, function (_ref4) {
6906
+ var theme = _ref4.theme;
6907
+ return theme.colors.primary === theme.colors.stream && "\n color: " + theme.colors.stream + ";\n background-color: " + theme.colors.white + ";\n ";
6904
6908
  }, devices.mobile);
6905
6909
  var CompactHeaderLogoWrapper = /*#__PURE__*/styled__default.div(_templateObject7$c || (_templateObject7$c = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n grid-area: logo;\n padding-left: 50px;\n justify-content: left;\n align-items: center;\n width: 100%;\n @media ", " {\n padding-left: 0px;\n justify-content: center;\n }\n @media ", " {\n width: fit-content;\n }\n"])), devices.mobile, devices.tablet);
6906
6910
  var CompactHeaderTitleWrapper = /*#__PURE__*/styled__default.div(_templateObject8$9 || (_templateObject8$9 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n grid-area: title;\n align-items: center;\n justify-content: center;\n font-family: var(--font-family-header);\n text-transform: uppercase;\n text-align: center;\n padding: 0 2em;\n @media ", " {\n justify-content: center;\n }\n"])), devices.mobile);
6907
6911
  var CompactHeaderCTAWrapper = /*#__PURE__*/styled__default.div(_templateObject9$4 || (_templateObject9$4 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n grid-area: cta;\n justify-content: right;\n align-items: center;\n padding-right: 50px;\n @media ", " {\n padding-right: 0px;\n justify-content: center;\n }\n"])), devices.mobile);
6908
- var PrimaryButtonWithInversion = /*#__PURE__*/styled__default(PrimaryButton)(_templateObject10$4 || (_templateObject10$4 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background-color: ", ";\n color: ", ";\n svg {\n fill: ", ";\n path {\n fill: ", ";\n }\n }\n min-width: 145px;\n"])), function (_ref4) {
6909
- var invert = _ref4.invert,
6910
- theme = _ref4.theme;
6911
- return invert ? theme.colors.primary : theme.colors.white;
6912
- }, function (_ref5) {
6912
+ var PrimaryButtonWithInversion = /*#__PURE__*/styled__default(PrimaryButton)(_templateObject10$4 || (_templateObject10$4 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background-color: ", ";\n color: ", ";\n svg {\n fill: ", ";\n path {\n fill: ", ";\n }\n }\n min-width: 145px;\n"])), function (_ref5) {
6913
6913
  var invert = _ref5.invert,
6914
6914
  theme = _ref5.theme;
6915
- return invert ? theme.colors.white : theme.colors.black;
6915
+ return invert ? theme.colors.primary : theme.colors.white;
6916
6916
  }, function (_ref6) {
6917
6917
  var invert = _ref6.invert,
6918
6918
  theme = _ref6.theme;
@@ -6921,6 +6921,10 @@ var PrimaryButtonWithInversion = /*#__PURE__*/styled__default(PrimaryButton)(_te
6921
6921
  var invert = _ref7.invert,
6922
6922
  theme = _ref7.theme;
6923
6923
  return invert ? theme.colors.white : theme.colors.black;
6924
+ }, function (_ref8) {
6925
+ var invert = _ref8.invert,
6926
+ theme = _ref8.theme;
6927
+ return invert ? theme.colors.white : theme.colors.black;
6924
6928
  });
6925
6929
 
6926
6930
  var renderBranding = function renderBranding(brandingStyle, invert, brandingText) {
@@ -6967,7 +6971,7 @@ var CompactHeaderBranding = function CompactHeaderBranding(_ref) {
6967
6971
  var isIOS = function isIOS() {
6968
6972
  try {
6969
6973
  console.warn('Do not use this on server side rendering, it may throw an error.');
6970
- if (typeof navigator === undefined) return false;
6974
+ if (typeof navigator === 'undefined') return false;
6971
6975
  return ['iPad Simulator', 'iPhone Simulator', 'iPod Simulator', 'iPad', 'iPhone', 'iPod'].includes(navigator.platform) || // iPad on iOS 13 detection
6972
6976
  navigator.userAgent.includes('Mac') && 'ontouchend' in document;
6973
6977
  } catch (e) {
@@ -6983,7 +6987,7 @@ var useIOS = function useIOS() {
6983
6987
  setIOS = _useState[1];
6984
6988
 
6985
6989
  React.useEffect(function () {
6986
- if (typeof navigator === undefined) return;
6990
+ if (typeof navigator === 'undefined') return;
6987
6991
  setIOS(isIOS());
6988
6992
  }, []);
6989
6993
  return IOS;