From 8417da39792c370e49a4af464de5b5c1969458bb Mon Sep 17 00:00:00 2001 From: Jan Ivan Viloria <158211769+ivanvatadobe@users.noreply.github.com> Date: Thu, 16 May 2024 07:55:23 -0400 Subject: [PATCH 1/3] OPT-26580 DC0994_US | Frictionless | Add sticky banner Upload CTA (#2298) * 05-13-24 ivan dc0944 first * Update libs/mep/dc0944/aside/aside.js Co-authored-by: Vivian A Goodrich <101133187+vgoodric@users.noreply.github.com> * 05-13-24 ivan dc0944 add css changes and js optimization * Update libs/mep/dc0944/aside/aside.js Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> * Update libs/mep/dc0944/aside/aside.js Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> * Update libs/mep/dc0944/aside/aside.js Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> * Update libs/mep/dc0944/aside/aside.js Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> * Update libs/mep/dc0944/aside/aside.js Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> * 05-14-24 ivan renamed mep test folder dc0994 * 05-14-24 ivan fix sticky banner close btn --------- Co-authored-by: Vivian A Goodrich <101133187+vgoodric@users.noreply.github.com> Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> Co-authored-by: markpadbe --- libs/mep/dc0994/aside/aside.css | 1204 +++++++++++++++++++++++++++++++ libs/mep/dc0994/aside/aside.js | 236 ++++++ 2 files changed, 1440 insertions(+) create mode 100644 libs/mep/dc0994/aside/aside.css create mode 100644 libs/mep/dc0994/aside/aside.js diff --git a/libs/mep/dc0994/aside/aside.css b/libs/mep/dc0994/aside/aside.css new file mode 100644 index 00000000000..e8f2d3c2cb7 --- /dev/null +++ b/libs/mep/dc0994/aside/aside.css @@ -0,0 +1,1204 @@ +.aside { + display: flex; + width: 100%; + position: relative; + align-items: center; + justify-content: center; + overflow: hidden; +} + +.dark .aside, +.aside.dark { + color: var(--color-white); +} + +.aside p { + margin: 0; +} + +.aside.split picture { + display: flex; +} + +.aside .split-image img, +.aside .split-image video { + object-fit: cover; + min-height: 700px; + width: 100%; + height: 100%; +} + +.aside.notification .background img { + min-height: unset; +} + +.aside .foreground.container { + display: flex; + position: relative; + align-items: center; + justify-content: center; + flex-direction: column; + gap: var(--spacing-l); +} + +.aside:not(.notification):not(.inline) .foreground > :first-child { + padding: var(--spacing-xxxl) 0 0; +} + +.aside:not(.notification):not(.inline) .foreground > :last-child { + margin-bottom: var(--spacing-xxxl); +} + +.aside .foreground.container .text { + display: flex; + flex-wrap: wrap; +} + +.aside.split .foreground.container .text { + margin: 0; + max-width: var(--grid-container-width); + padding: var(--spacing-xxxl) 0 var(--spacing-l) 0; +} + +.aside.simple .foreground.container .text { + margin-bottom: 80px; +} + +.aside.notification .foreground.container .text { + max-width: none; + padding-top: 0; + padding-bottom: 0; +} + +.aside .foreground.container .image { + position: relative; + display: flex; +} + +.aside .foreground.container > div { + flex-grow: 1; + flex-basis: 0; + min-width: 0; +} + +.aside.notification .foreground.container > div { + flex-basis: 100%; +} + +.aside.inline .foreground.container .image, +.aside.inline .foreground.container .text { + padding: 0; +} + +.aside.split.large .foreground.container .text { + padding: var(--spacing-l) 0 var(--spacing-xxxl) 0; +} + +.aside.split .icon-stack-area li, +.aside.split .icon-stack-area li a { + display: flex; + align-items: center; + gap: 12px; + font-weight: bold; +} + +.aside.notification .foreground.container .text a { + white-space: nowrap; +} + +.aside:not(.notification) .foreground.container .text > * { + width: 100%; +} + +.aside .foreground.container .text .heading-xl { + margin: 0 0 var(--spacing-xs); +} + +.aside .foreground.container .text .body-m, +.aside .foreground.container .text .body-s { + margin-bottom: var(--spacing-s); +} + +.aside .foreground.container .text .supplemental-text { + padding-top: var(--spacing-s); + margin-bottom: 0; +} + +.aside.promobar .promo-text .action-area { + flex-wrap: nowrap; + gap: var(--spacing-xs); +} + +.aside.promobar .promo-text .action-area, +.aside .foreground.container .text .action-area { + margin-bottom: 0; + display: flex; + gap: var(--spacing-s); + flex-wrap: wrap; + align-items: center; +} + +.aside.notification .icon-area { + display: flex; + align-items: center; +} + +.aside .foreground.container .icon-area { + height: 56px; + max-width: 234px; + margin-bottom: var(--spacing-s); +} + +.aside .foreground.container a.icon-area { + height: auto; + margin-bottom: 0; +} + +.aside.split .split-image img, +.aside.split .split-image video { + position: relative; + min-height: 270px; +} + +.aside.split .split-image video { + display: block; +} + +.aside.split .mobile-square img, +.aside.split .mobile-square video { + aspect-ratio: var(--aspect-ratio-square); +} + +.aside.split .mobile-wide img, +.aside.split .mobile-wide video { + aspect-ratio: var(--aspect-ratio-wide); +} + +.aside.split .mobile-standard img, +.aside.split .mobile-standard video { + aspect-ratio: var(--aspect-ratio-standard); +} + +.aside.split .format img, +.aside.split .format video { + height: auto; +} + +.aside.split .icon-stack-area li img { + width: var(--icon-size-m); + height: auto; +} + +.aside.split .format picture, +.aside.split .format video { + display: flex; + height: 100%; + align-items: center; +} + +.aside .foreground.container .icon-area img { + max-width: 234px; + height: var(--icon-size-l); + width: auto; + object-fit: cover; + object-position: left top; +} + +.aside.simple .foreground.container .image { + display: none; +} + +.aside.split { + flex-direction: column; +} + +.aside.split.large { + flex-direction: column-reverse; +} + +.aside.split .foreground.container { + width: 100%; + max-width: 100%; + flex-direction: column; + z-index: 1; +} + +.aside.split .background { + position: relative; +} + +.aside.split.large .background { + background-color: transparent; +} + +.aside.split .foreground.container .image { + margin: 0; + display: none; +} + +.aside.split .icon-stack-area li picture { + flex-shrink: 0; +} + +.aside.notification .text [class^="heading-"] + .action-area { + margin-top: var(--spacing-xs); +} + +.aside.notification .foreground.container img { + display: block; +} + +.aside .foreground.container .image video, +.aside .foreground.container .image picture, +.aside .foreground.container .image picture img { + width: 100%; + display: flex; +} + +.aside.split .foreground.container .split-image img, +.aside.split .foreground.container .split-image video { + object-fit: cover; + height: 270px; +} + +.aside.inline { + border-radius: 10px; +} + +.aside.inline .foreground.container { + width: 100%; + min-height: 0; + margin: var(--spacing-m); + padding: 0; + gap: var(--spacing-m); +} + +.aside.inline .foreground.container .image { + margin-top: 0; +} + +.aside.inline .heading-s { + margin-bottom: var(--spacing-s); +} + +.aside.notification { + min-height: 0; +} + +.aside.notification .foreground.container { + padding-top: var(--spacing-s); + padding-bottom: var(--spacing-s); + box-sizing: border-box; + justify-content: flex-start; +} + +.aside.notification .foreground.container .image { + max-width: 75px; + margin: 0; + order: -1; +} + +.aside.notification .foreground.container .text a:not(.con-button) { + width: auto; + font-weight: normal; +} + +.aside.notification .foreground.container .text .action-area > a { + margin-right: 0; +} + +.aside.promobar .foreground.container { + min-height: 0; + display: flex; + flex-direction: column; + padding: 0; + margin: 0; +} + +.aside.promobar .foreground.container .icon-area { + margin-bottom: 0; + height: var(--icon-size-m); +} + +.aside.promobar .foreground.container .icon-area img { + height: var(--icon-size-m); +} + +.aside.notification.extra-small .foreground.container a:last-child { + font-weight: bold; +} + +.aside.notification.extra-small .foreground.container a:not(.con-button):last-of-type { + margin-left: var(--spacing-xs); + color: var(--link-color); +} + +.static-links .aside.notification.extra-small .foreground.container a:not(.con-button):last-of-type { + color: inherit; +} + +.aside.notification.small .foreground.container .text a.con-button { + display: table; + margin-left: 0; +} + +.aside.notification .foreground.container .text .heading-l { + margin-bottom: var(--spacing-xxs); +} + +.aside.notification .foreground.container:not(.no-image) .text .body-s.action-area, +.aside.notification .foreground.container:not(.no-image) .text .body-m.action-area { + margin-bottom: 0; +} + +.aside.notification .foreground.container .icon-area { + height: auto; + max-width: none; + margin-bottom: var(--spacing-xs); +} + +.aside.notification .foreground.container .icon-area img { + max-height: 40px; + height: auto; +} + +.aside.notification.extra-small .foreground.container { + min-height: 50px; + padding-top: var(--spacing-xs); + padding-bottom: var(--spacing-xs); +} + +.aside.notification.extra-small .foreground.container .text { + display: block; +} + +.aside.notification.medium .foreground.container .text, +.aside.notification.large .foreground.container .text { + flex-direction: column; +} + +.aside.notification.small .foreground.container .text { + flex-direction: column; + max-width: 1000px; +} + +.aside.center:not(.notification) .foreground.container .text { + margin: 80px 0; + text-align: center; + padding: 0; +} + +.aside.notification.center.small .foreground.container .text { + text-align: left; +} + +.aside.notification.center.small .foreground.container .text, +.aside.notification.center.extra-small .foreground.container .text { + margin: 0 auto; +} + +.aside.notification.small { + min-height: 88px; +} + +.aside.notification.medium { + min-height: 160px; +} + +.aside.notification.large { + min-height: 250px; +} + +.aside.notification.medium .foreground.container { + max-width: 800px; + gap: var(--spacing-xs); +} + +.aside.notification.medium .foreground.container .text .heading-s { + margin-bottom: var(--spacing-xxs); +} + +.aside.notification.center.small .foreground.container .text p { + text-align: initial; +} + +.aside.notification.large .foreground.container { + max-width: 1000px; + gap: var(--spacing-xs); +} + +.aside.notification .foreground.container [data-align=center], +.aside.notification.center .foreground.container, +.aside.notification.center .foreground.container > * { + text-align: center; + justify-content: center; +} + +.aside.promobar.popup .foreground.container { + width: 100%; + padding: 0; +} + +.aside.center:not(.notification) .foreground.container { + padding: 0; +} + +.aside.notification.large.center .foreground.container, +.aside.notification.large .foreground.container.no-image { + max-width: 800px; +} + +.aside.promobar.popup .promo-text .action-area { + justify-content: flex-end; + padding: 0 var(--spacing-xxs) var(--spacing-xxs) 0; + gap: var(--spacing-xxs); +} + +.aside.notification.center .foreground.container .action-area { + justify-content: center; +} + +.aside.notification.center.small .foreground.container .text, +.aside.notification.center.small .foreground.container .text > * { + justify-content: flex-start; +} + +.aside.split .icon-stack-area { + display: flex; + flex-flow: row wrap; + flex-direction: column; + gap: 12px; + margin: -8px 0 var(--spacing-s); + width: 100%; + padding: 0; + list-style-type: none; +} + +.aside.promobar.popup .promo-text .icon-area, +.aside.promobar.popup .promo-text .icon-area img { + display: flex; + gap: var(--spacing-xxs); + align-items: center; + height: var(--icon-size-xs); +} + +.aside.center:not(.notification) .foreground.container .icon-area { + max-width: 100%; +} + +.aside.center:not(.notification) .foreground.container .text .action-area { + justify-content: center; +} + +.aside:not(.notification) .foreground.container .text .detail-m { + margin-bottom: var(--spacing-xs); +} + +.aside.split .image.format { + display: flex; +} + +.aside.split.bio .foreground.container .text .icon-area { + display: none; +} + +.aside.center:not(.notification) .foreground.container .text .icon-area { + height: var(--icon-size-xxl); +} + +.aside.center:not(.notification) .foreground.container .text .icon-area img { + height: var(--icon-size-xxl); + max-width: 300px; + width: auto; +} + +.aside.promobar .foreground.container > :first-child { + padding: var(--spacing-xs) 0; +} + +.aside.promobar .promo-text[data-align="center"] { + justify-content: center; +} + +.aside.promobar .action-area .con-button { + flex-shrink: 0; +} + +.aside.promobar .promo-text.desktop-up, +.aside.promobar .promo-text.tablet-up { + display: none; +} + +.aside.promobar .promo-text.mobile-up { + display: flex; +} + +.aside.promobar .promo-text { + display: flex; + flex-flow: row nowrap; + gap: var(--spacing-xs); + justify-content: space-between; + width: 100%; + padding: var(--spacing-xs) 0; +} + +.aside.promobar .promo-text .content-area { + display: flex; + flex-flow: row nowrap; + gap: var(--spacing-xs); + align-items: center; +} + +.aside.promobar.popup { + border-radius: var(--spacing-xs); + width: var(--grid-container-width); + margin: auto; + box-shadow: 0 3px 6px #707070; +} + +.aside.promobar.popup .foreground.container .promo-text { + flex-direction: column; + padding: 0; +} + +.aside.promobar.popup .promo-text .content-area { + padding: var(--spacing-xs) var(--spacing-xs) 0 var(--spacing-xs); + flex-direction: column; + align-items: flex-start; + gap: var(--spacing-xxs); +} + +.aside.promobar.popup .promo-text .text-area { + margin-top: var(--spacing-m); +} + +.aside.promobar.popup .promo-text .icon-area+.text-area { + margin-top: 0; +} + +.aside.promobar.popup .promo-text .content-area .text-area { + display: flex; + flex-direction: column; + gap: var(--spacing-xxs); +} + +.aside.promobar.popup .mobile-up.promo-text .detail-xs+.text-area { + gap: var(--spacing-xs); +} + +.aside.promobar.popup .promo-close { + position: absolute; + right: var(--spacing-xxs); + top: var(--spacing-xxs); + height: 20px; + width: 20px; + border: none; + background: none; + cursor: pointer; +} + +.aside.promobar.popup .promo-close svg { + position: absolute; + top: 0; + left: 0; +} + +.aside.promobar.popup .promo-close circle { + fill: var(--color-black); +} + +.aside.promobar.popup .promo-close line { + stroke: var(--color-white); +} + +@media screen and (max-width: 600px) { + .aside.no-media:not(.notification) .foreground.container { + gap: 0; + } + + .aside.split.no-media:not(.notification) .foreground.container .text { + padding: var(--spacing-xxxl) 0; + } + + .aside.promobar.popup .mobile-up.hide-block ~ .promo-close { + display: none; + } +} + +@media screen and (min-width: 600px) { + .aside.small { + min-height: 420px; + } + + .aside.medium { + min-height: 560px; + } + + .aside.large { + min-height: 700px; + } + + .aside .foreground.container { + align-items: center; + flex-direction: row; + margin: 0 auto; + padding: var(--spacing-m) 0; + gap: var(--spacing-xl); + } + + .aside:not(.notification):not(.inline) .foreground.container > :first-child { + padding: 0; + } + + .aside:not(.notification):not(.inline):not(.center) .foreground.container > :last-child { + margin-bottom: 0; + } + + .aside .foreground.container .image { + margin: 0; + } + + .aside .foreground.container .text.image { + justify-content: flex-start; + } + + .aside .background, + .aside.split .split-image { + overflow: hidden; + position: absolute; + left: 0; + right: 0; + top: 0; + bottom: 0; + } + + .aside .foreground.container .text { + margin-bottom: 0; + padding-right: var(--spacing-s); + } + + .aside.split-right .foreground.container .text { + padding-left: var(--spacing-s); + } + + .aside.simple .foreground.container .text { + margin-bottom: 0; + max-width: 318px; + padding-right: 0; + } + + .aside.split .split-image { + overflow: hidden; + position: absolute; + left: 0; + right: 0; + top: 0; + bottom: 0; + } + + .aside.split .tablet-wide img, + .aside.split .tablet-wide video { + aspect-ratio: var(--aspect-ratio-wide); + } + + .aside.split .tablet-standard img, + .aside.split .tablet-standard video { + aspect-ratio: var(--aspect-ratio-standard); + } + + .aside.split-right .split-image img, + .aside.split-right .split-image video { + left: 0; + } + + .aside.split.large { + flex-direction: column; + } + + .aside .split-image .modal-img-link, + .aside.split .split-image img, + .aside.split .split-image video { + width: 60.5vw; + max-width: 56%; + position: absolute; + right: 0; + object-fit: cover; + object-position: center top; + } + + .aside .split-image .modal-img-link, + .aside.split.half .split-image img, + .aside.split.half .split-image video { + width: 50vw; + max-width: 1396px; + object-position: left top; + } + + .aside.split.split-left .split-image img, + .aside.split.split-left .split-image video { + right: 0; + left: auto; + } + + .aside.split.split-right .split-image img, + .aside.split.split-right .split-image video { + left: 0; + right: auto; + } + + [dir="rtl"] .aside.split.split-right .split-image img, + [dir="rtl"] .aside.split.split-right .split-image video { + right: 0; + left: auto; + } + + [dir="rtl"] .aside.split.split-left .split-image img, + [dir="rtl"] .aside.split.split-left .split-image video { + left: 0; + right: auto; + } + + .aside.split .foreground.container { + flex-direction: row; + justify-content: stretch; + max-width: var(--grid-container-width); + margin: 0 auto; + background-color: transparent; + } + + .aside.split .foreground.container .text { + flex: 0 0 31vw; + padding: var(--spacing-xxl) 0; + max-width: 100%; + margin: 0; + } + + .aside.split .foreground.container .image { + object-fit: cover; + flex: 0 0 61%; + display: block; + padding: 0; + } + + .aside.inline .foreground.container .text { + flex: 0 0 calc(60% - var(--spacing-s)); + max-width: none; + } + + .aside.notification .foreground.container .text { + padding-right: 0; + } + + .aside.notification.small .foreground.container .text { + flex-flow: row nowrap; + align-items: center; + flex-grow: 1; + } + + .aside.notification.small .foreground.container .text .body-m { + margin: 0; + } + + .aside.notification.small .foreground.container .text .body-m.action-area { + margin-left: 24px; + } + + [dir = "rtl"] .aside.notification.small .foreground.container .text .body-m.action-area { + margin-left: 0; + margin-right: 24px; + } + + .aside.split.half .foreground.container .text { + flex: 0 0 41.72%; + } + + .aside.split-right .foreground.container { + flex-direction: row-reverse; + } + + .aside.inline .foreground.container .image { + flex: 0 0 calc(40% - var(--spacing-s)); + margin-bottom: 0; + } + + .aside.notification .foreground.container { + flex-direction: row; + } + + .aside.notification.medium .foreground.container, + .aside.notification.large .foreground.container { + gap: var(--spacing-s); + } + + .aside.notification .foreground.container .image { + width: 30%; + max-width: 188px; + margin: 0; + padding: 0; + order: unset; + } + + .aside.notification .foreground.container .text+.image { + margin-right: 0; + } + + .aside.notification .foreground.container .icon-area { + width: auto; + margin-right: var(--spacing-xs); + margin-bottom: 0; + } + + [dir = "rtl"] .aside.notification .foreground.container .icon-area { + margin-left: var(--spacing-xs); + margin-right: 0; + } + + .aside.notification.extra-small .foreground.container.no-image .text { + display: flex; + } + + .aside.notification.extra-small .foreground.container.no-image .text a { + margin-left: 5px; + } + + .aside.promobar.popup .promo-text .action-area { + justify-content: center; + padding: 0 0 var(--spacing-xxs); + } + + .aside.notification.small .foreground.container .text .action-area { + width: auto; + margin-top: 0; + } + + .aside.split.bio .foreground.container .text .icon-area { + display: block; + } + + .aside.notification.small .foreground.container .text .icon-area { + height: 40px; + } + + .aside.center:not(.notification) .foreground.container .text .icon-area img { + max-width: 234px; + } + + .aside.medium.split.bio .foreground.container .text .icon-area, + .aside.large.split.bio .foreground.container .text .icon-area { + height: var(--icon-size-xxl); + margin-bottom: var(--spacing-xs); + } + + .aside.medium.split.bio .foreground.container .text .icon-area img, + .aside.large.split.bio .foreground.container .text .icon-area img { + width: var(--icon-size-xxl); + height: var(--icon-size-xxl); + border-radius: 50%; + } + + .aside.promobar .promo-text .content-area .text-area { + display: flex; + flex-flow: column nowrap; + gap: var(--spacing-xxs); + } + + .aside.promobar .promo-text.mobile-up, + .aside.promobar .promo-text.desktop-up { + display: none; + } + + .aside.promobar .promo-text.tablet-up { + display: flex; + } + + .aside.promobar.popup .promo-text { + gap: var(--spacing-s); + } + + .aside.promobar.popup .promo-text .content-area { + padding: var(--spacing-xxs) 0 0; + align-items: center; + text-align: center; + } +} + +@media (min-width: 600px) and (max-width: 1200px) { + .aside.promobar.popup .tablet-up.hide-block ~ .promo-close { + display: none; + } +} + +@media screen and (min-width: 1200px) { + .aside .foreground.container { + min-height: 420px; + width: var(--grid-container-width); + } + + .aside .foreground.container > div { + object-fit: cover; + padding-left: 0; + } + + .aside .foreground.container .text { + padding: var(--spacing-xxl) 0; + } + + .aside .foreground.container .icon-area { + max-width: 400px; + } + + .aside .foreground.container .text .heading-xl { + margin: 0 0 var(--spacing-xs); + } + + .aside.inline .foreground.container .text { + flex: 0 0 calc(64% - var(--spacing-s)); + } + + .aside.simple .foreground.container .text { + margin-bottom: 0; + max-width: 500px; + } + + .aside.split .foreground.container .text { + flex: 0 0 300px; + } + + .aside.split .foreground.container .image { + flex: 0 0 70%; + max-width: none; + object-fit: cover; + } + + .aside.split .split-image img, + .aside.split .split-image video { + max-width: 1396px; + } + + .aside.split .desktop-wide img, + .aside.split .desktop-wide video { + aspect-ratio: var(--aspect-ratio-wide); + } + + .aside.split .desktop-standard img, + .aside.split .desktop-standard video { + aspect-ratio: var(--aspect-ratio-standard); + } + + .aside.split.half .foreground.container .text { + max-width: 500px; + } + + .aside.inline { + max-width: 800px; + margin-right: auto; + margin-left: auto; + } + + .aside.inline .foreground.container .image { + flex: 0 0 calc(36% - var(--spacing-s)); + } + + .aside.split.icon-stack .foreground.container .text, + .aside.split.bio .foreground.container .text { + padding: var(--spacing-xxl) 0; + } + + .aside.split .icon-stack-area li { + max-width: calc(50% - 6px); + min-width: calc(50% - 6px); + } + + .aside.split .icon-stack-area { + flex-direction: row; + } + + .aside.promobar .foreground.container .icon-area, + .aside.promobar .foreground.container .icon-area img { + height: var(--icon-size-xxl); + } + + .aside.promobar.popup .promo-text .icon-area, + .aside.promobar.popup .promo-text .icon-area img { + height: var(--icon-size-m); + } + + .aside.center:not(.notification) .foreground.container .text .icon-area img { + max-width: 400px; + } + + .aside.center:not(.notification) .foreground.container .text { + max-width: 50%; + } + + .aside.notification .foreground.container { + min-height: 0; + } + + .aside.notification.extra-small .foreground.container { + padding-top: var(--spacing-xxs); + padding-bottom: var(--spacing-xxs); + } + + .aside.notification.medium .foreground.container { + gap: var(--spacing-m); + } + + .aside.notification.large .foreground.container { + gap: var(--spacing-l); + } + + .aside.notification .foreground.container .image { + width: 20%; + } + + .aside.notification .foreground.container .text+.image { + margin-right: 0; + } + + .aside.notification.small .foreground.container .text { + align-items: center; + justify-content: flex-start; + } + + .aside.notification.center.small .foreground.container .text, + .aside.notification.center.small .foreground.container .text > * { + justify-content: center; + } + + .aside.notification.center.small .foreground.container .text p { + text-align: center; + } + + .aside.notification.medium .foreground.container .image { + max-width: 168px; + } + + .aside.notification.large .foreground.container .image { + max-width: 304px; + } + + .aside.notification.medium .foreground.container .text+.image { + margin-right: 0; + } + + .aside.promobar .promo-text .content-area { + gap: var(--spacing-m); + } + + .aside.promobar .promo-text .content-area .text-area { + gap: var(--spacing-xs); + } + + .aside.promobar .promo-text .action-area { + gap: var(--spacing-s); + } + + .aside.promobar .promo-text.mobile-up, + .aside.promobar .promo-text.tablet-up { + display: none; + } + + .aside.promobar .promo-text.desktop-up { + display: flex; + gap: var(--spacing-m); + } + + .aside.promobar.popup { + border-radius: var(--spacing-xl); + width: 85%; + max-width: 1600px; + } + + .aside.promobar.popup .foreground.container .promo-text { + padding: var(--spacing-xs) 0; + flex-direction: row; + gap: var(--spacing-l); + justify-content: center; + max-width: 83.4%; + } + + .aside.promobar.popup .promo-text .content-area, + .aside.promobar.popup .promo-text .action-area { + flex-direction: row; + padding: 0; + gap: var(--spacing-xs); + min-height: 40px; + } + + .aside.promobar.popup .promo-close { + right: var(--spacing-s); + top: calc(50% - 10px); + } + + .aside.promobar.popup .desktop-up.hide-block ~ .promo-close { + display: none; + } + + .aside.promobar.popup .promo-text .text-area { + margin-top: 0; + } +} + +/* Added for frictionless dc0944 */ +.section.hide-on-step-start:not(.hide-sticky-section):not(.close-sticky-section) { + background: none !important; + display: flex; + justify-content: center; + padding: 0 7% 20px; +} + +.aside.frictionless { + background-color: rgb(0, 11, 29); + max-width: 1200px; + border-radius: 50px; + display: flex; + justify-content: center; + align-items: center; + position: relative; +} + +.aside.frictionless .foreground.container { + position: relative; + flex-direction: row; +} + +.aside.frictionless .promo-close { + background: rgb(0, 11, 29); + margin: 0; + width: 20px; + height: 20px +} + +.aside.frictionless .promo-text { + justify-content: center; +} + +.aside.frictionless .promo-text .text-area { + display: flex; + flex-direction: row !important; +} + +.aside.frictionless .promo-text .icon-area { + height: auto !important; +} + +.aside.frictionless .promo-text .icon-area img { + height: 38px !important; +} + +body.dc-bc[data-current-event="start"] .section.hide-on-step-start { + display: none; + background-color: none; +} + +@media screen and (min-width: 1440px) { + .aside.frictionless .promo-close { + position: absolute; + right: 40px; + } +} + +.sticky-banner-disable { + display: none !important; +} diff --git a/libs/mep/dc0994/aside/aside.js b/libs/mep/dc0994/aside/aside.js new file mode 100644 index 00000000000..2283e0e1d93 --- /dev/null +++ b/libs/mep/dc0994/aside/aside.js @@ -0,0 +1,236 @@ +/* + * Copyright 2022 Adobe. All rights reserved. + * This file is licensed to you under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. You may obtain a copy + * of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under + * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS + * OF ANY KIND, either express or implied. See the License for the specific language + * governing permissions and limitations under the License. + */ + +/* +* Aside - v5.1 +*/ + +import { decorateBlockText, decorateIconStack, applyHoverPlay, decorateBlockBg } from '../../../utils/decorate.js'; +import { createTag } from '../../../utils/utils.js'; + +// standard/default aside uses same text sizes as the split +const variants = ['split', 'inline', 'notification']; +const sizes = ['extra-small', 'small', 'medium', 'large']; +const [split, inline, notification] = variants; +const [xsmall, small, medium, large] = sizes; +const blockConfig = { + [split]: ['xl', 's', 'm'], + [inline]: ['s', 'm'], + [notification]: { + [xsmall]: ['m', 'm'], + [small]: ['m', 'm'], + [medium]: ['s', 's'], + [large]: ['l', 'm'], + }, +}; +const FORMAT_REGEX = /^format:/i; +const closeSvg = ` + + + + + + `; + +const linkSectionToModuleStep = (el) => el.closest('.section').classList.add('hide-on-step-start'); + +function editCtaToModuleClick(el) { + el.querySelectorAll('a').forEach((cta) => { + if (cta.href.toLowerCase().includes('#module')) { + cta.addEventListener('click', (e) => { + e.preventDefault(); + window.scrollTo(0, 0); + document.querySelector('.CTAButtons')?.click(); + }); + } + }); +} + +function getBlockData(el) { + const variant = variants.find((variantClass) => el.classList.contains(variantClass)); + const size = sizes.find((sizeClass) => el.classList.contains(sizeClass)); + const blockData = variant ? blockConfig[variant] : blockConfig[Object.keys(blockConfig)[0]]; + return variant && size && !Array.isArray(blockData) ? blockData[size] : blockData; +} + +function decorateStaticLinks(el) { + if (!el.classList.contains('notification')) return; + el.querySelectorAll('a:not([class])').forEach((link) => { link.classList.add('static'); }); +} + +function decorateMedia(el) { + if (!(el.classList.contains('medium') || el.classList.contains('large'))) return; + const allMedia = el.querySelectorAll('div > p video, div > p picture'); + [...allMedia].some((media) => { + const parentP = media.closest('p'); + const siblingP = parentP?.nextElementSibling; + if (!siblingP || siblingP.nodeName !== 'P') return false; + const siblingText = siblingP.textContent; + if (!FORMAT_REGEX.test(siblingText)) return false; + const formats = siblingText.split(': ')[1]?.split(/\s+/); + if (formats) { + const formatClasses = []; + formatClasses.push('format'); + if (formats.length === 3) formatClasses.push(`desktop-${formats[2]}`); + if (formats.length >= 2) formatClasses.push(`tablet-${formats[1]}`); + formatClasses.push(`mobile-${formats[0]}`); + media.closest('div').classList.add(...formatClasses); + } + siblingP.remove(); + media.closest('div').insertBefore(media, parentP); + parentP.remove(); + return true; + }); +} + +function formatPromoButton(el) { + if (!el.classList.contains('promobar')) return; + el.querySelectorAll('.action-area').forEach((aa) => { + aa.querySelectorAll('.con-button').forEach((btn) => { + btn.classList.add('button-l'); + if (!el.classList.contains('popup')) return; + if (!btn.classList.contains('outline')) btn.classList.add('fill'); + }); + }); +} + +function addCloseButton(el) { + const closeBtn = createTag('button', { class: 'promo-close', 'aria-label': 'Close' }, closeSvg); + el.querySelector('.foreground').appendChild(closeBtn); + closeBtn.addEventListener('click', (e) => { + e.target.closest('.section').classList.add('close-sticky-section'); + }); +} + +function addPromobar(sourceEl, parent) { + parent.appendChild(sourceEl.cloneNode(true)); +} + +function checkViewportPromobar(foreground) { + const { children, childElementCount: childCount } = foreground; + if (childCount < 2) addPromobar(children[childCount - 1], foreground); + if (childCount < 3) addPromobar(children[childCount - 1], foreground); +} + +function combineTextBocks(textBlocks, iconArea, viewPort, variant) { + const promobarConfig = { + default: { + 'mobile-up': ['s', 's'], + 'tablet-up': ['s', 's'], + 'desktop-up': ['m', 'l'], + }, + popup: { + 'mobile-up': ['s', 's'], + 'tablet-up': ['l', 'm'], + 'desktop-up': ['xxl', 'xl'], + }, + }; + const textStyle = promobarConfig[variant][viewPort]; + const contentArea = createTag('p', { class: 'content-area' }); + const textArea = createTag('p', { class: 'text-area' }); + textBlocks[0].parentElement.prepend(contentArea); + textBlocks.forEach((textBlock) => { + textArea.appendChild(textBlock); + if (textBlock.nodeName === 'P') { + textBlock.classList.add(`body-${textStyle[1]}`); + } else { + textBlock.classList.add(`heading-${textStyle[0]}`); + } + }); + if (iconArea) { + if (iconArea.innerText?.trim()) iconArea.classList.add('detail-xs'); + iconArea.classList.add('icon-area'); + contentArea.appendChild(iconArea); + } + contentArea.appendChild(textArea); +} + +function decoratePromobar(el) { + const viewports = ['mobile-up', 'tablet-up', 'desktop-up']; + const foreground = el.querySelector('.foreground'); + const variant = el.classList.contains('popup') ? 'popup' : 'default'; + if (foreground.childElementCount !== 3) checkViewportPromobar(foreground); + [...foreground.children].forEach((child, index) => { + child.className = viewports[index]; + child.classList.add('promo-text'); + const textBlocks = [...child.children]; + const iconArea = child.querySelector('picture')?.closest('p'); + const actionArea = child.querySelectorAll('em a, strong a, p > a strong'); + if (iconArea) textBlocks.shift(); + if (actionArea.length) textBlocks.pop(); + if (!(textBlocks.length || iconArea || actionArea.length)) child.classList.add('hide-block'); + else if (textBlocks.length) combineTextBocks(textBlocks, iconArea, viewports[index], variant); + }); + if (variant === 'popup' || el.classList.contains('frictionless')) addCloseButton(el); + return foreground; +} + +function decorateLayout(el) { + const elems = el.querySelectorAll(':scope > div'); + if (elems.length > 1) { + decorateBlockBg(el, elems[0]); + } + const foreground = elems[elems.length - 1]; + foreground.classList.add('foreground', 'container'); + if (el.classList.contains('promobar')) return decoratePromobar(el); + if (el.classList.contains('split')) decorateMedia(el); + const text = foreground.querySelector('h1, h2, h3, h4, h5, h6, p')?.closest('div'); + text?.classList.add('text'); + const media = foreground.querySelector(':scope > div:not([class])'); + if (media && !el.classList.contains('notification')) { + media.classList.add('image'); + const video = media.querySelector('video'); + if (video) applyHoverPlay(video); + } + const picture = text?.querySelector('p picture'); + const iconArea = picture ? (picture.closest('p') || createTag('p', null, picture)) : null; + iconArea?.classList.add('icon-area'); + const foregroundImage = foreground.querySelector(':scope > div:not(.text) img')?.closest('div'); + const bgImage = el.querySelector(':scope > div:not(.text):not(.foreground) img')?.closest('div'); + const foregroundMedia = foreground.querySelector(':scope > div:not(.text) video, :scope > div:not(.text) a[href*=".mp4"]')?.closest('div'); + const bgMedia = el.querySelector(':scope > div:not(.text):not(.foreground) video, :scope > div:not(.text):not(.foreground) a[href*=".mp4"]')?.closest('div'); + const image = foregroundImage ?? bgImage; + const asideMedia = foregroundMedia ?? bgMedia ?? image; + const isSplit = el.classList.contains('split'); + const hasMedia = foregroundImage ?? foregroundMedia ?? (isSplit && asideMedia); + if (!hasMedia) el.classList.add('no-media'); + if (asideMedia && !asideMedia.classList.contains('text')) { + asideMedia.classList.add(`${isSplit ? 'split-' : ''}image`); + if (isSplit) { + const position = [...asideMedia.parentNode.children].indexOf(asideMedia); + el.classList.add(`split${!position ? '-right' : '-left'}`); + foreground.parentElement.appendChild(asideMedia); + } + } else if (!iconArea) { + foreground?.classList.add('no-image'); + } + if (el.classList.contains('split') + && (el.classList.contains('medium') || el.classList.contains('large'))) { + decorateIconStack(el); + } + return foreground; +} + +export default function init(el) { + el.classList.add('con-block'); + const blockData = getBlockData(el); + const blockText = decorateLayout(el); + decorateBlockText(blockText, blockData); + decorateStaticLinks(el); + formatPromoButton(el); + if (el.classList.contains('frictionless')) { + if (document.querySelectorAll('.CTAButtons').length) { + linkSectionToModuleStep(el); + editCtaToModuleClick(el); + } else el.closest('.section').classList.add('.sticky-banner-disable'); + } +} From a17d00c35c271a3d4ddb67e6ee7d45c95b9ebd99 Mon Sep 17 00:00:00 2001 From: "milo-pr-merge[bot]" <169241390+milo-pr-merge[bot]@users.noreply.github.com> Date: Thu, 16 May 2024 13:56:15 +0200 Subject: [PATCH 2/3] [Release] Stage to Main (#2309) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * MWPW-147599: CaaS Bulk Publisher not working after MS authentication change (#2248) Potential fix for bulk publisher issues Co-authored-by: Blaine Gunn Co-authored-by: Sheridan Sunier * Preflight Accessibility tab update (#2254) Updating how alt text is used and displayed in preflight Co-authored-by: Ryan Clayton * MWPW-146407: add new card style to caas configurator (#2279) Co-authored-by: Brad Johnson Co-authored-by: Sheridan Sunier * MWPW-141780 - Clean up Accordion block attributes (#2276) remove role attribute on dd elements Co-authored-by: Okan Sahin <39759830+mokimo@users.noreply.github.com> * MWPW-147158: adds support for footer divider at the collection level (#2198) * MWPW-147158: adds support for footer divider at the collection level * Updatest unit-test files * Update windows copy hash * Update OSX copy hash * Updates OSX hash again * Removes console log * Adds console logs for debbuging * Removes console logs * Adds console logs for debbuging again * Removes console log * Updates OSX hash * Adds debuging message to test * Update os-hash check logic * trim() generated hash * Changes the comparison logic for the hash * Reverts last attempt * new attempt to fix test --------- Co-authored-by: Okan Sahin <39759830+mokimo@users.noreply.github.com> * MWPW-147594: Consumers mappings for origin not being sent when using sidekick (#2244) * Fix for origin always being upper cased * Update tools/send-to-caas/send-utils.js changing to const Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> --------- Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: Okan Sahin <39759830+mokimo@users.noreply.github.com> * Stage automation, update the body after merging another PR in (#2289) * Stage process improvements * Remove team reviewers * Formatting * Simplify PR bodies --------- Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> * Remove label requirements & merge workflows (#2288) Remove label & merge workflows Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> * Quiz entry block (#2294) * Initial quiz-entry block with ml field * MWPW-144810: Quiz Entry - Add option cards and text to the block (#2095) * Quiz entry block (#2103) * MWPW-144810: Quiz Entry - Add option cards and text to the block * MWPW-144810: Add the text to strings.xlsx for title, subtitle, ML field default, card instruction bar and the button * MWPW-146243 - Quiz entry code optimization (#2121) * MWPW-146243 - Quiz entry code optimization * Restores code optimization that was lost in previous PRs Resolves: [MWPW-146243](https://jira.corp.adobe.com/browse/MWPW-146243) * Update utils.js * Update quiz-entry.js Set button to use string values * Update quiz-entry.js Fixed to use new strings object * MWPW-146034 - Quiz entry block accessibility (#2139) * resolved accessibility concerns when the ml input is used * general code refinements for more clarity, specifically for getting string values Resolves: [MWPW-146034](https://jira.corp.adobe.com/browse/MWPW-146034) * MWPW-146036 - Rig up quiz entry button (#2190) * Support for ml filtering * Debug support using ?debug=quiz-entry * Store quizState in local storage and redirect to the quiz Resolves: [MWPW-146036](https://jira.corp.adobe.com/browse/MWPW-146036) * Quiz entry block (#2204) * MWPW-144810: Quiz Entry - Add option cards and text to the block * MWPW-144810: Add the text to strings.xlsx for title, subtitle, ML field default, card instruction bar and the button * MWPW-147031:Add Analytics for Quiz Entry Block, MWPW-146080: Integrate Auto-Complete for Open Text Field on UAR Exposed Front Door * fix eslint * fix code according feedbacks * MWPW-144022: Quiz entry block (#2227) * carousel starts * got buttons working * MWPW-144022: Prototype carousel refinement, keybord controls updated * linting fixes * MWPW-147482 - ML Input Bulletproofing (#2242) * add support for fallback fi codes * add lana logging for ml field failures * fix so the redirect checks for maxQuestions Resolves: [MWPW-147482](https://jira.corp.adobe.com/browse/MWPW-147482) **Test URLs:** - Before: https://main--milo--adobecom.hlx.page/?martech=off - After: https://--milo--adobecom.hlx.page/?martech=off * MWPW-147683 - CSS Cleanup (#2267) * MWPW-147683 - CSS Cleanup * Final pass on the css * Edits to markup where necessary Resolves: [MWPW-147683](https://jira.corp.adobe.com/browse/MWPW-147683) * pr feedback for vars and eslint errors * more PR feedback on icon placement * pr feedback for button border * cleaned up the carousel widths so it's consistent it all times as it was previously 8px short. * pr feedback on the location of the input clear X. * PR feedback - reduced border on input, fixed a card disable bug, addressed card layout in tablet * carousel starts * got buttons working * MWPW-144022: Prototype carousel refinement, keybord controls updated * linting fixes * Tests * working tests update * Small font size fixes that design has asked for * linting * linting * Update quiz-entry.js with default vals * Bring back debug * debugging debug * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/quiz-entry.test.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/quiz-entry.test.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * added quiz-entry to utils.js (#2296) Co-authored-by: Denys Fedotov * MWPW-148206: Update Spectra ML host from cchome-dev to cchome for PROD --------- Co-authored-by: Jacky Sun <67350368+JackySun9@users.noreply.github.com> Co-authored-by: Brad Johnson Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: Denys Fedotov Co-authored-by: Denys Fedotov Co-authored-by: Jacky Sun * MWPW-147472: auto adjust commerce iframe (#2251) * MWPW-147472: auto adjust commerce iframe. * typo fix * fix for potential bfcache issues * improve modal selector query w.r.t hash improve test. --------- Co-authored-by: Mira Fedas <30750556+mirafedas@users.noreply.github.com> * MWPW-141725 Graybox Block (#2282) * Initial graybox overlay * Add title & desc support * Use more variables * Add tests; fix issues found with tests * Add blue design changes + body outline * Fix blue border on device preview. Small bug fixes. * Only enable on -graybox urls or with graybox url param * Update graybox check to use hostname instead of path * Small bug fixes to handle when graybox url param already present * Add check for localhost for unit tests * PR feedback * Add metadata check; code cov tweaks * Change metadata setting * add .page/.live selector * Disable georouting modal when graybox is enabled --------- Co-authored-by: Sunil Kamat <107644736+sukamat@users.noreply.github.com> Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> * MWPW-148253 Quiz Entry Coverage (#2305) * Initial quiz-entry block with ml field * MWPW-144810: Quiz Entry - Add option cards and text to the block (#2095) * Quiz entry block (#2103) * MWPW-144810: Quiz Entry - Add option cards and text to the block * MWPW-144810: Add the text to strings.xlsx for title, subtitle, ML field default, card instruction bar and the button * MWPW-146243 - Quiz entry code optimization (#2121) * MWPW-146243 - Quiz entry code optimization * Restores code optimization that was lost in previous PRs Resolves: [MWPW-146243](https://jira.corp.adobe.com/browse/MWPW-146243) * Update utils.js * Update quiz-entry.js Set button to use string values * Update quiz-entry.js Fixed to use new strings object * MWPW-146034 - Quiz entry block accessibility (#2139) * resolved accessibility concerns when the ml input is used * general code refinements for more clarity, specifically for getting string values Resolves: [MWPW-146034](https://jira.corp.adobe.com/browse/MWPW-146034) * MWPW-146036 - Rig up quiz entry button (#2190) * Support for ml filtering * Debug support using ?debug=quiz-entry * Store quizState in local storage and redirect to the quiz Resolves: [MWPW-146036](https://jira.corp.adobe.com/browse/MWPW-146036) * Quiz entry block (#2204) * MWPW-144810: Quiz Entry - Add option cards and text to the block * MWPW-144810: Add the text to strings.xlsx for title, subtitle, ML field default, card instruction bar and the button * MWPW-147031:Add Analytics for Quiz Entry Block, MWPW-146080: Integrate Auto-Complete for Open Text Field on UAR Exposed Front Door * fix eslint * fix code according feedbacks * MWPW-144022: Quiz entry block (#2227) * carousel starts * got buttons working * MWPW-144022: Prototype carousel refinement, keybord controls updated * linting fixes * MWPW-147482 - ML Input Bulletproofing (#2242) * add support for fallback fi codes * add lana logging for ml field failures * fix so the redirect checks for maxQuestions Resolves: [MWPW-147482](https://jira.corp.adobe.com/browse/MWPW-147482) **Test URLs:** - Before: https://main--milo--adobecom.hlx.page/?martech=off - After: https://--milo--adobecom.hlx.page/?martech=off * MWPW-147683 - CSS Cleanup (#2267) * MWPW-147683 - CSS Cleanup * Final pass on the css * Edits to markup where necessary Resolves: [MWPW-147683](https://jira.corp.adobe.com/browse/MWPW-147683) * pr feedback for vars and eslint errors * more PR feedback on icon placement * pr feedback for button border * cleaned up the carousel widths so it's consistent it all times as it was previously 8px short. * pr feedback on the location of the input clear X. * PR feedback - reduced border on input, fixed a card disable bug, addressed card layout in tablet * carousel starts * got buttons working * MWPW-144022: Prototype carousel refinement, keybord controls updated * linting fixes * Tests * working tests update * linting * linting * Update quiz-entry.js with default vals * Bring back debug * debugging debug * Improved test coverage * resolve conflicts * restore style * formatting fix --------- Co-authored-by: Cody Lloyd Co-authored-by: Jacky Sun <67350368+JackySun9@users.noreply.github.com> Co-authored-by: Cody Lloyd <119891065+colloyd@users.noreply.github.com> * Revert "MWPW-141725 Graybox Block (#2282)" This reverts commit 7c475418c847186480f820cc6feaac6cc6b084f4. * Revert "MWPW-148253 Quiz Entry Coverage (#2305)" This reverts commit ed796304d59cbd66e6fd443dc43380b4689ac08b. * Revert "Revert "MWPW-141725 Graybox Block (#2282)"" This reverts commit e14572ac393c319de6e2ee1bcb7fe387f2499eaa. * MWPW-148253 Quiz Entry Coverage (#2305) * Initial quiz-entry block with ml field * MWPW-144810: Quiz Entry - Add option cards and text to the block (#2095) * Quiz entry block (#2103) * MWPW-144810: Quiz Entry - Add option cards and text to the block * MWPW-144810: Add the text to strings.xlsx for title, subtitle, ML field default, card instruction bar and the button * MWPW-146243 - Quiz entry code optimization (#2121) * MWPW-146243 - Quiz entry code optimization * Restores code optimization that was lost in previous PRs Resolves: [MWPW-146243](https://jira.corp.adobe.com/browse/MWPW-146243) * Update utils.js * Update quiz-entry.js Set button to use string values * Update quiz-entry.js Fixed to use new strings object * MWPW-146034 - Quiz entry block accessibility (#2139) * resolved accessibility concerns when the ml input is used * general code refinements for more clarity, specifically for getting string values Resolves: [MWPW-146034](https://jira.corp.adobe.com/browse/MWPW-146034) * MWPW-146036 - Rig up quiz entry button (#2190) * Support for ml filtering * Debug support using ?debug=quiz-entry * Store quizState in local storage and redirect to the quiz Resolves: [MWPW-146036](https://jira.corp.adobe.com/browse/MWPW-146036) * Quiz entry block (#2204) * MWPW-144810: Quiz Entry - Add option cards and text to the block * MWPW-144810: Add the text to strings.xlsx for title, subtitle, ML field default, card instruction bar and the button * MWPW-147031:Add Analytics for Quiz Entry Block, MWPW-146080: Integrate Auto-Complete for Open Text Field on UAR Exposed Front Door * fix eslint * fix code according feedbacks * MWPW-144022: Quiz entry block (#2227) * carousel starts * got buttons working * MWPW-144022: Prototype carousel refinement, keybord controls updated * linting fixes * MWPW-147482 - ML Input Bulletproofing (#2242) * add support for fallback fi codes * add lana logging for ml field failures * fix so the redirect checks for maxQuestions Resolves: [MWPW-147482](https://jira.corp.adobe.com/browse/MWPW-147482) **Test URLs:** - Before: https://main--milo--adobecom.hlx.page/?martech=off - After: https://--milo--adobecom.hlx.page/?martech=off * MWPW-147683 - CSS Cleanup (#2267) * MWPW-147683 - CSS Cleanup * Final pass on the css * Edits to markup where necessary Resolves: [MWPW-147683](https://jira.corp.adobe.com/browse/MWPW-147683) * pr feedback for vars and eslint errors * more PR feedback on icon placement * pr feedback for button border * cleaned up the carousel widths so it's consistent it all times as it was previously 8px short. * pr feedback on the location of the input clear X. * PR feedback - reduced border on input, fixed a card disable bug, addressed card layout in tablet * carousel starts * got buttons working * MWPW-144022: Prototype carousel refinement, keybord controls updated * linting fixes * Tests * working tests update * linting * linting * Update quiz-entry.js with default vals * Bring back debug * debugging debug * Improved test coverage * resolve conflicts * restore style * formatting fix --------- Co-authored-by: Cody Lloyd Co-authored-by: Jacky Sun <67350368+JackySun9@users.noreply.github.com> Co-authored-by: Cody Lloyd <119891065+colloyd@users.noreply.github.com> * Merge main into stage to resolve history issues (#2310) * [Release] Stage to Main (#2299) * MWPW-147599: CaaS Bulk Publisher not working after MS authentication change (#2248) Potential fix for bulk publisher issues Co-authored-by: Blaine Gunn Co-authored-by: Sheridan Sunier * Preflight Accessibility tab update (#2254) Updating how alt text is used and displayed in preflight Co-authored-by: Ryan Clayton * MWPW-146407: add new card style to caas configurator (#2279) Co-authored-by: Brad Johnson Co-authored-by: Sheridan Sunier * MWPW-141780 - Clean up Accordion block attributes (#2276) remove role attribute on dd elements Co-authored-by: Okan Sahin <39759830+mokimo@users.noreply.github.com> * MWPW-147158: adds support for footer divider at the collection level (#2198) * MWPW-147158: adds support for footer divider at the collection level * Updatest unit-test files * Update windows copy hash * Update OSX copy hash * Updates OSX hash again * Removes console log * Adds console logs for debbuging * Removes console logs * Adds console logs for debbuging again * Removes console log * Updates OSX hash * Adds debuging message to test * Update os-hash check logic * trim() generated hash * Changes the comparison logic for the hash * Reverts last attempt * new attempt to fix test --------- Co-authored-by: Okan Sahin <39759830+mokimo@users.noreply.github.com> * MWPW-147594: Consumers mappings for origin not being sent when using sidekick (#2244) * Fix for origin always being upper cased * Update tools/send-to-caas/send-utils.js changing to const Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> --------- Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: Okan Sahin <39759830+mokimo@users.noreply.github.com> * Stage automation, update the body after merging another PR in (#2289) * Stage process improvements * Remove team reviewers * Formatting * Simplify PR bodies --------- Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> * Remove label requirements & merge workflows (#2288) Remove label & merge workflows Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> * Quiz entry block (#2294) * Initial quiz-entry block with ml field * MWPW-144810: Quiz Entry - Add option cards and text to the block (#2095) * Quiz entry block (#2103) * MWPW-144810: Quiz Entry - Add option cards and text to the block * MWPW-144810: Add the text to strings.xlsx for title, subtitle, ML field default, card instruction bar and the button * MWPW-146243 - Quiz entry code optimization (#2121) * MWPW-146243 - Quiz entry code optimization * Restores code optimization that was lost in previous PRs Resolves: [MWPW-146243](https://jira.corp.adobe.com/browse/MWPW-146243) * Update utils.js * Update quiz-entry.js Set button to use string values * Update quiz-entry.js Fixed to use new strings object * MWPW-146034 - Quiz entry block accessibility (#2139) * resolved accessibility concerns when the ml input is used * general code refinements for more clarity, specifically for getting string values Resolves: [MWPW-146034](https://jira.corp.adobe.com/browse/MWPW-146034) * MWPW-146036 - Rig up quiz entry button (#2190) * Support for ml filtering * Debug support using ?debug=quiz-entry * Store quizState in local storage and redirect to the quiz Resolves: [MWPW-146036](https://jira.corp.adobe.com/browse/MWPW-146036) * Quiz entry block (#2204) * MWPW-144810: Quiz Entry - Add option cards and text to the block * MWPW-144810: Add the text to strings.xlsx for title, subtitle, ML field default, card instruction bar and the button * MWPW-147031:Add Analytics for Quiz Entry Block, MWPW-146080: Integrate Auto-Complete for Open Text Field on UAR Exposed Front Door * fix eslint * fix code according feedbacks * MWPW-144022: Quiz entry block (#2227) * carousel starts * got buttons working * MWPW-144022: Prototype carousel refinement, keybord controls updated * linting fixes * MWPW-147482 - ML Input Bulletproofing (#2242) * add support for fallback fi codes * add lana logging for ml field failures * fix so the redirect checks for maxQuestions Resolves: [MWPW-147482](https://jira.corp.adobe.com/browse/MWPW-147482) **Test URLs:** - Before: https://main--milo--adobecom.hlx.page/?martech=off - After: https://--milo--adobecom.hlx.page/?martech=off * MWPW-147683 - CSS Cleanup (#2267) * MWPW-147683 - CSS Cleanup * Final pass on the css * Edits to markup where necessary Resolves: [MWPW-147683](https://jira.corp.adobe.com/browse/MWPW-147683) * pr feedback for vars and eslint errors * more PR feedback on icon placement * pr feedback for button border * cleaned up the carousel widths so it's consistent it all times as it was previously 8px short. * pr feedback on the location of the input clear X. * PR feedback - reduced border on input, fixed a card disable bug, addressed card layout in tablet * carousel starts * got buttons working * MWPW-144022: Prototype carousel refinement, keybord controls updated * linting fixes * Tests * working tests update * Small font size fixes that design has asked for * linting * linting * Update quiz-entry.js with default vals * Bring back debug * debugging debug * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/quiz-entry.test.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/quiz-entry.test.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Update test/blocks/quiz-entry/mocks/mock-data.js Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * added quiz-entry to utils.js (#2296) Co-authored-by: Denys Fedotov * MWPW-148206: Update Spectra ML host from cchome-dev to cchome for PROD --------- Co-authored-by: Jacky Sun <67350368+JackySun9@users.noreply.github.com> Co-authored-by: Brad Johnson Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: Denys Fedotov Co-authored-by: Denys Fedotov Co-authored-by: Jacky Sun --------- Co-authored-by: Sanjay Rai Co-authored-by: Blaine Gunn Co-authored-by: Sheridan Sunier Co-authored-by: Ryan Clayton Co-authored-by: Ryan Clayton Co-authored-by: Brad Johnson Co-authored-by: Sheridan Sunier Co-authored-by: Elan Bartholomew <79870969+elan-tbx@users.noreply.github.com> Co-authored-by: Okan Sahin <39759830+mokimo@users.noreply.github.com> Co-authored-by: cmiqueo <64917520+cmiqueo@users.noreply.github.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> Co-authored-by: Cody Lloyd <119891065+colloyd@users.noreply.github.com> Co-authored-by: Jacky Sun <67350368+JackySun9@users.noreply.github.com> Co-authored-by: Denys Fedotov Co-authored-by: Denys Fedotov Co-authored-by: Jacky Sun * Revert "MWPW-141725 Graybox Block (#2282)" This reverts commit 7c475418c847186480f820cc6feaac6cc6b084f4. * Revert "MWPW-148253 Quiz Entry Coverage (#2305)" This reverts commit ed796304d59cbd66e6fd443dc43380b4689ac08b. * Revert "Revert "MWPW-141725 Graybox Block (#2282)"" This reverts commit e14572ac393c319de6e2ee1bcb7fe387f2499eaa. * MWPW-148253 Quiz Entry Coverage (#2305) * Initial quiz-entry block with ml field * MWPW-144810: Quiz Entry - Add option cards and text to the block (#2095) * Quiz entry block (#2103) * MWPW-144810: Quiz Entry - Add option cards and text to the block * MWPW-144810: Add the text to strings.xlsx for title, subtitle, ML field default, card instruction bar and the button * MWPW-146243 - Quiz entry code optimization (#2121) * MWPW-146243 - Quiz entry code optimization * Restores code optimization that was lost in previous PRs Resolves: [MWPW-146243](https://jira.corp.adobe.com/browse/MWPW-146243) * Update utils.js * Update quiz-entry.js Set button to use string values * Update quiz-entry.js Fixed to use new strings object * MWPW-146034 - Quiz entry block accessibility (#2139) * resolved accessibility concerns when the ml input is used * general code refinements for more clarity, specifically for getting string values Resolves: [MWPW-146034](https://jira.corp.adobe.com/browse/MWPW-146034) * MWPW-146036 - Rig up quiz entry button (#2190) * Support for ml filtering * Debug support using ?debug=quiz-entry * Store quizState in local storage and redirect to the quiz Resolves: [MWPW-146036](https://jira.corp.adobe.com/browse/MWPW-146036) * Quiz entry block (#2204) * MWPW-144810: Quiz Entry - Add option cards and text to the block * MWPW-144810: Add the text to strings.xlsx for title, subtitle, ML field default, card instruction bar and the button * MWPW-147031:Add Analytics for Quiz Entry Block, MWPW-146080: Integrate Auto-Complete for Open Text Field on UAR Exposed Front Door * fix eslint * fix code according feedbacks * MWPW-144022: Quiz entry block (#2227) * carousel starts * got buttons working * MWPW-144022: Prototype carousel refinement, keybord controls updated * linting fixes * MWPW-147482 - ML Input Bulletproofing (#2242) * add support for fallback fi codes * add lana logging for ml field failures * fix so the redirect checks for maxQuestions Resolves: [MWPW-147482](https://jira.corp.adobe.com/browse/MWPW-147482) **Test URLs:** - Before: https://main--milo--adobecom.hlx.page/?martech=off - After: https://--milo--adobecom.hlx.page/?martech=off * MWPW-147683 - CSS Cleanup (#2267) * MWPW-147683 - CSS Cleanup * Final pass on the css * Edits to markup where necessary Resolves: [MWPW-147683](https://jira.corp.adobe.com/browse/MWPW-147683) * pr feedback for vars and eslint errors * more PR feedback on icon placement * pr feedback for button border * cleaned up the carousel widths so it's consistent it all times as it was previously 8px short. * pr feedback on the location of the input clear X. * PR feedback - reduced border on input, fixed a card disable bug, addressed card layout in tablet * carousel starts * got buttons working * MWPW-144022: Prototype carousel refinement, keybord controls updated * linting fixes * Tests * working tests update * linting * linting * Update quiz-entry.js with default vals * Bring back debug * debugging debug * Improved test coverage * resolve conflicts * restore style * formatting fix --------- Co-authored-by: Cody Lloyd Co-authored-by: Jacky Sun <67350368+JackySun9@users.noreply.github.com> Co-authored-by: Cody Lloyd <119891065+colloyd@users.noreply.github.com> --------- Co-authored-by: Brad Johnson Co-authored-by: milo-pr-merge[bot] <169241390+milo-pr-merge[bot]@users.noreply.github.com> Co-authored-by: Sanjay Rai Co-authored-by: Blaine Gunn Co-authored-by: Sheridan Sunier Co-authored-by: Ryan Clayton Co-authored-by: Ryan Clayton Co-authored-by: Sheridan Sunier Co-authored-by: Elan Bartholomew <79870969+elan-tbx@users.noreply.github.com> Co-authored-by: cmiqueo <64917520+cmiqueo@users.noreply.github.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> Co-authored-by: Cody Lloyd <119891065+colloyd@users.noreply.github.com> Co-authored-by: Jacky Sun <67350368+JackySun9@users.noreply.github.com> Co-authored-by: Denys Fedotov Co-authored-by: Denys Fedotov Co-authored-by: Jacky Sun Co-authored-by: Cody Lloyd * Revert "MWPW-147472: auto adjust commerce iframe" (#2312) Revert "MWPW-147472: auto adjust commerce iframe (#2251)" This reverts commit 481bbcb6bb6cb99b003c4637d3d4b01530df4ebe. * OPT-26580 DC0994_US | Frictionless | Add sticky banner Upload CTA (#2298) * 05-13-24 ivan dc0944 first * Update libs/mep/dc0944/aside/aside.js Co-authored-by: Vivian A Goodrich <101133187+vgoodric@users.noreply.github.com> * 05-13-24 ivan dc0944 add css changes and js optimization * Update libs/mep/dc0944/aside/aside.js Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> * Update libs/mep/dc0944/aside/aside.js Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> * Update libs/mep/dc0944/aside/aside.js Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> * Update libs/mep/dc0944/aside/aside.js Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> * Update libs/mep/dc0944/aside/aside.js Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> * 05-14-24 ivan renamed mep test folder dc0994 * 05-14-24 ivan fix sticky banner close btn --------- Co-authored-by: Vivian A Goodrich <101133187+vgoodric@users.noreply.github.com> Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> Co-authored-by: markpadbe --------- Co-authored-by: Sanjay Rai Co-authored-by: Blaine Gunn Co-authored-by: Sheridan Sunier Co-authored-by: Ryan Clayton Co-authored-by: Ryan Clayton Co-authored-by: Brad Johnson Co-authored-by: Sheridan Sunier Co-authored-by: Elan Bartholomew <79870969+elan-tbx@users.noreply.github.com> Co-authored-by: Okan Sahin <39759830+mokimo@users.noreply.github.com> Co-authored-by: cmiqueo <64917520+cmiqueo@users.noreply.github.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: Robert Bogos <146744221+robert-bogos@users.noreply.github.com> Co-authored-by: Cody Lloyd <119891065+colloyd@users.noreply.github.com> Co-authored-by: Jacky Sun <67350368+JackySun9@users.noreply.github.com> Co-authored-by: Denys Fedotov Co-authored-by: Denys Fedotov Co-authored-by: Jacky Sun Co-authored-by: ilyas Stéphane Türkben Co-authored-by: Mira Fedas <30750556+mirafedas@users.noreply.github.com> Co-authored-by: Chris Peyer Co-authored-by: Sunil Kamat <107644736+sukamat@users.noreply.github.com> Co-authored-by: Cody Lloyd Co-authored-by: Okan Sahin Co-authored-by: milo-pr-merge[bot] <169241390+milo-pr-merge[bot]@users.noreply.github.com> Co-authored-by: Jan Ivan Viloria <158211769+ivanvatadobe@users.noreply.github.com> Co-authored-by: Vivian A Goodrich <101133187+vgoodric@users.noreply.github.com> Co-authored-by: markpadbe --- libs/blocks/graybox/graybox.css | 284 +++++ libs/blocks/graybox/graybox.js | 285 +++++ libs/blocks/graybox/mobileFrames.js | 5 + libs/blocks/quiz-entry/quiz-entry.js | 8 +- libs/blocks/quiz-entry/quizoption.js | 7 - libs/blocks/quiz-entry/utils.js | 5 +- libs/mep/dc0994/aside/aside.css | 1204 +++++++++++++++++++++ libs/mep/dc0994/aside/aside.js | 236 ++++ libs/styles/styles.css | 3 + libs/utils/utils.js | 1 + test/blocks/graybox/graybox.test.js | 89 ++ test/blocks/graybox/mocks/graybox.html | 129 +++ test/blocks/quiz-entry/mocks/mock-data.js | 4 +- test/blocks/quiz-entry/quiz-entry.test.js | 145 ++- test/blocks/quiz-entry/utils.test.js | 149 +++ 15 files changed, 2542 insertions(+), 12 deletions(-) create mode 100644 libs/blocks/graybox/graybox.css create mode 100644 libs/blocks/graybox/graybox.js create mode 100644 libs/blocks/graybox/mobileFrames.js create mode 100644 libs/mep/dc0994/aside/aside.css create mode 100644 libs/mep/dc0994/aside/aside.js create mode 100644 test/blocks/graybox/graybox.test.js create mode 100644 test/blocks/graybox/mocks/graybox.html create mode 100644 test/blocks/quiz-entry/utils.test.js diff --git a/libs/blocks/graybox/graybox.css b/libs/blocks/graybox/graybox.css new file mode 100644 index 00000000000..4d3cac4ad8f --- /dev/null +++ b/libs/blocks/graybox/graybox.css @@ -0,0 +1,284 @@ +:root { + --gb-container-bg: white; + --gb-outline-color: #1473E6; + --gb-container-btn-bg: #505050; + --gb-overlay-color: rgba(0 0 0 / 45%); + --gb-modal-bg: #323232; + --gb-container-border: 4px solid var(--gb-outline-color); + --gb-page-outline-border: 8px solid var(--gb-outline-color); + --gb-toggle-arrow: 3px solid white; +} + +.graybox { + display: none; +} + +.gb-graybox-body { + position: relative; +} + +.gb-graybox-body:not(.gb-no-border)::before { + content: ''; + position: absolute; + top: calc(50% + 8px); + left: 50%; + transform: translate(-50%, -50%); + width: calc(100% - 15.5px); + height: 100%; + border: var(--gb-page-outline-border); + z-index: var(--above-all); + pointer-events: none; +} + +.gb-graybox-body.gb-tablet-preview:not(.gb-no-border)::before, +.gb-graybox-body.gb-phone-preview:not(.gb-no-border)::before { + top: auto; + left: auto; + transform: none; + height: calc(100% - 15.5px); + position: fixed; +} + +.gb-graybox-body .gb-no-click::before { + content: ""; + height: 100%; + pointer-events: all; + position: absolute; + width: 100%; + z-index: var(--above-all); +} + +.gb-no-change { + position: relative; +} + +.gb-overlay { + position: relative; +} + +.gb-graybox-body .gb-no-change::before, +.gb-graybox-body.gb-overlay::before { + background-color: var(--gb-overlay-color); + content: ""; + display: block; + height: 100%; + left: 0; + pointer-events: none; + position: absolute; + top: 0; + width: 100%; + z-index: calc(var(--above-all) - 1); +} + +body.gb-overlay::before { + position: fixed; +} + +/* The elements that should appear above the overlay */ +.gb-graybox-body .gb-changed { + position: relative; + z-index: var(--above-all); +} + +.graybox-container { + position: fixed; + right: 0; + top: 15%; + z-index: calc(var(--above-all) + 1); +} + +.graybox-container .gb-toggle { + background-color: var(--gb-outline-color); + border: var(--gb-container-border); + cursor: pointer; + height: 64px; + left: -40px; + position: absolute; + width: 40px; +} + +.graybox-container .gb-toggle::before { + border-bottom: var(--gb-toggle-arrow); + border-left: var(--gb-toggle-arrow); + border-radius: 2px; + content: " "; + cursor: pointer; + display: block; + height: 8px; + margin-left: 8px; + scale: 85%; + transform: rotate(140deg) scaleX(-1); + transition: transform 0.2s ease-in-out, margin-left 0.2s ease-in-out; + width: 8px; +} + +.graybox-container.open .gb-toggle::before { + margin-left: 3px; + transform: rotate(225deg) scaleX(1); +} + +.graybox-container .graybox-menu { + background-color: var(--gb-container-bg); + border-radius: 3px; + border-top-right-radius: 0; + border: 0; + box-sizing: border-box; + display: grid; + grid-template-rows: 1fr 66px; + overflow: hidden; + position: absolute; + right: 39px; + width: 0; +} + +.graybox-container .graybox-menu.hide-devices { + border-bottom-right-radius: 0; + grid-template-rows: 1fr 0; +} + +.graybox-container.open .graybox-menu { + border: var(--gb-container-border); + min-height: 60px; + min-width: 320px; +} + +.graybox-text { + color: #000; + font-size: 14px; + font-weight: normal; + line-height: 24px; + padding: 16px; +} + +.graybox-text > p:first-child { + font-weight: bold; + font-size: 24px; + margin: 0; +} + +.graybox-devices { + display: grid; + grid-template-columns: 1fr 1fr 1fr; + justify-content: center; + align-content: center; + justify-items: center; + padding: 16px; + column-gap: 10px; + height: 34px; + border-top: var(--gb-container-border); + box-sizing: content-box; +} + +.graybox-devices > a { + box-sizing: border-box; + width: 85px; + text-align: center; + color: var(--gb-container-btn-bg); + border-color: var(--gb-container-btn-bg); + cursor: default; +} + +.graybox-devices > a:hover { + background-color: var(--gb-container-btn-bg); + text-decoration: none; +} + +.dialog-modal.graybox-modal { + z-index: var(--above-all); +} + +.dialog-modal.graybox-modal.mobile > div { + overflow-x: hidden; + border-radius: 88px; +} + +.dialog-modal.graybox-modal.tablet > div { + overflow-x: hidden; + border-radius: 88px; +} + +.dialog-modal.graybox-modal.mobile .graybox-device-border { + position: absolute; + pointer-events: none; + width: 418px; + height: 863px; +} + +.dialog-modal.graybox-modal.tablet .graybox-device-border { + position: absolute; + pointer-events: none; + width: 859px; + height: 1205px; +} + +.dialog-modal.graybox-modal.mobile { + width: 417px; + border-radius: 66px; + background: var(--gb-modal-bg); + overflow-y: hidden; +} + +.dialog-modal.graybox-modal.tablet { + width: 858px; + border-radius: 66px; + background: var(--gb-modal-bg); + border-top-right-radius: 60px 78px; + border-bottom-right-radius: 51px 69px; + border-bottom-left-radius: 55px 84px; + overflow-y: hidden; +} + +.dialog-modal.graybox-modal.mobile iframe { + width: 391px; + height: 852px; + padding-left: 16px; + margin-left: 4px; +} + +.dialog-modal.graybox-modal.tablet iframe { + width: 808px; + height: 1194px; + padding-left: 26px; + margin-left: 6px; + margin-top: 62px; + margin-bottom: -62px; +} + +.dialog-modal.graybox-modal button.dialog-close { + display: none; +} + +.modal-curtain.graybox-curtain.is-open { + background: var(--gb-modal-bg); + z-index: calc(var(--above-all) - 1); +} + +@media (max-height: 910px) { + body.gb-phone-preview::after { + content: "Expand window height to see full preview"; + position: fixed; + right: 10px; + bottom: 2px; + padding: 10px; + background-color: #f0f0f0; + color: #000; + font-size: 16px; + z-index: var(--above-all); + border-radius: 5px; + } +} + +@media (max-height: 1255px) { + body.gb-tablet-preview::after { + content: "Expand window height to see full preview"; + position: fixed; + right: 10px; + bottom: 2px; + padding: 10px; + background-color: #f0f0f0; + color: #000; + font-size: 16px; + z-index: var(--above-all); + border-radius: 5px; + } +} diff --git a/libs/blocks/graybox/graybox.js b/libs/blocks/graybox/graybox.js new file mode 100644 index 00000000000..236aa04ffc0 --- /dev/null +++ b/libs/blocks/graybox/graybox.js @@ -0,0 +1,285 @@ +import { createTag, getMetadata, MILO_EVENTS } from '../../utils/utils.js'; +import { getModal, closeModal } from '../modal/modal.js'; +import { iphoneFrame, ipadFrame } from './mobileFrames.js'; + +const OPTION = { + CHANGED: 'changed', + NO_CLICK: 'no-click', +}; + +const CLASS = { + CHANGED: 'gb-changed', + GRAYBOX_BODY: 'gb-graybox-body', + NO_BORDER: 'gb-no-border', + NO_CHANGE: 'gb-no-change', + NO_CLICK: 'gb-no-click', + NO_OVERLAY: 'gb-no-overlay', + OVERLAY: 'gb-overlay', + PHONE_PREVIEW: 'gb-phone-preview', + TABLET_PREVIEW: 'gb-tablet-preview', +}; + +const METADATA = { + DESC: 'gb-desc', + FOOTER: 'gb-footer', + GNAV: 'gb-gnav', + TITLE: 'gb-title', +}; + +const USER_AGENT = { + iPhone: 'Mozilla/5.0 (iPhone13,2; U; CPU iPhone OS 14_0 like Mac OS X) AppleWebKit/602.1.50 (KHTML, like Gecko) Version/10.0 Mobile/15E148 Safari/602.1', + iPad: 'Mozilla/5.0 (iPad; CPU OS 13_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/13.0.3 Mobile/15E148 Safari/604.1', +}; + +let deviceModal; + +const setMetadata = (metadata) => { + const { selector, val } = metadata; + if (!selector || !val) return; + const propName = selector.startsWith('og:') ? 'property' : 'name'; + let metaEl = document.querySelector(`meta[${propName}="${selector}"]`); + if (!metaEl) { + metaEl = document.createElement('meta'); + metaEl.setAttribute(propName, selector); + document.head.append(metaEl); + } + metaEl.setAttribute('content', val); +}; + +const isMobileDevice = () => /Android|webOS|iPhone|iPad|iPod/i.test(navigator.userAgent); + +const getTableValues = (el) => [...el.childNodes].reduce((rdx, row) => { + if (!row.children) return rdx; + + const key = row.children[0].textContent?.trim().toLowerCase(); + const content = row.children[1]; + let text = content?.textContent.trim(); + /* c8 ignore next 3 */ + if (key !== 'title' && key !== 'desc') { + text = text.toLowerCase(); + } + if (key && content) { + rdx.keys.push(key); + rdx[key] = { content, text }; + } + return rdx; +}, { keys: [] }); + +/* c8 ignore start */ +const getOptions = (text, metadata) => { + const options = text || getMetadata(metadata); + return options?.toLowerCase().split(',').map((opt) => opt.trim()); +}; + +const decorateFooter = (footer, options) => { + const footerOptions = getOptions(options.footer?.text, METADATA.FOOTER); + if (footerOptions?.includes(OPTION.CHANGED)) { + footer.classList.add(CLASS.CHANGED); + } else { + footer.classList.add(CLASS.OVERLAY); + } + if (footerOptions?.includes(OPTION.NO_CLICK)) { + footer.classList.add(CLASS.NO_CLICK); + } +}; + +const footerMutationObserver = (footerEl, callback, options) => { + const footerObserver = new MutationObserver((mutations) => { + mutations.forEach((mutation) => { + if (mutation.target.classList.contains('global-footer')) { + footerObserver.disconnect(); + decorateFooter(footerEl, options); + } + }); + }); + + footerObserver.observe(footerEl, { attributes: true }); +}; + +const checkFooter = (options) => { + const footerEl = document.querySelector('footer'); + if (footerEl?.classList.contains('global-footer')) { + decorateFooter(footerEl, options); + } else if (footerEl) { + footerMutationObserver(footerEl, decorateFooter, options); + } +}; + +const checkGnav = (options, globalNoClick) => { + const gnav = document.querySelector('.global-navigation'); + if (gnav) { + gnav.style.zIndex = '1002'; + const gnavOptions = getOptions(options.gnav?.text, METADATA.GNAV); + if (!(gnavOptions?.includes(OPTION.CHANGED))) { + gnav.classList.add(CLASS.OVERLAY); + if (globalNoClick) { + gnav.classList.add(CLASS.NO_CLICK); + } + } + if (gnavOptions?.includes(OPTION.NO_CLICK)) { + gnav.classList.add(CLASS.NO_CLICK); + } + } +}; +/* c8 ignore stop */ + +const checkNoClick = (grayboxEl, noClickOnGray) => { + if (!noClickOnGray) { + return; + } + /* c8 ignore next 6 */ + if (document.body.classList.contains(CLASS.OVERLAY)) { + document.body.classList.add(CLASS.NO_CLICK); + } else { + document.querySelectorAll(`.${CLASS.NO_CHANGE}`) + .forEach((el) => el.classList.add(CLASS.NO_CLICK)); + } +}; + +const capitalizeFirstLetter = (str) => str.charAt(0).toUpperCase() + str.slice(1); + +function setUserAgent(window, userAgent) { + /* c8 ignore next 3 */ + if (window.navigator.userAgent === userAgent) { + return; + } + + const userAgentProp = { get: () => userAgent }; + try { + Object.defineProperty(window.navigator, 'userAgent', userAgentProp); + /* c8 ignore next 3 */ + } catch (e) { + window.navigator = Object.create(navigator, { userAgent: userAgentProp }); + } +} + +const openDeviceModal = async (e) => { + if (deviceModal) { + closeModal(deviceModal); + deviceModal = null; + } + + if (e.target.classList.contains('graybox-desktop')) { + return; + } + + const isMobile = e.target.classList.contains('graybox-mobile'); + const isTablet = e.target.classList.contains('graybox-tablet'); + const docFrag = new DocumentFragment(); + const iFrameUrl = new URL(window.location.href); + iFrameUrl.searchParams.set('graybox', 'menu-off'); + const deviceBorder = createTag('img', { class: 'graybox-device-border', src: isMobile ? iphoneFrame : ipadFrame }); + const iFrame = createTag('iframe', { src: iFrameUrl.href, width: '100%', height: '100%' }); + + const modal = createTag('div', null, [deviceBorder, iFrame]); + docFrag.append(modal); + + deviceModal = await getModal(null, { class: 'graybox-modal', id: 'graybox-modal', content: docFrag, closeEvent: 'closeGrayboxModal' }); + + // Disable modal.js forcing 100% height + iFrame.style.height = ''; + + if (isMobile) { + document.body.classList.add(CLASS.PHONE_PREVIEW); + deviceModal.classList.add('mobile'); + setUserAgent(iFrame.contentWindow, USER_AGENT.iPhone); + } else if (isTablet) { + document.body.classList.add(CLASS.TABLET_PREVIEW); + deviceModal.classList.add('tablet'); + setUserAgent(iFrame.contentWindow, USER_AGENT.iPad); + } + + const removeBodyPreviewClasses = () => document.body.classList.remove( + CLASS.PHONE_PREVIEW, + CLASS.TABLET_PREVIEW, + ); + + window.addEventListener('milo:modal:closed', removeBodyPreviewClasses, { once: true }); + + const curtain = deviceModal.nextElementSibling; + curtain.classList.add('graybox-curtain'); +}; + +const createGrayboxMenu = (options, { isOpen = false } = {}) => { + const grayboxContainer = createTag('div', { class: 'graybox-container' }); + const grayboxMenu = createTag('div', { class: 'graybox-menu' }, null, { parent: grayboxContainer }); + /* c8 ignore next 3 */ + if (window.innerWidth < 600 || isMobileDevice()) { + grayboxMenu.classList.add('hide-devices'); + } + + const grayboxText = createTag('div', { class: 'graybox-text' }, null, { parent: grayboxMenu }); + const title = options.title?.text || getMetadata(METADATA.TITLE) || 'Review Update'; + const desc = options.desc?.text || getMetadata(METADATA.DESC) || ''; + grayboxText.innerHTML = `

${title}

${desc && `

${desc}

`}`; + + const grayboxDevices = createTag('div', { class: 'graybox-devices' }, null, { parent: grayboxMenu }); + + ['mobile', 'tablet', 'desktop'].forEach((device) => { + const button = createTag( + 'a', + { class: `graybox-${device} con-button` }, + capitalizeFirstLetter(device), + { parent: grayboxDevices }, + ); + button.addEventListener('click', openDeviceModal); + }); + + const toggleBtn = document.createElement('button'); + toggleBtn.className = 'gb-toggle'; + toggleBtn.addEventListener('click', () => { + grayboxContainer.classList.toggle('open'); + }); + + grayboxContainer.appendChild(toggleBtn); + document.body.appendChild(grayboxContainer); + + if (isOpen) { + grayboxContainer.classList.add('open'); + } +}; + +export default function init(grayboxEl) { + const url = new URL(window.location.href); + + const grayboxParam = url.searchParams.get('graybox'); + + /* c8 ignore next 9 */ + const enableGraybox = grayboxParam === 'on' + || url.hostname.includes('graybox.adobe.com') + || url.hostname.includes('localhost') + || url.hostname.includes('-graybox--') + || getMetadata('project') === 'graybox'; + + if (grayboxParam === 'off' || !enableGraybox) { + return; + } + + setMetadata({ selector: 'georouting', val: 'off' }); + + const options = getTableValues(grayboxEl); + const grayboxThePage = () => { + document.body.classList.add(CLASS.GRAYBOX_BODY); + const hasGrayboxChanged = !!document.querySelector(`.${CLASS.CHANGED}`); + if (hasGrayboxChanged) { + document.body.classList.add(CLASS.OVERLAY); + + document.querySelectorAll(`.${CLASS.CHANGED}`).forEach((el) => { + el.classList.add(CLASS.NO_OVERLAY); + if (!el.style.backgroundColor) el.style.backgroundColor = 'white'; + }); + } + const globalNoClick = grayboxEl.classList.contains(OPTION.NO_CLICK); + checkGnav(options, globalNoClick); + checkFooter(options); + checkNoClick(grayboxEl, globalNoClick); + /* c8 ignore next 3 */ + if (url.searchParams.get('graybox') === 'menu-off') { + document.body.classList.add(CLASS.NO_BORDER); + } else { + createGrayboxMenu(options, { isOpen: true }); + } + }; + + document.addEventListener(MILO_EVENTS.DEFERRED, grayboxThePage, { once: true }); +} diff --git a/libs/blocks/graybox/mobileFrames.js b/libs/blocks/graybox/mobileFrames.js new file mode 100644 index 00000000000..094c16ea843 --- /dev/null +++ b/libs/blocks/graybox/mobileFrames.js @@ -0,0 +1,5 @@ +const iphoneFrame = ''; + +const ipadFrame = ''; + +export { iphoneFrame, ipadFrame }; diff --git a/libs/blocks/quiz-entry/quiz-entry.js b/libs/blocks/quiz-entry/quiz-entry.js index 8559d7f04e4..5e569bfe161 100644 --- a/libs/blocks/quiz-entry/quiz-entry.js +++ b/libs/blocks/quiz-entry/quiz-entry.js @@ -4,6 +4,12 @@ import { mlField, getMLResults } from './mlField.js'; import { GetQuizOption } from './quizoption.js'; import { quizPopover, getSuggestions } from './quizPopover.js'; +export const locationWrapper = { + redirect: (url) => { + window.location = url; + }, +}; + const App = ({ quizPath, maxQuestions, @@ -222,7 +228,7 @@ const App = ({ if (questionCount.current === maxQuestions || currentQuizState.userFlow.length === 1) { if (!debug) { setSelectedQuestion(null); - window.location = quizPath; + locationWrapper.redirect(quizPath); } } else { setSelectedCards({}); diff --git a/libs/blocks/quiz-entry/quizoption.js b/libs/blocks/quiz-entry/quizoption.js index a2774c89b08..42db01b59ba 100644 --- a/libs/blocks/quiz-entry/quizoption.js +++ b/libs/blocks/quiz-entry/quizoption.js @@ -89,13 +89,6 @@ export const GetQuizOption = ({ } }; - useEffect(() => { - const entry = document.querySelector('.quiz-entry'); - if (entry && entry.querySelector('.no-carousel')) { - entry.removeChild(entry.querySelector('.no-carousel')); - } - }, []); - return html`
${index > 0 && html``} diff --git a/libs/blocks/quiz-entry/utils.js b/libs/blocks/quiz-entry/utils.js index 0d04f203645..f5551f1fc47 100644 --- a/libs/blocks/quiz-entry/utils.js +++ b/libs/blocks/quiz-entry/utils.js @@ -78,7 +78,10 @@ export const handleSelections = (prevSelections, selectedQuestion, selections) = // de-dup any existing data if they use the ml field and cards. if (prevSelections.length > 0) { prevSelections.forEach((selection) => { - if (selection.selectedQuestion === selectedQuestion) { + const jsonSelectionSelectedQustion = JSON.stringify(selection.selectedQuestion); + const jsonSelectedQuesion = JSON.stringify(selectedQuestion[0].selectedQuestion); + const isSameQuestion = jsonSelectionSelectedQustion === jsonSelectedQuesion; + if (isSameQuestion) { selection.selectedCards = selections; isNewQuestion = false; } diff --git a/libs/mep/dc0994/aside/aside.css b/libs/mep/dc0994/aside/aside.css new file mode 100644 index 00000000000..e8f2d3c2cb7 --- /dev/null +++ b/libs/mep/dc0994/aside/aside.css @@ -0,0 +1,1204 @@ +.aside { + display: flex; + width: 100%; + position: relative; + align-items: center; + justify-content: center; + overflow: hidden; +} + +.dark .aside, +.aside.dark { + color: var(--color-white); +} + +.aside p { + margin: 0; +} + +.aside.split picture { + display: flex; +} + +.aside .split-image img, +.aside .split-image video { + object-fit: cover; + min-height: 700px; + width: 100%; + height: 100%; +} + +.aside.notification .background img { + min-height: unset; +} + +.aside .foreground.container { + display: flex; + position: relative; + align-items: center; + justify-content: center; + flex-direction: column; + gap: var(--spacing-l); +} + +.aside:not(.notification):not(.inline) .foreground > :first-child { + padding: var(--spacing-xxxl) 0 0; +} + +.aside:not(.notification):not(.inline) .foreground > :last-child { + margin-bottom: var(--spacing-xxxl); +} + +.aside .foreground.container .text { + display: flex; + flex-wrap: wrap; +} + +.aside.split .foreground.container .text { + margin: 0; + max-width: var(--grid-container-width); + padding: var(--spacing-xxxl) 0 var(--spacing-l) 0; +} + +.aside.simple .foreground.container .text { + margin-bottom: 80px; +} + +.aside.notification .foreground.container .text { + max-width: none; + padding-top: 0; + padding-bottom: 0; +} + +.aside .foreground.container .image { + position: relative; + display: flex; +} + +.aside .foreground.container > div { + flex-grow: 1; + flex-basis: 0; + min-width: 0; +} + +.aside.notification .foreground.container > div { + flex-basis: 100%; +} + +.aside.inline .foreground.container .image, +.aside.inline .foreground.container .text { + padding: 0; +} + +.aside.split.large .foreground.container .text { + padding: var(--spacing-l) 0 var(--spacing-xxxl) 0; +} + +.aside.split .icon-stack-area li, +.aside.split .icon-stack-area li a { + display: flex; + align-items: center; + gap: 12px; + font-weight: bold; +} + +.aside.notification .foreground.container .text a { + white-space: nowrap; +} + +.aside:not(.notification) .foreground.container .text > * { + width: 100%; +} + +.aside .foreground.container .text .heading-xl { + margin: 0 0 var(--spacing-xs); +} + +.aside .foreground.container .text .body-m, +.aside .foreground.container .text .body-s { + margin-bottom: var(--spacing-s); +} + +.aside .foreground.container .text .supplemental-text { + padding-top: var(--spacing-s); + margin-bottom: 0; +} + +.aside.promobar .promo-text .action-area { + flex-wrap: nowrap; + gap: var(--spacing-xs); +} + +.aside.promobar .promo-text .action-area, +.aside .foreground.container .text .action-area { + margin-bottom: 0; + display: flex; + gap: var(--spacing-s); + flex-wrap: wrap; + align-items: center; +} + +.aside.notification .icon-area { + display: flex; + align-items: center; +} + +.aside .foreground.container .icon-area { + height: 56px; + max-width: 234px; + margin-bottom: var(--spacing-s); +} + +.aside .foreground.container a.icon-area { + height: auto; + margin-bottom: 0; +} + +.aside.split .split-image img, +.aside.split .split-image video { + position: relative; + min-height: 270px; +} + +.aside.split .split-image video { + display: block; +} + +.aside.split .mobile-square img, +.aside.split .mobile-square video { + aspect-ratio: var(--aspect-ratio-square); +} + +.aside.split .mobile-wide img, +.aside.split .mobile-wide video { + aspect-ratio: var(--aspect-ratio-wide); +} + +.aside.split .mobile-standard img, +.aside.split .mobile-standard video { + aspect-ratio: var(--aspect-ratio-standard); +} + +.aside.split .format img, +.aside.split .format video { + height: auto; +} + +.aside.split .icon-stack-area li img { + width: var(--icon-size-m); + height: auto; +} + +.aside.split .format picture, +.aside.split .format video { + display: flex; + height: 100%; + align-items: center; +} + +.aside .foreground.container .icon-area img { + max-width: 234px; + height: var(--icon-size-l); + width: auto; + object-fit: cover; + object-position: left top; +} + +.aside.simple .foreground.container .image { + display: none; +} + +.aside.split { + flex-direction: column; +} + +.aside.split.large { + flex-direction: column-reverse; +} + +.aside.split .foreground.container { + width: 100%; + max-width: 100%; + flex-direction: column; + z-index: 1; +} + +.aside.split .background { + position: relative; +} + +.aside.split.large .background { + background-color: transparent; +} + +.aside.split .foreground.container .image { + margin: 0; + display: none; +} + +.aside.split .icon-stack-area li picture { + flex-shrink: 0; +} + +.aside.notification .text [class^="heading-"] + .action-area { + margin-top: var(--spacing-xs); +} + +.aside.notification .foreground.container img { + display: block; +} + +.aside .foreground.container .image video, +.aside .foreground.container .image picture, +.aside .foreground.container .image picture img { + width: 100%; + display: flex; +} + +.aside.split .foreground.container .split-image img, +.aside.split .foreground.container .split-image video { + object-fit: cover; + height: 270px; +} + +.aside.inline { + border-radius: 10px; +} + +.aside.inline .foreground.container { + width: 100%; + min-height: 0; + margin: var(--spacing-m); + padding: 0; + gap: var(--spacing-m); +} + +.aside.inline .foreground.container .image { + margin-top: 0; +} + +.aside.inline .heading-s { + margin-bottom: var(--spacing-s); +} + +.aside.notification { + min-height: 0; +} + +.aside.notification .foreground.container { + padding-top: var(--spacing-s); + padding-bottom: var(--spacing-s); + box-sizing: border-box; + justify-content: flex-start; +} + +.aside.notification .foreground.container .image { + max-width: 75px; + margin: 0; + order: -1; +} + +.aside.notification .foreground.container .text a:not(.con-button) { + width: auto; + font-weight: normal; +} + +.aside.notification .foreground.container .text .action-area > a { + margin-right: 0; +} + +.aside.promobar .foreground.container { + min-height: 0; + display: flex; + flex-direction: column; + padding: 0; + margin: 0; +} + +.aside.promobar .foreground.container .icon-area { + margin-bottom: 0; + height: var(--icon-size-m); +} + +.aside.promobar .foreground.container .icon-area img { + height: var(--icon-size-m); +} + +.aside.notification.extra-small .foreground.container a:last-child { + font-weight: bold; +} + +.aside.notification.extra-small .foreground.container a:not(.con-button):last-of-type { + margin-left: var(--spacing-xs); + color: var(--link-color); +} + +.static-links .aside.notification.extra-small .foreground.container a:not(.con-button):last-of-type { + color: inherit; +} + +.aside.notification.small .foreground.container .text a.con-button { + display: table; + margin-left: 0; +} + +.aside.notification .foreground.container .text .heading-l { + margin-bottom: var(--spacing-xxs); +} + +.aside.notification .foreground.container:not(.no-image) .text .body-s.action-area, +.aside.notification .foreground.container:not(.no-image) .text .body-m.action-area { + margin-bottom: 0; +} + +.aside.notification .foreground.container .icon-area { + height: auto; + max-width: none; + margin-bottom: var(--spacing-xs); +} + +.aside.notification .foreground.container .icon-area img { + max-height: 40px; + height: auto; +} + +.aside.notification.extra-small .foreground.container { + min-height: 50px; + padding-top: var(--spacing-xs); + padding-bottom: var(--spacing-xs); +} + +.aside.notification.extra-small .foreground.container .text { + display: block; +} + +.aside.notification.medium .foreground.container .text, +.aside.notification.large .foreground.container .text { + flex-direction: column; +} + +.aside.notification.small .foreground.container .text { + flex-direction: column; + max-width: 1000px; +} + +.aside.center:not(.notification) .foreground.container .text { + margin: 80px 0; + text-align: center; + padding: 0; +} + +.aside.notification.center.small .foreground.container .text { + text-align: left; +} + +.aside.notification.center.small .foreground.container .text, +.aside.notification.center.extra-small .foreground.container .text { + margin: 0 auto; +} + +.aside.notification.small { + min-height: 88px; +} + +.aside.notification.medium { + min-height: 160px; +} + +.aside.notification.large { + min-height: 250px; +} + +.aside.notification.medium .foreground.container { + max-width: 800px; + gap: var(--spacing-xs); +} + +.aside.notification.medium .foreground.container .text .heading-s { + margin-bottom: var(--spacing-xxs); +} + +.aside.notification.center.small .foreground.container .text p { + text-align: initial; +} + +.aside.notification.large .foreground.container { + max-width: 1000px; + gap: var(--spacing-xs); +} + +.aside.notification .foreground.container [data-align=center], +.aside.notification.center .foreground.container, +.aside.notification.center .foreground.container > * { + text-align: center; + justify-content: center; +} + +.aside.promobar.popup .foreground.container { + width: 100%; + padding: 0; +} + +.aside.center:not(.notification) .foreground.container { + padding: 0; +} + +.aside.notification.large.center .foreground.container, +.aside.notification.large .foreground.container.no-image { + max-width: 800px; +} + +.aside.promobar.popup .promo-text .action-area { + justify-content: flex-end; + padding: 0 var(--spacing-xxs) var(--spacing-xxs) 0; + gap: var(--spacing-xxs); +} + +.aside.notification.center .foreground.container .action-area { + justify-content: center; +} + +.aside.notification.center.small .foreground.container .text, +.aside.notification.center.small .foreground.container .text > * { + justify-content: flex-start; +} + +.aside.split .icon-stack-area { + display: flex; + flex-flow: row wrap; + flex-direction: column; + gap: 12px; + margin: -8px 0 var(--spacing-s); + width: 100%; + padding: 0; + list-style-type: none; +} + +.aside.promobar.popup .promo-text .icon-area, +.aside.promobar.popup .promo-text .icon-area img { + display: flex; + gap: var(--spacing-xxs); + align-items: center; + height: var(--icon-size-xs); +} + +.aside.center:not(.notification) .foreground.container .icon-area { + max-width: 100%; +} + +.aside.center:not(.notification) .foreground.container .text .action-area { + justify-content: center; +} + +.aside:not(.notification) .foreground.container .text .detail-m { + margin-bottom: var(--spacing-xs); +} + +.aside.split .image.format { + display: flex; +} + +.aside.split.bio .foreground.container .text .icon-area { + display: none; +} + +.aside.center:not(.notification) .foreground.container .text .icon-area { + height: var(--icon-size-xxl); +} + +.aside.center:not(.notification) .foreground.container .text .icon-area img { + height: var(--icon-size-xxl); + max-width: 300px; + width: auto; +} + +.aside.promobar .foreground.container > :first-child { + padding: var(--spacing-xs) 0; +} + +.aside.promobar .promo-text[data-align="center"] { + justify-content: center; +} + +.aside.promobar .action-area .con-button { + flex-shrink: 0; +} + +.aside.promobar .promo-text.desktop-up, +.aside.promobar .promo-text.tablet-up { + display: none; +} + +.aside.promobar .promo-text.mobile-up { + display: flex; +} + +.aside.promobar .promo-text { + display: flex; + flex-flow: row nowrap; + gap: var(--spacing-xs); + justify-content: space-between; + width: 100%; + padding: var(--spacing-xs) 0; +} + +.aside.promobar .promo-text .content-area { + display: flex; + flex-flow: row nowrap; + gap: var(--spacing-xs); + align-items: center; +} + +.aside.promobar.popup { + border-radius: var(--spacing-xs); + width: var(--grid-container-width); + margin: auto; + box-shadow: 0 3px 6px #707070; +} + +.aside.promobar.popup .foreground.container .promo-text { + flex-direction: column; + padding: 0; +} + +.aside.promobar.popup .promo-text .content-area { + padding: var(--spacing-xs) var(--spacing-xs) 0 var(--spacing-xs); + flex-direction: column; + align-items: flex-start; + gap: var(--spacing-xxs); +} + +.aside.promobar.popup .promo-text .text-area { + margin-top: var(--spacing-m); +} + +.aside.promobar.popup .promo-text .icon-area+.text-area { + margin-top: 0; +} + +.aside.promobar.popup .promo-text .content-area .text-area { + display: flex; + flex-direction: column; + gap: var(--spacing-xxs); +} + +.aside.promobar.popup .mobile-up.promo-text .detail-xs+.text-area { + gap: var(--spacing-xs); +} + +.aside.promobar.popup .promo-close { + position: absolute; + right: var(--spacing-xxs); + top: var(--spacing-xxs); + height: 20px; + width: 20px; + border: none; + background: none; + cursor: pointer; +} + +.aside.promobar.popup .promo-close svg { + position: absolute; + top: 0; + left: 0; +} + +.aside.promobar.popup .promo-close circle { + fill: var(--color-black); +} + +.aside.promobar.popup .promo-close line { + stroke: var(--color-white); +} + +@media screen and (max-width: 600px) { + .aside.no-media:not(.notification) .foreground.container { + gap: 0; + } + + .aside.split.no-media:not(.notification) .foreground.container .text { + padding: var(--spacing-xxxl) 0; + } + + .aside.promobar.popup .mobile-up.hide-block ~ .promo-close { + display: none; + } +} + +@media screen and (min-width: 600px) { + .aside.small { + min-height: 420px; + } + + .aside.medium { + min-height: 560px; + } + + .aside.large { + min-height: 700px; + } + + .aside .foreground.container { + align-items: center; + flex-direction: row; + margin: 0 auto; + padding: var(--spacing-m) 0; + gap: var(--spacing-xl); + } + + .aside:not(.notification):not(.inline) .foreground.container > :first-child { + padding: 0; + } + + .aside:not(.notification):not(.inline):not(.center) .foreground.container > :last-child { + margin-bottom: 0; + } + + .aside .foreground.container .image { + margin: 0; + } + + .aside .foreground.container .text.image { + justify-content: flex-start; + } + + .aside .background, + .aside.split .split-image { + overflow: hidden; + position: absolute; + left: 0; + right: 0; + top: 0; + bottom: 0; + } + + .aside .foreground.container .text { + margin-bottom: 0; + padding-right: var(--spacing-s); + } + + .aside.split-right .foreground.container .text { + padding-left: var(--spacing-s); + } + + .aside.simple .foreground.container .text { + margin-bottom: 0; + max-width: 318px; + padding-right: 0; + } + + .aside.split .split-image { + overflow: hidden; + position: absolute; + left: 0; + right: 0; + top: 0; + bottom: 0; + } + + .aside.split .tablet-wide img, + .aside.split .tablet-wide video { + aspect-ratio: var(--aspect-ratio-wide); + } + + .aside.split .tablet-standard img, + .aside.split .tablet-standard video { + aspect-ratio: var(--aspect-ratio-standard); + } + + .aside.split-right .split-image img, + .aside.split-right .split-image video { + left: 0; + } + + .aside.split.large { + flex-direction: column; + } + + .aside .split-image .modal-img-link, + .aside.split .split-image img, + .aside.split .split-image video { + width: 60.5vw; + max-width: 56%; + position: absolute; + right: 0; + object-fit: cover; + object-position: center top; + } + + .aside .split-image .modal-img-link, + .aside.split.half .split-image img, + .aside.split.half .split-image video { + width: 50vw; + max-width: 1396px; + object-position: left top; + } + + .aside.split.split-left .split-image img, + .aside.split.split-left .split-image video { + right: 0; + left: auto; + } + + .aside.split.split-right .split-image img, + .aside.split.split-right .split-image video { + left: 0; + right: auto; + } + + [dir="rtl"] .aside.split.split-right .split-image img, + [dir="rtl"] .aside.split.split-right .split-image video { + right: 0; + left: auto; + } + + [dir="rtl"] .aside.split.split-left .split-image img, + [dir="rtl"] .aside.split.split-left .split-image video { + left: 0; + right: auto; + } + + .aside.split .foreground.container { + flex-direction: row; + justify-content: stretch; + max-width: var(--grid-container-width); + margin: 0 auto; + background-color: transparent; + } + + .aside.split .foreground.container .text { + flex: 0 0 31vw; + padding: var(--spacing-xxl) 0; + max-width: 100%; + margin: 0; + } + + .aside.split .foreground.container .image { + object-fit: cover; + flex: 0 0 61%; + display: block; + padding: 0; + } + + .aside.inline .foreground.container .text { + flex: 0 0 calc(60% - var(--spacing-s)); + max-width: none; + } + + .aside.notification .foreground.container .text { + padding-right: 0; + } + + .aside.notification.small .foreground.container .text { + flex-flow: row nowrap; + align-items: center; + flex-grow: 1; + } + + .aside.notification.small .foreground.container .text .body-m { + margin: 0; + } + + .aside.notification.small .foreground.container .text .body-m.action-area { + margin-left: 24px; + } + + [dir = "rtl"] .aside.notification.small .foreground.container .text .body-m.action-area { + margin-left: 0; + margin-right: 24px; + } + + .aside.split.half .foreground.container .text { + flex: 0 0 41.72%; + } + + .aside.split-right .foreground.container { + flex-direction: row-reverse; + } + + .aside.inline .foreground.container .image { + flex: 0 0 calc(40% - var(--spacing-s)); + margin-bottom: 0; + } + + .aside.notification .foreground.container { + flex-direction: row; + } + + .aside.notification.medium .foreground.container, + .aside.notification.large .foreground.container { + gap: var(--spacing-s); + } + + .aside.notification .foreground.container .image { + width: 30%; + max-width: 188px; + margin: 0; + padding: 0; + order: unset; + } + + .aside.notification .foreground.container .text+.image { + margin-right: 0; + } + + .aside.notification .foreground.container .icon-area { + width: auto; + margin-right: var(--spacing-xs); + margin-bottom: 0; + } + + [dir = "rtl"] .aside.notification .foreground.container .icon-area { + margin-left: var(--spacing-xs); + margin-right: 0; + } + + .aside.notification.extra-small .foreground.container.no-image .text { + display: flex; + } + + .aside.notification.extra-small .foreground.container.no-image .text a { + margin-left: 5px; + } + + .aside.promobar.popup .promo-text .action-area { + justify-content: center; + padding: 0 0 var(--spacing-xxs); + } + + .aside.notification.small .foreground.container .text .action-area { + width: auto; + margin-top: 0; + } + + .aside.split.bio .foreground.container .text .icon-area { + display: block; + } + + .aside.notification.small .foreground.container .text .icon-area { + height: 40px; + } + + .aside.center:not(.notification) .foreground.container .text .icon-area img { + max-width: 234px; + } + + .aside.medium.split.bio .foreground.container .text .icon-area, + .aside.large.split.bio .foreground.container .text .icon-area { + height: var(--icon-size-xxl); + margin-bottom: var(--spacing-xs); + } + + .aside.medium.split.bio .foreground.container .text .icon-area img, + .aside.large.split.bio .foreground.container .text .icon-area img { + width: var(--icon-size-xxl); + height: var(--icon-size-xxl); + border-radius: 50%; + } + + .aside.promobar .promo-text .content-area .text-area { + display: flex; + flex-flow: column nowrap; + gap: var(--spacing-xxs); + } + + .aside.promobar .promo-text.mobile-up, + .aside.promobar .promo-text.desktop-up { + display: none; + } + + .aside.promobar .promo-text.tablet-up { + display: flex; + } + + .aside.promobar.popup .promo-text { + gap: var(--spacing-s); + } + + .aside.promobar.popup .promo-text .content-area { + padding: var(--spacing-xxs) 0 0; + align-items: center; + text-align: center; + } +} + +@media (min-width: 600px) and (max-width: 1200px) { + .aside.promobar.popup .tablet-up.hide-block ~ .promo-close { + display: none; + } +} + +@media screen and (min-width: 1200px) { + .aside .foreground.container { + min-height: 420px; + width: var(--grid-container-width); + } + + .aside .foreground.container > div { + object-fit: cover; + padding-left: 0; + } + + .aside .foreground.container .text { + padding: var(--spacing-xxl) 0; + } + + .aside .foreground.container .icon-area { + max-width: 400px; + } + + .aside .foreground.container .text .heading-xl { + margin: 0 0 var(--spacing-xs); + } + + .aside.inline .foreground.container .text { + flex: 0 0 calc(64% - var(--spacing-s)); + } + + .aside.simple .foreground.container .text { + margin-bottom: 0; + max-width: 500px; + } + + .aside.split .foreground.container .text { + flex: 0 0 300px; + } + + .aside.split .foreground.container .image { + flex: 0 0 70%; + max-width: none; + object-fit: cover; + } + + .aside.split .split-image img, + .aside.split .split-image video { + max-width: 1396px; + } + + .aside.split .desktop-wide img, + .aside.split .desktop-wide video { + aspect-ratio: var(--aspect-ratio-wide); + } + + .aside.split .desktop-standard img, + .aside.split .desktop-standard video { + aspect-ratio: var(--aspect-ratio-standard); + } + + .aside.split.half .foreground.container .text { + max-width: 500px; + } + + .aside.inline { + max-width: 800px; + margin-right: auto; + margin-left: auto; + } + + .aside.inline .foreground.container .image { + flex: 0 0 calc(36% - var(--spacing-s)); + } + + .aside.split.icon-stack .foreground.container .text, + .aside.split.bio .foreground.container .text { + padding: var(--spacing-xxl) 0; + } + + .aside.split .icon-stack-area li { + max-width: calc(50% - 6px); + min-width: calc(50% - 6px); + } + + .aside.split .icon-stack-area { + flex-direction: row; + } + + .aside.promobar .foreground.container .icon-area, + .aside.promobar .foreground.container .icon-area img { + height: var(--icon-size-xxl); + } + + .aside.promobar.popup .promo-text .icon-area, + .aside.promobar.popup .promo-text .icon-area img { + height: var(--icon-size-m); + } + + .aside.center:not(.notification) .foreground.container .text .icon-area img { + max-width: 400px; + } + + .aside.center:not(.notification) .foreground.container .text { + max-width: 50%; + } + + .aside.notification .foreground.container { + min-height: 0; + } + + .aside.notification.extra-small .foreground.container { + padding-top: var(--spacing-xxs); + padding-bottom: var(--spacing-xxs); + } + + .aside.notification.medium .foreground.container { + gap: var(--spacing-m); + } + + .aside.notification.large .foreground.container { + gap: var(--spacing-l); + } + + .aside.notification .foreground.container .image { + width: 20%; + } + + .aside.notification .foreground.container .text+.image { + margin-right: 0; + } + + .aside.notification.small .foreground.container .text { + align-items: center; + justify-content: flex-start; + } + + .aside.notification.center.small .foreground.container .text, + .aside.notification.center.small .foreground.container .text > * { + justify-content: center; + } + + .aside.notification.center.small .foreground.container .text p { + text-align: center; + } + + .aside.notification.medium .foreground.container .image { + max-width: 168px; + } + + .aside.notification.large .foreground.container .image { + max-width: 304px; + } + + .aside.notification.medium .foreground.container .text+.image { + margin-right: 0; + } + + .aside.promobar .promo-text .content-area { + gap: var(--spacing-m); + } + + .aside.promobar .promo-text .content-area .text-area { + gap: var(--spacing-xs); + } + + .aside.promobar .promo-text .action-area { + gap: var(--spacing-s); + } + + .aside.promobar .promo-text.mobile-up, + .aside.promobar .promo-text.tablet-up { + display: none; + } + + .aside.promobar .promo-text.desktop-up { + display: flex; + gap: var(--spacing-m); + } + + .aside.promobar.popup { + border-radius: var(--spacing-xl); + width: 85%; + max-width: 1600px; + } + + .aside.promobar.popup .foreground.container .promo-text { + padding: var(--spacing-xs) 0; + flex-direction: row; + gap: var(--spacing-l); + justify-content: center; + max-width: 83.4%; + } + + .aside.promobar.popup .promo-text .content-area, + .aside.promobar.popup .promo-text .action-area { + flex-direction: row; + padding: 0; + gap: var(--spacing-xs); + min-height: 40px; + } + + .aside.promobar.popup .promo-close { + right: var(--spacing-s); + top: calc(50% - 10px); + } + + .aside.promobar.popup .desktop-up.hide-block ~ .promo-close { + display: none; + } + + .aside.promobar.popup .promo-text .text-area { + margin-top: 0; + } +} + +/* Added for frictionless dc0944 */ +.section.hide-on-step-start:not(.hide-sticky-section):not(.close-sticky-section) { + background: none !important; + display: flex; + justify-content: center; + padding: 0 7% 20px; +} + +.aside.frictionless { + background-color: rgb(0, 11, 29); + max-width: 1200px; + border-radius: 50px; + display: flex; + justify-content: center; + align-items: center; + position: relative; +} + +.aside.frictionless .foreground.container { + position: relative; + flex-direction: row; +} + +.aside.frictionless .promo-close { + background: rgb(0, 11, 29); + margin: 0; + width: 20px; + height: 20px +} + +.aside.frictionless .promo-text { + justify-content: center; +} + +.aside.frictionless .promo-text .text-area { + display: flex; + flex-direction: row !important; +} + +.aside.frictionless .promo-text .icon-area { + height: auto !important; +} + +.aside.frictionless .promo-text .icon-area img { + height: 38px !important; +} + +body.dc-bc[data-current-event="start"] .section.hide-on-step-start { + display: none; + background-color: none; +} + +@media screen and (min-width: 1440px) { + .aside.frictionless .promo-close { + position: absolute; + right: 40px; + } +} + +.sticky-banner-disable { + display: none !important; +} diff --git a/libs/mep/dc0994/aside/aside.js b/libs/mep/dc0994/aside/aside.js new file mode 100644 index 00000000000..2283e0e1d93 --- /dev/null +++ b/libs/mep/dc0994/aside/aside.js @@ -0,0 +1,236 @@ +/* + * Copyright 2022 Adobe. All rights reserved. + * This file is licensed to you under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. You may obtain a copy + * of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under + * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS + * OF ANY KIND, either express or implied. See the License for the specific language + * governing permissions and limitations under the License. + */ + +/* +* Aside - v5.1 +*/ + +import { decorateBlockText, decorateIconStack, applyHoverPlay, decorateBlockBg } from '../../../utils/decorate.js'; +import { createTag } from '../../../utils/utils.js'; + +// standard/default aside uses same text sizes as the split +const variants = ['split', 'inline', 'notification']; +const sizes = ['extra-small', 'small', 'medium', 'large']; +const [split, inline, notification] = variants; +const [xsmall, small, medium, large] = sizes; +const blockConfig = { + [split]: ['xl', 's', 'm'], + [inline]: ['s', 'm'], + [notification]: { + [xsmall]: ['m', 'm'], + [small]: ['m', 'm'], + [medium]: ['s', 's'], + [large]: ['l', 'm'], + }, +}; +const FORMAT_REGEX = /^format:/i; +const closeSvg = ` + + + + + + `; + +const linkSectionToModuleStep = (el) => el.closest('.section').classList.add('hide-on-step-start'); + +function editCtaToModuleClick(el) { + el.querySelectorAll('a').forEach((cta) => { + if (cta.href.toLowerCase().includes('#module')) { + cta.addEventListener('click', (e) => { + e.preventDefault(); + window.scrollTo(0, 0); + document.querySelector('.CTAButtons')?.click(); + }); + } + }); +} + +function getBlockData(el) { + const variant = variants.find((variantClass) => el.classList.contains(variantClass)); + const size = sizes.find((sizeClass) => el.classList.contains(sizeClass)); + const blockData = variant ? blockConfig[variant] : blockConfig[Object.keys(blockConfig)[0]]; + return variant && size && !Array.isArray(blockData) ? blockData[size] : blockData; +} + +function decorateStaticLinks(el) { + if (!el.classList.contains('notification')) return; + el.querySelectorAll('a:not([class])').forEach((link) => { link.classList.add('static'); }); +} + +function decorateMedia(el) { + if (!(el.classList.contains('medium') || el.classList.contains('large'))) return; + const allMedia = el.querySelectorAll('div > p video, div > p picture'); + [...allMedia].some((media) => { + const parentP = media.closest('p'); + const siblingP = parentP?.nextElementSibling; + if (!siblingP || siblingP.nodeName !== 'P') return false; + const siblingText = siblingP.textContent; + if (!FORMAT_REGEX.test(siblingText)) return false; + const formats = siblingText.split(': ')[1]?.split(/\s+/); + if (formats) { + const formatClasses = []; + formatClasses.push('format'); + if (formats.length === 3) formatClasses.push(`desktop-${formats[2]}`); + if (formats.length >= 2) formatClasses.push(`tablet-${formats[1]}`); + formatClasses.push(`mobile-${formats[0]}`); + media.closest('div').classList.add(...formatClasses); + } + siblingP.remove(); + media.closest('div').insertBefore(media, parentP); + parentP.remove(); + return true; + }); +} + +function formatPromoButton(el) { + if (!el.classList.contains('promobar')) return; + el.querySelectorAll('.action-area').forEach((aa) => { + aa.querySelectorAll('.con-button').forEach((btn) => { + btn.classList.add('button-l'); + if (!el.classList.contains('popup')) return; + if (!btn.classList.contains('outline')) btn.classList.add('fill'); + }); + }); +} + +function addCloseButton(el) { + const closeBtn = createTag('button', { class: 'promo-close', 'aria-label': 'Close' }, closeSvg); + el.querySelector('.foreground').appendChild(closeBtn); + closeBtn.addEventListener('click', (e) => { + e.target.closest('.section').classList.add('close-sticky-section'); + }); +} + +function addPromobar(sourceEl, parent) { + parent.appendChild(sourceEl.cloneNode(true)); +} + +function checkViewportPromobar(foreground) { + const { children, childElementCount: childCount } = foreground; + if (childCount < 2) addPromobar(children[childCount - 1], foreground); + if (childCount < 3) addPromobar(children[childCount - 1], foreground); +} + +function combineTextBocks(textBlocks, iconArea, viewPort, variant) { + const promobarConfig = { + default: { + 'mobile-up': ['s', 's'], + 'tablet-up': ['s', 's'], + 'desktop-up': ['m', 'l'], + }, + popup: { + 'mobile-up': ['s', 's'], + 'tablet-up': ['l', 'm'], + 'desktop-up': ['xxl', 'xl'], + }, + }; + const textStyle = promobarConfig[variant][viewPort]; + const contentArea = createTag('p', { class: 'content-area' }); + const textArea = createTag('p', { class: 'text-area' }); + textBlocks[0].parentElement.prepend(contentArea); + textBlocks.forEach((textBlock) => { + textArea.appendChild(textBlock); + if (textBlock.nodeName === 'P') { + textBlock.classList.add(`body-${textStyle[1]}`); + } else { + textBlock.classList.add(`heading-${textStyle[0]}`); + } + }); + if (iconArea) { + if (iconArea.innerText?.trim()) iconArea.classList.add('detail-xs'); + iconArea.classList.add('icon-area'); + contentArea.appendChild(iconArea); + } + contentArea.appendChild(textArea); +} + +function decoratePromobar(el) { + const viewports = ['mobile-up', 'tablet-up', 'desktop-up']; + const foreground = el.querySelector('.foreground'); + const variant = el.classList.contains('popup') ? 'popup' : 'default'; + if (foreground.childElementCount !== 3) checkViewportPromobar(foreground); + [...foreground.children].forEach((child, index) => { + child.className = viewports[index]; + child.classList.add('promo-text'); + const textBlocks = [...child.children]; + const iconArea = child.querySelector('picture')?.closest('p'); + const actionArea = child.querySelectorAll('em a, strong a, p > a strong'); + if (iconArea) textBlocks.shift(); + if (actionArea.length) textBlocks.pop(); + if (!(textBlocks.length || iconArea || actionArea.length)) child.classList.add('hide-block'); + else if (textBlocks.length) combineTextBocks(textBlocks, iconArea, viewports[index], variant); + }); + if (variant === 'popup' || el.classList.contains('frictionless')) addCloseButton(el); + return foreground; +} + +function decorateLayout(el) { + const elems = el.querySelectorAll(':scope > div'); + if (elems.length > 1) { + decorateBlockBg(el, elems[0]); + } + const foreground = elems[elems.length - 1]; + foreground.classList.add('foreground', 'container'); + if (el.classList.contains('promobar')) return decoratePromobar(el); + if (el.classList.contains('split')) decorateMedia(el); + const text = foreground.querySelector('h1, h2, h3, h4, h5, h6, p')?.closest('div'); + text?.classList.add('text'); + const media = foreground.querySelector(':scope > div:not([class])'); + if (media && !el.classList.contains('notification')) { + media.classList.add('image'); + const video = media.querySelector('video'); + if (video) applyHoverPlay(video); + } + const picture = text?.querySelector('p picture'); + const iconArea = picture ? (picture.closest('p') || createTag('p', null, picture)) : null; + iconArea?.classList.add('icon-area'); + const foregroundImage = foreground.querySelector(':scope > div:not(.text) img')?.closest('div'); + const bgImage = el.querySelector(':scope > div:not(.text):not(.foreground) img')?.closest('div'); + const foregroundMedia = foreground.querySelector(':scope > div:not(.text) video, :scope > div:not(.text) a[href*=".mp4"]')?.closest('div'); + const bgMedia = el.querySelector(':scope > div:not(.text):not(.foreground) video, :scope > div:not(.text):not(.foreground) a[href*=".mp4"]')?.closest('div'); + const image = foregroundImage ?? bgImage; + const asideMedia = foregroundMedia ?? bgMedia ?? image; + const isSplit = el.classList.contains('split'); + const hasMedia = foregroundImage ?? foregroundMedia ?? (isSplit && asideMedia); + if (!hasMedia) el.classList.add('no-media'); + if (asideMedia && !asideMedia.classList.contains('text')) { + asideMedia.classList.add(`${isSplit ? 'split-' : ''}image`); + if (isSplit) { + const position = [...asideMedia.parentNode.children].indexOf(asideMedia); + el.classList.add(`split${!position ? '-right' : '-left'}`); + foreground.parentElement.appendChild(asideMedia); + } + } else if (!iconArea) { + foreground?.classList.add('no-image'); + } + if (el.classList.contains('split') + && (el.classList.contains('medium') || el.classList.contains('large'))) { + decorateIconStack(el); + } + return foreground; +} + +export default function init(el) { + el.classList.add('con-block'); + const blockData = getBlockData(el); + const blockText = decorateLayout(el); + decorateBlockText(blockText, blockData); + decorateStaticLinks(el); + formatPromoButton(el); + if (el.classList.contains('frictionless')) { + if (document.querySelectorAll('.CTAButtons').length) { + linkSectionToModuleStep(el); + editCtaToModuleClick(el); + } else el.closest('.section').classList.add('.sticky-banner-disable'); + } +} diff --git a/libs/styles/styles.css b/libs/styles/styles.css index 335733b636b..4514987e6e8 100644 --- a/libs/styles/styles.css +++ b/libs/styles/styles.css @@ -126,6 +126,9 @@ --icon-size-s: 32px; --icon-size-xs: 24px; --icon-size-xxs: 16px; + + /* z-index */ + --above-all: 9000; /* Used for page tools that overlay page content */ } :root:lang(ar) { diff --git a/libs/utils/utils.js b/libs/utils/utils.js index 2e22650ee23..86dc6c3dc52 100644 --- a/libs/utils/utils.js +++ b/libs/utils/utils.js @@ -34,6 +34,7 @@ const MILO_BLOCKS = [ 'featured-article', 'global-footer', 'global-navigation', + 'graybox', 'footer', 'gnav', 'how-to', diff --git a/test/blocks/graybox/graybox.test.js b/test/blocks/graybox/graybox.test.js new file mode 100644 index 00000000000..d7cc4c8808c --- /dev/null +++ b/test/blocks/graybox/graybox.test.js @@ -0,0 +1,89 @@ +import { readFile } from '@web/test-runner-commands'; +import { expect } from '@esm-bundle/chai'; +import { loadStyle, MILO_EVENTS } from '../../../libs/utils/utils.js'; +import { waitForElement, waitForRemoval } from '../../helpers/waitfor.js'; + +const { default: init } = await import('../../../libs/blocks/graybox/graybox.js'); +await loadStyle('../../../libs/blocks/graybox/graybox.css'); + +describe('Graybox', () => { + before(async () => { + document.body.innerHTML = await readFile({ path: './mocks/graybox.html' }); + await init(document.querySelector('.graybox')); + document.dispatchEvent(new Event(MILO_EVENTS.DEFERRED)); + }); + + it('Displays a graybox dialog', async () => { + const dialogEl = document.querySelector('.graybox-container'); + expect(dialogEl).to.exist; + expect(dialogEl.classList.contains('open')).to.be.true; + }); + + it('Displays a mobile iframe on device button click', async () => { + const dialogEl = document.querySelector('.graybox-container'); + const mobileBtn = dialogEl.querySelector('.graybox-mobile'); + mobileBtn.click(); + await waitForElement('iframe'); + let iframeEl = document.querySelector('iframe'); + expect(iframeEl).to.exist; + + const desktopBtn = dialogEl.querySelector('.graybox-desktop'); + desktopBtn.click(); + await waitForRemoval('iframe'); + iframeEl = document.querySelector('iframe'); + expect(iframeEl).not.to.exist; + + const tabletBtn = dialogEl.querySelector('.graybox-tablet'); + tabletBtn.click(); + await waitForElement('iframe'); + iframeEl = document.querySelector('iframe'); + expect(iframeEl).to.exist; + + desktopBtn.click(); + await waitForRemoval('iframe'); + iframeEl = document.querySelector('iframe'); + expect(iframeEl).not.to.exist; + }); + + it('Can open and close the dialog', async () => { + const dialogEl = document.querySelector('.graybox-container'); + expect(dialogEl.classList.contains('open')).to.be.true; + const toggleBtn = document.querySelector('.gb-toggle'); + toggleBtn.click(); + expect(dialogEl.classList.contains('open')).to.be.false; + toggleBtn.click(); + expect(dialogEl.classList.contains('open')).to.be.true; + }); + + it('Puts an overlay on the entire page', async () => { + expect(document.body.classList.contains('gb-overlay')).to.be.true; + const beforeStyle = window.getComputedStyle(document.body, '::before'); + expect(beforeStyle.backgroundColor).to.equal('rgba(0, 0, 0, 0.45)'); + }); + + it('Does not put an overlay on gb-changed blocks', async () => { + const gbChangedEl = document.querySelector('.gb-changed'); + const gbChangedElStyle = window.getComputedStyle(gbChangedEl); + expect(gbChangedEl?.classList.contains('gb-no-overlay')).to.be.true; + expect(gbChangedElStyle.backgroundColor).to.equal('rgb(255, 255, 255)'); + }); + + it('Does not put an overlay on gb-no-change sections', async () => { + const gbChangedSection = document.querySelector('.section.gb-changed'); + const gbChangedSectionStyle = window.getComputedStyle(gbChangedSection); + expect(gbChangedSection?.classList.contains('gb-no-overlay')).to.be.true; + expect(gbChangedSectionStyle.backgroundColor).to.equal('rgb(255, 255, 255)'); + }); + + it('Can use gb-no-change inside of a gb-changed section', async () => { + const noChangeEl = document.querySelector('.gb-no-change'); + const beforeStyle = window.getComputedStyle(noChangeEl, '::before'); + expect(beforeStyle.backgroundColor).to.equal('rgba(0, 0, 0, 0.45)'); + }); + + it('Can use gb-no-click to disable clicks', async () => { + const noClickEl = document.querySelector('.gb-no-click'); + const noClickElStyle = window.getComputedStyle(noClickEl, '::before'); + expect(noClickElStyle.pointerEvents).to.equal('all'); + }); +}); diff --git a/test/blocks/graybox/mocks/graybox.html b/test/blocks/graybox/mocks/graybox.html new file mode 100644 index 00000000000..38ff28cc80e --- /dev/null +++ b/test/blocks/graybox/mocks/graybox.html @@ -0,0 +1,129 @@ + + +
+
+
+
+
title
+
Project Review - 3/7/24
+
+
+
desc
+
Chuck Norris once roundhouse kicked someone so hard that his foot broke the speed of light, went back in time, and killed Amelia Earhart while she was flying over the Pacific Ocean
+
+
+
+
+
+ + + +
+
+
+
+

Marquee standard small dark

+

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation.

+

Call to action

+
+
+ + + +
+
+
+

Random text outside of the marquee block.

+

That's what's so funny! I switched glasses when your back was turned! Ha ha! You fool! You fell victim to one of the classic blunders - The most famous of which is "never get involved in a land war in Asia" - but only slightly less well-known is this: "Never go against a Sicilian when death is on the line"! Ha ha ha ha ha ha ha! Ha ha ha ha ha ha ha! Ha ha ha...

+

+ + + +

+

You're the Dread Pirate Roberts, admit it. How may do you think you could handle? You mean you wish to surrender to me? Very well, I accept. But how can you be sure? Will this do? You truly love each other and so you might have been truly happy. Not one couple in a century has that chance, no matter what the story books say.

+
+
+
+ + + +
+
+
+
+

“3D is a crucial part of how we explore the brand in a digital workflow. Adobe Substance 3D Stager takes the barrier of entry out of 3D design by enabling us to skip physical mockups and look at feedback faster. We’ve been able to bring digital design entirely in-house.”

+

Benny Lee

+

Global Manager of Experiential Design, Coca-Cola Company

+
+
+
+

The ability to destroy a planet is insignificant next to the power of the Force. Don't try to frighten us with your sorcerer's ways, Lord Vader. Your sad devotion to that ancient religion has not helped you conjure up the stolen data tapes, or given you clairvoyance enough to find the Rebel's hidden fort. I find your lack of faith disturbing. Enough of this! Vader, release him! As you wish.

+

Did you hear that? They've shut down the main reactor. We'll be destroyed for sure. This is madness! We're doomed! There'll be no escape for the Princess this time. What's that? Artoo! Artoo-Detoo, where are you? At last! Where have you been? They're heading in this direction.

+
+
+

This Section is graybox-changed

+
+
+
+

+ + + +

+

Body S Regular 2-line 36 CC

+
+
+
+
+
+
This text block has gb-no-chage inside of a gb-changed section.
+
+
+
+
+

How to compress a PDF online

+

Note that there is no JSONLD schema saved and the image (svg in this case) is part of the header

+

https://main--milo--adobecom.hlx.page/assets/img/compress-pdf-how-to-400x240.svg

+
+
+
+
+
    +
  • Click the Select a file button above or drag and drop files into the drop zone.
  • +
  • Select the PDF file you want to make smaller.
  • +
  • After uploading, Acrobat will automatically reduce the PDF size.
  • +
  • Download your compressed PDF file or sign in to share it.
  • +
+
+
+
+ +
+
+
+
+
+

“This was our opportunity to be one of the first teams to delve into Adobe Experience Platform, and we wanted to show people just how powerful it can be.”

+

Ron Nagy

+

Sr. Evangelist, Adobe@Adobe

+
+
+
+
+
+
+

Text - This is graybox-changed!

+

Kick things off with hundreds of premium and free presets you can access with your Lightroom subscription.

+

Learn more Explore the premium collection

+
+
+
+
+
+
+ diff --git a/test/blocks/quiz-entry/mocks/mock-data.js b/test/blocks/quiz-entry/mocks/mock-data.js index 01d7a933d6c..e317479c83a 100644 --- a/test/blocks/quiz-entry/mocks/mock-data.js +++ b/test/blocks/quiz-entry/mocks/mock-data.js @@ -100,7 +100,7 @@ const resultsMock = { options: 'photo', title: 'Photography', text: 'Edit or organize my photos', - icon: '', + icon: 'https://milo.adobe.com/drafts/quiz/quiz-ai/search.svg', image: 'https://main--milo--adobecom.hlx.page/drafts/colloyd/quiz-entry/images/photography.png', }, { @@ -664,7 +664,7 @@ const resultsMock = { }, { options: 'video', - next: 'q-rather,q-video', + next: 'RESET', type: 'card', endpoint: '', 'api-key': '', diff --git a/test/blocks/quiz-entry/quiz-entry.test.js b/test/blocks/quiz-entry/quiz-entry.test.js index 993ee21594c..d1de93beb24 100644 --- a/test/blocks/quiz-entry/quiz-entry.test.js +++ b/test/blocks/quiz-entry/quiz-entry.test.js @@ -3,7 +3,7 @@ import { readFile } from '@web/test-runner-commands'; import { expect } from '@esm-bundle/chai'; import sinon from 'sinon'; import init from '../../../libs/blocks/quiz-entry/quiz-entry.js'; -import { getSuggestions } from '../../../libs/blocks/quiz-entry/quizPopover.js'; // Correct the path as needed +import { getSuggestions } from '../../../libs/blocks/quiz-entry/quizPopover.js'; let fetchStub; let quizEntryElement; @@ -156,4 +156,147 @@ describe('Quiz Entry Component', () => { await new Promise((resolve) => setTimeout(resolve, 100)); expect(continueButton.classList.contains('disabled')).to.be.false; }); + it('should navigate the carousel using keyboard commands', async () => { + const options = document.querySelectorAll('.quiz-option'); + const option = document.querySelector('.quiz-option'); + option.click(); + await new Promise((resolve) => setTimeout(resolve, 100)); + const carousel = document.querySelector('.quiz-options-container'); + const rightArrowEvent = new KeyboardEvent('keydown', { key: 'ArrowRight' }); + const leftArrowEvent = new KeyboardEvent('keydown', { key: 'ArrowLeft' }); + carousel.dispatchEvent(rightArrowEvent); + await new Promise((resolve) => setTimeout(resolve, 100)); + carousel.dispatchEvent(leftArrowEvent); + await new Promise((resolve) => setTimeout(resolve, 100)); + const leftArrow = document.querySelector('.carousel-arrow.arrow-prev'); + expect(leftArrow).to.not.exist; + + const tabKeyEvent = new KeyboardEvent('keydown', { key: 'Tab' }); + option.dispatchEvent(tabKeyEvent); + await new Promise((resolve) => setTimeout(resolve, 100)); + expect(option.classList.contains('selected')).to.be.true; + + const spaceKeyEvent = new KeyboardEvent('keydown', { key: ' ', keyCode: 32 }); + carousel.dispatchEvent(spaceKeyEvent); + await new Promise((resolve) => setTimeout(resolve, 100)); + + const enterKeyEvent = new KeyboardEvent('keydown', { + key: 'Enter', + code: 'Enter', + keyCode: 13, + }); + carousel.dispatchEvent(enterKeyEvent); + await new Promise((resolve) => setTimeout(resolve, 100)); + expect(options[1].classList.contains('selected')).to.be.false; + }); +}); + +describe('RTL Quiz Entry', () => { + beforeEach(async () => { + window.lana = { log: sinon.stub() }; + fetchStub = sinon.stub(window, 'fetch'); + fetchStub.resolves({ + ok: true, + json: () => Promise.resolve({ suggested_completions: ['designer desk', 'design logos'] }), + }); + document.body.innerHTML = await readFile({ path: './mocks/index.html' }); + document.documentElement.setAttribute('dir', 'rtl'); + quizEntryElement = document.querySelector('.quiz-entry'); + await init(quizEntryElement, quizConfig); + await new Promise((resolve) => setTimeout(resolve, 100)); + }); + + afterEach(() => { + sinon.restore(); + }); + + it('should navigate the carousel using keyboard commands', async () => { + const options = document.querySelectorAll('.quiz-option'); + const option = document.querySelector('.quiz-option'); + option.click(); + await new Promise((resolve) => setTimeout(resolve, 100)); + const carousel = document.querySelector('.quiz-options-container'); + const rightArrowEvent = new KeyboardEvent('keydown', { key: 'ArrowRight' }); + const leftArrowEvent = new KeyboardEvent('keydown', { key: 'ArrowLeft' }); + carousel.dispatchEvent(rightArrowEvent); + await new Promise((resolve) => setTimeout(resolve, 100)); + carousel.dispatchEvent(leftArrowEvent); + await new Promise((resolve) => setTimeout(resolve, 100)); + const leftArrow = document.querySelector('.carousel-arrow.arrow-prev'); + expect(leftArrow).to.exist; + + const tabKeyEvent = new KeyboardEvent('keydown', { key: 'Tab' }); + option.dispatchEvent(tabKeyEvent); + await new Promise((resolve) => setTimeout(resolve, 100)); + expect(option.classList.contains('selected')).to.be.false; + + const spaceKeyEvent = new KeyboardEvent('keydown', { key: ' ', keyCode: 32 }); + carousel.dispatchEvent(spaceKeyEvent); + await new Promise((resolve) => setTimeout(resolve, 100)); + + const enterKeyEvent = new KeyboardEvent('keydown', { + key: 'Enter', + code: 'Enter', + keyCode: 13, + }); + carousel.dispatchEvent(enterKeyEvent); + await new Promise((resolve) => setTimeout(resolve, 100)); + expect(options[1].classList.contains('selected')).to.be.false; + }); +}); + +describe('ML Result Trigger', () => { + beforeEach(async () => { + window.lana = { log: sinon.stub() }; + fetchStub = sinon.stub(window, 'fetch'); + const mockApiResponse = { + statusCode: 200, + data: { + data: [ + { + ficode: 'illustrator_cc', + prob: '0.33', + }, + { + ficode: 'indesign_cc', + prob: '0.27', + }, + { + ficode: 'free_spark', + prob: '0.22', + }, + ], + jobName: '', + }, + }; + fetchStub.resolves({ + ok: true, + json: () => Promise.resolve(mockApiResponse.data), + }); + document.body.innerHTML = await readFile({ path: './mocks/index.html' }); + quizEntryElement = document.querySelector('.quiz-entry'); + await init(quizEntryElement, quizConfig); + await new Promise((resolve) => setTimeout(resolve, 100)); + }); + + afterEach(() => { + sinon.restore(); + }); + + it('Should trigger results fetching scenario', async () => { + const mlInputField = document.querySelector('#quiz-input'); + const testInput = 'design'; + const inputEvent = new Event('input', { bubbles: true }); + mlInputField.value = testInput; + mlInputField.dispatchEvent(inputEvent); + await new Promise((resolve) => setTimeout(resolve, 100)); + + const enterKeyEvent = new KeyboardEvent('keypress', { + key: 'Enter', + code: 'Enter', + keyCode: 13, + }); + mlInputField.dispatchEvent(enterKeyEvent); + expect(mlInputField.value).to.equal('design'); + }); }); diff --git a/test/blocks/quiz-entry/utils.test.js b/test/blocks/quiz-entry/utils.test.js new file mode 100644 index 00000000000..700f349907f --- /dev/null +++ b/test/blocks/quiz-entry/utils.test.js @@ -0,0 +1,149 @@ +/* eslint-disable no-promise-executor-return */ +import { readFile } from '@web/test-runner-commands'; +import { expect } from '@esm-bundle/chai'; +import sinon from 'sinon'; +import { handleNext, getQuizJson, handleSelections, getQuizEntryData } from '../../../libs/blocks/quiz-entry/utils.js'; // Correct the path as needed + +let fetchStub; +const { default: mockData } = await import('./mocks/mock-data.js'); +const mockQuestionsData = mockData.questions; +const mockStringsData = mockData.strings; +const quizConfig = { + quizPath: '/drafts/quiz/', + maxQuestions: 1, + analyticsQuiz: 'uarv4', + analyticsType: 'cc:app-reco', + questionData: undefined, + stringsData: undefined, +}; +const selectedQuestion = { + questions: 'q-category', + 'max-selections': '3', + 'min-selections': '1', +}; +const userInputSelections = { photo: true }; +const userInputSelectionsNot = { '3d': true }; +const userInputSelectionsReset = { video: true }; + +const userFlow = []; +const nextFlow = { nextFlow: ['q-rather', 'q-photo'] }; +const nextFlowNot = { nextFlow: ['q-3d'] }; +const nextFlowReset = { nextFlow: [] }; +const prevSelections = []; +const selections = ['photo']; +const nextSelectionsExpected = { + nextSelections: [ + { + selectedCards: [ + 'photo', + ], + selectedQuestion: { + 'max-selections': '3', + 'min-selections': '1', + questions: 'q-category', + }, + }, + ], +}; + +describe('Quiz Entry Utils', () => { + beforeEach(async () => { + window.lana = { log: sinon.stub() }; + fetchStub = sinon.stub(window, 'fetch'); + fetchStub.resolves({ + ok: true, + json: () => Promise.resolve(mockData), + }); + }); + + afterEach(() => { + sinon.restore(); + }); + + it('should handle the next flow of questions', async () => { + const nextQuestion = handleNext( + mockQuestionsData, + selectedQuestion, + userInputSelections, + userFlow, + ); + expect(nextQuestion).to.deep.equal(nextFlow); + }); + + it('should handle the next flow of questions with not()', async () => { + const nextQuestion = handleNext( + mockQuestionsData, + selectedQuestion, + userInputSelectionsNot, + userFlow, + ); + expect(nextQuestion).to.deep.equal(nextFlowNot); + }); + + it('should handle the next flow of questions with reset()', async () => { + const nextQuestion = handleNext( + mockQuestionsData, + selectedQuestion, + userInputSelectionsReset, + userFlow, + ); + expect(nextQuestion).to.deep.equal(nextFlowReset); + }); + + it('should fetch quiz data', async () => { + const [questions, strings] = await getQuizJson('./mocks/'); + expect(questions.questions).to.deep.equal(mockQuestionsData); + expect(strings.strings).to.deep.equal(mockStringsData); + }); +}); + +describe('Quiz Entry Utils failed request', () => { + beforeEach(async () => { + window.lana = { log: sinon.stub() }; + fetchStub = sinon.stub(window, 'fetch'); + fetchStub.resolves({ ok: false }); + }); + + afterEach(() => { + sinon.restore(); + }); + + it('should log an error when fetching quiz data fails', async () => { + await getQuizJson('./mocks/'); + expect(window.lana.log.called).to.be.true; + }); + it('should return nextSelections on handleSelections', async () => { + const nextSelections = handleSelections(prevSelections, selectedQuestion, selections); + expect(nextSelections).to.deep.equal(nextSelectionsExpected); + }); + + it('should de-dup any existing data if they use the ml field and cards.', async () => { + const prevSelectionsLength = [{ + selectedQuestion: { + 'max-selections': '3', + 'min-selections': '1', + questions: 'q-category', + }, + }]; + + const selectedQuestionPrev = [{ + selectedQuestion: { + 'max-selections': '3', + 'min-selections': '1', + questions: 'q-category', + }, + }]; + + const nextSelections = handleSelections(prevSelectionsLength, selectedQuestionPrev, selections); + await new Promise((resolve) => setTimeout(resolve, 100)); + expect(nextSelections).to.deep.equal(nextSelections); + }); + + it('should return quizPath, maxQuestions, analyticsQuiz, analyticsType, questionData', async () => { + document.body.innerHTML = await readFile({ path: './mocks/index.html' }); + const el = document.querySelector('.quiz-entry'); + + const quizEntryData = await getQuizEntryData(el); + expect(quizEntryData).to.deep.equal(quizConfig); + }); +}); From a22f8161e7a9d830c577311ee2b6a06ade35edf5 Mon Sep 17 00:00:00 2001 From: James Tsay <65299136+TsayAdobe@users.noreply.github.com> Date: Thu, 16 May 2024 06:16:13 -0700 Subject: [PATCH 3/3] MWPW-147527 Fix JP text issue in Review component (#2268) * Fix JP text issue in Review component * Clear ESLint --- .../review/components/review/RatingSummary.js | 27 +++++++--- test/blocks/review/mocks/body_jp.html | 54 +++++++++++++++++++ test/blocks/review/mocks/head.html | 3 ++ test/blocks/review/review_jp.test.js | 49 +++++++++++++++++ 4 files changed, 126 insertions(+), 7 deletions(-) create mode 100644 test/blocks/review/mocks/body_jp.html create mode 100644 test/blocks/review/mocks/head.html create mode 100644 test/blocks/review/review_jp.test.js diff --git a/libs/blocks/review/components/review/RatingSummary.js b/libs/blocks/review/components/review/RatingSummary.js index dd4ab4010dc..8bd6e07716a 100644 --- a/libs/blocks/review/components/review/RatingSummary.js +++ b/libs/blocks/review/components/review/RatingSummary.js @@ -1,4 +1,5 @@ -import { html } from '../../../../deps/htm-preact.js'; +/* eslint-disable react-hooks/rules-of-hooks */ +import { html, useRef } from '../../../../deps/htm-preact.js'; function RatingSummary({ averageRating = 0, @@ -11,17 +12,29 @@ function RatingSummary({ if (!averageRating) return html`
`; + const spanAverage = useRef(html` + ${averageRatingRounded} + `); + const spanMax = useRef(html` + ${maxRating} + `); + const spanTotalReviews = useRef(html` + ${totalReviews} + `); + const spanVote = useRef(html` + + ${totalReviews === 1 ? reviewString : reviewStringPlural} + + `); // placeholder return html`
- ${averageRatingRounded} + ${spanAverage.current} / - ${maxRating} + ${spanMax.current} - - ${totalReviews} - - ${totalReviews === 1 ? reviewString : reviewStringPlural} - + ${spanTotalReviews.current} + ${spanVote.current}
`; } diff --git a/test/blocks/review/mocks/body_jp.html b/test/blocks/review/mocks/body_jp.html new file mode 100644 index 00000000000..0336efec49f --- /dev/null +++ b/test/blocks/review/mocks/body_jp.html @@ -0,0 +1,54 @@ +
+
+
+
+
Review url
+
https://main--helixdemo--nkthakur48.hlx.page/data/review
+
+
+
Title
+
私たちのツールをぜひ評価してください。いただいた評価が開発チームの原動力となります。
+
+
+
Hide title
+
true
+
+
+
Rating verb
+
投票する, 件の評価
+
+
+
Rating noun
+
星, 星
+
+
+
Comment placeholder
+
フィードバックをお聞かせください
+
+
+
Comment field label
+
レビューのフィードバック
+
+
+
Submit text
+
送信
+
+
+
Thank you text
+
アンケートにご協力いただき、誠にありがとうございました。
+
+
+
Tooltips
+
悪い, 平均以下, 良い, 非常に良い, 優れている
+
+
+
Tooltip delay
+
5
+
+
+
Initial Value
+
0
+
+
+
+
diff --git a/test/blocks/review/mocks/head.html b/test/blocks/review/mocks/head.html new file mode 100644 index 00000000000..026913447a5 --- /dev/null +++ b/test/blocks/review/mocks/head.html @@ -0,0 +1,3 @@ + + + diff --git a/test/blocks/review/review_jp.test.js b/test/blocks/review/review_jp.test.js new file mode 100644 index 00000000000..b6e3eb17e51 --- /dev/null +++ b/test/blocks/review/review_jp.test.js @@ -0,0 +1,49 @@ +import sinon from 'sinon'; +import { readFile } from '@web/test-runner-commands'; +import { expect } from '@esm-bundle/chai'; +import { waitForElement, delay } from '../../helpers/waitfor.js'; +import { getConfig, updateConfig, loadArea } from '../../../libs/utils/utils.js'; + +describe('Review Component for JP', () => { + beforeEach(async () => { + const config = getConfig(); + updateConfig({ ...config, base: '/libs', codeRoot: '/libs', locale: { ietf: 'ja-JP', tk: '', prefix: 'jp' } }); + document.head.innerHTML = await readFile({ path: './mocks/head.html' }); + document.body.innerHTML = await readFile({ path: './mocks/body_jp.html' }); + window.s_adobe = { visitor: { getMarketingCloudVisitorID: () => 'abcd' } }; + sinon.stub(window, 'fetch').resolves( + new Response(JSON.stringify({ + total: 4, + offset: 0, + limit: 4, + data: [ + { country: 'all', total: '17', average: '3.5' }, + { country: 'en', total: '6', average: '3.3' }, + { country: 'fr', total: '3', average: '3.3' }, + { country: 'de', total: '3', average: '3.3' }, + ], + ':type': 'sheet', + }), { + status: 200, + headers: { 'Content-type': 'application/json' }, + }), + ); + await loadArea(); + }); + + afterEach(() => { + sinon.restore(); + }); + + it('should show JP text correctly', async () => { + const review = await waitForElement('.hlx-ReviewWrapper'); + const ratingInputs = review.querySelectorAll('.hlx-Review-ratingFields input'); + await delay(125); + await ratingInputs[2].dispatchEvent(new Event('click')); + await delay(125); + const title = review.querySelector('.hlx-reviewTitle'); + expect(title.textContent).to.equal('私たちのツールをぜひ評価してください。いただいた評価が開発チームの原動力となります。'); + const vote = review.querySelector('.hlx-ReviewStats'); + expect(vote.textContent).to.equal('3.5/5-17 件の評価'); + }); +});