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