From 23ad1f722326a31d504d50ba99a3a2cd310be777 Mon Sep 17 00:00:00 2001 From: Anian Weber Date: Fri, 8 Dec 2023 13:51:25 +0100 Subject: [PATCH 1/8] SPIN-126 // Prototype for hubspot integration --- blocks/form/form.js | 196 ++------------------------------------------ 1 file changed, 8 insertions(+), 188 deletions(-) diff --git a/blocks/form/form.js b/blocks/form/form.js index 0894e3f..c2b113f 100644 --- a/blocks/form/form.js +++ b/blocks/form/form.js @@ -1,192 +1,12 @@ -function createSelect(fd) { - const select = document.createElement('select'); - select.id = fd.Field; - if (fd.Placeholder) { - const ph = document.createElement('option'); - ph.textContent = fd.Placeholder; - ph.setAttribute('selected', ''); - ph.setAttribute('disabled', ''); - select.append(ph); - } - fd.Options.split(',').forEach((o) => { - const option = document.createElement('option'); - option.textContent = o.trim(); - option.value = o.trim(); - select.append(option); - }); - if (fd.Mandatory === 'x') { - select.setAttribute('required', 'required'); - } - return select; -} - -function constructPayload(form) { - const payload = {}; - [...form.elements].forEach((fe) => { - if (fe.type === 'checkbox') { - if (fe.checked) payload[fe.id] = fe.value; - } else if (fe.id) { - payload[fe.id] = fe.value; - } - }); - return payload; -} - -async function submitForm(form) { - const payload = constructPayload(form); - const resp = await fetch(form.dataset.action, { - method: 'POST', - cache: 'no-cache', - headers: { - 'Content-Type': 'application/json', - }, - body: JSON.stringify({ data: payload }), - }); - await resp.text(); - return payload; -} - -function createButton(fd) { - const button = document.createElement('button'); - button.textContent = fd.Label; - button.classList.add('button'); - if (fd.Type === 'submit') { - button.addEventListener('click', async (event) => { - const form = button.closest('form'); - const formBlock = button.closest('.form.block'); - if (form.checkValidity()) { - event.preventDefault(); - button.setAttribute('disabled', ''); - await submitForm(form); - const formThankYou = formBlock.querySelector('.form-thank-you'); - if (formThankYou) { - formBlock.querySelector('.form-content').classList.add('hidden'); - formThankYou.classList.remove('hidden'); - } - - window.location.hash = '#form'; - } - }); - } - return button; -} - -function createHeading(fd) { - const heading = document.createElement('h3'); - heading.textContent = fd.Label; - return heading; -} +import { loadScript } from '../../scripts/lib-franklin.js'; -function createInput(fd) { - const input = document.createElement('input'); - input.type = fd.Type; - input.id = fd.Field; - input.setAttribute('placeholder', fd.Placeholder); - if (fd.Mandatory === 'x') { - input.setAttribute('required', 'required'); - } - return input; -} - -function createTextArea(fd) { - const input = document.createElement('textarea'); - input.id = fd.Field; - input.setAttribute('placeholder', fd.Placeholder); - if (fd.Mandatory === 'x') { - input.setAttribute('required', 'required'); - } - return input; -} +export default async function decorate() { + await loadScript('https://js.hsforms.net/forms/embed/v2.js'); -function createLabel(fd) { - const label = document.createElement('label'); - label.setAttribute('for', fd.Field); - label.textContent = fd.Label; - if (fd.Mandatory === 'x') { - label.classList.add('required'); - } - return label; -} - -function applyRules(form, rules) { - const payload = constructPayload(form); - rules.forEach((field) => { - const { type, condition: { key, operator, value } } = field.rule; - if (type === 'visible') { - if (operator === 'eq') { - if (payload[key] === value) { - form.querySelector(`.${field.fieldId}`).classList.remove('hidden'); - } else { - form.querySelector(`.${field.fieldId}`).classList.add('hidden'); - } - } - } + window.hbspt.forms.create({ + region: 'na1', + portalId: '3458432', + formId: 'a9f10e4b-6c50-442b-ae10-df1b06d21e6f', + target: '.form', }); } - -async function createForm(formURL) { - const { pathname } = new URL(formURL); - const resp = await fetch(pathname); - const json = await resp.json(); - const form = document.createElement('form'); - const rules = []; - // eslint-disable-next-line prefer-destructuring - form.dataset.action = pathname.split('.json')[0]; - json.data.forEach((fd) => { - fd.Type = fd.Type || 'text'; - const fieldWrapper = document.createElement('div'); - const style = fd.Style ? ` form-${fd.Style}` : ''; - const fieldId = `form-${fd.Type}-wrapper${style}`; - fieldWrapper.className = fieldId; - fieldWrapper.classList.add('field-wrapper'); - switch (fd.Type) { - case 'select': - fieldWrapper.append(createLabel(fd)); - fieldWrapper.append(createSelect(fd)); - break; - case 'heading': - fieldWrapper.append(createHeading(fd)); - break; - case 'checkbox': - fieldWrapper.append(createInput(fd)); - fieldWrapper.append(createLabel(fd)); - break; - case 'text-area': - fieldWrapper.append(createLabel(fd)); - fieldWrapper.append(createTextArea(fd)); - break; - case 'submit': - fieldWrapper.append(createButton(fd)); - break; - default: - fieldWrapper.append(createInput(fd)); - fieldWrapper.append(createLabel(fd)); - } - - if (fd.Rules) { - try { - rules.push({ fieldId, rule: JSON.parse(fd.Rules) }); - } catch (e) { - // eslint-disable-next-line no-console - console.warn(`Invalid Rule ${fd.Rules}: ${e}`); - } - } - form.append(fieldWrapper); - }); - - form.addEventListener('change', () => applyRules(form, rules)); - applyRules(form, rules); - - return (form); -} - -export default async function decorate(block) { - const form = block.querySelector('a[href$=".json"]'); - block.id = 'form'; - if (form) { - form.parentElement.replaceWith(await createForm(form.href)); - } - const formRows = block.querySelectorAll('.form>div'); - formRows[0].classList.add('form-content'); - formRows[1].classList.add('form-thank-you', 'hidden'); -} From b3c05c3e6b172b6f974ea57d309cfba77c7b1f75 Mon Sep 17 00:00:00 2001 From: voggenauerm Date: Mon, 11 Dec 2023 15:20:04 +0100 Subject: [PATCH 2/8] SPIN-126 // Include basic hubspot form, adjust form styling to work with new markup --- blocks/form/form.css | 98 ++++++++++++++------ blocks/form/form.js | 206 +++++-------------------------------------- styles/styles.css | 9 +- 3 files changed, 99 insertions(+), 214 deletions(-) diff --git a/blocks/form/form.css b/blocks/form/form.css index 3e88b9e..ac2361b 100644 --- a/blocks/form/form.css +++ b/blocks/form/form.css @@ -81,34 +81,72 @@ gap: 52px; } -.section-ready-to-fly .field-wrapper { +fieldset { + max-width: none !important; /* Override hs styling */ +} + +.input { + margin-right: 0 !important; /* Override hs styling */ +} + +:is(.hs-fieldtype-text, .hs-fieldtype-phonenumber, .hs-fieldtype-textarea) .hs-input { + width: 100% !important; /* Override hs styling */ +} + +.form-columns-2 { + display: grid; + grid-template-columns: 1fr; + column-gap: 16px; + row-gap: 52px; +} + +@media (min-width: 700px) { + .form-columns-2 { + grid-template-columns: repeat(2, 1fr); + } +} + +.form-columns-2 .hs-form-field { + width: 100% !important; /* Override hs styling */ +} + +.section-ready-to-fly .field { position: relative; } -.section-ready-to-fly .field-wrapper input, -.section-ready-to-fly .field-wrapper textarea { +.section-ready-to-fly .field input, +.section-ready-to-fly .field textarea { margin: 0; max-width: 100vw; } -.section-ready-to-fly .field-wrapper textarea { +.section-ready-to-fly .field textarea { border: none; padding: 16px 25px; border-radius: 15px; - background-color: var(--color-light-purple); + background-color: #382F6F; +} + +.hs-richtext { + font-size: var(--body-font-size-s); +} + +.hs-richtext:not(:last-child) { + margin-bottom: 16px; } /* ===================================================================== CHECKBOX */ -.section-ready-to-fly .form-checkbox-wrapper { +.section-ready-to-fly .hs-fieldtype-booleancheckbox { display: flex; gap: 30px; + margin-bottom: 16px !important; /* Override hs styling */ } -.section-ready-to-fly .form-checkbox-wrapper label { +.section-ready-to-fly .hs-fieldtype-booleancheckbox label { font-size: var(--body-font-size-s); } -.section-ready-to-fly .form-checkbox-wrapper input { +.section-ready-to-fly .hs-fieldtype-booleancheckbox input { --checkbox-size: 25px; position: relative; @@ -119,8 +157,8 @@ visibility: hidden; } -.section-ready-to-fly .form-checkbox-wrapper input::before, -.section-ready-to-fly .form-checkbox-wrapper input::after { +.section-ready-to-fly .hs-fieldtype-booleancheckbox input::before, +.section-ready-to-fly .hs-fieldtype-booleancheckbox input::after { box-sizing: border-box; content: ''; display: inline-block; @@ -132,53 +170,59 @@ border: 1px solid white; } -.section-ready-to-fly .form-checkbox-wrapper input::before { +.section-ready-to-fly .hs-fieldtype-booleancheckbox input::before { visibility: visible; } -.section-ready-to-fly .form-checkbox-wrapper input::after { +.section-ready-to-fly .hs-fieldtype-booleancheckbox input::after { transform: scale(60%, 60%); background-color: white; } -.section-ready-to-fly .form-checkbox-wrapper input:checked::after { +.section-ready-to-fly .hs-fieldtype-booleancheckbox input:checked::after { visibility: visible; } +.legal-consent-container .hs-form-booleancheckbox-display>span { + margin-left: 0 !important; /* Override hs styling */ + margin-top: -5px; /* Relativise the line height */ + margin-bottom: -5px; /* Relativise the line height */ +} + /* ===================================================================== TEXT AREAS */ -.section-ready-to-fly .form-text-area-wrapper { +.section-ready-to-fly .hs-fieldtype-textarea { display: flex; flex-direction: column; } -.section-ready-to-fly .form-text-area-wrapper label { +.section-ready-to-fly .hs-fieldtype-textarea label { margin-bottom: 5px; } -.section-ready-to-fly .form-text-area-wrapper textarea { +.section-ready-to-fly .hs-fieldtype-textarea textarea { height: 256px; background-color: #382F6F; } -.section-ready-to-fly .form-text-area-wrapper textarea:focus, -.section-ready-to-fly .form-text-area-wrapper textarea:not(:placeholder-shown){ +.section-ready-to-fly .hs-fieldtype-textarea textarea:focus, +.section-ready-to-fly .hs-fieldtype-textarea textarea:not(:placeholder-shown){ outline: none; } /* ===================================================================== TEXT FIELDS */ -.section-ready-to-fly .form-text-field-wrapper input { +.section-ready-to-fly :is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) input { border: 1px solid rgb(255 255 255 / 0%); border-radius: 0; border-bottom: 1px solid var(--text-color); background-color: rgb(28 10 77 / 75%); } -.section-ready-to-fly .form-text-field-wrapper input:focus { +.section-ready-to-fly :is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) input:focus { outline: none; border: 1px solid white; } -.section-ready-to-fly .form-text-field-wrapper label { +.section-ready-to-fly :is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) label { position: absolute; top: 13px; transition: all 0.075s ease-out; @@ -186,20 +230,24 @@ pointer-events: none; } -.section-ready-to-fly .form-text-field-wrapper input:focus ~ label, -.section-ready-to-fly .form-text-field-wrapper input:not(:placeholder-shown) ~ label { +.section-ready-to-fly :is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) input:focus ~ label, +.section-ready-to-fly :is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) input:not(:placeholder-shown) ~ label { transform-origin: left; padding: 5px; transform: translate(-5px, calc(-50% - 13px)) scale(0.8, 0.8); } /* ===================================================================== FORM SUBMIT BUTTON */ -.section-ready-to-fly .form-submit-wrapper { +.section-ready-to-fly .hs-submit .actions { display: flex; justify-content: right; } /* ===================================================================== HIDDEN */ -.section-ready-to-fly .hidden { +.section-ready-to-fly .hs-fieldtype-hidden { + display: none; +} + +.hs-error-msgs { display: none; } diff --git a/blocks/form/form.js b/blocks/form/form.js index 0894e3f..a2f804f 100644 --- a/blocks/form/form.js +++ b/blocks/form/form.js @@ -1,192 +1,32 @@ -function createSelect(fd) { - const select = document.createElement('select'); - select.id = fd.Field; - if (fd.Placeholder) { - const ph = document.createElement('option'); - ph.textContent = fd.Placeholder; - ph.setAttribute('selected', ''); - ph.setAttribute('disabled', ''); - select.append(ph); - } - fd.Options.split(',').forEach((o) => { - const option = document.createElement('option'); - option.textContent = o.trim(); - option.value = o.trim(); - select.append(option); - }); - if (fd.Mandatory === 'x') { - select.setAttribute('required', 'required'); - } - return select; -} - -function constructPayload(form) { - const payload = {}; - [...form.elements].forEach((fe) => { - if (fe.type === 'checkbox') { - if (fe.checked) payload[fe.id] = fe.value; - } else if (fe.id) { - payload[fe.id] = fe.value; - } - }); - return payload; -} - -async function submitForm(form) { - const payload = constructPayload(form); - const resp = await fetch(form.dataset.action, { - method: 'POST', - cache: 'no-cache', - headers: { - 'Content-Type': 'application/json', - }, - body: JSON.stringify({ data: payload }), - }); - await resp.text(); - return payload; -} - -function createButton(fd) { - const button = document.createElement('button'); - button.textContent = fd.Label; - button.classList.add('button'); - if (fd.Type === 'submit') { - button.addEventListener('click', async (event) => { - const form = button.closest('form'); - const formBlock = button.closest('.form.block'); - if (form.checkValidity()) { - event.preventDefault(); - button.setAttribute('disabled', ''); - await submitForm(form); - const formThankYou = formBlock.querySelector('.form-thank-you'); - if (formThankYou) { - formBlock.querySelector('.form-content').classList.add('hidden'); - formThankYou.classList.remove('hidden'); - } - - window.location.hash = '#form'; +import { loadScript } from '../../scripts/lib-franklin.js'; +import { debounce } from '../../scripts/utilities.js'; + +function rearrangeInputLabels() { + const forms = document.querySelectorAll('form'); + forms.forEach((form) => { + const inputWrappers = form.querySelectorAll('.hs-fieldtype-text, .hs-fieldtype-phonenumber, .hs-fieldtype-booleancheckbox'); + inputWrappers.forEach((input) => { + const inputElement = input.querySelector('input'); + const inputLabel = input.querySelector('label'); + if (inputElement && inputLabel) { + input.prepend(inputLabel); + input.prepend(inputElement); + input.querySelector('.input').remove(); } }); - } - return button; -} - -function createHeading(fd) { - const heading = document.createElement('h3'); - heading.textContent = fd.Label; - return heading; -} - -function createInput(fd) { - const input = document.createElement('input'); - input.type = fd.Type; - input.id = fd.Field; - input.setAttribute('placeholder', fd.Placeholder); - if (fd.Mandatory === 'x') { - input.setAttribute('required', 'required'); - } - return input; -} - -function createTextArea(fd) { - const input = document.createElement('textarea'); - input.id = fd.Field; - input.setAttribute('placeholder', fd.Placeholder); - if (fd.Mandatory === 'x') { - input.setAttribute('required', 'required'); - } - return input; -} - -function createLabel(fd) { - const label = document.createElement('label'); - label.setAttribute('for', fd.Field); - label.textContent = fd.Label; - if (fd.Mandatory === 'x') { - label.classList.add('required'); - } - return label; -} - -function applyRules(form, rules) { - const payload = constructPayload(form); - rules.forEach((field) => { - const { type, condition: { key, operator, value } } = field.rule; - if (type === 'visible') { - if (operator === 'eq') { - if (payload[key] === value) { - form.querySelector(`.${field.fieldId}`).classList.remove('hidden'); - } else { - form.querySelector(`.${field.fieldId}`).classList.add('hidden'); - } - } - } }); } -async function createForm(formURL) { - const { pathname } = new URL(formURL); - const resp = await fetch(pathname); - const json = await resp.json(); - const form = document.createElement('form'); - const rules = []; - // eslint-disable-next-line prefer-destructuring - form.dataset.action = pathname.split('.json')[0]; - json.data.forEach((fd) => { - fd.Type = fd.Type || 'text'; - const fieldWrapper = document.createElement('div'); - const style = fd.Style ? ` form-${fd.Style}` : ''; - const fieldId = `form-${fd.Type}-wrapper${style}`; - fieldWrapper.className = fieldId; - fieldWrapper.classList.add('field-wrapper'); - switch (fd.Type) { - case 'select': - fieldWrapper.append(createLabel(fd)); - fieldWrapper.append(createSelect(fd)); - break; - case 'heading': - fieldWrapper.append(createHeading(fd)); - break; - case 'checkbox': - fieldWrapper.append(createInput(fd)); - fieldWrapper.append(createLabel(fd)); - break; - case 'text-area': - fieldWrapper.append(createLabel(fd)); - fieldWrapper.append(createTextArea(fd)); - break; - case 'submit': - fieldWrapper.append(createButton(fd)); - break; - default: - fieldWrapper.append(createInput(fd)); - fieldWrapper.append(createLabel(fd)); - } +export default async function decorate() { + await loadScript('https://js.hsforms.net/forms/embed/v2.js'); - if (fd.Rules) { - try { - rules.push({ fieldId, rule: JSON.parse(fd.Rules) }); - } catch (e) { - // eslint-disable-next-line no-console - console.warn(`Invalid Rule ${fd.Rules}: ${e}`); - } - } - form.append(fieldWrapper); + window.hbspt.forms.create({ + region: 'na1', + portalId: '3458432', + formId: 'a9f10e4b-6c50-442b-ae10-df1b06d21e6f', + target: '.form', }); - form.addEventListener('change', () => applyRules(form, rules)); - applyRules(form, rules); - - return (form); -} - -export default async function decorate(block) { - const form = block.querySelector('a[href$=".json"]'); - block.id = 'form'; - if (form) { - form.parentElement.replaceWith(await createForm(form.href)); - } - const formRows = block.querySelectorAll('.form>div'); - formRows[0].classList.add('form-content'); - formRows[1].classList.add('form-thank-you', 'hidden'); + const debouncedRearrangeInputLabels = debounce(() => rearrangeInputLabels()); + debouncedRearrangeInputLabels(); } diff --git a/styles/styles.css b/styles/styles.css index 78b5d81..3a5800f 100644 --- a/styles/styles.css +++ b/styles/styles.css @@ -238,7 +238,7 @@ pre { /* buttons */ -a.button:any-link, button, main .form .button, header nav li:nth-last-child(2) a { +a.button:any-link, button, form .hs-button, main .form .button, header nav li:nth-last-child(2) a { font-family: var(--body-font-family); display: inline-flex; position: relative; @@ -265,6 +265,7 @@ nav ul li:nth-last-child(2) a { a.button:hover, a.button:focus, button:hover, button:focus, +form .hs-button:hover, form .hs-button:focus, main .form .button:hover, main .form .button:focus, nav ul li a:hover, nav ul li a:focus { background-color: var(--button-color-hover); @@ -290,7 +291,7 @@ a.button.secondary, button.secondary { } -main input, +main input:not([type='submit']), main textarea { box-sizing: border-box; display: block; @@ -307,10 +308,6 @@ main textarea { background-color: var(--background-color); } -main input:hover { - border: 1px solid var(--text-color); -} - main .section { padding: 100px var(--section-padding); position: relative; From 076a142629840e6a75898cbc1a126b40e5ce3693 Mon Sep 17 00:00:00 2001 From: voggenauerm Date: Mon, 11 Dec 2023 16:07:23 +0100 Subject: [PATCH 3/8] SPIN-126 // Style error states --- blocks/form/form.css | 43 +++++++++++++++++++++++++++++++++++-------- 1 file changed, 35 insertions(+), 8 deletions(-) diff --git a/blocks/form/form.css b/blocks/form/form.css index ac2361b..33888c2 100644 --- a/blocks/form/form.css +++ b/blocks/form/form.css @@ -135,9 +135,40 @@ fieldset { margin-bottom: 16px; } +/* ===================================================================== ERROR */ +.hs-error-msgs { + font-size: var(--body-font-size-s); + width: 100%; + grid-column: span 2; + list-style: none; + padding-left: 0; + margin: 0; +} + +:is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) .hs-error-msgs { + position: absolute; + left: 0; + right: 0; + top: calc(100% + 8px); +} + +.hs-error-msgs label { + --background-color: transparent; + + color: orangered !important; /* Override hs style */ +} + +.error, +.error + label { + --text-color: orangered; + + color: orangered; +} + /* ===================================================================== CHECKBOX */ .section-ready-to-fly .hs-fieldtype-booleancheckbox { - display: flex; + display: grid; + grid-template-columns: 25px 1fr; gap: 30px; margin-bottom: 16px !important; /* Override hs styling */ } @@ -222,7 +253,7 @@ fieldset { border: 1px solid white; } -.section-ready-to-fly :is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) label { +.section-ready-to-fly :is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) label:not(.hs-error-msg) { position: absolute; top: 13px; transition: all 0.075s ease-out; @@ -230,8 +261,8 @@ fieldset { pointer-events: none; } -.section-ready-to-fly :is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) input:focus ~ label, -.section-ready-to-fly :is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) input:not(:placeholder-shown) ~ label { +.section-ready-to-fly :is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) input:focus ~ label:not(.hs-error-msg), +.section-ready-to-fly :is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) input:not(:placeholder-shown) ~ label:not(.hs-error-msg) { transform-origin: left; padding: 5px; transform: translate(-5px, calc(-50% - 13px)) scale(0.8, 0.8); @@ -247,7 +278,3 @@ fieldset { .section-ready-to-fly .hs-fieldtype-hidden { display: none; } - -.hs-error-msgs { - display: none; -} From 0df7508fbb2b403a96985e60aa24e849d453f25f Mon Sep 17 00:00:00 2001 From: voggenauerm Date: Tue, 12 Dec 2023 09:31:23 +0100 Subject: [PATCH 4/8] SPIN-126 // Make hubspot form id editable in backend, make it possible to create multiple forms on one page --- blocks/form/form.js | 21 +++++++++++++++------ scripts/delayed.js | 2 ++ 2 files changed, 17 insertions(+), 6 deletions(-) diff --git a/blocks/form/form.js b/blocks/form/form.js index a2f804f..f9a30a7 100644 --- a/blocks/form/form.js +++ b/blocks/form/form.js @@ -17,14 +17,23 @@ function rearrangeInputLabels() { }); } -export default async function decorate() { +export default function decorate(block) { + block.dataset.formId = block.children[0].children[0].innerHTML; + block.innerHTML = 'loading'; +} + +export async function initializeHubspot() { await loadScript('https://js.hsforms.net/forms/embed/v2.js'); - window.hbspt.forms.create({ - region: 'na1', - portalId: '3458432', - formId: 'a9f10e4b-6c50-442b-ae10-df1b06d21e6f', - target: '.form', + const hubspotForms = document.querySelectorAll('.form[data-form-id]'); + hubspotForms.forEach((form, index) => { + form.dataset.formIndex = `${index}`; + window.hbspt.forms.create({ + region: 'na1', + portalId: '3458432', + formId: form.dataset.formId, + target: `[data-form-id][data-form-index='${form.dataset.formIndex}']`, + }); }); const debouncedRearrangeInputLabels = debounce(() => rearrangeInputLabels()); diff --git a/scripts/delayed.js b/scripts/delayed.js index f30b766..f3f6979 100644 --- a/scripts/delayed.js +++ b/scripts/delayed.js @@ -1,10 +1,12 @@ // eslint-disable-next-line import/no-cycle import { sampleRUM } from './lib-franklin.js'; import injectStarsLayers from './inject-stars-layers.js'; +import { initializeHubspot } from '../blocks/form/form.js'; // Core Web Vitals RUM collection sampleRUM('cwv'); injectStarsLayers(); +initializeHubspot(); /* IMPORTANT: this is just for fun and not actually used. Please ignore this :) */ let lastKeys = ''; From 420534ae2a17f45e342feeeeeaa2de6a4fd06ebf Mon Sep 17 00:00:00 2001 From: voggenauerm Date: Tue, 12 Dec 2023 09:54:04 +0100 Subject: [PATCH 5/8] SPIN-126 // Make form styling global --- blocks/form/form.css | 61 ++++++++++++++++++++------------------------ styles/styles.css | 16 +++++++++--- 2 files changed, 40 insertions(+), 37 deletions(-) diff --git a/blocks/form/form.css b/blocks/form/form.css index 33888c2..69428f6 100644 --- a/blocks/form/form.css +++ b/blocks/form/form.css @@ -75,7 +75,7 @@ } /* ===================================================================== FORMS GENERAL */ -.section-ready-to-fly form { +form { display: flex; flex-direction: column; gap: 52px; @@ -110,17 +110,17 @@ fieldset { width: 100% !important; /* Override hs styling */ } -.section-ready-to-fly .field { +.field { position: relative; } -.section-ready-to-fly .field input, -.section-ready-to-fly .field textarea { +.field input, +.field textarea { margin: 0; max-width: 100vw; } -.section-ready-to-fly .field textarea { +.field textarea { border: none; padding: 16px 25px; border-radius: 15px; @@ -155,29 +155,29 @@ fieldset { .hs-error-msgs label { --background-color: transparent; - color: orangered !important; /* Override hs style */ + color: var(--error-color) !important; /* Override hs style */ } .error, .error + label { - --text-color: orangered; + --text-color: var(--error-color); - color: orangered; + color: var(--error-color); } /* ===================================================================== CHECKBOX */ -.section-ready-to-fly .hs-fieldtype-booleancheckbox { +.hs-fieldtype-booleancheckbox { display: grid; grid-template-columns: 25px 1fr; gap: 30px; margin-bottom: 16px !important; /* Override hs styling */ } -.section-ready-to-fly .hs-fieldtype-booleancheckbox label { +.hs-fieldtype-booleancheckbox label { font-size: var(--body-font-size-s); } -.section-ready-to-fly .hs-fieldtype-booleancheckbox input { +.hs-fieldtype-booleancheckbox input { --checkbox-size: 25px; position: relative; @@ -188,8 +188,8 @@ fieldset { visibility: hidden; } -.section-ready-to-fly .hs-fieldtype-booleancheckbox input::before, -.section-ready-to-fly .hs-fieldtype-booleancheckbox input::after { +.hs-fieldtype-booleancheckbox input::before, +.hs-fieldtype-booleancheckbox input::after { box-sizing: border-box; content: ''; display: inline-block; @@ -201,16 +201,16 @@ fieldset { border: 1px solid white; } -.section-ready-to-fly .hs-fieldtype-booleancheckbox input::before { +.hs-fieldtype-booleancheckbox input::before { visibility: visible; } -.section-ready-to-fly .hs-fieldtype-booleancheckbox input::after { +.hs-fieldtype-booleancheckbox input::after { transform: scale(60%, 60%); background-color: white; } -.section-ready-to-fly .hs-fieldtype-booleancheckbox input:checked::after { +.hs-fieldtype-booleancheckbox input:checked::after { visibility: visible; } @@ -221,39 +221,32 @@ fieldset { } /* ===================================================================== TEXT AREAS */ -.section-ready-to-fly .hs-fieldtype-textarea { +.hs-fieldtype-textarea { display: flex; flex-direction: column; } -.section-ready-to-fly .hs-fieldtype-textarea label { +.hs-fieldtype-textarea label { margin-bottom: 5px; } -.section-ready-to-fly .hs-fieldtype-textarea textarea { +.hs-fieldtype-textarea textarea { height: 256px; background-color: #382F6F; } -.section-ready-to-fly .hs-fieldtype-textarea textarea:focus, -.section-ready-to-fly .hs-fieldtype-textarea textarea:not(:placeholder-shown){ +.hs-fieldtype-textarea textarea:focus, +.hs-fieldtype-textarea textarea:not(:placeholder-shown){ outline: none; } /* ===================================================================== TEXT FIELDS */ -.section-ready-to-fly :is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) input { - border: 1px solid rgb(255 255 255 / 0%); - border-radius: 0; - border-bottom: 1px solid var(--text-color); - background-color: rgb(28 10 77 / 75%); -} - -.section-ready-to-fly :is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) input:focus { +:is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) input:focus { outline: none; border: 1px solid white; } -.section-ready-to-fly :is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) label:not(.hs-error-msg) { +:is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) label:not(.hs-error-msg) { position: absolute; top: 13px; transition: all 0.075s ease-out; @@ -261,20 +254,20 @@ fieldset { pointer-events: none; } -.section-ready-to-fly :is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) input:focus ~ label:not(.hs-error-msg), -.section-ready-to-fly :is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) input:not(:placeholder-shown) ~ label:not(.hs-error-msg) { +:is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) input:focus ~ label:not(.hs-error-msg), +:is(.hs-fieldtype-text, .hs-fieldtype-phonenumber) input:not(:placeholder-shown) ~ label:not(.hs-error-msg) { transform-origin: left; padding: 5px; transform: translate(-5px, calc(-50% - 13px)) scale(0.8, 0.8); } /* ===================================================================== FORM SUBMIT BUTTON */ -.section-ready-to-fly .hs-submit .actions { +.hs-submit .actions { display: flex; justify-content: right; } /* ===================================================================== HIDDEN */ -.section-ready-to-fly .hs-fieldtype-hidden { +.hs-fieldtype-hidden { display: none; } diff --git a/styles/styles.css b/styles/styles.css index 3a5800f..48f6004 100644 --- a/styles/styles.css +++ b/styles/styles.css @@ -21,10 +21,14 @@ :root, .theme-default { /* colors */ --color-purple: #1C0A4D; + --rgb-purple: 28 10 77; --color-light-purple: #5764EF; + --rgb-light-purple: 87 100 239; + --error-color: #ff4242; --link-color: #035fe6; --link-hover-color: #136ff6; --background-color: var(--color-purple); + --background-color-transparent: rgba(var(--rgb-purple) / 75%); --overlay-background-color: #eee; --highlight-background-color: #ccc; --text-color: #fff; @@ -72,7 +76,9 @@ .theme-light-purple { /* colors */ + --error-color: #ff8787; --background-color: var(--color-light-purple); + --background-color-transparent: rgba(var(--rgb-light-purple) / 75%); --button-color: var(--color-purple); --button-border-color: transparent; --button-color-hover: var(--link-hover-color); @@ -302,10 +308,14 @@ main textarea { font-family: var(--body-font-family); font-size: 1.25rem; line-height: 24px; - border: 1px solid var(--text-color); - border-radius: 0.25rem; color: var(--text-color); - background-color: var(--background-color); + background-color: var(--background-color-transparent); +} + +main input:not([type='submit']) { + border: 1px solid transparent; + border-bottom: 1px solid var(--text-color); + border-radius: 0; } main .section { From 54d1ddaa4079930148871b53d25400c02565a011 Mon Sep 17 00:00:00 2001 From: voggenauerm Date: Tue, 12 Dec 2023 10:28:43 +0100 Subject: [PATCH 6/8] SPIN-126 // Reset the delay for the delayed script to the initial 3 seconds --- scripts/scripts.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/scripts/scripts.js b/scripts/scripts.js index 8093a56..a6857a8 100644 --- a/scripts/scripts.js +++ b/scripts/scripts.js @@ -227,7 +227,7 @@ async function loadLazy(doc) { */ function loadDelayed() { // eslint-disable-next-line import/no-cycle - window.setTimeout(() => import('./delayed.js'), 2000); + window.setTimeout(() => import('./delayed.js'), 3000); // load anything that can be postponed to the latest here } From 07fcd1c22959a240b0d8dd39d5bf9730df3b478b Mon Sep 17 00:00:00 2001 From: voggenauerm Date: Tue, 12 Dec 2023 10:49:47 +0100 Subject: [PATCH 7/8] SPIN-126 // Adjust the script delays --- scripts/delayed.js | 4 +++- scripts/scripts.js | 2 +- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/scripts/delayed.js b/scripts/delayed.js index f3f6979..f098110 100644 --- a/scripts/delayed.js +++ b/scripts/delayed.js @@ -6,7 +6,9 @@ import { initializeHubspot } from '../blocks/form/form.js'; // Core Web Vitals RUM collection sampleRUM('cwv'); injectStarsLayers(); -initializeHubspot(); +setTimeout(() => { + initializeHubspot(); +}, 2000); /* IMPORTANT: this is just for fun and not actually used. Please ignore this :) */ let lastKeys = ''; diff --git a/scripts/scripts.js b/scripts/scripts.js index a6857a8..8093a56 100644 --- a/scripts/scripts.js +++ b/scripts/scripts.js @@ -227,7 +227,7 @@ async function loadLazy(doc) { */ function loadDelayed() { // eslint-disable-next-line import/no-cycle - window.setTimeout(() => import('./delayed.js'), 3000); + window.setTimeout(() => import('./delayed.js'), 2000); // load anything that can be postponed to the latest here } From 23707cb10de2875e9a6ecd9daa5add0320d90c3e Mon Sep 17 00:00:00 2001 From: Markus Biberger Date: Tue, 12 Dec 2023 16:22:20 +0100 Subject: [PATCH 8/8] [SPIN-126] Change form input font size. --- styles/styles.css | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/styles/styles.css b/styles/styles.css index 48f6004..78f2d3b 100644 --- a/styles/styles.css +++ b/styles/styles.css @@ -306,7 +306,7 @@ main textarea { padding: 0.75rem 0.6rem; margin-bottom: 1rem; font-family: var(--body-font-family); - font-size: 1.25rem; + font-size: 18px; line-height: 24px; color: var(--text-color); background-color: var(--background-color-transparent);