Skip to content

Commit

Permalink
Merge branch 'main' into hero-headline
Browse files Browse the repository at this point in the history
  • Loading branch information
rrusher authored Jan 3, 2024
2 parents d0441d4 + fd9a8ba commit f389372
Show file tree
Hide file tree
Showing 33 changed files with 509 additions and 139 deletions.
1 change: 0 additions & 1 deletion .eslintignore
Original file line number Diff line number Diff line change
@@ -1,2 +1 @@
helix-importer-ui
scripts/partytown
23 changes: 0 additions & 23 deletions blocks/avm-report/avm-report-delayed.js

This file was deleted.

3 changes: 3 additions & 0 deletions blocks/avm-report/avm-report.css
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,9 @@
width: 67px;
}

.avm-report.block form button[type="submit"] {
transition: all .3s ease-in;
}

@media screen and (min-width: 600px) {
.avm-report.block {
Expand Down
39 changes: 18 additions & 21 deletions blocks/avm-report/avm-report.js
Original file line number Diff line number Diff line change
@@ -1,23 +1,8 @@
import {
showModal,
} from '../../scripts/util.js';

let alreadyDeferred = false;
function initGooglePlacesAPI() {
if (alreadyDeferred) {
return;
}
alreadyDeferred = true;
const script = document.createElement('script');
script.type = 'text/partytown';
script.innerHTML = `
const script = document.createElement('script');
script.type = 'module';
script.src = '${window.hlx.codeBasePath}/blocks/avm-report/avm-report-delayed.js';
document.head.append(script);
`;
document.head.append(script);
}
import { showModal } from '../../scripts/util.js';

import loadMaps from '../../scripts/google-maps/index.js';

let autocompleteAttached = false;

export default async function decorate(block) {
const form = document.createElement('form');
Expand All @@ -32,6 +17,19 @@ export default async function decorate(block) {

const addressField = form.querySelector('input[name="avmaddress"]');

addressField.addEventListener('focus', async () => {
if (!autocompleteAttached) {
loadMaps();
await window.google.maps.importLibrary('places');
// eslint-disable-next-line no-unused-vars
const autocomplete = new window.google.maps.places.Autocomplete(addressField, {
fields: ['formatted_address'],
types: ['address'],
});
autocompleteAttached = true;
}
});

form.addEventListener('submit', (e) => {
e.preventDefault();
const address = addressField.value;
Expand All @@ -49,5 +47,4 @@ export default async function decorate(block) {
window.location = redirect;
});
block.append(form);
initGooglePlacesAPI();
}
75 changes: 73 additions & 2 deletions blocks/cards/cards.css
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,11 @@
padding: 0;
}

.cards.block.cards-1-cols .cards-list .card-image {
margin-bottom: 25px;
}


.cards.block .cards-list .cards-item .card-image {
position: relative;
display: flex;
Expand All @@ -43,12 +48,11 @@
position: relative;
height: 100%;
width: 100%;
padding-bottom: 66%;
}

.cards.block .cards-list .cards-item .card-image img {
position: absolute;
top: 0;
bottom: 0;
left: 0;
object-fit: cover;
object-position: center;
Expand Down Expand Up @@ -127,19 +131,71 @@
letter-spacing: var(--letter-spacing-xs);
}

.cards.block.shade-icon .cards-list .cards-item .card-body p {
text-align: center;
margin-bottom: 10px;
}

.section.grey-background .cards.block .cards-list .cards-item .card-image p {
background-color: var(--light-grey);
}

.cards.block.shade-icon .cards-list .cards-item {
background-color: var(--light-grey);
padding: 0;
border-top: 1px solid #000;
min-height: 274px;
align-items: center;
justify-content: center;
}

.cards.block.shade-icon .cards-list .cards-item .card-body h4 {
padding: 8px 30px;
text-align: center;
font-weight: var(--font-weight-bold);
line-height: var(--line-height-l);
letter-spacing: var(--letter-spacing-m);
}

.cards.block.shade-icon .cards-list .cards-item .card-body p:not(:first-of-type) {
margin-bottom: 20px;
padding: 0 31px 34px;
font-size: var(--body-font-size-s);
}

.cards.block.shade-icon .cards-list .cards-item .card-body .icon {
display: block;
margin-top: 61px;
}

.cards.block.shade-icon .cards-list .cards-item .card-body .icon img {
margin: 0 auto;
display: block;
height: 45px;
width: 62px;
}

@media screen and (min-width: 600px) {
.cards.block.icons {
margin: 0 auto;
max-width: 83.333%;
}

.cards.block.shade-icon .cards-list {
flex-direction: row;
column-gap: 20px;
align-items: stretch;
margin-bottom: 50px;
}

.cards.block .cards-list .cards-item .card-body h3 {
font-size: var(--heading-font-size-m);
}

.cards.block.shade-icon .cards-list .cards-item .card-body p:not(:first-of-type) {
padding: 0 20px;
}

}

@media (min-width: 900px) {
Expand Down Expand Up @@ -179,5 +235,20 @@
align-items: stretch;
column-gap: 20px;
}

.cards.block.shade-icon .cards-list .cards-item .card-body p:not(:first-of-type) {
padding: 0 25px 54px;
}

}

@media (min-width: 1200px) {
.cards.block.shade-icon .cards-list {
justify-content: space-around;
column-gap: unset;
}

.cards.block.shade-icon .cards-list .cards-item {
flex: 0 1 28%;
}
}
16 changes: 14 additions & 2 deletions blocks/cards/cards.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ export default function decorate(block) {
const cards = [...block.children];

// Check for a title row
if (block.children[0].children.length === 1) {
if (!block.classList.contains('shade-icon') && block.children[0].children.length === 1) {
const wrapper = cards.shift();
const title = wrapper.children[0];
title.classList.add('title');
Expand All @@ -14,7 +14,7 @@ export default function decorate(block) {
list.classList.add('cards-list');
block.append(list);

// add logic for check-list case
// add logic for checklist case
if (block.classList.contains('icons')) {
block.classList.add('cards-2-cols');
cards.forEach((row) => {
Expand All @@ -24,6 +24,7 @@ export default function decorate(block) {
list.append(row);
});
} else {
let ratio = 9999;
block.classList.add(`cards-${cards.length}-cols`);
cards.forEach((row) => {
row.className = 'cards-item';
Expand All @@ -32,13 +33,24 @@ export default function decorate(block) {
// update container for picture with label
div.classList.add('card-image');
const picture = div.querySelector('picture');
const img = picture.querySelector('img');
const tmp = (parseInt(img.height, 10) / parseInt(img.width, 10)) * 100;
if (tmp < ratio) {
ratio = tmp;
}
const paragraphElement = document.createElement(('p'));
paragraphElement.textContent = div.textContent.trim();
div.replaceChildren(picture, paragraphElement);
} else {
div.classList.add('card-body');
}
});
// Pad the picture with the smallest ratio image.
[...row.children].forEach((div) => {
if (div.querySelector('picture')) {
div.querySelector('picture').style.paddingBottom = `${ratio}%`;
}
});
list.append(row);
});
}
Expand Down
90 changes: 90 additions & 0 deletions blocks/embed/lite-yt-embed.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
/* copied from https://github.com/paulirish/lite-youtube-embed/releases/tag/v0.2.0 */
/* stylelint-disable */

lite-youtube {
background-color: #000;
position: relative;
display: block;
contain: content;
background-position: center center;
background-size: cover;
cursor: pointer;
max-width: 720px;
}

/* gradient */
lite-youtube::before {
content: '';
display: block;
position: absolute;
top: 0;
background-image: url();
background-position: top;
background-repeat: repeat-x;
height: 60px;
padding-bottom: 50px;
width: 100%;
transition: all 0.2s cubic-bezier(0, 0, 0.2, 1);
}

/* responsive iframe with a 16:9 aspect ratio
thanks https://css-tricks.com/responsive-iframes/
*/
lite-youtube::after {
content: "";
display: block;
padding-bottom: calc(100% / (16 / 9));
}

lite-youtube > iframe {
width: 100%;
height: 100%;
position: absolute;
top: 0;
left: 0;
border: 0;
}

/* play button */
lite-youtube > .lty-playbtn {
width: 68px;
height: 48px;
position: absolute;
cursor: pointer;
transform: translate3d(-50%, -50%, 0);
top: 50%;
left: 50%;
z-index: 1;
background-color: transparent;
/* YT's actual play button svg */
background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" version="1.1" viewBox="0 0 68 48"><path fill="%23f00" fill-opacity="0.8" d="M66.52,7.74c-0.78-2.93-2.49-5.41-5.42-6.19C55.79,.13,34,0,34,0S12.21,.13,6.9,1.55 C3.97,2.33,2.27,4.81,1.48,7.74C0.06,13.05,0,24,0,24s0.06,10.95,1.48,16.26c0.78,2.93,2.49,5.41,5.42,6.19 C12.21,47.87,34,48,34,48s21.79-0.13,27.1-1.55c2.93-0.78,4.64-3.26,5.42-6.19C67.94,34.95,68,24,68,24S67.94,13.05,66.52,7.74z"></path><path d="M 45,24 27,14 27,34" fill="%23fff"></path></svg>');
filter: grayscale(100%);
transition: filter .1s cubic-bezier(0, 0, 0.2, 1);
border: none;
}

lite-youtube:hover > .lty-playbtn,
lite-youtube .lty-playbtn:focus {
filter: none;
}

/* Post-click styles */
lite-youtube.lyt-activated {
cursor: unset;
}

lite-youtube.lyt-activated::before,
lite-youtube.lyt-activated > .lty-playbtn {
opacity: 0;
pointer-events: none;
}

.lyt-visually-hidden {
clip: rect(0 0 0 0);
clip-path: inset(50%);
height: 1px;
overflow: hidden;
position: absolute;
white-space: nowrap;
width: 1px;
}
Loading

0 comments on commit f389372

Please sign in to comment.