|
1 |
| -const loadScript = (url, callback, type) => { |
2 |
| - const head = document.querySelector('head'); |
3 |
| - const script = document.createElement('script'); |
4 |
| - script.src = url; |
5 |
| - if (type) { |
6 |
| - script.setAttribute('type', type); |
7 |
| - } |
8 |
| - script.onload = callback; |
9 |
| - head.append(script); |
10 |
| - return script; |
11 |
| -}; |
12 | 1 |
|
13 | 2 | const embedMarketoForm = (formId) => {
|
14 |
| - const scriptUrl = '//www2.mammotome.com/js/forms2/js/forms2.min.js'; |
15 |
| - loadScript(scriptUrl, () => { |
16 |
| - const formContainer = document.createElement('div'); |
17 |
| - formContainer.innerHTML = `<form id="mktoForm_${formId}"></form>`; |
| 3 | +formContainer.innerHTML = `<script src="//www2.mammotome.com/js/forms2/js/forms2.min.js"></script> <form id="mktoForm_1063"></form> <script>MktoForms2.loadForm("//www2.mammotome.com", "435-TDP-284", ${formId});</script>`; |
18 | 4 | document.body.appendChild(formContainer);
|
19 |
| - |
20 |
| - if (window.MktoForms2) { |
21 |
| - window.MktoForms2.loadForm('//www2.mammotome.com', '435-TDP-284', formId); |
22 |
| - } else { |
23 |
| - console.error('Marketo Forms library failed to load.'); |
24 |
| - } |
25 |
| - }); |
26 |
| - return `<div id="marketo-embed-container"> |
27 |
| - <form id="mktoForm_${formId}"></form> |
28 |
| - </div>`; |
29 |
| -}; |
30 |
| - |
31 |
| -const loadEmbed = (block, link, formId) => { |
32 |
| - if (block.classList.contains('embed-is-loaded')) { |
33 |
| - return; |
34 |
| - } |
35 |
| - |
36 |
| - if (link.includes('mammotome.com')) { |
37 |
| - block.innerHTML = embedMarketoForm(formId); |
38 |
| - block.classList.add('embed-is-loaded'); |
39 |
| - } else { |
40 |
| - console.error('Invalid link for Marketo form.'); |
41 |
| - } |
42 |
| -}; |
| 5 | + return embedMarketoForm; |
| 6 | +} |
43 | 7 |
|
44 | 8 | export default function decorate(block) {
|
45 |
| - const link = block.dataset.link; // Assume link is provided via a data attribute |
46 |
| - const formId = block.dataset.formId || '1063'; // Default to 1063 if no form ID provided |
47 |
| - block.textContent = ''; // Clear block content |
| 9 | + const link = block.dataset.link; |
| 10 | + const formId = block.dataset.formId || '1063'; // default form is US-EN website form |
| 11 | + block.textContent = ''; |
48 | 12 | loadEmbed(block, link, formId);
|
49 | 13 | }
|
0 commit comments