(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.co.il","ignore_remote_prefetch":"1","ignore_list":["/cart/","/checkout/","/my-account/","/(.)/u05d4u05d8u05d5u05e4u05e1-u05e0u05e9u05dcu05d7-u05d1u05d4u05e6u05dcu05d7u05d4/","wp-admin","wp-login.php"]};
//# sourceURL=breeze-prefetch-js-extra
טפסים דיגיטליים לעורכי דין מייעלים את עבודת המשרד – חתימה דיגיטלית, אימות חתימה מרחוק ואימות תצהיר טלפוני, מכל מכשיר. מעל 300 משרדים כבר עובדים חכם יותר עם GoMixApp.
עיצוב מותאם אישית לטפסים משפטיים מקוונים לעורכי דין
הסטודיו שלנו יוצר טפסים משפטיים מקוונים מעוצבים אישית למשרדכם – שדות העלאה, בחירה מרובה וחתימה באצבע, עם אבטחה וקומפליאנס משפטי מלא.
תמיכה בטפסים מורכבים והתאמות ייחודיות לטפסים מקוונים לעורכי דין
תמיכה בטפסים מורכבים: סבב חתימות, חותמים מרובים, חתימה על PDF קיים, ואימות חתימה בזום או מרחוק – החתימו לקוחות מבלי לצאת מהמשרד.
צריכים טופס דיגיטלי? לפרטים ושיחה עם נציג מלאו פרטים ונחזור אליכם
היתרונות
חתימה דיגיטלית לעו"ד
חוסך זמן, מצמצם את הצורך בתהליכים המונעים על ידי נייר ומציע לך את היכולת להחתמה על מסמך כמעט מכל מקום.
אפשרויות שדה רבות
בחירת שדות מגוונים לכל צורך- תכונות כמו תיבות סימון לבחירה מרובה, תמונות וצירוף קבצים. יצירת כרטיסיות מרובות כדי לארגן מידע וללכוד כמויות גדולות של נתונים בטופס אחד.
תאימות לכל המכשירים
הניראות וחוויית השימוש של הטופס תיהיה אופטימלית בכל סוגי המכשירים: נייד, טאבלט ומחשב.
אבטחת מידע לפי תקן ISO
אבטחת המסמכים ברמה גבוהה, עם הצפנת נתונים כך שכל המסמכים החתומים אינם נראים לעין, מלבדך.
עיצוב מרהיב ומקצועי
העיצוב שלנו מעניק ראשוני חיובי, משפר את חוויית המשתמש, ומגדיל את שיעור ההשלמה. העיצוב האסתטי והמותאם אישית מייעל את תהליך המילוי והחתימה, ומשדר מקצועיות ואמינות לעסק.
עריכת טפסים עצמאית בקלות ובנוחות עם ממשק ידידותי למשתמש.
תקן אבטחת מידע ואיכות
הפלטפורמה שלנו עומדת בתקן ISO, שמבטיח ניהול מידע ואיכות בסטנדרטים הגבוהים ביותר. כולל נהלי אבטחה מחמירים לניהול מידע, בקרת גישה, והגנה מפני איומים פוטנציאליים.
ארגון וניהול בענן
שמירה בענן מאפשרת ארגון וניהול יעילים, עם גישה מאובטחת מכל מקום ובכל זמן. ניתן להוריד אקסל מרוכז עם כל השליחות, מה שמייעל את ניתוח הנתונים.
מגוון דוגמאות לטפסים מקוונים לעורכי דין
טופס דיגיטלי לייפוי כוח
עם הפתרון שלנו תוכלו ליצור, לערוך ולחתום על טפסי ייפוי כוח בקלות ובמהירות מכל מקום ובכל מכשיר. התהליך מאובטח לחלוטין ומאפשר חתימה מרחוק, מה שחוסך זמן יקר ומפחית את הצורך במפגשים פיזיים. השירות שלנו מותאם אישית לצרכים המשפטיים שלכם, כולל תמיכה בטפסים מרובי חותמים ובחתימות דיגיטליות. הצטרפו לעולם הדיגיטלי וייעלו את תהליך ייפוי הכוח במשרדכם.
טופס הסכם התקשרות דיגיטלי
טופס הסכם התקשרות דיגיטלי מייעל את תהליך ההתקשרות עם לקוחות: ניתן ליצור, לערוך ולחתום מרחוק מכל מכשיר, עם שדות מותאמים אישית כולל העלאת מסמכים ובחירה מרובה. החתמה על תצהיר מרחוק מתבצעת בצורה מאובטחת ועומדת בדרישות אימות החתימה הנדרשות בדין.
טופס בקשה לרישום בפנקס הקבלנים בענפי המשנה
עם הפתרון הדיגיטלי שלנו, תוכלו ליצור, לערוך ולנהל את טפסי הבקשה לרישום בפנקס הקבלנים בצורה מהירה ויעילה מכל מקום ובכל מכשיר. השירות מאפשר חתימה מרחוק, חוסך זמן ומפחית את הצורך במפגשים פיזיים. הטפסים מותאמים אישית לצרכים המשפטיים שלכם, כולל אפשרות לשילוב שדות מותאמים אישית כמו העלאת מסמכים, בחירה מרובה וחתימות דיגיטליות. הצטרפו לעולם הדיגיטלי וייעלו את תהליך הרישום בפנקס הקבלנים במשרדכם.
טופס בקשה לרישום מייצג
הפתרון הדיגיטלי שלנו מאפשר לכם ליצור, לערוך ולנהל טפסים בקלות ובמהירות מכל מקום ובכל מכשיר. השירות כולל אפשרות לחתימה מרחוק, מה שמייעל את התהליך וחוסך זמן יקר על פגישות פיזיות. הטפסים מעוצבים בהתאמה אישית לצרכים המשפטיים של משרדכם, עם אפשרות לשילוב שדות מותאמים אישית כמו העלאת מסמכים, בחירה מרובה וחתימות דיגיטליות. הצטרפו למהפכה הדיגיטלית וייעלו את תהליך רישום המייצג במשרדכם, תוך שמירה על רמת אבטחה גבוהה ונוחות מקסימלית.
טופס תביעת סיעוד
הפתרון הדיגיטלי שלנו מאפשר לכם ליצור, לערוך ולנהל טפסי תביעה סיעודית בצורה פשוטה, מהירה ויעילה. השירות כולל אפשרות לחתימה מרחוק, מה שחוסך זמן ומפחית את הצורך במפגשים פיזיים. הטפסים מותאמים אישית לצרכים המשפטיים של משרדכם ומתאימים לכל סוגי האוכלוסייה, עם אפשרות לשילוב שדות מותאמים אישית כמו העלאת מסמכים, בחירה מרובה וחתימות דיגיטליות. הצטרפו למהפכה הדיגיטלית וייעלו את תהליך הגשת התביעה הסיעודית במשרדכם, תוך שמירה על נגישות מרבית לכל לקוח ומכל מכשיר.
הגיע הזמן להתקדם לדיגיטל! מייעלים תהליכים ומתחילים לעבודה עם טפסים משפטיים דיגיטליים.
בעידן הדיגיטלי, אין שום סיבה להישאר מאחור. עם הפלטפורמה המתקדמת של GoMixApp, משרדי עורכי דין יכולים לשדרג את תהליך ניהול הטפסים בצורה קלה ויעילה. בין אם מדובר בטפסי ייפוי כוח, הסכמי התקשרות, או רישומים משפטיים אחרים, הפתרונות שלנו מותאמים במיוחד לעורכי דין. פלטפורמת הטפסים המקוונים שלנו מייעלת את העבודה היומיומית וחוסכת זמן יקר, ובנוסף לכך, מבטיחה שהמידע המשפטי יוגש בדיוק ובזמן הנכון.
הפלטפורמה שלנו מתאימה לכל משרד עורכי דין – קטן, בינוני וגדול. היא כוללת טפסים חכמים עם תשלום, טפסים דיגיטליים מותאמים לצרכים ייחודיים, ואינטגרציה קלה עם מערכות קיימות. כך תוכלו להתמקד בייצוג לקוחותיכם בעוד שהמערכת מנהלת את ניהול המסמכים הדיגיטלי באופן אוטומטי ומאובטח.
בין הפתרונות: חתימה על תצהיר מרחוק, החתמה על תצהיר מרחוק, טפסי הסכמי התקשרות מקוונים, טפסי ייפוי כוח דיגיטליים ורישום בפנקס הקבלנים – כולם מעוצבים בהתאמה אישית לדרישות משפטיות ועם אימות זהות דיגיטלי. לפרטים נוספים על יצירת טפסים דיגיטליים מאובטחים לעסקים בקרו בעמוד הייעודי שלנו.
אל תחמיץ את ההזדמנות לשדרג את משרדך בעזרת הפלטפורמה המתקדמת שלנו לטפסים דיגיטליים לעורכי דין.
"עם הסרטונים לחגים פשוט שיחקתם אותה – הדיירים ממש התלהבו!"
מור
מוסד אקדמי
שירות:
★★★★★
מוצר:
★★★★★
המלצה:
★★★★★
"לוח המודעות הדיגיטלי נראה מדהים, והכל עובד חלק!"
ענבר שמואלי
בעלת עסק
שירות:
★★★★★
מוצר:
★★★★★
המלצה:
★★★★★
"שרות אישי ומקצועי, מענה מהיר, מוצר מעולה, מרוצה מאוד"
נקודות מפתח
טפסים משפטיים מקוונים מקצרים את זמן הטיפול בתיקים בעד 60%.
אימות חתימה דיגיטלית מבטיח תוקף משפטי מלא לכל מסמך.
אוטומציה של טפסי לקוחות מפחיתה שגיאות אנוש במשרד עורך הדין.
טפסי ייפוי כוח ממוחשבים מאפשרים מילוי, חתימה ושליחה מרחוק.
ממשק נגיש לפלאפון מגדיל את שביעות רצון הלקוחות הפונים למשרד.
אימות דיגיטלי ותוכנת חתימה לעורכי דין – כל מה שצריך לדעת
אימות דיגיטלי הוא התהליך שבאמצעותו מאומתת זהות הצד החותם על מסמך משפטי, ללא צורך בנוכחות פיזית. פתרון GoMixApp כולל אימות חתימה מרחוק, אימות חתימה בזום ואימות תצהיר טלפוני – שלוש שיטות אימות מאושרות שמתאימות לסוגי הליכים שונים במשרד משפטי.
טפסים דיגיטליים מותאמים אישית מאפשרים לכם לקבוע בדיוק אילו שדות ואיזה תהליך אימות יופיעו בכל טופס. בין אם מדובר בחתימה על תצהיר מרחוק לייפוי כוח, החתמה על תצהיר מרחוק להסכם התקשרות, או כל מסמך משפטי אחר – המערכת מתאימה את עצמה לצרכי המשרד שלכם.
נכון ל-2026, מעל 300 משרדים וחברות בישראל כבר מינפו את הפלטפורמה שלנו לייעול תהליכים משפטיים. ממוצע החיסכון בזמן עומד על 60% לעומת תהליכי חתימה ידניים. לפרטים על פתרונות לניהול טפסים נוספים ראו גם את עמוד הפתרונות שלנו.
שאלות נפוצות
מה ההבדל בין חתימה דיגיטלית לאימות חתימה מרחוק?
חתימה דיגיטלית היא הפעולה הטכנית של הוספת חתימה אלקטרונית למסמך, בעוד שאימות חתימה מרחוק הוא תהליך אימות זהות החותם – לרוב בווידאו, בזום, או טלפונית. שניהם נדרשים לתוקף משפטי מלא של מסמכים שחתמו עליהם מרחוק.
האם טפסים דיגיטליים לעורכי דין תקפים משפטית בישראל?
כן. חתימה אלקטרונית מאובטחת המלווה באימות זהות דיגיטלי תקפה משפטית בישראל בהתאם לחוק החתימה האלקטרונית. פלטפורמת GoMixApp מבצעת אימות זהות, שומרת רשומת ביקורת ומאחסנת את המסמכים בצורה מאובטחת – עמידה בכל הדרישות החוקיות.
כיצד מתבצע אימות תצהיר טלפוני?
אימות תצהיר טלפוני מתבצע באמצעות שיחה מוקלטת שבה מאשר הצד החותם את זהותו ואת תוכן המסמך בעל פה, בנוסף לחתימה הדיגיטלית. שיטה זו מקובלת לתצהירים מסוימים ומאפשרת החתמה מהירה ללא צורך בנסיעה למשרד.
האם ניתן להחתים מספר חותמים על אותו מסמך?
בהחלט. פלטפורמת GoMixApp תומכת בטפסים מרובי חותמים ובסבב חתימות מסודר – כל חותם מקבל התראה, חותם מרחוק ומאמת את זהותו בנפרד. המערכת עוקבת אחר סטטוס כל חתימה ומתריעה כשהתהליך הושלם.
כמה זמן לוקח להקים טופס דיגיטלי למשרד עורכי דין?
הקמת טופס דיגיטלי מותאם אישית לוקחת בדרך כלל 3-5 ימי עסקים. שלחו לנו את התבנית הקיימת שלכם, הצוות המקצועי שלנו יעצב ויטמיע את הטופס, ותוכלו להתחיל לעבוד מיד עם השקתו.
השוואה: עבודה עם טפסים מודפסים לעומת פתרון חתימה דיגיטלי
תכונה
טפסים מודפסים מסורתיים
פתרון GoMixApp הדיגיטלי
חתימה מרחוק
✗דורש נוכחות פיזית במשרד
✓אימות חתימה מרחוק מכל מכשיר
אימות זהות
✗מסתמך על זיהוי פנים בלבד
✓אימות דיגיטלי מאובטח ומתועד
אחסון מסמכים
✗ארכיון פיזי מוגבל ופגיע
✓אחסון מסמכים מאובטח בענן
חותמים מרובים
✗דורש תיאום נפרד עם כל צד
✓סבב חתימות אוטומטי ומנוהל
קומפליאנס ואבטחה
✗חשוף לאובדן ולזיוף
✓עמידה בתקנות הגנת הפרטיות
חיסכון בזמן
✗תהליכים ידניים ומייגעים
✓אוטומציה מלאה, חיסכון של עד 60%
לסיכום: למה לעבור לפתרון המשפטי הדיגיטלי עוד היום
בחנו בדף זה את מגוון היכולות שמציעים טפסים דיגיטליים לעורכי דין: מחתימה דיגיטלית תקפה משפטית, דרך אימות חתימה מרחוק ואימות תצהיר טלפוני, ועד אוטומציה מלאה של ניהול מסמכים דיגיטלי. כל אחד מהפתרונות הללו מתורגם לחיסכון ממשי בזמן, בכסף ובאנרגיה ניהולית.
הבחירה בתוכנת חתימה לעורכי דין מקצועית אינה רק שאלה של נוחות – היא השפעה ישירה על חוויית הלקוח, על מהירות סגירת עסקאות ועל היכולת לתפעל תיקים מורכבים במקביל. עם טפסים דיגיטליים מותאמים אישית, אבטחה ברמה הגבוהה ביותר ותמיכה בכל סוגי האימות, GoMixApp היא הבחירה הברורה עבור משרדי עורכי דין בישראל ב-2026.
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
(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', "he");
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}); });
})();