(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 לעריכה ועיצוב משלכם.
מבצע!
[מוצר]
[הנחה] הנחה
המבצע בתוקף בתאריכים: [תאריכים]
או עד גמר המלאי — המוקדם מביניהם.
פרטים נוספים בקופה. לא כולל כפל מבצעים.
[שם העסק]
איך מנסחים שלט מבצע שמוכר — ולא מסבך אתכם
שלט מבצע טוב עובד לפי כלל אחד: מוצר אחד, מספר אחד. העין של לקוח חולף קולטת בשתי שניות את המילה "מבצע", את שם המוצר ואת גובה ההנחה — וזהו. שלט שמנסה לדחוס חמישה מוצרים, כוכביות ושלוש שורות תנאים פשוט לא נקרא. את הפרטים הקטנים (תוקף, כפל מבצעים, פרטים בקופה) כותבים בשורה קטנה בתחתית — הם שם בשביל ההגינות והחוק, לא בשביל המכירה.
חשוב להכיר גם את הצד החוקי: לפי חוק הגנת הצרכן, אסור להטעות לגבי קיומו או היקפו של מבצע. בפועל זה אומר שלושה דברים — המחיר המוצג על השלט מחייב בקופה; "מחיר קודם" שמופיע בהשוואה חייב להיות המחיר שנגבה בפועל לפני המבצע; ואם כתבתם תאריכים, מכבדים אותם עד הסוף. התוספת "או עד גמר המלאי — המוקדם מביניהם" מגינה עליכם כשהמלאי אוזל, אבל היא לא תחליף לכמות מלאי סבירה ביחס לפרסום. ושלט של מבצע שהסתיים — מורידים באותו יום.
מיקום וגודל: שלושת המוקדים שעובדים הם חלון הראווה (מכניס לקוחות), המדף ליד המוצר (סוגר את ההחלטה) והקופה (תזכורת אחרונה). הדפיסו A4 למדף ו-A3 לחלון, בניגודיות חזקה — כיתוב כהה על רקע בהיר או להפך — וודאו שמספר ההנחה נקרא מארבעה מטרים. ובמבצע ארוך, החליפו את השלט אם התקמט או דהה: שלט בלוי משדר סחורה בלויה.
שאלות נפוצות
מה הופך שלט מבצע לאפקטיבי?
מוצר אחד, מספר אחד. שלט שמנסה למכור חמישה דברים בבת אחת לא מוכר אף אחד מהם — העין קולטת מילה אחת גדולה ("מבצע!"), מוצר אחד ומספר הנחה אחד בולט. את כל השאר (תוקף, תנאים, כפל מבצעים) כותבים בקטן למטה. כלל זהב: אם אי אפשר לקרוא את השלט תוך שתי שניות מהליכה — הוא עמוס מדי.
האם חובה לכתוב תאריכים על שלט מבצע?
כן, מומלץ מאוד — וזה גם משתלם. מבצע בלי מועד סיום לא מייצר דחיפות, ולקוחות דוחים את הקנייה. מבחינת הדין, חוק הגנת הצרכן אוסר הטעיה לגבי קיומו והיקפו של מבצע: אם כתבתם תאריכים — חובה לכבד אותם, ואם המלאי מוגבל מוסיפים "עד גמר המלאי". אל תשאירו שלט של מבצע שהסתיים — מחיר מוצג מחייב בקופה.
מה כותבים — אחוז הנחה או מחיר חדש?
תלוי במוצר. באחוזים ("30% הנחה") משתמשים כשההנחה משמעותית ועל קטגוריה שלמה; במחיר ("49.90 ₪ במקום 79.90 ₪") כשמדובר במוצר ספציפי — מחיר לפני/אחרי קונקרטי נתפס אמין ומוחשי יותר. שימו לב: כשמציגים "מחיר קודם", הוא חייב להיות המחיר שנגבה בפועל לפני המבצע — מחיר קודם מנופח הוא הטעיה אסורה.
איפה לתלות את שלט המבצע בחנות?
בשלוש נקודות: בחלון הראווה (מושך נכנסים), ליד המוצר עצמו (מסיר ספק), וליד הקופה (מזכיר רגע לפני התשלום). שלט בודד באמצע החנות עובד הכי פחות. הקפידו על ניגודיות חזקה וגודל אות שנקרא משלושה-ארבעה מטרים, ובחלון — תלו בגובה מבט של עובר אורח, לא בגובה הרצפה.
האם מותר לכתוב "עד גמר המלאי" בלי תאריכים?
מותר, אבל פחות מומלץ. "עד גמר המלאי" לבדו לא יוצר דחיפות אמיתית — לקוח לא יודע אם המלאי נגמר מחר או בעוד חודש. השילוב המנצח הוא תאריכים מוגדרים + "או עד גמר המלאי, המוקדם מביניהם": גם דחיפות, גם הגנה מפני מצב שבו המוצר אזל לפני תום המבצע. בכל מקרה, ודאו שכמות המלאי סבירה ביחס לפרסום.
נקודות מפתח
מוצר אחד + מספר אחד = שלט שעובד; שלט עמוס לא נקרא
תאריכי תוקף + "עד גמר המלאי, המוקדם מביניהם" — דחיפות וגם הגנה
מחיר קודם חייב להיות אמיתי — מחיר מנופח הוא הטעיה לפי חוק הגנת הצרכן
תולים בשלוש נקודות: חלון ראווה, ליד המוצר וליד הקופה
הנוסח כאן חינמי — העתקה, הדפסה או הורדה כ-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}); });
})();