@royaloperahouse/harmonic 0.2.2-b → 0.2.3-a

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.
@@ -5200,31 +5200,34 @@ var NavigationWrapper = /*#__PURE__*/styled.div(_templateObject$x || (_templateO
5200
5200
  var isMenuOpen = _ref.isMenuOpen;
5201
5201
  return isMenuOpen && "\n position: fixed;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: " + zIndexes.overlay + ";\n background-color: var(--color-base-white);\n overflow-y: auto;\n scrollbar-width: none;\n ::-webkit-scrollbar {\n display: none;\n }\n ";
5202
5202
  });
5203
- var FullScreenContainer = /*#__PURE__*/styled.div(_templateObject2$o || (_templateObject2$o = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background-color: var(--color-base-white);\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n width: 100%;\n z-index: ", ";\n opacity: 0;\n animation: fadeIn 0.3s ease forwards;\n\n @media ", " {\n top: 230px;\n background-color: var(--color-base-black);\n }\n\n @keyframes fadeIn {\n to {\n opacity: 0.5;\n }\n }\n"])), zIndexes.searchOverlay, devices.mobileAndTablet);
5203
+ var FullScreenContainer = /*#__PURE__*/styled.div(_templateObject2$o || (_templateObject2$o = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background-color: var(--color-base-white);\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n width: 100%;\n z-index: ", ";\n opacity: 0;\n animation: fadeIn 0.3s ease forwards;\n\n @media ", " {\n top: 230px;\n background-color: var(--color-base-black);\n }\n\n @keyframes fadeIn {\n to {\n opacity: 0.5;\n }\n }\n"])), function (_ref2) {
5204
+ var isMobile = _ref2.isMobile;
5205
+ return isMobile ? zIndexes.overlay : zIndexes.searchOverlay;
5206
+ }, devices.mobileAndTablet);
5204
5207
  var NavigationGrid = /*#__PURE__*/styled(Grid)(_templateObject3$e || (_templateObject3$e = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n position: relative;\n background-color: var(--color-base-white);\n height: 140px;\n justify-content: space-evenly;\n width: 100%;\n z-index: ", ";\n\n @media ", " {\n height: 60px;\n }\n"])), zIndexes.navigation, devices.mobileAndTablet);
5205
- var SearchBackground = /*#__PURE__*/styled.div(_templateObject4$b || (_templateObject4$b = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n visibility: ", ";\n opacity: ", ";\n transform: ", ";\n transition:\n opacity 0.3s ease,\n transform 0.3s ease,\n visibility 0.3s ease;\n background-color: var(--color-base-white);\n height: 100px;\n border-top: 1px solid var(--color-base-light-grey);\n width: 100%;\n position: absolute;\n top: 140px;\n z-index: ", ";\n\n @media ", " {\n height: 86px;\n top: 144px;\n }\n"])), function (_ref2) {
5206
- var visible = _ref2.visible;
5207
- return visible ? 'visible' : 'hidden';
5208
- }, function (_ref3) {
5208
+ var SearchBackground = /*#__PURE__*/styled.div(_templateObject4$b || (_templateObject4$b = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n visibility: ", ";\n opacity: ", ";\n transform: ", ";\n transition:\n opacity 0.3s ease,\n transform 0.3s ease,\n visibility 0.3s ease;\n background-color: var(--color-base-white);\n height: 100px;\n border-top: 1px solid var(--color-base-light-grey);\n width: 100%;\n position: absolute;\n top: 140px;\n z-index: ", ";\n\n @media ", " {\n height: 86px;\n top: 144px;\n }\n"])), function (_ref3) {
5209
5209
  var visible = _ref3.visible;
5210
- return visible ? 1 : 0;
5210
+ return visible ? 'visible' : 'hidden';
5211
5211
  }, function (_ref4) {
5212
5212
  var visible = _ref4.visible;
5213
+ return visible ? 1 : 0;
5214
+ }, function (_ref5) {
5215
+ var visible = _ref5.visible;
5213
5216
  return visible ? 'translateY(0)' : 'translateY(-10px)';
5214
5217
  }, zIndexes.search, devices.mobile);
5215
- var GridItemSearch = /*#__PURE__*/styled(GridItem)(_templateObject5$8 || (_templateObject5$8 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n visibility: ", ";\n opacity: ", ";\n transform: ", ";\n transition:\n opacity 0.3s ease,\n transform 0.3s ease,\n visibility 0.3s ease;\n background-color: var(--color-base-white);\n border-top: 1px solid var(--color-base-light-grey);\n width: 100%;\n position: absolute;\n top: 140px;\n z-index: ", ";\n height: 100px;\n\n @media ", " {\n height: 86px;\n top: 144px;\n }\n"])), function (_ref5) {
5216
- var visible = _ref5.visible;
5217
- return visible ? 'visible' : 'hidden';
5218
- }, function (_ref6) {
5218
+ var GridItemSearch = /*#__PURE__*/styled(GridItem)(_templateObject5$8 || (_templateObject5$8 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n visibility: ", ";\n opacity: ", ";\n transform: ", ";\n transition:\n opacity 0.3s ease,\n transform 0.3s ease,\n visibility 0.3s ease;\n background-color: var(--color-base-white);\n border-top: 1px solid var(--color-base-light-grey);\n width: 100%;\n position: absolute;\n top: 140px;\n z-index: ", ";\n height: 100px;\n\n @media ", " {\n height: 86px;\n top: 144px;\n }\n"])), function (_ref6) {
5219
5219
  var visible = _ref6.visible;
5220
- return visible ? 1 : 0;
5220
+ return visible ? 'visible' : 'hidden';
5221
5221
  }, function (_ref7) {
5222
5222
  var visible = _ref7.visible;
5223
+ return visible ? 1 : 0;
5224
+ }, function (_ref8) {
5225
+ var visible = _ref8.visible;
5223
5226
  return visible ? 'translateY(0)' : 'translateY(-10px)';
5224
5227
  }, zIndexes.search, devices.mobile);
5225
5228
  var NavigationGridMobile = /*#__PURE__*/styled(Grid)(_templateObject6$5 || (_templateObject6$5 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: none;\n\n @media ", " {\n display: grid;\n padding-top: 32px;\n padding-bottom: var(--navigation-large-margin);\n }\n"])), devices.mobileAndTablet);
5226
- var MobileMenuContainer = /*#__PURE__*/styled(Grid)(_templateObject7$2 || (_templateObject7$2 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: none;\n\n @media ", " {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n justify-content: space-evenly;\n transition: row-gap 0.3s ease;\n row-gap: ", ";\n }\n"])), devices.mobileAndTablet, function (_ref8) {
5227
- var showSearch = _ref8.showSearch;
5229
+ var MobileMenuContainer = /*#__PURE__*/styled(Grid)(_templateObject7$2 || (_templateObject7$2 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: none;\n\n @media ", " {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n justify-content: space-evenly;\n transition: row-gap 0.3s ease;\n row-gap: ", ";\n }\n"])), devices.mobileAndTablet, function (_ref9) {
5230
+ var showSearch = _ref9.showSearch;
5228
5231
  return showSearch ? '110px' : '12px';
5229
5232
  });
5230
5233
  var LogoContainer = /*#__PURE__*/styled.a(_templateObject8$2 || (_templateObject8$2 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n\n &&& .logoImg {\n height: 96px;\n width: 80px;\n }\n\n span > svg path,\n span > svg g path {\n fill: var(--color-primary-black);\n }\n\n @media ", " {\n display: none;\n }\n"])), devices.mobileAndTablet);
@@ -5955,6 +5958,8 @@ var Navigation = function Navigation(_ref) {
5955
5958
  var onCloseSearchHandler = function onCloseSearchHandler() {
5956
5959
  setshowSearch(false);
5957
5960
  };
5961
+ var _useViewport = useViewport(),
5962
+ isMobile = _useViewport.isMobile;
5958
5963
  return /*#__PURE__*/React__default.createElement(NavigationWrapper, {
5959
5964
  isMenuOpen: showMenu,
5960
5965
  className: className,
@@ -5965,7 +5970,8 @@ var Navigation = function Navigation(_ref) {
5965
5970
  style: {
5966
5971
  height: "" + fullScreenHeight
5967
5972
  },
5968
- onClick: onCloseSearchHandler
5973
+ onClick: onCloseSearchHandler,
5974
+ isMobile: isMobile
5969
5975
  })), /*#__PURE__*/React__default.createElement(NavigationGrid, null, /*#__PURE__*/React__default.createElement(NavContainerGridItem, {
5970
5976
  columnStartDesktop: 1,
5971
5977
  columnSpanDesktop: 18,
@@ -7656,7 +7662,11 @@ var Swipe = /*#__PURE__*/forwardRef(function (_ref, ref) {
7656
7662
  };
7657
7663
  var handleTouchEnd = function handleTouchEnd() {
7658
7664
  isDragging.current = false;
7659
- navigateOnSwipeEnd();
7665
+ if (isClickPrevented.current) {
7666
+ navigateOnSwipeEnd();
7667
+ } else {
7668
+ setDragTranslateX(null);
7669
+ }
7660
7670
  };
7661
7671
  var handleMouseMove = function handleMouseMove(e) {
7662
7672
  if (!isDragging.current || !isMouseDown.current || transitioning) return;
@@ -7787,6 +7797,7 @@ var Carousel = function Carousel(_ref) {
7787
7797
  }
7788
7798
  };
7789
7799
  var carouselTitleId = "carousel-title-" + title;
7800
+ var titleSemanticLevelValue = titleSemanticLevel ? "h" + titleSemanticLevel : 'h2';
7790
7801
  var Wrapper = type === CarouselType.Image ? ImageCarouselWrapper : CardsCarouselWrapper;
7791
7802
  return /*#__PURE__*/React__default.createElement(Wrapper, {
7792
7803
  className: className,
@@ -7807,9 +7818,9 @@ var Carousel = function Carousel(_ref) {
7807
7818
  id: carouselTitleId,
7808
7819
  isDescriptionPresent: !!description
7809
7820
  }, /*#__PURE__*/React__default.createElement(HarmonicHeader, {
7810
- size: "small",
7821
+ size: "medium",
7811
7822
  serif: true,
7812
- hierarchy: "h" + titleSemanticLevel
7823
+ hierarchy: titleSemanticLevelValue
7813
7824
  }, title)), /*#__PURE__*/React__default.createElement(BodyCopyHarmonic, {
7814
7825
  size: "large"
7815
7826
  }, description)))), /*#__PURE__*/React__default.createElement(GridItem, {
@@ -10148,13 +10159,13 @@ var PromoWithTitleImageWrapper = /*#__PURE__*/styled.div(_templateObject2$U || (
10148
10159
  var imageToLeft = _ref3.imageToLeft;
10149
10160
  return imageToLeft ? 'left' : 'right';
10150
10161
  }, devices.mobile);
10151
- var PromoWithTitleContentWrapper = /*#__PURE__*/styled.div(_templateObject3$G || (_templateObject3$G = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n grid-area: ", ";\n align-self: center;\n @media ", " {\n & {\n grid-area: row2;\n align-self: start;\n }\n }\n"])), function (_ref4) {
10162
+ var PromoWithTitleContentWrapper = /*#__PURE__*/styled.div(_templateObject3$G || (_templateObject3$G = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n grid-area: ", ";\n align-self: center;\n\n @media ", " {\n & {\n grid-area: row2;\n align-self: start;\n }\n }\n"])), function (_ref4) {
10152
10163
  var imageToLeft = _ref4.imageToLeft;
10153
10164
  return imageToLeft ? 'right' : 'left';
10154
10165
  }, devices.mobile);
10155
- var PromoWithTitleContainer = /*#__PURE__*/styled.div(_templateObject4$A || (_templateObject4$A = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n h2,\n h3 {\n margin: 0 0 32px;\n\n @media ", " {\n & {\n margin: 0 0 24px;\n }\n }\n }\n"])), devices.mobile);
10156
- var PromoWithTitleSubtitle = /*#__PURE__*/styled.span(_templateObject5$t || (_templateObject5$t = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n font-family: var(--font-family-subtitle);\n font-feature-settings: var(--font-feature-settings-subtitle);\n font-size: var(--font-size-subtitle-1);\n font-weight: var(--font-weight-subtitle-1);\n line-height: var(--line-height-subtitle-1);\n letter-spacing: var(--letter-spacing-subtitle-1);\n text-transform: var(--text-transform-subtitle);\n margin-bottom: var(--editorial-subtitle-margin-bottom);\n display: block;\n overflow-wrap: break-word;\n"])));
10157
- var PromoWithTitleText = /*#__PURE__*/styled.div(_templateObject6$n || (_templateObject6$n = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n font-family: var(--font-family-body);\n font-feature-settings: var(--font-feature-settings-body);\n font-size: var(--font-size-body-1);\n font-weight: var(--font-weight-body-1);\n line-height: var(--line-height-body-1);\n letter-spacing: var(--letter-spacing-body-1);\n text-transform: var(--text-transform-body);\n margin: 0;\n padding: 0;\n white-space: break-spaces;\n overflow-wrap: break-word;\n\n h5,\n h6 {\n margin: 0 0 4px 0;\n font-family: var(--font-family-subtitle);\n font-feature-settings: var(--font-feature-settings-subtitle);\n font-size: var(--font-size-subtitle-2);\n font-weight: var(--font-weight-subtitle-2);\n line-height: var(--line-height-subtitle-2);\n letter-spacing: var(--letter-spacing-subtitle-2);\n text-transform: var(--text-transform-subtitle);\n overflow-wrap: break-word;\n }\n\n em {\n font-family: var(--font-family-body-italics);\n }\n\n a {\n text-decoration: underline;\n cursor: pointer;\n\n &[href^='tel:'] {\n text-decoration: none;\n }\n\n &:link {\n color: var(--color-primary-black);\n }\n\n &:visited {\n color: var(--color-base-dark-grey);\n }\n\n &:hover {\n color: var(--color-primary-red);\n }\n }\n"])));
10166
+ var HarmonicHeaderWithWrapper = /*#__PURE__*/styled(HarmonicHeader)(_templateObject4$A || (_templateObject4$A = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n margin-bottom: 32px;\n\n @media ", " {\n margin-bottom: 24px;\n }\n"])), devices.mobile);
10167
+ var HarmonicSubtitleWithWrapper = /*#__PURE__*/styled(HarmonicSubtitle)(_templateObject5$t || (_templateObject5$t = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n margin: 0;\n overflow-wrap: break-word;\n margin-bottom: 16px;\n"])));
10168
+ var BodyCopyHarmonicWithWrapper = /*#__PURE__*/styled(BodyCopyHarmonic)(_templateObject6$n || (_templateObject6$n = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n padding: 0;\n margin: 0;\n margin-bottom: 32px;\n whiete-space: break-spaces;\n overflow-wrap: break-word;\n\n a {\n text-decoration: underline;\n cursor: pointer;\n\n &[href^='tel:'] {\n text-decoration: none;\n }\n\n &:link {\n color: var(--color-primary-black);\n }\n\n &:visited {\n color: var(--color-base-dark-grey);\n }\n\n &:hover {\n color: var(--color-primary-red);\n }\n }\n @media ", " {\n margin-bottom: 24px;\n }\n"])), devices.mobile);
10158
10169
  var ButtonsContainer$3 = /*#__PURE__*/styled.div(_templateObject7$h || (_templateObject7$h = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n gap: 16px;\n margin-top: 32px;\n\n ", "\n\n @media ", " {\n gap: 24px;\n margin-top: 24px;\n flex-direction: column;\n align-items: center;\n }\n\n @media ", " {\n gap: 24px;\n margin-top: 24px;\n align-items: flex-start;\n\n ", "\n }\n"])), function (_ref5) {
10159
10170
  var _ref5$primaryButtonTe = _ref5.primaryButtonTextLength,
10160
10171
  primaryButtonTextLength = _ref5$primaryButtonTe === void 0 ? 0 : _ref5$primaryButtonTe,
@@ -10300,18 +10311,17 @@ var PromoWithTitle = function PromoWithTitle(_ref) {
10300
10311
  title = _ref$title === void 0 ? '' : _ref$title,
10301
10312
  _ref$titleSize = _ref.titleSize,
10302
10313
  titleSize = _ref$titleSize === void 0 ? 'large' : _ref$titleSize,
10314
+ titleHierarchy = _ref.titleHierarchy,
10303
10315
  subtitle = _ref.subtitle,
10304
10316
  text = _ref.text,
10305
10317
  links = _ref.links,
10306
10318
  children = _ref.children,
10307
10319
  videoSettings = _ref.videoSettings,
10308
- titleSemanticLevel = _ref.titleSemanticLevel,
10309
10320
  className = _ref.className;
10310
10321
  var truncate = function truncate(str, n) {
10311
10322
  return str.length >= n ? str.substr(0, n) : str;
10312
10323
  };
10313
10324
  var imageToLeft = imagePosition === 'left';
10314
- var titleLevel = titleSize === 'large' ? 2 : 3;
10315
10325
  var primaryButton = links == null ? void 0 : links[0];
10316
10326
  var _ref2 = primaryButton || {},
10317
10327
  _ref2$text = _ref2.text,
@@ -10335,20 +10345,19 @@ var PromoWithTitle = function PromoWithTitle(_ref) {
10335
10345
  imageToLeft: imageToLeft,
10336
10346
  className: className,
10337
10347
  "data-testid": "promo-with-title"
10338
- }, /*#__PURE__*/React__default.createElement(PromoChild
10339
- // eslint-disable-next-line react/no-children-prop
10340
- , {
10341
- // eslint-disable-next-line react/no-children-prop
10342
- children: children,
10348
+ }, /*#__PURE__*/React__default.createElement(PromoChild, {
10343
10349
  videoSettings: _extends({}, defaultVideoSettings, videoSettings),
10344
10350
  imageToLeft: imageToLeft
10345
- }), /*#__PURE__*/React__default.createElement(PromoWithTitleContentWrapper, {
10351
+ }, children), /*#__PURE__*/React__default.createElement(PromoWithTitleContentWrapper, {
10346
10352
  "data-testid": "content-wrapper",
10347
10353
  imageToLeft: imageToLeft
10348
- }, /*#__PURE__*/React__default.createElement(PromoWithTitleContainer, null, /*#__PURE__*/React__default.createElement(Header, {
10349
- level: titleLevel,
10350
- semanticLevel: titleSemanticLevel != null ? titleSemanticLevel : titleLevel
10351
- }, title)), subtitle ? /*#__PURE__*/React__default.createElement(PromoWithTitleSubtitle, null, subtitle) : null, /*#__PURE__*/React__default.createElement(PromoWithTitleText, {
10354
+ }, /*#__PURE__*/React__default.createElement(HarmonicHeaderWithWrapper, {
10355
+ size: titleSize,
10356
+ hierarchy: titleHierarchy
10357
+ }, title), subtitle ? /*#__PURE__*/React__default.createElement(HarmonicSubtitleWithWrapper, {
10358
+ size: "medium"
10359
+ }, subtitle) : null, /*#__PURE__*/React__default.createElement(BodyCopyHarmonicWithWrapper, {
10360
+ size: "medium",
10352
10361
  dangerouslySetInnerHTML: {
10353
10362
  __html: text
10354
10363
  }
@@ -12270,6 +12279,7 @@ var HighlightsCarousel = function HighlightsCarousel(_ref) {
12270
12279
  return !isVideoSlide(slide);
12271
12280
  });
12272
12281
  var carouselTitleId = "highlights-carousel-title-" + carouselTitle;
12282
+ var titleSemanticLevelValue = titleSemanticLevel ? "h" + titleSemanticLevel : 'h2';
12273
12283
  var carouselRef = useRef(null);
12274
12284
  var onNext = function onNext() {
12275
12285
  var _carouselRef$current;
@@ -12292,9 +12302,9 @@ var HighlightsCarousel = function HighlightsCarousel(_ref) {
12292
12302
  }, /*#__PURE__*/React__default.createElement(HeaderWrapper, {
12293
12303
  id: carouselTitleId
12294
12304
  }, /*#__PURE__*/React__default.createElement(HarmonicHeader, {
12295
- size: "small",
12305
+ size: "medium",
12296
12306
  serif: true,
12297
- hierarchy: "h" + titleSemanticLevel
12307
+ hierarchy: titleSemanticLevelValue
12298
12308
  }, carouselTitle))), hasMultipleSlides && (/*#__PURE__*/React__default.createElement(RotatorButtonsWrapperMobile, null, /*#__PURE__*/React__default.createElement(RotatorButtons, {
12299
12309
  onClickNext: onNext,
12300
12310
  onClickPrev: onPrev