Nemocenské pojištění 2025: Vyšší platby i limit pro účast na pojištění a ošetřovné pro víc lidí

6. 11. 2024
Doba čtení: 5 minut

Sdílet

Autor: Depositphotos.com, podle licence: Rights Managed
S novým rokem nastane v oblasti nemocenského pojištění řada změn. Dotknou se OSVČ i zaměstnanců nebo pracovníků na dohody.

Nový rok přinese řadu změn do oblasti nemocenského pojištění. V dnešním článku si je proto shrneme.

Limit pro účast na pojištění

Výše rozhodného příjmu, který u zaměstnanců zakládá povinnou účast na nemocenském a důchodovém pojištění, se v příštím roce zvýší. Změna vyplývá z nové úrovně odhadované průměrné mzdy pro rok 2025, která je ve výši 46 557 Kč.

Z průměrné mzdy totiž vychází i tzv. rozhodný příjem pro účast na nemocenském pojištění, tedy minimální výše sjednaného příjmu, který zakládá účast na nemocenském pojištění.

Zvýšení rozhodného příjmu má ale význam nejen pro účast na nemocenském pojištění. Odvíjí se od něj i účast na pojištění důchodovém.

Hranice pro účast na pojištění se zvyšuje v případě, že jedna desetina součinu všeobecného vyměřovacího základu, který o dva roky předchází danému kalendářnímu roku, a přepočítacího koeficientu pro jeho úpravu (tedy veličiny, které stanovují průměrnou mzdu) je po zaokrouhlení na celou pětistovku (směrem dolů) vyšší než dosud platná částka rozhodného příjmu. 

V takové situaci se pak rozhodný příjem spočte právě jako jedna desetina průměrné mzdy pro daný rok zaokrouhlená na pětistovky dolů.

Protože má průměrná mzda činit 46 557 Kč, vzroste hranice rozhodného příjmu ze současných 4000 Kč na 4500 Kč.

Pro zaměstnané, kteří budou mít příští rok měsíční příjem do 4500 Kč, to tedy znamená, že se nebudou v daném měsíci účastnit nemocenského, a tím ani důchodového pojištění. Pojištěni tedy budou jen v těch měsících, kdy jejich započitatelný měsíční příjem bude aspoň 4500 Kč.

Limit pro účast na nemocenském pojištění se zvýší. Ovlivní to i dohody Přečtěte si také:

Limit pro účast na nemocenském pojištění se zvýší. Ovlivní to i dohody

Zvýšení hranice rozhodného příjmu ovlivní i pravidla aplikovaná u dohody o pracovní činnosti. Tento limit zde určuje výši měsíčních příjmů, od kterých platíte odvody, a v případě nepodepsaného prohlášení k dani také určuje, zda budete odvádět zálohovou daň, nebo daň srážkovou.

Změny u zaměstnávání na dohodu připomínají kovbojku. Co bude platit a co ne? Přečtěte si také:

Změny u zaměstnávání na dohodu připomínají kovbojku. Co bude platit a co ne?

Minimální záloha na nemocenské pojištění pro OSVČ

Minimální měsíční základ pro pojistné na nemocenské pojištění u OSVČ nemůže být nižší než dvojnásobek částky rozhodného příjmu.

Z výše rozhodného příjmu odvodíme i to, že se zvýší také minimální vyměřovací základ u nemocenského pojištění pro OSVČ. Ten činí dvojnásobek rozhodného příjmu (resp. minimální měsíční základ pro pojistné na nemocenské pojištění nemůže být nižší než dvojnásobek částky rozhodné pro účast zaměstnanců na nemocenském pojištění). Pro rok 2024 je ve výši 8000 Kč, a pro příští rok tedy bude ve výši 9000 Kč.

Z minimálního vyměřovacího základu odvodíme minimální zálohu na nemocenské pojištění pro OSVČ (ty mají účast na nemocenském pojištění dobrovolnou). V současné době činí sazba 2,7 %, takže nová výše minimální zálohy bude příští rok 243 Kč.

Zdravotní a sociální pojištění 2025: Jak se zvýší minimální zálohy pro OSVČ? Přečtěte si také:

Zdravotní a sociální pojištění 2025: Jak se zvýší minimální zálohy pro OSVČ?

Krátkodobé ošetřovné i pro OSVČ

OSVČ účastné nemocenského pojištění budou mít od příštího roku také nárok na krátkodobé ošetřovné. Na vybrané dávky nemocenského pojištění od roku 2025 mají dosáhnout také další zaměstnanci. Změny vyplývají z novely zákona o nemocenském pojištění, kterou schválila Sněmovna ve třetím čtení.

V současnosti mají nemocensky pojištěné OSVČ nárok jenom na dlouhodobé ošetřovné. Na to krátkodobé nově vznikne v případě, že v daném okamžiku trvá účast na nemocenském pojištění alespoň tři měsíce přede dnem vzniku potřeby ošetřování nebo přede dnem převzetí tohoto ošetřování. Dále ale bude moci OSVČ toto ošetřovné čerpat, i pokud vznikla účast na pojištění do 8 kalendářních dní od skončení zaměstnání, jež také zakládalo (aspoň v posledních třech měsících) účast na nemocenském pojištění.

Historicky bylo ošetřovné sice poskytováno vždy jen pojištěncům, kteří měli pevně rozvrženu pracovní dobu, ovšem s ohledem na vývoj a proměny společnosti se mění i potřeby a možnosti lidí, na které je nezbytné reagovat. Již mnoho zaměstnanců v pracovním poměru má v současné době možnost využívat flexibilní pracovní dobu, která není pevně rozvržena. Naopak pracovní doba některých zaměstnanců na „dohodu“ nebo OSVČ musí být pevně stanovena, pokud souvisí např. s činností provozovny nebo poskytováním služeb obyvatelstvu (např. kadeřnictví, veterinární ordinace). Není proto důvod, aby uvedeným pojištěncům nevznikal nárok na ošetřovné za dobu, v níž z důvodu určité sociální události nemohou vykonávat samostatnou výdělečnou činnost, vysvětlují autoři návrhu v důvodové zprávě.

Novela má také rozšířit možnost zpětného pojištění osob dobrovolně důchodově pojištěných o bývalé OSVČ pro získání doby pojištění. U OSVČ také dojde ke zohlednění uhrazené pravděpodobné výše pojistného pro budoucí nároky. Zákonem se také změní promlčecí lhůta u dlužného pojistného z 10 let na 6 let a dojde tak ke sjednocení s lhůtou pro placení daní. Doplňuje se i povinnost OSVČ používat datovou schránku, popisuje další novinky redaktorka Dagmar Kučerová na sesterském serveru Podnikatel.cz.

Souhrn změn v nemocenském pojištění od roku 2025 Přečtěte si také:

Souhrn změn v nemocenském pojištění od roku 2025

Nárok vznikne i zahraničním zaměstnancům

Zahraniční zaměstnanec je ten, jehož zaměstnavatel má sídlo v „nesmluvní cizině“ (stát, se kterým ČR nemá uzavřenou smlouvu o sociálním zabezpečení), ale zaměstnanec pro něj přitom pracuje v ČR.

Návrh počítá s tím, že nárok na tuto dávku by získali i zahraniční zaměstnanci, kteří mají, stejně jako OSVČ, účast na nemocenském pojištění dobrovolnou. Vznik nároku na ošetřovné se bude řídit stejným, výše popsaným pravidlem jako u OSVČ.

Pro obě tyto skupiny pojištěnců také bude platit, že si budou moci stanovit výši pojistného na nemocenské pojištění, ale jen v rozmezí minimálního měsíčního vyměřovacího základu a měsíčního vyměřovacího základu pro důchodové pojištění v daném měsíci.

Další změny popisujeme také v souhrnném článku o novinkách v sociálním pojištění

Sociální pojištění 2025: Jaké změny se dotknou OSVČ a zaměstnanců? Přečtěte si také:

Sociální pojištění 2025: Jaké změny se dotknou OSVČ a zaměstnanců?

Získají ho i další zaměstnanci

Na ošetřovné nově dosáhnou také nemocensky pojištění zaměstnanci na dohodu o provedení práce (s příjmem nad stanovenou měsíční hranici pro vznik účasti na pojištění a odvody) a lidé v pracovním poměru nebo na dohodu o pracovní činnosti, pokud jde o tzv. zaměstnání malého rozsahu. Podmínkou pro vznik nároku na dávku je účast na nemocenském pojištění aspoň po tři měsíce před tím, ve kterém vznikla potřeba ošetřování.

Školení pro účetní - podzimní novinky

Zaměstnání malého rozsahu je zaměstnání se sjednaným příjmem do 4000 Kč měsíčně (tzv. rozhodný příjem) nebo s příjmem sjednaným neurčitě či přímo bez sjednaného příjmu. V těchto případech je zaměstnanec nemocensky pojištěn jen v měsících, kdy dosáhl příjmu aspoň 4000 Kč měsíčně, nebo pokud vykonával v daném měsíci u téhož zaměstnavatele více takových zaměstnání a úhrn příjmů dosáhl aspoň rozhodného příjmu. Jak už jsme naznačili výše, limit se příští rok zvýší na 4500 Kč.

Novela také u dlouhodobého ošetřovného zruší podmínku shodného trvalého bydliště v případě ošetřovného u druha a družky nebo podmínku písemného souhlasu ošetřované osoby s poskytováním péče. Předloha přinese změny také u dávky otcovské nebo mateřské.

Na ošetřovné od příštího roku dosáhne více lidí. Budete to i vy? Přečtěte si také:

Na ošetřovné od příštího roku dosáhne více lidí. Budete to i vy?

Jejím cílem je i zrychlení výplat a elektronizace dalších dávek nemocenského pojištění. Podrobněji se elektronizaci opět věnuje Dagmar Kučerová na serveru Podnikatel.cz.

Elektronizace nemocenských dávek se dotkne i jejich příjemců Přečtěte si také:

Elektronizace nemocenských dávek se dotkne i jejich příjemců

'; document.getElementById('preroll-iframe').onload = function () { setupIframe(); } prerollContainer = document.getElementsByClassName('preroll-container-iframe')[0]; } function setupIframe() { prerollDocument = document.getElementById('preroll-iframe').contentWindow.document; let el = prerollDocument.createElement('style'); prerollDocument.head.appendChild(el); el.innerText = "#adContainer>div:nth-of-type(1),#adContainer>div:nth-of-type(1) > iframe { width: 99% !important;height: 99% !important;max-width: 100%;}#videoContent,body{ width:100vw;height:100vh}body{ font-family:'Helvetica Neue',Arial,sans-serif}#videoContent{ overflow:hidden;background:#000}#adMuteBtn{ width:35px;height:35px;border:0;background:0 0;display:none;position:absolute;fill:rgba(230,230,230,1);bottom:20px;right:25px}"; videoContent = prerollDocument.getElementById('contentElement'); videoContent.style.display = 'none'; videoContent.volume = 1; videoContent.muted = false; const playPromise = videoContent.play(); if (playPromise !== undefined) { playPromise.then(function () { console.log('PREROLL sound allowed'); // setUpIMA(true); videoContent.volume = 1; videoContent.muted = false; setUpIMA(); }).catch(function () { console.log('PREROLL sound forbidden'); videoContent.volume = 0; videoContent.muted = true; setUpIMA(); }); } } function setupDimensions() { prerollWidth = Math.min(iinfoPrerollPosition.offsetWidth, 480); prerollHeight = Math.min(iinfoPrerollPosition.offsetHeight, 320); } function setUpIMA() { google.ima.settings.setDisableCustomPlaybackForIOS10Plus(true); google.ima.settings.setLocale('cs'); google.ima.settings.setNumRedirects(10); // Create the ad display container. createAdDisplayContainer(); // Create ads loader. adsLoader = new google.ima.AdsLoader(adDisplayContainer); // Listen and respond to ads loaded and error events. adsLoader.addEventListener( google.ima.AdsManagerLoadedEvent.Type.ADS_MANAGER_LOADED, onAdsManagerLoaded, false); adsLoader.addEventListener( google.ima.AdErrorEvent.Type.AD_ERROR, onAdError, false); // An event listener to tell the SDK that our content video // is completed so the SDK can play any post-roll ads. const contentEndedListener = function () { adsLoader.contentComplete(); }; videoContent.onended = contentEndedListener; // Request video ads. const adsRequest = new google.ima.AdsRequest(); adsRequest.adTagUrl = iinfoVastUrls[iinfoVastUrlIndex]; console.log('Preroll advert: ' + iinfoVastUrls[iinfoVastUrlIndex]); videoContent.muted = false; videoContent.volume = 1; // Specify the linear and nonlinear slot sizes. This helps the SDK to // select the correct creative if multiple are returned. // adsRequest.linearAdSlotWidth = prerollWidth; // adsRequest.linearAdSlotHeight = prerollHeight; adsRequest.nonLinearAdSlotWidth = 0; adsRequest.nonLinearAdSlotHeight = 0; adsLoader.requestAds(adsRequest); } function createAdDisplayContainer() { // We assume the adContainer is the DOM id of the element that will house // the ads. prerollDocument.getElementById('videoContent').style.display = 'none'; adDisplayContainer = new google.ima.AdDisplayContainer( prerollDocument.getElementById('adContainer'), videoContent); } function unmutePrerollAdvert() { adVolume = !adVolume; if (adVolume) { adsManager.setVolume(0.3); prerollDocument.getElementById('adMuteBtn').innerHTML = ''; } else { adsManager.setVolume(0); prerollDocument.getElementById('adMuteBtn').innerHTML = ''; } } function onAdsManagerLoaded(adsManagerLoadedEvent) { // Get the ads manager. const adsRenderingSettings = new google.ima.AdsRenderingSettings(); adsRenderingSettings.restoreCustomPlaybackStateOnAdBreakComplete = true; adsRenderingSettings.loadVideoTimeout = 12000; // videoContent should be set to the content video element. adsManager = adsManagerLoadedEvent.getAdsManager(videoContent, adsRenderingSettings); // Add listeners to the required events. adsManager.addEventListener(google.ima.AdErrorEvent.Type.AD_ERROR, onAdError); adsManager.addEventListener( google.ima.AdEvent.Type.CONTENT_PAUSE_REQUESTED, onContentPauseRequested); adsManager.addEventListener( google.ima.AdEvent.Type.CONTENT_RESUME_REQUESTED, onContentResumeRequested); adsManager.addEventListener( google.ima.AdEvent.Type.ALL_ADS_COMPLETED, onAdEvent); // Listen to any additional events, if necessary. adsManager.addEventListener(google.ima.AdEvent.Type.LOADED, onAdEvent); adsManager.addEventListener(google.ima.AdEvent.Type.STARTED, onAdEvent); adsManager.addEventListener(google.ima.AdEvent.Type.COMPLETE, onAdEvent); playAds(); } function playAds() { // Initialize the container. Must be done through a user action on mobile // devices. videoContent.load(); adDisplayContainer.initialize(); // setupDimensions(); try { // Initialize the ads manager. Ad rules playlist will start at this time. adsManager.init(1920, 1080, google.ima.ViewMode.NORMAL); // Call play to start showing the ad. Single video and overlay ads will // start at this time; the call will be ignored for ad rules. adsManager.start(); // window.addEventListener('resize', function (event) { // if (adsManager) { // setupDimensions(); // adsManager.resize(prerollWidth, prerollHeight, google.ima.ViewMode.NORMAL); // } // }); } catch (adError) { // An error may be thrown if there was a problem with the VAST response. // videoContent.play(); } } function onAdEvent(adEvent) { const ad = adEvent.getAd(); console.log('Preroll event: ' + adEvent.type); switch (adEvent.type) { case google.ima.AdEvent.Type.LOADED: if (!ad.isLinear()) { videoContent.play(); } prerollDocument.getElementById('adContainer').style.width = '100%'; prerollDocument.getElementById('adContainer').style.maxWidth = '640px'; prerollDocument.getElementById('adContainer').style.height = '360px'; break; case google.ima.AdEvent.Type.STARTED: window.addEventListener('scroll', onActiveView); if (ad.isLinear()) { intervalTimer = setInterval( function () { // Example: const remainingTime = adsManager.getRemainingTime(); // adsManager.pause(); }, 300); // every 300ms } prerollDocument.getElementById('adMuteBtn').style.display = 'block'; break; case google.ima.AdEvent.Type.ALL_ADS_COMPLETED: if (ad.isLinear()) { clearInterval(intervalTimer); } if (prerollLastError === 303) { playYtVideo(); } break; case google.ima.AdEvent.Type.COMPLETE: if (ad.isLinear()) { clearInterval(intervalTimer); } playYtVideo(); break; } } function onAdError(adErrorEvent) { console.log(adErrorEvent.getError()); prerollLastError = adErrorEvent.getError().getErrorCode(); if (!loadNext()) { playYtVideo(); } } function loadNext() { iinfoVastUrlIndex++; if (iinfoVastUrlIndex < iinfoVastUrls.length) { iinfoPrerollPosition.remove(); playPrerollAd(); } else { return false; } adVolume = 1; return true; } function onContentPauseRequested() { videoContent.pause(); } function onContentResumeRequested() { videoContent.play(); } function onActiveView() { if (prerollContainer) { const containerOffset = prerollContainer.getBoundingClientRect(); const windowHeight = window.innerHeight; if (containerOffset.top < windowHeight/1 && containerOffset.bottom > 0.0) { if (prerollPaused) { adsManager.resume(); prerollPaused = false; } return true; } else { if (!prerollPaused) { adsManager.pause(); prerollPaused = true; } } } return false; } function playYtVideo() { iinfoPrerollPosition.remove(); youtubeIframe.style.display = 'block'; youtubeIframe.src += '&autoplay=1&mute=1'; } }
Upozorníme vás na články, které by vám neměly uniknout (maximálně 2x týdně).
'; document.getElementById('outstream-iframe').onload = function () { setupIframe(); } replayScreen = document.getElementById('iinfoOutstreamReplay'); iinfoOutstreamPosition = document.getElementById('iinfoOutstreamPosition'); outstreamContainer = document.getElementsByClassName('outstream-container')[0]; setupReplayScreen(); } function setupIframe() { outstreamDocument = document.getElementById('outstream-iframe').contentWindow.document; let el = outstreamDocument.createElement('style'); outstreamDocument.head.appendChild(el); el.innerText = "#adContainer>div:nth-of-type(1),#adContainer>div:nth-of-type(1) > iframe { width: 99% !important;height: 99% !important;max-width: 100%;}#videoContent,body{ width:100vw;height:100vh}body{ font-family:'Helvetica Neue',Arial,sans-serif}#videoContent{ overflow:hidden;background:#000}#adMuteBtn{ width:35px;height:35px;border:0;background:0 0;display:none;position:absolute;fill:rgba(230,230,230,1);bottom:-5px;right:25px}"; videoContent = outstreamDocument.getElementById('contentElement'); videoContent.style.display = 'none'; videoContent.volume = 1; videoContent.muted = false; if ( location.href.indexOf('rejstriky.finance.cz') !== -1 || location.href.indexOf('finance-rejstrik') !== -1 || location.href.indexOf('firmy.euro.cz') !== -1 || location.href.indexOf('euro-rejstrik') !== -1 || location.href.indexOf('/rejstrik/') !== -1 || location.href.indexOf('/rejstrik-firem/') !== -1) { outstreamDirectPlayed = true; soundAllowed = true; iinfoVastUrlIndex = 0; } if (!outstreamDirectPlayed) { console.log('OUTSTREAM direct'); setUpIMA(true); } else { if (soundAllowed) { const playPromise = videoContent.play(); if (playPromise !== undefined) { playPromise.then(function () { console.log('OUTSTREAM sound allowed'); setUpIMA(false); }).catch(function () { console.log('OUTSTREAM sound forbidden'); renderBanner(); }); } } else { renderBanner(); } } } function getWrapper() { let articleWrapper = document.querySelector('.rs-outstream-placeholder'); // Outstream Placeholder from RedSys manipulation if (articleWrapper && articleWrapper.style.display !== 'block') { articleWrapper.innerHTML = ""; articleWrapper.style.display = 'block'; } // Don't render OutStream on homepages if (articleWrapper === null) { if (document.querySelector('body.p-index')) { return null; } } if (articleWrapper === null) { articleWrapper = document.getElementById('iinfo-outstream'); } if (articleWrapper === null) { articleWrapper = document.querySelector('.layout-main__content .detail__article p:nth-of-type(6)'); } if (articleWrapper === null) { // Euro, Autobible, Zdravi articleWrapper = document.querySelector('.o-article .o-article__text p:nth-of-type(6)'); } if (articleWrapper === null) { articleWrapper = document.getElementById('sidebar'); } if (!articleWrapper) { console.error("Outstream wrapper of article was not found."); } return articleWrapper; } function setupDimensions() { outstreamWidth = Math.min(iinfoOutstreamPosition.offsetWidth, 480); outstreamHeight = Math.min(iinfoOutstreamPosition.offsetHeight, 320); } /** * Sets up IMA ad display container, ads loader, and makes an ad request. */ function setUpIMA(direct) { google.ima.settings.setDisableCustomPlaybackForIOS10Plus(true); google.ima.settings.setLocale('cs'); google.ima.settings.setNumRedirects(10); // Create the ad display container. createAdDisplayContainer(); // Create ads loader. adsLoader = new google.ima.AdsLoader(adDisplayContainer); // Listen and respond to ads loaded and error events. adsLoader.addEventListener( google.ima.AdsManagerLoadedEvent.Type.ADS_MANAGER_LOADED, onAdsManagerLoaded, false); adsLoader.addEventListener( google.ima.AdErrorEvent.Type.AD_ERROR, onAdError, false); // An event listener to tell the SDK that our content video // is completed so the SDK can play any post-roll ads. const contentEndedListener = function () { adsLoader.contentComplete(); }; videoContent.onended = contentEndedListener; // Request video ads. const adsRequest = new google.ima.AdsRequest(); if (direct) { adsRequest.adTagUrl = directVast; console.log('Outstream DIRECT CAMPAING advert: ' + directVast); videoContent.muted = true; videoContent.volume = 0; outstreamDirectPlayed = true; } else { adsRequest.adTagUrl = iinfoVastUrls[iinfoVastUrlIndex]; console.log('Outstream advert: ' + iinfoVastUrls[iinfoVastUrlIndex]); videoContent.muted = false; videoContent.volume = 1; } // Specify the linear and nonlinear slot sizes. This helps the SDK to // select the correct creative if multiple are returned. // adsRequest.linearAdSlotWidth = outstreamWidth; // adsRequest.linearAdSlotHeight = outstreamHeight; adsRequest.nonLinearAdSlotWidth = 0; adsRequest.nonLinearAdSlotHeight = 0; adsLoader.requestAds(adsRequest); } function setupReplayScreen() { replayScreen.addEventListener('click', function () { iinfoOutstreamPosition.remove(); iinfoVastUrlIndex = 0; outstreamInit(); }); } /** * Sets the 'adContainer' div as the IMA ad display container. */ function createAdDisplayContainer() { // We assume the adContainer is the DOM id of the element that will house // the ads. outstreamDocument.getElementById('videoContent').style.display = 'none'; adDisplayContainer = new google.ima.AdDisplayContainer( outstreamDocument.getElementById('adContainer'), videoContent); } function unmuteAdvert() { adVolume = !adVolume; if (adVolume) { adsManager.setVolume(0.3); outstreamDocument.getElementById('adMuteBtn').innerHTML = ''; } else { adsManager.setVolume(0); outstreamDocument.getElementById('adMuteBtn').innerHTML = ''; } } /** * Loads the video content and initializes IMA ad playback. */ function playAds() { // Initialize the container. Must be done through a user action on mobile // devices. videoContent.load(); adDisplayContainer.initialize(); // setupDimensions(); try { // Initialize the ads manager. Ad rules playlist will start at this time. adsManager.init(1920, 1080, google.ima.ViewMode.NORMAL); // Call play to start showing the ad. Single video and overlay ads will // start at this time; the call will be ignored for ad rules. adsManager.start(); // window.addEventListener('resize', function (event) { // if (adsManager) { // setupDimensions(); // adsManager.resize(outstreamWidth, outstreamHeight, google.ima.ViewMode.NORMAL); // } // }); } catch (adError) { // An error may be thrown if there was a problem with the VAST response. // videoContent.play(); } } /** * Handles the ad manager loading and sets ad event listeners. * @param { !google.ima.AdsManagerLoadedEvent } adsManagerLoadedEvent */ function onAdsManagerLoaded(adsManagerLoadedEvent) { // Get the ads manager. const adsRenderingSettings = new google.ima.AdsRenderingSettings(); adsRenderingSettings.restoreCustomPlaybackStateOnAdBreakComplete = true; adsRenderingSettings.loadVideoTimeout = 12000; // videoContent should be set to the content video element. adsManager = adsManagerLoadedEvent.getAdsManager(videoContent, adsRenderingSettings); // Add listeners to the required events. adsManager.addEventListener(google.ima.AdErrorEvent.Type.AD_ERROR, onAdError); adsManager.addEventListener( google.ima.AdEvent.Type.CONTENT_PAUSE_REQUESTED, onContentPauseRequested); adsManager.addEventListener( google.ima.AdEvent.Type.CONTENT_RESUME_REQUESTED, onContentResumeRequested); adsManager.addEventListener( google.ima.AdEvent.Type.ALL_ADS_COMPLETED, onAdEvent); // Listen to any additional events, if necessary. adsManager.addEventListener(google.ima.AdEvent.Type.LOADED, onAdEvent); adsManager.addEventListener(google.ima.AdEvent.Type.STARTED, onAdEvent); adsManager.addEventListener(google.ima.AdEvent.Type.COMPLETE, onAdEvent); playAds(); } /** * Handles actions taken in response to ad events. * @param { !google.ima.AdEvent } adEvent */ function onAdEvent(adEvent) { // Retrieve the ad from the event. Some events (for example, // ALL_ADS_COMPLETED) don't have ad object associated. const ad = adEvent.getAd(); console.log('Outstream event: ' + adEvent.type); switch (adEvent.type) { case google.ima.AdEvent.Type.LOADED: // This is the first event sent for an ad - it is possible to // determine whether the ad is a video ad or an overlay. if (!ad.isLinear()) { // Position AdDisplayContainer correctly for overlay. // Use ad.width and ad.height. videoContent.play(); } outstreamDocument.getElementById('adContainer').style.width = '100%'; outstreamDocument.getElementById('adContainer').style.maxWidth = '640px'; outstreamDocument.getElementById('adContainer').style.height = '360px'; break; case google.ima.AdEvent.Type.STARTED: window.addEventListener('scroll', onActiveView); // This event indicates the ad has started - the video player // can adjust the UI, for example display a pause button and // remaining time. if (ad.isLinear()) { // For a linear ad, a timer can be started to poll for // the remaining time. intervalTimer = setInterval( function () { // Example: const remainingTime = adsManager.getRemainingTime(); // adsManager.pause(); }, 300); // every 300ms } outstreamDocument.getElementById('adMuteBtn').style.display = 'block'; break; case google.ima.AdEvent.Type.ALL_ADS_COMPLETED: if (ad.isLinear()) { clearInterval(intervalTimer); } if (outstreamLastError === 303) { if (isBanner) { renderBanner(); } else { replayScreen.style.display = 'flex'; } } break; case google.ima.AdEvent.Type.COMPLETE: // This event indicates the ad has finished - the video player // can perform appropriate UI actions, such as removing the timer for // remaining time detection. if (ad.isLinear()) { clearInterval(intervalTimer); } if (isBanner) { renderBanner(); } else { replayScreen.style.display = 'flex'; } break; } } /** * Handles ad errors. * @param { !google.ima.AdErrorEvent } adErrorEvent */ function onAdError(adErrorEvent) { // Handle the error logging. console.log(adErrorEvent.getError()); outstreamLastError = adErrorEvent.getError().getErrorCode(); if (!loadNext()) { renderBanner(); } } function renderBanner() { if (isBanner) { console.log('Outstream: Render Banner'); iinfoOutstreamPosition.innerHTML = ""; iinfoOutstreamPosition.style.height = "330px"; iinfoOutstreamPosition.appendChild(bannerDiv); } else { console.log('Outstream: Banner is not set'); } } function loadNext() { iinfoVastUrlIndex++; if (iinfoVastUrlIndex < iinfoVastUrls.length) { iinfoOutstreamPosition.remove(); outstreamInit(); } else { return false; } adVolume = 1; return true; } /** * Pauses video content and sets up ad UI. */ function onContentPauseRequested() { videoContent.pause(); // This function is where you should setup UI for showing ads (for example, // display ad timer countdown, disable seeking and more.) // setupUIForAds(); } /** * Resumes video content and removes ad UI. */ function onContentResumeRequested() { videoContent.play(); // This function is where you should ensure that your UI is ready // to play content. It is the responsibility of the Publisher to // implement this function when necessary. // setupUIForContent(); } function onActiveView() { if (outstreamContainer) { const containerOffset = outstreamContainer.getBoundingClientRect(); const windowHeight = window.innerHeight; if (containerOffset.top < windowHeight/1 && containerOffset.bottom > 0.0) { if (outstreamPaused) { adsManager.resume(); outstreamPaused = false; } return true; } else { if (!outstreamPaused) { adsManager.pause(); outstreamPaused = true; } } } return false; } let outstreamInitInterval; if (typeof cpexPackage !== "undefined") { outstreamInitInterval = setInterval(tryToInitializeOutstream, 100); } else { const wrapper = getWrapper(); if (wrapper) { let outstreamInitialized = false; window.addEventListener('scroll', () => { if (!outstreamInitialized) { const containerOffset = wrapper.getBoundingClientRect(); const windowHeight = window.innerHeight; if (containerOffset.top < windowHeight / 1 && containerOffset.bottom > 0.0) { outstreamInit(); outstreamInitialized = true; } } }); } } function tryToInitializeOutstream() { const wrapper = getWrapper(); if (wrapper) { const containerOffset = wrapper.getBoundingClientRect(); const windowHeight = window.innerHeight; if (containerOffset.top < windowHeight / 1 && containerOffset.bottom > 0.0) { if (cpexPackage.adserver.displayed) { clearInterval(outstreamInitInterval); outstreamInit(); } } } else { clearInterval(outstreamInitInterval); } } }
OSZAR »