diff --git a/blocks/comparison/comparison.js b/blocks/comparison/comparison.js index 09ffa0b..78e220c 100644 --- a/blocks/comparison/comparison.js +++ b/blocks/comparison/comparison.js @@ -1,10 +1,10 @@ -import { getLibs } from '../../scripts/utils.js'; +import { LIBS } from '../../scripts/scripts.js'; /** * @param {Element} el */ const init = async (el) => { - const { createTag } = await import(`${getLibs()}/utils/utils.js`); + const { createTag } = await import(`${LIBS}/utils/utils.js`); const rows = Array.from(el.querySelectorAll(':scope > div')); const headers = Array.from(rows.shift().children); const headersRow = createTag('tr'); diff --git a/blocks/faas-decode/faas-decode.js b/blocks/faas-decode/faas-decode.js index f6976dc..0224600 100644 --- a/blocks/faas-decode/faas-decode.js +++ b/blocks/faas-decode/faas-decode.js @@ -1,7 +1,7 @@ -import { getLibs } from '../../scripts/utils.js'; +import { LIBS } from '../../scripts/scripts.js'; export default async function init(el) { - const { createTag, parseEncodedConfig } = await import(`${getLibs()}/utils/utils.js`); + const { createTag, parseEncodedConfig } = await import(`${LIBS}/utils/utils.js`); const url = el.querySelector('a')?.href; const resp = await fetch(url); diff --git a/blocks/redirects-formatter/redirects-formatter.js b/blocks/redirects-formatter/redirects-formatter.js index 700da63..f03288d 100644 --- a/blocks/redirects-formatter/redirects-formatter.js +++ b/blocks/redirects-formatter/redirects-formatter.js @@ -1,4 +1,4 @@ -import { getLibs } from '../../scripts/utils.js'; +import { LIBS } from '../../scripts/scripts.js'; export const SELECT_ALL_REGIONS = 'Select All Regions'; export const DESELECT_ALL_REGIONS = 'De-select All Regions'; @@ -12,7 +12,7 @@ const INSTRUCTIONS_TEXT = 'Select the locales you require by checking the checkb + ' press "Copy to clipboard" or select them with the cursor manually.'; async function createLocaleCheckboxes(prefixGroup) { - const { createTag } = await import(`${getLibs()}/utils/utils.js`); + const { createTag } = await import(`${LIBS}/utils/utils.js`); return Object.keys(prefixGroup).map((key) => { const { prefix } = prefixGroup[key]; @@ -87,7 +87,7 @@ export function stringifyListForExcel(urls) { } export default async function init(el) { - const { createTag } = await import(`${getLibs()}/utils/utils.js`); + const { createTag } = await import(`${LIBS}/utils/utils.js`); const xlPath = './locale-config.json'; const resp = await fetch(xlPath); if (!resp.ok) return; diff --git a/blocks/stats/stats.js b/blocks/stats/stats.js index 68055eb..84af4aa 100644 --- a/blocks/stats/stats.js +++ b/blocks/stats/stats.js @@ -1,4 +1,4 @@ -import { getLibs } from '../../scripts/utils.js'; +import { LIBS } from '../../scripts/scripts.js'; async function decorateRow(row, module) { const { decorateLinkAnalytics } = module; @@ -14,8 +14,8 @@ async function decorateRow(row, module) { } export default async function init(el) { - const { createTag } = await import(`${getLibs()}/utils/utils.js`); - const module = await import(`${getLibs()}/martech/attributes.js`); + const { createTag } = await import(`${LIBS}/utils/utils.js`); + const module = await import(`${LIBS}/martech/attributes.js`); module.decorateBlockAnalytics(el); const firstRow = el.querySelector(':scope > div'); diff --git a/blocks/tree-view/tree-view.js b/blocks/tree-view/tree-view.js index 771ac00..385cdb9 100644 --- a/blocks/tree-view/tree-view.js +++ b/blocks/tree-view/tree-view.js @@ -1,4 +1,4 @@ -import { getLibs } from '../../scripts/utils.js'; +import { LIBS } from '../../scripts/scripts.js'; const BACOM_HOSTS = ['localhost', '--bacom--adobecom.hlx.page', '--bacom--adobecom.hlx.live', 'business.adobe.com']; @@ -110,7 +110,7 @@ const init = async (el) => { if (!topList) return; - const { createTag } = await import(`${getLibs()}/utils/utils.js`); + const { createTag } = await import(`${LIBS}/utils/utils.js`); const subLists = topList.querySelectorAll('ul'); const isAccordion = subLists.length > 0; const links = el.querySelectorAll('a'); diff --git a/blocks/workfront-login/workfront-login.js b/blocks/workfront-login/workfront-login.js index 6c6d0c1..1b7ceda 100644 --- a/blocks/workfront-login/workfront-login.js +++ b/blocks/workfront-login/workfront-login.js @@ -1,4 +1,4 @@ -import { getLibs } from '../../scripts/utils.js'; +import { LIBS } from '../../scripts/scripts.js'; export async function createProofForm(createTag, replaceKey, config) { const form = createTag('form', { action: 'https://app.proofhq.com/login', method: 'post' }); @@ -105,8 +105,8 @@ export async function createSubdomainForm(createTag, replaceKey, config) { /* c8 ignore next 14 */ export default async function init(el) { - const { createTag, getConfig } = await import(`${getLibs()}/utils/utils.js`); - const { replaceKey } = await import(`${getLibs()}/features/placeholders.js`); + const { createTag, getConfig } = await import(`${LIBS}/utils/utils.js`); + const { replaceKey } = await import(`${LIBS}/features/placeholders.js`); const config = getConfig(); const isProof = el.classList.contains('proof'); diff --git a/scripts/scripts.js b/scripts/scripts.js index 533c05d..9c9f1e0 100644 --- a/scripts/scripts.js +++ b/scripts/scripts.js @@ -1,6 +1,3 @@ -import { setLibs } from './utils.js'; - -const LIBS = '/libs'; const STYLES = ['/styles/styles.css']; const CONFIG = { imsClientId: 'bacom', @@ -157,10 +154,18 @@ const loadStyle = (path) => { eagerLoad(marquee.querySelector('img')); }()); -const miloLibs = setLibs(LIBS); +export function setLibs(location) { + const { hostname, search } = location; + if (!['.hlx.', '.stage.', 'local'].some((i) => hostname.includes(i))) return '/libs'; + const branch = new URLSearchParams(search).get('milolibs') || 'main'; + if (branch === 'local') return 'http://localhost:6456/libs'; + return branch.includes('--') ? `https://${branch}.hlx.live/libs` : `https://${branch}--milo--adobecom.hlx.live/libs`; +} + +export const LIBS = setLibs(window.location); (function loadStyles() { - const paths = [`${miloLibs}/styles/styles.css`]; + const paths = [`${LIBS}/styles/styles.css`]; if (STYLES) { paths.push(...(Array.isArray(STYLES) ? STYLES : [STYLES])); } @@ -168,7 +173,7 @@ const miloLibs = setLibs(LIBS); }()); (async function loadPage() { - const { loadArea, loadLana, setConfig, createTag, getMetadata } = await import(`${miloLibs}/utils/utils.js`); + const { loadArea, loadLana, setConfig, createTag, getMetadata } = await import(`${LIBS}/utils/utils.js`); if (getMetadata('template') === '404') window.SAMPLE_PAGEVIEWS_AT_RATE = 'high'; const metaCta = document.querySelector('meta[name="chat-cta"]'); if (metaCta && !document.querySelector('.chat-cta')) { @@ -179,7 +184,7 @@ const miloLibs = setLibs(LIBS); if (lastSection) lastSection.insertAdjacentElement('beforeend', chatDiv); } } - setConfig({ ...CONFIG, miloLibs }); + setConfig({ ...CONFIG, miloLibs: LIBS }); loadLana({ clientId: 'bacom', tags: 'info' }); await loadArea(); diff --git a/scripts/utils.js b/scripts/utils.js deleted file mode 100644 index bd9f037..0000000 --- a/scripts/utils.js +++ /dev/null @@ -1,15 +0,0 @@ -export const [setLibs, getLibs] = (() => { - let libs; - return [ - (prodLibs, location) => { - libs = (() => { - const { hostname, search } = location || window.location; - if (!['.hlx.', '.stage.', 'local'].some((i) => hostname.includes(i))) return prodLibs; - const branch = new URLSearchParams(search).get('milolibs') || 'main'; - if (branch === 'local') return 'http://localhost:6456/libs'; - return branch.includes('--') ? `https://${branch}.hlx.live/libs` : `https://${branch}--milo--adobecom.hlx.live/libs`; - })(); - return libs; - }, () => libs, - ]; -})(); diff --git a/templates/featured-story/featured-story.js b/templates/featured-story/featured-story.js index 5a6c596..6e463d0 100644 --- a/templates/featured-story/featured-story.js +++ b/templates/featured-story/featured-story.js @@ -2,9 +2,9 @@ Templates - featured story */ -import { getLibs } from '../../scripts/utils.js'; +import { LIBS } from '../../scripts/scripts.js'; -const { createTag } = await import(`${getLibs()}/utils/utils.js`); +const { createTag } = await import(`${LIBS}/utils/utils.js`); function init() { const i = 1; diff --git a/test/blocks/comparison/comparison.test.js b/test/blocks/comparison/comparison.test.js index a19a25f..40771e9 100644 --- a/test/blocks/comparison/comparison.test.js +++ b/test/blocks/comparison/comparison.test.js @@ -1,9 +1,7 @@ import { readFile } from '@web/test-runner-commands'; import { expect } from '@esm-bundle/chai'; import init from '../../../blocks/comparison/comparison.js'; -import { setLibs } from '../../../scripts/utils.js'; -setLibs('/libs'); document.body.innerHTML = await readFile({ path: './mocks/body.html' }); describe('Comparison Table', () => { it('Verify Comparison Table Exists', async () => { diff --git a/test/blocks/faas-decode/faas-decode.test.js b/test/blocks/faas-decode/faas-decode.test.js index e643aff..7d31a01 100644 --- a/test/blocks/faas-decode/faas-decode.test.js +++ b/test/blocks/faas-decode/faas-decode.test.js @@ -1,7 +1,6 @@ import { expect } from '@esm-bundle/chai'; import sinon from 'sinon'; import init from '../../../blocks/faas-decode/faas-decode.js'; -import { setLibs } from '../../../scripts/utils.js'; import waitForElement from '../../helpers/waitForElement.js'; window.lana = { log: () => {} }; @@ -9,7 +8,6 @@ window.lana = { log: () => {} }; describe('FaaS Decode', () => { before(() => { sinon.stub(window.lana, 'log'); - setLibs('/libs'); }); after(() => { diff --git a/test/blocks/redirects-formatter/redirects-formatter.test.js b/test/blocks/redirects-formatter/redirects-formatter.test.js index 9077128..ac9002a 100644 --- a/test/blocks/redirects-formatter/redirects-formatter.test.js +++ b/test/blocks/redirects-formatter/redirects-formatter.test.js @@ -1,7 +1,6 @@ import { readFile } from '@web/test-runner-commands'; import { expect } from '@esm-bundle/chai'; import sinon from 'sinon'; -import { setLibs } from '../../../scripts/utils.js'; const { default: init, @@ -14,8 +13,6 @@ const { } = await import('../../../blocks/redirects-formatter/redirects-formatter.js'); const { htmlIncluded, htmlExcluded, externalUrls, mixedSpaceTabUrls } = await import('./mocks/textAreaValues.js'); -setLibs('libs'); - describe('Redirects Formatter', () => { const ogFetch = window.fetch; diff --git a/test/blocks/stats/stats.test.js b/test/blocks/stats/stats.test.js index 0179ce3..9905012 100644 --- a/test/blocks/stats/stats.test.js +++ b/test/blocks/stats/stats.test.js @@ -1,10 +1,7 @@ import { expect } from '@esm-bundle/chai'; -import { setLibs } from '../../../scripts/utils.js'; const { default: init } = await import('../../../blocks/stats/stats.js'); -setLibs('libs'); - describe('Stats', () => { it('Allows intro', async () => { document.body.innerHTML = '
Intro
Stat 1
Stat 2
'; diff --git a/test/blocks/tree-view/tree-view.test.js b/test/blocks/tree-view/tree-view.test.js index 428284a..bd3abfe 100644 --- a/test/blocks/tree-view/tree-view.test.js +++ b/test/blocks/tree-view/tree-view.test.js @@ -1,12 +1,10 @@ import { readFile } from '@web/test-runner-commands'; import { expect } from '@esm-bundle/chai'; import sinon from 'sinon'; -import { setLibs } from '../../../scripts/utils.js'; const { default: init, isCurrentPage } = await import('../../../blocks/tree-view/tree-view.js'); window.lana = { log: () => {} }; -setLibs('libs'); describe('Tree View', () => { describe('simple', () => { diff --git a/test/blocks/workfront-login/workfront.test.js b/test/blocks/workfront-login/workfront.test.js index 25f5ef5..11511b5 100644 --- a/test/blocks/workfront-login/workfront.test.js +++ b/test/blocks/workfront-login/workfront.test.js @@ -1,12 +1,9 @@ import { expect } from '@esm-bundle/chai'; import sinon from 'sinon'; import waitForElement from '../../helpers/waitForElement.js'; -import { setLibs } from '../../../scripts/utils.js'; import { createTag, replaceKey, getConfig } from './mocks/workfront-utils.js'; import { createSubdomainForm, createProofForm, location } from '../../../blocks/workfront-login/workfront-login.js'; -setLibs('libs'); - const config = getConfig(); const delay = (timeOut, cb) => new Promise((resolve) => { diff --git a/test/scripts/scripts.test.js b/test/scripts/scripts.test.js new file mode 100644 index 0000000..3c75c51 --- /dev/null +++ b/test/scripts/scripts.test.js @@ -0,0 +1,36 @@ +import { expect } from '@esm-bundle/chai'; +import { setLibs, LIBS } from '../../scripts/scripts.js'; + +describe('Libs', () => { + const tests = [ + ['https://business.adobe.com', '/libs'], + ['https://business.adobe.com?milolibs=foo', '/libs'], + ['https://business.stage.adobe.com', 'https://main--milo--adobecom.hlx.live/libs'], + ['https://business.stage.adobe.com?milolibs=foo', 'https://foo--milo--adobecom.hlx.live/libs'], + ['https://business.stage.adobe.com?milolibs=awesome--milo--forkedowner', 'https://awesome--milo--forkedowner.hlx.live/libs'], + ['https://main--bacom--adobecom.hlx.page/', 'https://main--milo--adobecom.hlx.live/libs'], + ['https://main--bacom--adobecom.hlx.page/?milolibs=foo', 'https://foo--milo--adobecom.hlx.live/libs'], + ['https://main--bacom--adobecom.hlx.page/?milolibs=local', 'http://localhost:6456/libs'], + ['https://main--bacom--adobecom.hlx.page/?milolibs=awesome--milo--forkedowner', 'https://awesome--milo--forkedowner.hlx.live/libs'], + ['https://main--bacom--adobecom.hlx.live/', 'https://main--milo--adobecom.hlx.live/libs'], + ['https://main--bacom--adobecom.hlx.live/?milolibs=foo', 'https://foo--milo--adobecom.hlx.live/libs'], + ['https://main--bacom--adobecom.hlx.live/?milolibs=local', 'http://localhost:6456/libs'], + ['https://main--bacom--adobecom.hlx.live/?milolibs=awesome--milo--forkedowner', 'https://awesome--milo--forkedowner.hlx.live/libs'], + ['http://localhost:3000', 'https://main--milo--adobecom.hlx.live/libs'], + ['http://localhost:3000?milolibs=foo', 'https://foo--milo--adobecom.hlx.live/libs'], + ['http://localhost:3000?milolibs=local', 'http://localhost:6456/libs'], + ['http://localhost:3000?milolibs=awesome--milo--forkedowner', 'https://awesome--milo--forkedowner.hlx.live/libs'], + ]; + + tests.forEach(([url, expected]) => { + it(`Sets libs for ${url}`, () => { + const location = new URL(url); + const libs = setLibs(location); + expect(libs).to.equal(expected); + }); + }); + + it('Sets LIBS', () => { + expect(LIBS).to.equal('https://main--milo--adobecom.hlx.live/libs'); + }); +}); diff --git a/test/scripts/utils.test.js b/test/scripts/utils.test.js deleted file mode 100644 index eb6cd39..0000000 --- a/test/scripts/utils.test.js +++ /dev/null @@ -1,45 +0,0 @@ -import { expect } from '@esm-bundle/chai'; -import { setLibs } from '../../scripts/utils.js'; - -describe('Libs', () => { - it('Sets default Libs', () => { - const libs = setLibs('/libs'); - expect(libs).to.equal('https://main--milo--adobecom.hlx.live/libs'); - }); - - it('Does not support milolibs query param on prod', () => { - const location = { - hostname: 'business.adobe.com', - search: '?milolibs=foo', - }; - const libs = setLibs('/libs', location); - expect(libs).to.equal('/libs'); - }); - - it('Supports milolibs query param', () => { - const location = { - hostname: 'localhost', - search: '?milolibs=foo', - }; - const libs = setLibs('/libs', location); - expect(libs).to.equal('https://foo--milo--adobecom.hlx.live/libs'); - }); - - it('Supports local milolibs query param', () => { - const location = { - hostname: 'localhost', - search: '?milolibs=local', - }; - const libs = setLibs('/libs', location); - expect(libs).to.equal('http://localhost:6456/libs'); - }); - - it('Supports forked milolibs query param', () => { - const location = { - hostname: 'localhost', - search: '?milolibs=awesome--milo--forkedowner', - }; - const libs = setLibs('/libs', location); - expect(libs).to.equal('https://awesome--milo--forkedowner.hlx.live/libs'); - }); -});