(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}); });
})();