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