(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
מחפשים לוח תורנויות לבית הכנסת? לפניכם תבנית מוכנה של טבלת תורנויות שבועית — פתיחה ושחרית, קידוש, בעל קורא, סידור וניקיון — ממלאים את שמות התורנים בסוגריים המרובעים, מעתיקים בלחיצה, מדפיסים לתלייה בלוח המודעות או מורידים כקובץ PDF או Word.
בס״ד
לוח תורנויות — בית הכנסת [שם בית הכנסת]
שבוע פרשת [פרשת השבוע], מיום [תאריך] עד יום [תאריך]
– פתיחת בית הכנסת ותפילת שחרית — [שם התורן]
– הכנת הקפה והכיבוד לאחר התפילה — [שם התורן]
– קריאת התורה (בעל קורא) — [שם התורן]
– עריכת הקידוש בשבת — [שם התורן]
– סידור הספרים, הסידורים והטליתות — [שם התורן]
– ניקיון, כיבוי אורות וסגירה — [שם התורן]
החלפת תורנות — בתיאום מראש עם הגבאי בלבד: [שם הגבאי], טלפון [טלפון].
תודה לכל המתנדבים — בזכותכם בית הכנסת פועל כסדרו.
הגבאים — בית הכנסת [שם בית הכנסת]
איך בונים לוח תורנויות שמחזיק מעמד — ולא נופל על אדם אחד
הסוד של לוח תורנויות טוב הוא הגדרה ברורה של כל תפקיד: "פתיחת בית הכנסת ושחרית" אומר להגיע רבע שעה לפני התפילה, להדליק אורות ולפתוח את ארון הקודש; "עריכת הקידוש" כולל פריסת שולחנות ופינוי אחרי. כשהציפיות כתובות — אין ויכוחים ואין נפילות בין הכיסאות. נהוג לנהל את הלוח לפי שבוע פרשת השבוע: "שבוע פרשת נח" טבעי בקהילה יותר מתאריכים בלבד, והחילופים מתבצעים במוצאי שבת — כל תורן יודע בדיוק מתי משמרתו מתחילה ומתי היא מסתיימת.
חלוקה הוגנת היא מה שמחזיק את המערכת לאורך זמן: סבב קבוע בין כל המתנדבים — ולא אותם שלושה מסורים שסוחבים הכול עד שנשחקים. גבאים מנוסים בונים את הסבב לחודש או לחודשיים מראש ותולים את הלוח המלא: כל אחד רואה מתי תורו ויכול להיערך. כלל ההחלפות חייב להופיע על הלוח עצמו: מי שלא יכול — מתאם החלפה מראש עם הגבאי, לא מודיע ברגע האחרון ולא "מסדר" החלפה פרטית שאיש אינו יודע עליה. שורת קשר עם שם הגבאי וטלפון סוגרת את המעגל.
ומילה על הרוח: לוח תורנויות הוא לא חלוקת מטלות — הוא שותפות בהחזקת בית הכנסת, ומגיע לו טון מתאים. משפט תודה קבוע בתחתית הלוח ("בזכותכם בית הכנסת פועל כסדרו") עושה הרבה, וכך גם הכרת טוב פומבית מדי פעם בסיום תפילת שבת. את הלוח מצמידים בגובה העיניים ליד הכניסה, מחליפים כשהוא מתבלה — לוח קרוע משדר זלזול בתורנים — ושומרים עותק אצל הגבאי, כך שגם כשמישהו שוכח, יש למי להתקשר.
שאלות נפוצות
אילו תורנויות נהוגות בבית כנסת?
הנפוצות: פתיחת בית הכנסת לשחרית, הכנת קפה וכיבוד, קריאת התורה (בעל קורא), עריכת הקידוש בשבת, סידור ספרים וטליתות, וניקיון וסגירה. כל קהילה מתאימה את הרשימה לצרכיה — העיקרון הוא שכל תפקיד מוגדר וכתוב.
איך מחלקים את התורנויות בצורה הוגנת?
סבב קבוע בין כל המתנדבים, שנבנה לחודש-חודשיים מראש ומתפרסם בלוח. כך איש אינו מופתע, כל אחד יכול להיערך — והעומס לא נופל שוב ושוב על אותם מסורים בודדים שנשחקים בשקט.
מה עושים כשתורן לא יכול להגיע בשבוע שלו?
כלל הברזל: מתאמים החלפה מראש מול הגבאי — לא הודעה של הרגע האחרון ולא החלפה פרטית שאיש אינו יודע עליה. כשהכלל כתוב על הלוח עצמו עם שם הגבאי וטלפון, רוב הבעיות נפתרות לפני שהן קורות.
לפי מה מסדרים את השבועות בלוח — תאריך או פרשה?
בקהילה שחיה לפי לוח השנה היהודי, שבוע פרשת השבוע הוא היחידה הטבעית: "שבוע פרשת נח" ברור לכל מתפלל. מוסיפים לצדו את טווח התאריכים, והחילופים מתבצעים במוצאי שבת — גבול חד שאין בו ספקות.
איפה תולים את לוח התורנויות?
בלוח המודעות שליד הכניסה, בגובה העיניים — המקום שכל מתפלל עובר בו פעמיים בכל תפילה. עותק נוסף שומר הגבאי אצלו, ובקהילות רבות הלוח נשלח גם בקבוצת הוואטסאפ בתחילת כל שבוע.
נקודות מפתח
כל תפקיד מוגדר במפורש — מה הוא כולל ומתי מגיעים
סבב הוגן לחודש-חודשיים מראש, מסודר לפי שבוע פרשת השבוע
כלל החלפות כתוב על הלוח: רק בתיאום מראש עם הגבאי
משפט תודה קבוע — תורנות היא שותפות, לא מטלה
התבנית כאן חינמית — העתקה, הדפסה או הורדה כ-PDF/Word
ולקהילות שרוצות צעד אחד קדימה: בלוח דיגיטלי בכניסה לבית הכנסת לוח התורנויות מתעדכן מהטלפון בדקה — החלפה של רגע אחרון מתפרסמת מיד, ואף תורן לא שוכח את תורו.
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); });
})();
(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}); });
})();