(function () {
try {
// AQ-r2 (2026-06-09): respect the explicit-denial sentinel
// written by cookie-consent-harden.js writeATR() on any
// marketing-axis denial (payload.marketing === false; cycle-3 F1).
// Without this gate, the next page navigation re-creates
// gmx_first_touch from the current URL+referrer+utm_*+click_ids,
// silently undoing the reject-all deletion (sweep finding #1).
// The sentinel is cleared the moment the visitor grants
// marketing in the banner (analytics-only grant does NOT
// clear), restoring the writer path on the very next
// page load. Page-cache-safe: the sentinel is a
// browser-resident cookie checked in the inline script, so
// varnish/breeze-served HTML still hits this gate.
if (/(?:^|;\s*)gmx_consent_denied=1(?:;|$)/.test(document.cookie || '')) return;
var CLICK_IDS = ['gclid','fbclid','msclkid','ttclid','wbraid','gbraid','li_fat_id'];
var qs = new URLSearchParams(window.location.search);
var urlClickIdKey = null;
for (var i = 0; i < CLICK_IDS.length; i++) {
if (qs.get(CLICK_IDS[i])) { urlClickIdKey = CLICK_IDS[i]; break; }
}// Parse existing cookie.
var existing = null;
var match = document.cookie.match(/(?:^|;\s*)gmx_first_touch=([^;]+)/);
if (match) {
try { existing = JSON.parse(decodeURIComponent(match[1])); } catch (e) { existing = null; }
}// GWP-273 — referrer-enrichment branch.
// Keep existing unless either (a) URL carries a new click id
// the stored payload lacks (paid click is a higher-value
// signal and upgrades direct/organic), OR (b) the stored
// payload has empty referrer AND the current document.referrer
// is non-empty + external (Safari/ITP/policy-quirk catch:
// first-hit may have missed the referrer; later same-session
// page-loads can recover it).
var existingHasRef = !!(existing && existing.referrer && existing.referrer !== '');
var docRef = document.referrer || '';
var refHost = '';
if (docRef) {
try {
refHost = new URL(docRef).hostname.replace(/^www\./, '').toLowerCase();
} catch (e) { refHost = ''; }
}
var ownHost = (location.host || '').replace(/^www\./, '').toLowerCase();
var currentExternalRef = !!(refHost && refHost !== ownHost);
var canEnrichRef = !!existing && !existingHasRef && currentExternalRef;if (existing) {
if (!urlClickIdKey && !canEnrichRef) return;
if (urlClickIdKey && existing[urlClickIdKey] && !canEnrichRef) return;
}var utm_keys = [
'utm_source','utm_medium','utm_campaign','utm_content','utm_term',
'utm_adgroup','utm_matchtype','utm_network','utm_device','utm_placement'
];
// GWP-273 — merge-preserving base. When enriching an existing
// payload, retain its landing_url + ts + prior click ids /
// utms; only overlay referrer (and any click id appended below
// via the forEach). Branches with/without urlClickIdKey were
// collapsed — both produced the identical Object.assign — the
// click id is added uniformly later.
//
// GWP-273 design choice: "latest external referrer wins" —
// accepted edge case where a user opens a new external tab
// post-empty-first-touch and returns; low-volume, simple, no
// sentinel flag needed.
var data;
if (existing && canEnrichRef) {
data = Object.assign({}, existing, { referrer: docRef });
} else {
data = { landing_url: window.location.href, referrer: docRef, ts: Date.now() };
}
utm_keys.concat(CLICK_IDS).forEach(function (k) {
var v = qs.get(k);
if (v) data[k] = v;
});
var encoded = encodeURIComponent(JSON.stringify(data));
if (encoded.length > 3800) return;
var expires = new Date(Date.now() + 90 * 864e5).toUTCString(); // GWP-143 C1: match Google Ads 90-day attribution window
var secure = window.location.protocol === 'https:' ? '; Secure' : '';
document.cookie = 'gmx_first_touch=' + encoded + '; Path=/; Expires=' + expires + '; SameSite=Lax' + secure;
} catch (e) {}
})();
var breeze_prefetch = {"local_url":"https://gomixapp.com","ignore_remote_prefetch":"1","ignore_list":["/cart/","/checkout/","/my-account/","https://gomixapp.co.il/(.)/u05d4u05d8u05d5u05e4u05e1-u05e0u05e9u05dcu05d7-u05d1u05d4u05e6u05dcu05d7u05d4/","wp-admin","wp-login.php"]};
//# sourceURL=breeze-prefetch-js-extra
Save Time and Streamline Processes: Digital Forms for Lawyers
Digital forms for lawyers streamline office work – digital signatures, remote signature verification and phone affidavit verification, from any device. Over 300 offices already work smarter with GoMixApp.
Custom Design for Online Legal Forms for Lawyers
Our studio creates custom-designed online legal forms for your office – upload fields, multiple selection and finger signature, with full security and legal compliance.
Support for Complex Forms and Unique Customizations for Online Forms for Lawyers
Support for complex forms: signature rounds, multiple signers, signing on existing PDF, and signature verification via Zoom or remotely – sign clients without leaving the office.
Need a digital solution? For more details fill in your details and we will get back to you shortly.
Advantages
Digital Signature for Lawyers
Saves time, reduces paper-driven processes and offers you the ability to sign a document from almost anywhere.
Many Field Options
Choose diverse fields for every need – features like multi-select checkboxes, images and file attachments. Create multiple tabs to organize information and capture large amounts of data in a single form.
Compatibility with All Devices
The appearance and user experience of the form will be optimal on all device types: mobile, tablet and desktop.
Information Security per ISO Standard
High-level document security, with data encryption so that all signed documents remain invisible to anyone but you.
Stunning Professional Design
Our design creates a positive first impression, improves user experience and increases completion rates. The aesthetic, custom design streamlines the filling and signing process, and conveys professionalism and reliability to the business.
Edit forms independently, easily and conveniently with a user-friendly interface.
Information Security and Quality Standard
Our platform meets the ISO standard, ensuring information management and quality at the highest standards. Includes strict security procedures for information management, access control, and protection against potential threats.
Cloud Organization and Management
Cloud storage enables efficient organization and management, with secure access from anywhere and at any time. You can download a consolidated Excel with all submissions, which streamlines data analysis.
A Variety of Online Form Examples for Lawyers
Digital Power of Attorney Form
With our solution, you can create, edit and sign power of attorney forms easily and quickly from anywhere and on any device. The process is fully secure and allows remote signing, saving valuable time and reducing the need for physical meetings. Our service is customized to your legal needs, including support for multi-signer forms and digital signatures. Join the digital world and streamline the power of attorney process in your office.
Digital Engagement Agreement Form
A digital engagement agreement form streamlines the client engagement process: you can create, edit and sign remotely from any device, with custom fields including document upload and multiple selection. Remote affidavit signing is performed securely and meets the signature verification requirements stipulated by law.
Application Form for Registration in the Sub-branches Contractors Registry
With our digital solution, you can create, edit and manage contractor registry application forms quickly and efficiently from anywhere and on any device. The service allows remote signing, saves time and reduces the need for physical meetings. The forms are customized to your legal needs, including the option to integrate custom fields like document upload, multiple selection and digital signatures. Join the digital world and streamline the contractor registry process in your office.
Representative Registration Application Form
Our digital solution allows you to create, edit and manage forms easily and quickly from anywhere and on any device. The service includes a remote signing option, which streamlines the process and saves valuable time on physical meetings. The forms are custom-designed to your office’s legal needs, with the option to integrate custom fields like document upload, multiple selection and digital signatures. Join the digital revolution and streamline the representative registration process in your office, while maintaining a high level of security and maximum convenience.
Nursing Care Claim Form
Our digital solution allows you to create, edit and manage nursing care claim forms simply, quickly and efficiently. The service includes a remote signing option, which saves time and reduces the need for physical meetings. The forms are customized to your office’s legal needs and suitable for all populations, with the option to integrate custom fields like document upload, multiple selection and digital signatures. Join the digital revolution and streamline the nursing care claim filing process in your office, while maintaining maximum accessibility for every client from any device.
Time to go digital! Streamline processes and start working with legal digital forms.
In the digital age, there is no reason to stay behind. With GoMixApp’s advanced platform, law firms can upgrade their form management process easily and efficiently. Whether it concerns power of attorney forms, engagement agreements, or other legal registrations, our solutions are tailored specifically for lawyers. Our online forms platform streamlines daily work and saves valuable time, while also ensuring that legal information is submitted accurately and on time.
Our platform is suitable for every law firm – small, medium and large. It includes smart forms with payment, digital forms tailored to unique needs, and easy integration with existing systems. This way you can focus on representing your clients while the system manages digital document management automatically and securely.
Among the solutions: remote affidavit signing, remote affidavit verification, online engagement agreement forms, digital power of attorney forms and contractor registry registration – all custom-designed to legal requirements with digital identity verification. For more details on creating secure digital forms for businesses visit our dedicated page.
Don’t miss the opportunity to upgrade your office with our advanced platform for digital forms for lawyers.
Didn’t find the form you were looking for? We’re here!
Among Our Clients
Customer Testimonials
Pinhas
Building Committee, Ramla
Service:
★★★★★
Product:
★★★★★
Recommendation:
★★★★★
“With the holiday videos you simply nailed it – the residents were really excited!”
Mor
Academic Institution
Service:
★★★★★
Product:
★★★★★
Recommendation:
★★★★★
“The digital noticeboard looks amazing, and everything works smoothly!”
Inbar Shmueli
Business Owner
Service:
★★★★★
Product:
★★★★★
Recommendation:
★★★★★
“Personal and professional service, fast response, excellent product, very satisfied”
Key Takeaways
Online legal forms cut case handling time by up to 60%.
Digital signature verification ensures full legal validity for every document.
Client form automation reduces human errors in the law office.
Computerized power of attorney forms enable remote filling, signing and submission.
A mobile-accessible interface increases satisfaction of clients reaching the office.
Digital Verification and Signature Software for Lawyers – Everything You Need to Know
Digital verification is the process by which the identity of the party signing a legal document is verified, without the need for physical presence. The GoMixApp solution includes remote signature verification, Zoom signature verification and phone affidavit verification – three approved verification methods suitable for different types of proceedings in a legal office.
Custom digital forms allow you to define exactly which fields and which verification process appear on each form. Whether it concerns remote affidavit signing for a power of attorney, remote affidavit verification for an engagement agreement, or any other legal document – the system adapts itself to your office’s needs.
As of 2026, over 300 offices and companies in Israel have already leveraged our platform to streamline legal processes. The average time saving stands at 60% compared to manual signing processes. For details on additional form management solutions also see our solutions page.
Frequently Asked Questions
What is the difference between a digital signature and remote signature verification?
A digital signature is the technical act of adding an electronic signature to a document, while remote signature verification is the process of verifying the signer’s identity – usually via video, Zoom, or phone. Both are required for full legal validity of remotely signed documents.
Are digital forms for lawyers legally valid in Israel?
Yes. A secure electronic signature accompanied by digital identity verification is legally valid in Israel under the Electronic Signature Law. The GoMixApp platform performs identity verification, maintains an audit record and stores documents securely – meeting all legal requirements.
How is phone affidavit verification performed?
Phone affidavit verification is performed via a recorded call in which the signing party verbally confirms their identity and the document’s contents, in addition to the digital signature. This method is accepted for certain affidavits and enables fast signing without the need to travel to the office.
Can multiple signers sign the same document?
Absolutely. The GoMixApp platform supports multi-signer forms and an orderly signature round – each signer receives a notification, signs remotely and verifies their identity separately. The system tracks the status of each signature and alerts when the process is complete.
How long does it take to set up a digital form for a law office?
Setting up a custom digital form usually takes 3-5 business days. Send us your existing template, our professional team will design and implement the form, and you can start working immediately upon launch.
Comparison: Working with Printed Forms vs. a Digital Signature Solution
Feature
Traditional Printed Forms
GoMixApp Digital Solution
Remote Signing
✗Requires physical presence at the office
✓Remote signature verification from any device
Identity Verification
✗Relies on face recognition only
✓Secure and documented digital verification
Document Storage
✗Limited and vulnerable physical archive
✓Secure cloud document storage
Multiple Signers
✗Requires separate coordination with each party
✓Automatic and managed signature round
Compliance and Security
✗Exposed to loss and forgery
✓Compliance with privacy protection regulations
Time Saving
✗Manual and tedious processes
✓Full automation, savings of up to 60%
In Summary: Why Switch to the Digital Legal Solution Today
We examined on this page the range of capabilities offered by digital forms for lawyers: from legally valid digital signatures, through remote signature verification and phone affidavit verification, to full automation of digital document management. Each of these solutions translates into real savings in time, money and managerial energy.
Choosing professional signature software for lawyers is not just a question of convenience – it directly impacts client experience, the speed of closing deals, and the ability to handle complex cases in parallel. With custom digital forms, top-level security and support for all verification types, GoMixApp is the clear choice for law firms in Israel in 2026.
Last update: January 2026. Ready to get started? Contact our expert team and we’ll tailor a precise solution for your office’s needs.
document.addEventListener('click', function(e) {
var el = e.target.closest('.gmx-lite-yt');
if (!el) return;
var vid = el.getAttribute('data-vid');
if (!vid) return;
var iframe = document.createElement('iframe');
iframe.src = 'https://www.youtube.com/embed/' + vid + '?autoplay=1';
iframe.style.cssText = 'position:absolute;top:0;left:0;width:100%;height:100%;border:0;';
iframe.allow = 'autoplay;encrypted-media';
iframe.allowFullscreen = true;
el.style.position = 'relative';
el.innerHTML = '';
el.appendChild(iframe);
});
(function () {
var c = document.body.className;
c = c.replace(/woocommerce-no-js/, 'woocommerce-js');
document.body.className = c;
})();
var gmxCf7LegacyUxI18n = {"errName":"Please enter a full name","errPhone":"Please enter a valid phone number","errEmail":"Please enter a valid email address","errRequired":"Required field"};
//# sourceURL=gmx-cf7-legacy-ux-js-extra
var gmxCf7UxI18n = {"progressTemplate":"{N} field(s) remaining","allSet":"All set to send!","sending":"Sending\u2026","successTitle":"Thank you! Your inquiry has been received","successBody":"A representative will get back to you within 24 hours with a tailored quote.","successCtaLabel":"See our areas of expertise","successCtaHref":"/expertise/","errorTitle":"Submission failed","errorBody":"Please try again, or call us directly"};
//# sourceURL=gmx-cf7-ux-js-extra
var atrCookieNoticeSettings = {"cookieName":"atr_cookie_notice_consent","decisionCookieName":"atr_cookie_notice_consent_given","expiryDays":"365","autoHideDelay":"0","enableDebug":"","siteName":"GoMixApp","isPrivacyPage":"","privacyPolicyUrl":"https://gomixapp.com/privacy-policy/","privacyNoteText":"\ud83d\udca1 You can read this page while deciding about cookies","mode":"simple"};
//# sourceURL=atr-cookie-notice-simple-js-extra
(function(){
function cleanUrl(url) {
// Strip query params embedded mid-path: /ID?params/file -> /ID/file
return url.replace(/\?[^\/]+\//g, '/');
}
function addWebPFallback(pic) {
if (pic.getAttribute('data-webp-fb')) return;
pic.setAttribute('data-webp-fb', '1');
var img = pic.querySelector('img');
if (!img) return;
img.onerror = function() {
this.onerror = null;
this.src = cleanUrl(this.src).replace('vi_webp','vi').replace('.webp','.jpg');
var sources = this.parentElement.querySelectorAll('source');
for (var i = 0; i < sources.length; i++) {
sources[i].srcset = cleanUrl(sources[i].srcset).replace('vi_webp','vi').replace('.webp','.jpg');
}
};
}
var observer = new MutationObserver(function() {
var pics = document.querySelectorAll('.video-seo-youtube-picture');
for (var i = 0; i < pics.length; i++) addWebPFallback(pics[i]);
});
observer.observe(document.documentElement, { childList: true, subtree: true });
})();
(function(){
var siteKey = "6Ldnu_gsAAAAAGpkh7vCd_h3L9BA193yFU59I4Do";
var action = "submit_lead_form";
var loaderUrl = "https:\/\/www.google.com\/recaptcha\/enterprise.js?render=6Ldnu_gsAAAAAGpkh7vCd_h3L9BA193yFU59I4Do";
// GWP-506 (perf): the reCAPTCHA Enterprise runtime costs ~900ms of main-thread
// work (PSI contactus TBT 660ms, perf 69). It was loaded eagerly on every page
// carrying a CF7 form. It now loads on the FIRST real page interaction
// (scroll/pointer/key/touch) — warming the runtime well before the user can
// reach submit — and never loads on a no-interaction (lab) page view, so the
// perf win holds. The token is still stamped on form focusin and refreshed at
// submit. IMPORTANT: the server gate is fail-CLOSED by default (GWP-412
// require_token) — a missing token at submit is treated as spam — so the
// runtime MUST be warm before submit; that is exactly why the warm trigger is
// first-page-interaction, NOT focusin-only (focusin-only left a race where a
// fast focus→submit could POST before the ~900ms download finished and drop a
// legit lead). The eager <script src> is gone.
var greReady = false, greWaiters = [], greLoadStarted = false;
function pollGre(attempts) {
if (typeof grecaptcha !== 'undefined' && grecaptcha.enterprise) {
greReady = true;
var queued = greWaiters;
greWaiters = [];
queued.forEach(function (fn) { try { fn(); } catch (e) {} });
return;
}
if (attempts > 200) {
// no-silent-failures: enterprise.js never became ready (network-blocked,
// consent/privacy blocker, or a Google outage). Surface it — a missing
// token fails CLOSED server-side (GWP-412) and drops the lead.
if (window.console && console.warn) {
console.warn('[GMX recaptcha] enterprise.js not ready after ~10s; token will be missing (submit fails closed).');
}
return; // give up after ~10s (200 * 50ms)
}
setTimeout(function () { pollGre(attempts + 1); }, 50);
}
function loadGre() {
if (greLoadStarted) return;
greLoadStarted = true;
var s = document.createElement('script');
s.src = loaderUrl;
s.async = true;
document.head.appendChild(s);
pollGre(0); // begin polling only once the runtime is actually loading
}
function whenGreReady(cb) {
if (greReady) return cb();
greWaiters.push(cb);
}
function stampToken(form) {
if (!form.querySelector('.wpcf7-form-control-wrap input[type="submit"], .wpcf7-submit')) return;
loadGre(); // lazy: kick off enterprise.js on demand (idempotent)
whenGreReady(function () {
grecaptcha.enterprise.ready(function () {
grecaptcha.enterprise.execute(siteKey, { action: action }).then(function (token) {
var hidden = form.querySelector('input[name="gmx_recaptcha_token"]');
if (!hidden) {
hidden = document.createElement('input');
hidden.type = 'hidden';
hidden.name = 'gmx_recaptcha_token';
form.appendChild(hidden);
}
hidden.value = token;
}).catch(function () {
// no-silent-failures: token generation failed; the server gate is
// fail-CLOSED (GWP-412), so this submit will be rejected as spam.
if (window.console && console.warn) {
console.warn('[GMX recaptcha] token execute failed; submit will fail closed.');
}
});
});
});
}
document.addEventListener('wpcf7submit', function (e) { stampToken(e.target); });
// Also stamp on first focus into any CF7 form (so token ready before submit).
// `whenGreReady()` queues the stamp until grecaptcha loads, so the once-
// listener stays safe even if grecaptcha isn't ready at focus-in time.
document.querySelectorAll('form.wpcf7-form').forEach(function (form) {
form.addEventListener('focusin', function once() {
form.removeEventListener('focusin', once);
stampToken(form);
});
});
// GWP-506: warm enterprise.js on the FIRST real page interaction so the ~900ms
// runtime is ready before the user reaches submit (closes the focusin-only race
// against the fail-CLOSED server gate, and covers AJAX/popup-injected forms that
// missed the focusin binding above). Never fires on a no-interaction (lab) view,
// so the perf win holds. Idempotent via loadGre()'s greLoadStarted guard.
var warmOpts = { passive: true, capture: true };
var warmEvents = ['pointerdown', 'keydown', 'touchstart', 'scroll'];
function warmGre() {
loadGre();
warmEvents.forEach(function (e) { window.removeEventListener(e, warmGre, warmOpts); });
}
warmEvents.forEach(function (e) { window.addEventListener(e, warmGre, warmOpts); });// GWP-507 (CONFIRMED LIVE: 19 real leads dropped in 8 days): capture-phase
// submit GATE. The warm/focusin logic above only *helps* the token be ready;
// it is NOT a guarantee. The race: a user whose FIRST interaction is clicking
// submit on an autofilled form (no prior scroll/field-touch to warm the
// ~900ms enterprise.js), or who submits before the runtime readies, serializes
// the AJAX POST with an EMPTY gmx_recaptcha_token → the fail-CLOSED server gate
// (GWP-412 require_token) drops the lead as spam. CF7's `wpcf7submit` fires
// AFTER the AJAX POST (too late), and CF7 exposes no documented pre-POST JS
// hook (verified: contactform7.com/dom-events). So the ONLY seam is to
// intercept the native DOM submit/click in CAPTURE phase, HOLD it until
// greReady + token stamped, then re-dispatch. grecaptcha token lifetime is
// 2 minutes, so holding briefly is safe.
//
// TIMEOUT-FALLBACK CHOICE (a): if enterprise.js never readies within the
// ~10s ceiling (network-blocked / consent-blocker / Google outage), we
// RE-ENABLE the button and let the submit proceed WITHOUT a token rather than
// hard-blocking the user. It will fail-CLOSED server-side (GWP-412), but the
// console.warn fires loudly (no-silent-failures) — we never trap a real user
// behind a spinner they can't escape.
var GATE_TIMEOUT_MS = 10000; // matches pollGre ceiling (200 * 50ms).
function gmxFormHasToken(form) {
var hidden = form.querySelector('input[name="gmx_recaptcha_token"]');
return !!(hidden && hidden.value);
}
function gmxSetVerifying(form, on) {
var btn = form.querySelector('.wpcf7-submit, input[type="submit"], button[type="submit"]');
if (!btn) return;
if (on) {
btn.disabled = true;
btn.setAttribute('data-gmx-verifying', '1');
} else {
btn.disabled = false;
btn.removeAttribute('data-gmx-verifying');
}
}
function gmxReleaseSubmit(form) {
// Mark released so the re-dispatched submit passes straight through the
// capture gate (no re-gate loop), re-enable UX, then re-trigger.
form.__gmxGateReleased = true;
gmxSetVerifying(form, false);
if (typeof form.requestSubmit === 'function') {
form.requestSubmit();
} else {
form.dispatchEvent(new Event('submit', { bubbles: true, cancelable: true }));
}
// GWP-507 finding-1 (BLOCKER fix): reset the release flag on the NEXT tick
// so any FUTURE user submit (user edits a field + resubmits) is re-gated and
// stamps a FRESH token. reCAPTCHA tokens are single-use with a ~2-min
// lifetime — without this reset, __gmxGateReleased stayed true forever after
// the first release, letting a second submit bypass the gate and POST a
// stale/used token. The setTimeout(0) lets the synchronous re-dispatch above
// complete (which short-circuits on the still-true flag) before we re-arm.
setTimeout(function () { form.__gmxGateReleased = false; }, 0);
}
function gmxSubmitGate(e) {
var form = e.currentTarget;
if (form.tagName !== 'FORM') { form = form.form || form.closest('form.wpcf7-form'); }
if (!form) return;
// Idempotent: a programmatic re-submit we already released proceeds. This is
// the ONLY pass-through — it lets the freshly-stamped re-dispatch reach CF7.
// (The flag is reset on the next tick in gmxReleaseSubmit, so the NEXT user
// submit is re-gated.)
if (form.__gmxGateReleased) return;
// GWP-507 finding-2 (stale/used token fix): every USER submit HOLDS + stamps
// a FRESH token — we do NOT early-return on an already-present token. A token
// already sitting in the hidden input may be stale or already used (single-
// use, ~2-min lifetime); proceeding on it would POST a dead token. enterprise.js
// is warm by submit time, so grecaptcha.enterprise.execute() resolves in
// ~100-300ms — the per-submit hold is brief. stampToken() OVERWRITES the
// hidden input value (hidden.value = token), so no stale token lingers.
// HOLD: block CF7's submit handler before the AJAX POST.
e.preventDefault();
e.stopImmediatePropagation();
if (form.__gmxGateWaiting) return; // a click + submit may both fire; hold once.
form.__gmxGateWaiting = true;
loadGre(); // kick the warm if not started.
gmxSetVerifying(form, true);
var released = false;
function release(missing) {
if (released) return;
released = true;
form.__gmxGateWaiting = false;
if (missing && window.console && console.warn) {
console.warn('[GMX recaptcha] submit gate timed out (~10s); releasing without token (submit fails closed).');
}
gmxReleaseSubmit(form);
}
var timer = setTimeout(function () { release(true); }, GATE_TIMEOUT_MS);
whenGreReady(function () {
stampToken(form);
// stampToken resolves the token asynchronously (enterprise.execute
// promise); poll briefly for the stamp, then release. Bounded by the
// same overall timer above.
(function awaitStamp(n) {
if (released) return;
if (gmxFormHasToken(form)) { clearTimeout(timer); release(false); return; }
if (n > 200) { clearTimeout(timer); release(true); return; } // ~10s (200*50ms)
setTimeout(function () { awaitStamp(n + 1); }, 50);
})(0);
});
}
// GWP-507 finding-4 (CF7 phase): WHY capture phase works. Our gate listener is
// registered in CAPTURE phase (3rd arg `true`), so it runs BEFORE CF7's own
// bubble-phase 'submit' handler on the same form. When we call
// e.stopImmediatePropagation() in the capture listener, the DOM spec stops ALL
// further listeners for that event on the target — including the later
// bubble-phase CF7 handler — so CF7's AJAX POST never fires until we re-dispatch
// with a fresh token. This capture-phase interception is the only documented
// pre-POST seam: CF7 exposes no pre-POST JS hook (wpcf7submit fires AFTER the
// AJAX POST). See contactform7.com/dom-events.
document.querySelectorAll('form.wpcf7-form').forEach(function (form) {
form.addEventListener('submit', gmxSubmitGate, true);
var btn = form.querySelector('.wpcf7-submit, input[type="submit"], button[type="submit"]');
if (btn) { btn.addEventListener('click', gmxSubmitGate, true); }
});
})();
(function(){
var loaded = false;
function loadUserWay() {
if (loaded) return;
loaded = true;
var el = document.createElement('script');
el.setAttribute('data-account', "UX40fo0Ctw");
el.setAttribute('data-language', "en");
el.setAttribute('src', 'https://cdn.userway.org/widget.js');
document.body.appendChild(el);
events.forEach(function(e){ window.removeEventListener(e, loadUserWay, {passive: true}); });
}
var events = ['scroll', 'mousemove', 'touchstart', 'click', 'keydown'];
events.forEach(function(e){ window.addEventListener(e, loadUserWay, {passive: true}); });
})();