Skip to content

Commit

Permalink
MWPW-147472: auto adjust commerce iframe (#2251)
Browse files Browse the repository at this point in the history
* 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>
  • Loading branch information
yesil and mirafedas authored May 15, 2024
1 parent 2b0a26c commit 481bbcb
Show file tree
Hide file tree
Showing 5 changed files with 72 additions and 12 deletions.
1 change: 0 additions & 1 deletion libs/blocks/merch/merch.css
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,6 @@ a[is='checkout-link'] > span {
}

#checkout-link-modal iframe {
height: 100%;
flex: 1;
}

Expand Down
4 changes: 2 additions & 2 deletions libs/blocks/merch/merch.js
Original file line number Diff line number Diff line change
Expand Up @@ -152,8 +152,8 @@ export async function fetchLiterals(url) {

export async function fetchCheckoutLinkConfigs(base = '') {
fetchCheckoutLinkConfigs.promise = fetchCheckoutLinkConfigs.promise
?? fetch(`${base}${CHECKOUT_LINK_CONFIG_PATH}`).catch(() => {
log?.error('Failed to fetch checkout link configs');
?? fetch(`${base}${CHECKOUT_LINK_CONFIG_PATH}`).catch((e) => {
log?.error('Failed to fetch checkout link configs', e);
}).then((mappings) => {
if (!mappings?.ok) return undefined;
return mappings.json();
Expand Down
13 changes: 11 additions & 2 deletions libs/blocks/modal/modal.merch.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,18 @@ import { debounce } from '../../utils/action.js';
export const MOBILE_MAX = 599;
export const TABLET_MAX = 1199;

window.addEventListener('pageshow', (event) => {
// if there is a commerce modal with an iframe open, reload the page to avoid bfcache issues.
if (event.persisted && document.querySelector('.dialog-modal.commerce-frame iframe')) {
window.location.reload();
}
});

export function adjustModalHeight(contentHeight) {
if (!window.location.hash) return;
const dialog = document.querySelector(`div.dialog-modal.commerce-frame${window.location.hash}`);
if (!(window.location.hash || document.getElementById('checkout-link-modal'))) return;
let selector = '#checkout-link-modal';
if (!/=/.test(window.location.hash)) selector = `${selector},div.dialog-modal.commerce-frame${window.location.hash}`;
const dialog = document.querySelector(selector);
const iframe = dialog?.querySelector('iframe');
const iframeWrapper = dialog?.querySelector('.milo-iframe');
if (!contentHeight || !iframe || !iframeWrapper) return;
Expand Down
18 changes: 18 additions & 0 deletions test/blocks/modals/mocks/iframe.plain.html
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
<main></main>
<template id="modal1">
<div class="dialog-modal commerce-frame" id="first-dialog">
<div class="fragment">
<div class="section">
Expand All @@ -7,7 +9,9 @@
</div>
</div>
</div>
</template>

<template id="modal2">
<div class="dialog-modal commerce-frame" id="second-dialog">
<div class="fragment">
<div class="section">
Expand All @@ -17,3 +21,17 @@
</div>
</div>
</div>
</template>


<template id="modal3">
<div class="dialog-modal commerce-frame" id="checkout-link-modal">
<div class="fragment">
<div class="section">
<div class="milo-iframe modal">
<iframe src="https://www.adobe.com/mini-plans/illustrator.html?mid=ft&amp;web=1&amp;pint=Illustrator" allowfullscreen="true"></iframe>
</div>
</div>
</div>
</div>
</template>
48 changes: 41 additions & 7 deletions test/blocks/modals/modal.merch.test.js
Original file line number Diff line number Diff line change
@@ -1,19 +1,38 @@
import { readFile, setViewport } from '@web/test-runner-commands';
import { expect } from '@esm-bundle/chai';
import sinon from 'sinon';
import enableCommerceFrameFeatures, { MOBILE_MAX, TABLET_MAX } from '../../../libs/blocks/modal/modal.merch.js';
import enableCommerceFrameFeatures, { MOBILE_MAX, TABLET_MAX, adjustModalHeight } from '../../../libs/blocks/modal/modal.merch.js';
import { delay } from '../../helpers/waitfor.js';

document.body.innerHTML = await readFile({ path: './mocks/iframe.plain.html' });
const dialog = document.querySelector('#first-dialog');
const iframeWrapper = dialog.querySelector('.milo-iframe');
const iframe = dialog.querySelector('iframe');
const secondDialog = document.querySelector('#second-dialog');
const secondIframeWrapper = secondDialog.querySelector('.milo-iframe');
const secondIframe = secondDialog.querySelector('iframe');

const main = document.querySelector('main');

const addModal = (selector) => {
main.append(document.getElementById(selector).content.cloneNode(true));
const dialog = document.querySelector('.dialog-modal');
const iframeWrapper = dialog.querySelector('.milo-iframe');
const iframe = dialog.querySelector('iframe');
const secondDialog = document.querySelector('.dialog-modal:nth-child(2)');
const secondIframeWrapper = secondDialog?.querySelector('.milo-iframe');
const secondIframe = secondDialog?.querySelector('iframe');
return {
dialog,
iframe,
iframeWrapper,
secondDialog,
secondIframe,
secondIframeWrapper,
};
};

describe('Modal dialog with a `commerce-frame` class', () => {
beforeEach(() => {
main.innerHTML = '';
});

it('adjustStyles: sets the iframe height to 100% if height adjustment is not applicable', () => {
const { dialog, iframe } = addModal('modal1');
const originalSrc = iframe.getAttribute('src');
iframe.setAttribute('src', 'https://www.adobe.com/somepage.html');
enableCommerceFrameFeatures({ dialog, iframe });
Expand All @@ -24,12 +43,15 @@ describe('Modal dialog with a `commerce-frame` class', () => {
});

it('adjustStyles: sets the `height-fit-content` class if height adjustment is applicable', () => {
const { dialog, iframe } = addModal('modal1');
enableCommerceFrameFeatures({ dialog, iframe });
expect(dialog.classList.contains('height-fit-content')).to.be.true;
expect(iframe.style.height).to.equal('');
});

it('sends viewport dimensions upon request, and then on every resize', async () => {
await setViewport({ width: 800, height: 600 });
const { dialog, iframe } = addModal('modal1');
sinon.spy(window, 'postMessage');
enableCommerceFrameFeatures({ dialog, iframe });
window.postMessage('viewportWidth');
Expand All @@ -52,6 +74,7 @@ describe('Modal dialog with a `commerce-frame` class', () => {
});

it('adjusts modal height if height auto adjustment is applicable', async () => {
const { dialog, iframe, iframeWrapper } = addModal('modal1');
const contentHeight = {
desktop: 714,
mobile: '100%',
Expand All @@ -74,6 +97,10 @@ describe('Modal dialog with a `commerce-frame` class', () => {
});

it('properly adjusts the modal height when there are two modals on the page', async () => {
addModal('modal1');
const {
dialog, iframe, iframeWrapper, secondDialog, secondIframe, secondIframeWrapper,
} = addModal('modal2');
const contentHeight = {
desktop1: 714,
desktop2: 600,
Expand Down Expand Up @@ -111,4 +138,11 @@ describe('Modal dialog with a `commerce-frame` class', () => {
expect(dialog.style.height).to.equal('');
window.location.hash = '';
});

it('initialises managed modals via merch block', async () => {
window.location.hash = '#page=2';
const { dialog } = addModal('modal3');
adjustModalHeight(600);
expect(dialog.style.height).to.equal('580px');
});
});

0 comments on commit 481bbcb

Please sign in to comment.