(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
עמדות מיינדפולנס לעובדים של GoMixApp הופכות כל הפסקה לרגע של שקט וריכוז. מסכי מגע אינטראקטיביים מביאים מדיטציה, מתיחות ויוגה למשרד, בהתאמה אישית של מדריך ותכנים. מעל 300 חברות בישראל כבר בחרו.
מעוניינים בעמדת כושר אינטראקטיבית? לפרטים ושיחה עם נציג מלאו פרטים ונחזור אליכם
היתרונות
קידום אורח חיים בריא
גוף בריא ומשוחרר ממתחים יוצר בסיס למוח חד ויצירתי לאורך כל יום עבודה. תוכניות wellness לעובדים משפרות את הבריאות הנפשית והפיזית של כל הצוות.
שימור עובדים ולחיזוק מותג
עובד שמרגיש שהארגון דואג לו נשאר לאורך זמן. שימור עובדים מתחיל בהשקעה אמיתית ברווחתם – וחברה כזו מושכת את הטאלנטים הטובים ביותר.
אווירה פרודוקטיביות ויצירתיות
הפסקה קצרה של מיינדפולנס בארגון מאתחלת ריכוז ופותחת דלת לרעיונות חדשים, ויוצרת אווירה פרודוקטיבית לאורך כל שעות היום.
סביבת עבודה חיובית ואפקטיבית
כשהלחץ יורד והאנרגיה עולה, המשרד הופך לסביבת עבודה חיובית שבה כל אחד מביא את המיטב שלו.
מצב של Win-Win: למה זה משתלם לכולם?
שילוב הפתרון שלנו במשרד יוצר באופן מיידי אווירה פרודוקטיבית, חיובית ובריאה יותר – וכאן תגלו למה זה משתלם לכולם:
עבור העובדים: הפסקה שמפחיתה סטרס, משחררת מתחים מישיבה ממושכת (כאבי גב וצוואר) ומשפרת ריכוז ורווחה (Well-being). מסר ברור: "הבריאות שלך חשובה לנו".
עבור החברה: ההשקעה מחזירה את עצמה מיידית. עובדים שלוקחים פסק זמן קצר חוזרים חדים ופרודוקטיביים יותר. קידום בריאות בעבודה מפחית שחיקה והיעדרויות, ומחזק נאמנות ומותג המעסיק.
תמיכה בקהילה ושייכות
שיפור תדמית הארגון
פרודוקטיביות ויצירתיות
הפתרון משמש כעמדת wellness לעובדים עם מדיטציה, מתיחות והרפיה. נכון ל-2026, ארגונים שמאמצים wellness רואים ירידה של 30% בעזיבה ועלייה של 25% בפרודוקטיביות. מכון וינגייט מדגיש את הפעילות הגופנית והנפשית בעבודה, ופתרונות דיגיטליים למשאבי אנוש משלימים את חווית הרווחה.
מה הן 7 עמדות המיינדפולנס ואיך הן קשורות לסביבת העבודה?
שבע העמדות: אי-שיפוטיות, סבלנות, מחשבת מתחיל, אמון, אי-שאיפה, קבלה ושחרור. בעבודה הן הופכות לתרגילי נשימה, מדיטציה ויוגה קצרים.
איך מדיטציה בעבודה משפרת את הפרודוקטיביות?
מדיטציה בעבודה מפחיתה סטרס, מחדדת ריכוז ומשפרת החלטות. הפסקת מיינדפולנס של 10 דקות מעלה יעילות ב-25% ומורידה שגיאות.
כיצד עמדות כושר לעובדים תורמות לשימור עובדים?
עובדים שמרגישים שהארגון משקיע ברווחתם נאמנים יותר. תוכניות wellness ועמדות מיינדפולנס מורידות עזיבה בעד 30%.
האם ניתן להתאים את תכני העמדה לצרכים הספציפיים של הארגון שלי?
בהחלט. כל עמדה מותאמת – מדריך, תכנים, שפה ולוח זמנים. מתאים להייטק, בתי חולים, מלונות ושירותים בכל גודל.
מה ה-5 עקרונות המרכזיים (5 C's) של מיינדפולנס שניתן ליישם בעבודה?
חמשת עקרונות המיינדפולנס בעבודה הם: מודעות (Consciousness), סקרנות (Curiosity), חמלה (Compassion), קשר (Connection) ושליטה (Control). הפתרון שלנו מיישם עקרונות אלה דרך תכנים מובנים שעובדים יכולים לבצע בעצמם בפחות מ-10 דקות.
כיצד מתחילים עם עמדות מיינדפולנס לעובדים בארגון?
לקוחות ממליצים
פנחס
ועד בית, רמלה
שירות:
★★★★★
מוצר:
★★★★★
המלצה:
★★★★★
"עם הסרטונים לחגים פשוט שיחקתם אותה – הדיירים ממש התלהבו!"
מור
מוסד אקדמי
שירות:
★★★★★
מוצר:
★★★★★
המלצה:
★★★★★
"לוח המודעות הדיגיטלי נראה מדהים, והכל עובד חלק!"
ענבר שמואלי
בעלת עסק
שירות:
★★★★★
מוצר:
★★★★★
המלצה:
★★★★★
"שרות אישי ומקצועי, מענה מהיר, מוצר מעולה, מרוצה מאוד"
כיצד מדיטציה בעבודה משנה את חיי הצוות שלכם?
מדיטציה בעבודה היא לא רק טרנד – היא כלי מדעי מוכח להפחתת סטרס בעבודה ולשיפור הריכוז, היצירתיות ושביעות הרצון של העובדים. ארגונים המשלבים פינות מיינדפולנס בסביבת העבודה מדווחים על שיפור ניכר באקלים הארגוני תוך 90 ימים.
הפתרון שלנו משלב ניהול סטרס בארגון עם עמדות כושר אינטראקטיביות מתקדמות, ומאפשר לכל עובד – ממשרדי הייטק ועד בתי חולים וחברות שירותים – ליהנות מדקות ספורות של שקט מחזיר אנרגיה. הנה מה שהעמדות שלנו מציעות:
תכני מדיטציה, נשימות ויוגה בהתאמה אישית לארגון
ממשק מסך מגע אינטואיטיבי – ללא צורך בהדרכה מוקדמת
אינטגרציה קלה בכל סביבת עבודה – משרד, לובי, חדר אוכל
ניהול תכנים מרחוק ועדכון שוטף של פעילויות wellness לעובדים
דוחות שימוש לניהול תוכניות שימור עובדים ומדידת ROI
רוצים לראות את הפתרון בפעולה? דברו איתנו ונתאים עבורכם הדגמה חינמית.
7 עמדות מיינדפולנס – מה הן ואיך הן מיושמות בארגון?
שבע העמדות המרכזיות של המיינדפולנס – אי-שיפוטיות, סבלנות, מחשבת מתחיל, אמון, אי-שאיפה, קבלה ושחרור – הן הבסיס לכושר נפשי בעבודה. הפתרון שלנו מתרגם עקרונות אלה לתכנים פרקטיים שניתן לבצע בפחות מ-10 דקות ביום.
אי-שיפוטיות: תרגילי נשימה המאפשרים לעובד להתבונן במחשבותיו ללא ביקורת עצמית.
סבלנות: מדיטציות קצרות המלמדות להאט ולפעול מתוך כוונה – לא מתוך לחץ.
מחשבת מתחיל: פעילויות יצירתיות המחזירות סקרנות וחדשנות לשגרת היום.
אמון: תרגילי גוף-נפש המחזקים את תחושת הבטחון האישית של העובד.
אי-שאיפה: הפסקות מיינדפולנס המזמינות נוכחות מלאה כאן ועכשיו.
קבלה: כלים להפחתת סטרס בעבודה ולניהול רגשות בזמן עומס.
שחרור: מתיחות ויוגה להורדת מתח פיזי ונפשי שנצבר לאורך היום.
לסיכום: מיינדפולנס בארגון – השקעה שמחזירה את עצמה
השקעה ברווחת העובדים היא אחת ההחלטות הניהוליות החכמות ביותר שארגון יכול לקבל. מיינדפולנס בארגון תורם ישירות להפחתת סטרס בעבודה, לשיפור האווירה הפרודוקטיבית ולחיזוק שימור עובדים – שלושת הגורמים המשפיעים ביותר על הצמיחה העסקית לטווח ארוך.
נכון ל-2026, חברות המאמצות תוכניות wellness לעובדים נהנות מיתרון תחרותי ברור בשוק הגיוס ומדווחות על עלייה משמעותית בשביעות רצון הצוות. כושר נפשי בעבודה אינו מותרות – הוא תשתית הכרחית לכל ארגון שרוצה לצמוח. עמדות כושר לעובדים ותכנים מותאמים אישית הם הדרך המהירה ביותר ליישום ברמה ארגונית.
עצירה מודעת של שלוש דקות ביום משנה את איכות קבלת ההחלטות.
טיפוח נוכחות מלאה בישיבות מעלה את רמת שיתוף הפעולה הצוותי.
שילוב שיטות קשב בסביבת העבודה מוביל לפרודוקטיביות גבוהה יותר לאורך זמן.
השוואת פתרונות מיינדפולנס לסביבת העבודה
קריטריון
עמדת מיינדפולנס במשרד
סדנאות מיינדפולנס חד-פעמיות
אפליקציית מדיטציה אישית
נגישות לעובדים
✓זמינה בכל עת במהלך יום העבודה
✗מוגבלת למועדים קבועים בלבד
✓נגישה מכל מקום ובכל שעה
חיזוק תחושת שייכות
✓מחזקת קהילה ושיתוף פעולה בצוות
✓מעודדת חוויה קבוצתית משותפת
✗חוויה אישית ומבודדת בלבד
השפעה על תדמית הארגון
✓משדרת מחויבות לרווחת העובד
✓מדגישה השקעה חד-פעמית ברווחה
✗אינה גלויה ואינה מחזקת מותג מעסיק
תמיכה בהפחתת סטרס יומיומי
✓מספקת מענה מיידי ברגעי לחץ
✗אינה זמינה בשעת הצורך היומיומי
✓מאפשרת הרפיה עצמאית בכל עת
עלות הטמעה לארגון
השקעה חד-פעמית עם תשואה לטווח ארוך
עלות נמוכה אך ללא המשכיות
מנוי חודשי לפי מספר משתמשים
תרומה לשימור עובדים
✓מגבירה נאמנות ושביעות רצון לאורך זמן
✗השפעה קצרת מועד בלבד
✗אינה קשורה ישירות לסביבת העבודה
שורה תחתונה: הגיע הזמן לפעול
במאמר זה ראינו כיצד בעמדות מיינדפולנס לעובדים של GoMixApp אפשר לשלב מדיטציה בעבודה, כושר ורווחה מנטלית בתוך סביבת המשרד — בלי עלויות תשתית גדולות. למדנו שבריאות עובדים אינה נושא רך אלא מנוע צמיחה אמיתי: פחות שחיקה, יותר ריכוז ותרבות ארגונית שמושכת כישרונות. עמדות כושר אינטראקטיביות עם תכנים מנטליים הוכיחו את עצמן ב-300 ארגונים בישראל — ויכולות לעשות את אותו הדבר גם אצלכם. אם אתם רוצים פתרון מדיד, מותאם אישית וקל להפעלה — צרו קשר עכשיו ונשמח להתאים לכם הצעה.
במידה ובכל זאת לא מצאתם את העמדות שאתם מחפשים, תציצו גם פה 🙂:
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}); });
})();