Marlins reflect on childhood experiences as multi-sport athletes


Marlins reflect on childhood experiences as multi-sport athletes | FOX Sports

‘, ‘‘, ‘See Full Coverage’, ‘‘, ‘

‘, ‘close‘, ‘

‘, ”, ”]; if (!isSmallContainer) { var flags = [‘

‘, ‘

‘, ‘‘, ‘

‘, ‘

vs

‘, ‘

‘, ‘‘, ‘

‘, ‘

‘].join(”); endcardLayout.splice(2, 0, flags); } endcardLayout = endcardLayout.join(”); playerElem.insertAdjacentHTML(‘afterend’, endcardLayout); var endcardElem = document.getElementById(endcardLayoutId); var endcardCloseElem = document.getElementById(endcardLayoutCloseId); var endcardFullCavElem = document.getElementById(endcardFullCavId); var seconds = 0; var timeInterval = setInterval(function () { if (seconds === 9) { endcardCloseClick(); return; } seconds++; }, 1000); var endacardFullCavClick = function endacardFullCavClick() { return window.open(fullCoverageUrl, target); }; if (!isEmbed) { endcardFullCavElem.addEventListener(‘click’, endacardFullCavClick); } var endcardCloseClick = function endcardCloseClick(e) { endcardCloseElem.removeEventListener(‘click’, endcardCloseClick); !isEmbed && endcardFullCavElem.removeEventListener(‘click’, endacardFullCavClick); clearInterval(timeInterval); endcardElem.remove(); _FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_0__[“default”].dispatchEvent(‘onForcePlay’, { player: data.player }); }; endcardCloseElem.addEventListener(‘click’, endcardCloseClick); } }]); return FsVideoWcEndcard;
}(); /* harmony default export */ __webpack_exports__[“default”] = (new FsVideoWcEndcard()); /***/ }), /***/ “./assets/components/platformPlayer/Pinner.js”:
/*!****************************************************!*\ !*** ./assets/components/platformPlayer/Pinner.js ***! \****************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) { “use strict”;
__webpack_require__.r(__webpack_exports__);
/* harmony import */ var _components_fsUtils_Viewports__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../components/fsUtils/Viewports */ “./assets/components/fsUtils/Viewports.js”);
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(“Cannot call a class as a function”); } } function _defineProperties(target, props) { for (var i = 0; i 0) { while (i–) { var el = arr[i]; if (el.elem === ‘Video’ + vid.id || el.elemId === ‘Video’ + vid.id) { return true; } } } return false; } }, { key: “loadVideos”, value: function loadVideos(Player, videoElementsData) { var sendPageView = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; var context = this; var videos = videoElementsData || context.getVideoElementsData(); if (videos.length > 0) { videos.map(function (videoData) { if (!window.fngPlayers) window.fngPlayers = []; if (!context.ArrayContainsVideo(window.fngPlayers, videoData)) { Object(_foxdcg_fs_segment_analytics__WEBPACK_IMPORTED_MODULE_3__[“getAuthData”])().then(function (res) { videoData.auth = res; var videoPlayer = new _components_jw_player_JWPlayer__WEBPACK_IMPORTED_MODULE_1__[“default”](Player, videoData); videoData.sendPageView = sendPageView; window.fngPlayers.push(videoPlayer); }); } }); } } }, { key: “loadPlatformVideos”, value: function loadPlatformVideos(FDM_Player, videoElementsData) { var sendPageView = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; var context = this; var videos = videoElementsData || context.getVideoElementsData(); if (videos.length > 0) { videos.map(function (videoData) { if (!window.fdmPlayer) window.fdmPlayer = []; if (!context.ArrayContainsVideo(window.fdmPlayer, videoData)) { var videoPlayer = new _fsVideo__WEBPACK_IMPORTED_MODULE_0__[“default”](); videoData.sendPageView = sendPageView; videoPlayer.initializeFSPlayer(videoData, FDM_Player); window.fdmPlayer.push(videoPlayer.player); } }); } } }, { key: “loadScript”, value: function loadScript(callback, videoElementsData, sendPageView) { if (typeof FDM_Player === ‘function’) { callback(FDM_Player, videoElementsData, sendPageView); } else { // Create a new script and setup the basics. var script = document.createElement(“script”); var firstScript = document.getElementsByTagName(‘script’)[0]; script.async = false; script.src = function (loc) { var metaEl = document.querySelector(‘[fs-prop=”video”]’); var scripturl = metaEl && metaEl.getAttribute(“script”); if (scripturl === null) { scripturl = ‘//player.foxdcg.com/sports’; } if (window.location.search.indexOf(‘debugVideoPlayer’) > -1) { if (scripturl.indexOf(‘?’) > -1) scripturl = scripturl + ‘&debug=all’;else scripturl = scripturl + ‘?debug=all’; } return scripturl; }(window.location); // Handle the case where an optional callback was passed in. script.onload = function () { if (typeof FDM_Player === ‘function’) { callback(FDM_Player, videoElementsData, sendPageView); } else if (typeof FNGPlayer.default === ‘function’) { callback(FNGPlayer, videoElementsData, sendPageView); } else { throw new Error(‘FDM_Player failed to load’); } // Clear it out to avoid getting called more than once or any memory leaks. script.onload = script.onreadystatechange = undefined; }.bind(this); script.onreadystatechange = function () { if (“loaded” === script.readyState || “complete” === script.readyState) { script.onload(); } }; //Attach the script tag to the page (before the first script) so the magic can happen. firstScript.parentNode.insertBefore(script, firstScript); } return this; } }]); return criticalVideoLoader;
}(); window.criticalVideoLoader = new criticalVideoLoader();
/* harmony default export */ __webpack_exports__[“default”] = (criticalVideoLoader); /***/ }), /***/ “./assets/components/platformPlayer/fsVideo.js”:
/*!*****************************************************!*\ !*** ./assets/components/platformPlayer/fsVideo.js ***! \*****************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) { “use strict”;
__webpack_require__.r(__webpack_exports__);
/* harmony import */ var _Pinner__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Pinner */ “./assets/components/platformPlayer/Pinner.js”);
/* harmony import */ var _components_fsUtils_TrackingUtils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../components/fsUtils/TrackingUtils */ “./assets/components/fsUtils/TrackingUtils.js”);
/* harmony import */ var _FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./FsVideoEventHandler */ “./assets/components/platformPlayer/FsVideoEventHandler.js”);
/* harmony import */ var _components_fsUtils_Viewports__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../components/fsUtils/Viewports */ “./assets/components/fsUtils/Viewports.js”);
/* harmony import */ var _fsUtils_fsPlayerUtils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../fsUtils/fsPlayerUtils */ “./assets/components/fsUtils/fsPlayerUtils.js”);
function _typeof(obj) { if (typeof Symbol === “function” && typeof Symbol.iterator === “symbol”) { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === “function” && obj.constructor === Symbol && obj !== Symbol.prototype ? “symbol” : typeof obj; }; } return _typeof(obj); } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(“Cannot call a class as a function”); } } function _defineProperties(target, props) { for (var i = 0; i .trending-title’); _this.urlQuery = location.search; _this.isModalEnabled = document.body.classList.contains(‘video-modal’); _this.bodySection = document.querySelector(‘.body-content’); _this.isSectionFront = document.body.classList.contains(‘single-fox_sectionfront’); _this.isCollectionSF = !!document.querySelector(‘.collections-section-front’); _this.isMediaHub = document.body.classList.contains(‘single-fox_media_hub’); _this.isBB = _this.bodySection ? _this.bodySection.classList.contains(‘body-content-big-board’) : false; _this.viewports = new _components_fsUtils_Viewports__WEBPACK_IMPORTED_MODULE_3__[“default”](); _this.currentUrl = location.href; if (trendingTitleEl != null) { _this.collectionOneUtm.term = _components_fsUtils_TrackingUtils__WEBPACK_IMPORTED_MODULE_1__[“default”].formatStringAsSlug(trendingTitleEl.innerHTML); } return _this; } _createClass(FsVideo, [{ key: “initPlayer”, value: function initPlayer(playerId, playerData) { //init player var player = new FDM_Player(playerId); // set player settings directly player.autoplay = playerData.autoplay; player.share_embed = playerData.share_embed; player.endcard = playerData.endcard; player.endcard_feed = playerData.endcard_feed; player.endcard_countdown = playerData.endcard_countdown; player.releaseURL = playerData.releaseURL; player.tag = playerData.tag ? playerData.tag : ”; player.title = playerData.title ? playerData.title : ”; player.vid = playerData.vid ? playerData.vid : null; player.url = playerData.url ? playerData.url : ”; player.endcard_autoadvance = playerData.endcard_autoadvance ? playerData.endcard_autoadvance : false; player.siteSection = playerData.siteSection ? playerData.siteSection : ”; if (playerData.categoryName) player.categoryName = playerData.categoryName; if (playerData.adpol) player.freewheel_keyvalue = encodeURIComponent(‘adpol=’ + playerData.adpol); if (playerData.wcEndcard) player.wcEndcard = playerData.wcEndcard; return player; } /** * gets player data from url */ }, { key: “getPlayerDataFromUrl”, value: function getPlayerDataFromUrl() { var urlQuery = location.search; var videourl = Object(_fsUtils_fsPlayerUtils__WEBPACK_IMPORTED_MODULE_4__[“getParam”])(urlQuery, “videourl”); var autoplay = Object(_fsUtils_fsPlayerUtils__WEBPACK_IMPORTED_MODULE_4__[“getParam”])(urlQuery, “autoplay”); var share = Object(_fsUtils_fsPlayerUtils__WEBPACK_IMPORTED_MODULE_4__[“getParam”])(urlQuery, “share”); var endcard_feed = Object(_fsUtils_fsPlayerUtils__WEBPACK_IMPORTED_MODULE_4__[“getParam”])(urlQuery, “endcard_feed”); var siteSection = Object(_fsUtils_fsPlayerUtils__WEBPACK_IMPORTED_MODULE_4__[“getParam”])(urlQuery, “siteSection”); var category = Object(_fsUtils_fsPlayerUtils__WEBPACK_IMPORTED_MODULE_4__[“getParam”])(urlQuery, “category”); var endcard_autoadvance = Object(_fsUtils_fsPlayerUtils__WEBPACK_IMPORTED_MODULE_4__[“getParam”])(urlQuery, “endcard_autoadvance”); var url = Object(_fsUtils_fsPlayerUtils__WEBPACK_IMPORTED_MODULE_4__[“getParam”])(urlQuery, “url”); var isAmp = Object(_fsUtils_fsPlayerUtils__WEBPACK_IMPORTED_MODULE_4__[“getParam”])(urlQuery, “amp”); var host = location.protocol + ‘//’ + location.hostname + ‘/’; var deepLink = “http://www.foxsports.com/” + category + ‘/video/’; var iframeurl = host + ‘video-embed?videourl=’ + videourl + ‘&share=’ + share + ‘&siteSection=’ + siteSection + ‘&autoplay=’ + autoplay + ‘&category=’ + category + ‘&endcard_autoadvance=’ + endcard_autoadvance + (endcard_feed ? ‘&endcard_feed=’ + endcard_feed : ”); var isWCEndacrd = Object(_fsUtils_fsPlayerUtils__WEBPACK_IMPORTED_MODULE_4__[“getParam”])(urlQuery, “wcEndcard”) === ‘true’; var vid = decodeURIComponent(url).split(‘/’).pop(); var wcEndcard = false; if (isWCEndacrd) { wcEndcard = { homeTeamCountryImgSrc: decodeURIComponent(Object(_fsUtils_fsPlayerUtils__WEBPACK_IMPORTED_MODULE_4__[“getParam”])(urlQuery, “homeTeam”)), awayTeamCountryImgSrc: decodeURIComponent(Object(_fsUtils_fsPlayerUtils__WEBPACK_IMPORTED_MODULE_4__[“getParam”])(urlQuery, “awayTeam”)), fullCoverageUrl: “https://www.foxsports.com” + decodeURIComponent(Object(_fsUtils_fsPlayerUtils__WEBPACK_IMPORTED_MODULE_4__[“getParam”])(urlQuery, “fcUrl”)) }; } return { releaseURL: decodeURIComponent(videourl), autoplay: autoplay, share: share, endcard_feed: decodeURIComponent(endcard_feed), isAmp: isAmp, siteSection: siteSection, category: category, endcard_autoadvance: endcard_autoadvance, url: url, deeplink: deepLink, iframeurl: iframeurl, vid: vid, wcEndcard: wcEndcard }; } /** * initializes FS video embed player * @param {*} data – player data */ }, { key: “initializeFSPlayer”, value: function initializeFSPlayer(data) { this.playerData = this.preparePlayerData(data); this.elId = this.getPlayerElement(this.playerData).id; this.el = document.getElementById(this.elId); this.utmObj = {}; //check if player has its own utm params if (typeof this.playerData.utm !== ‘undefined’) { this.utmObj = _components_fsUtils_TrackingUtils__WEBPACK_IMPORTED_MODULE_1__[“default”].getUtmObj(this.playerData.utm); } else { this.utmObj = _components_fsUtils_TrackingUtils__WEBPACK_IMPORTED_MODULE_1__[“default”].getUtmObj(_components_fsUtils_TrackingUtils__WEBPACK_IMPORTED_MODULE_1__[“default”].getUtmParams(this.playerData.pageName)); } //init player this.player = this.initPlayer(this.elId, this.playerData); this.isPlaying = false; this.isPaused = false; this.isFullScreen = false; //init an empty set that will keep track all the videos that have been played this.playedVideos = new Set(); this.sendPageView = data.sendPageView; // set player settings using functions this.setPlayerShare(); this.setPlayerEvents(); document.addEventListener(‘visibilitychange’, this.onVisibilityChange.bind(this)); //start pinning from Pinner.js. Dont enable on iphone !this.isIphone() && this.startPinning(); this.saveToPlayerCollection(); } /** * initializes FS video embed player */ }, { key: “initializeFSEmbedPlayer”, value: function initializeFSEmbedPlayer() { //init player var playerData = this.getPlayerDataFromUrl(); this.player = this.initPlayer(“player”, playerData); this.utmObj = _components_fsUtils_TrackingUtils__WEBPACK_IMPORTED_MODULE_1__[“default”].getUtmObj({ ‘medium’: playerData.isAmp ? “amp_video_player” : “embed_video_player”, ‘source’: ’embed-video-page’, ‘content’: playerData.category, ‘term’: ” }); if (playerData.share) { this.player.share = { deeplinkfunc: function deeplinkfunc(z, A) { return playerData.deeplink + z; }, embed: true, iframeurl: playerData.iframeurl, emailscript: “”, sharetargets: [{ name: “Facebook”, image: “”, urlTemplate: “http://www.facebook.com/sharer.php?u=” }, { name: “Twitter”, image: “”, urlTemplate: “http://twitter.com/share?url=&text=” }, { name: “googleplus”, image: “”, urlTemplate: “https://plus.google.com/share?url=” }, { name: “reddit”, image: “”, urlTemplate: “http://reddit.com/submit?url=” }, { name: “stumbleupon”, image: “”, urlTemplate: “http://www.stumbleupon.com/submit?url=” }], omitSeries: true }; } this.setPlayerEvents(); } }, { key: “isIphone”, value: function isIphone() { return /iPhone/i.test(navigator.userAgent); } //save instances of player to collection }, { key: “saveToPlayerCollection”, value: function saveToPlayerCollection() { window.fsPlayerCollection = window.fsPlayerCollection || []; window.fsPlayerCollection.push(this); } /** * @desc pause other players in the page triggered by setPlay method */ }, { key: “pauseOtherPlayers”, value: function pauseOtherPlayers() { var _this2 = this; try { //returns all players except the current player the user is interacting with var players = window.fsPlayerCollection.filter(function (fsPlayer) { return fsPlayer.elId !== _this2.elId; }); } catch (e) { console.log(“VIDEO: error – “, e); } if (players.length > 0) { players.forEach(function (fsPlayer) { fsPlayer.isPinned && fsPlayer.unpin(fsPlayer.parentEl); fsPlayer.isPlaying = false; fsPlayer.player.pause(); }); } } }, { key: “pauseAllPlayers”, value: function pauseAllPlayers() { var players = window.fdmPlayer; try { players.forEach(function (player, index) { if (index !== players.length – 1) { player.releaseUrl = ”; player.releaseURL = ”; player.setReleaseCall(”); player.pause(); } }); } catch (e) { console.log(‘something went wrong’, e); } } }, { key: “onVisibilityChange”, value: function onVisibilityChange() { document.hidden && this.player.pause(); } /** * @desc event triggered on player OnMediaStart and OnMediaUnpause events * @param isAd True or False for e.data.baseClip.isAd that is passed from player OnMediaStart and OnMediaUnpause events * @returns {FsVideo} */ }, { key: “setPlay”, value: function setPlay(isAd) { this.isPlaying = true; this.isPaused = false; if (window.fsPlayerCollection) { this.pauseOtherPlayers(); } _components_fsUtils_TrackingUtils__WEBPACK_IMPORTED_MODULE_1__[“default”].sendPlay(isAd, this.player, this.utmObj); return this; } }, { key: “pause”, value: function pause() { this.player.pause(true); } /** * @desc event triggered on player OnMediaStart event * @returns {FsVideo} */ }, { key: “setPause”, value: function setPause(isAd) { this.isPlaying = false; this.isPaused = true; _components_fsUtils_TrackingUtils__WEBPACK_IMPORTED_MODULE_1__[“default”].sendPause(isAd, this.player, this.utmObj); return this; } /* get page type of where the video player is set/loaded */ }, { key: “getPageType”, value: function getPageType(playerData) { /* first 3 conditions supercedes what is set on the video config’s “pageName” which, from testing, doesn’t reflect the actual page type of where the video is set. */ if (this.isSectionFront) return ‘section-front’; // if page is section front if (this.isMediaHub) return ‘media-hub’; // if page is media hub // if page isn’t section front or media hub, but the url of the post passed on the video config is a story if (playerData.url.indexOf(‘\/story\/’) > -1) return ‘story-page’; // everything else aside from the conditions above are assumed var pageName = playerData.pageName.split(/\:/); return pageName[pageName.length – 1].replace(/ /g, “-“); } /** * send page view to Parsely on video player. We only send the page view on first click on section front pages. * We send page view only if the video ID is in the video player url that is available to us */ }, { key: “sendParselyTracking”, value: function sendParselyTracking() { //add player video id into the set if it is not in the set so that it is only tracked on the first click on that video var vid = this.player.videoinfo.id ? this.player.videoinfo.id : this.player.vid; if (_components_fsUtils_TrackingUtils__WEBPACK_IMPORTED_MODULE_1__[“default”].isTrackable(vid, this.currentUrl) && !this.playedVideos.has(vid)) { // update player url if (vid !== this.player.vid) { this.player.url = this.getVideoUrl(this.player.videoinfo.id); this.player.vid = vid; } if (typeof PARSELY !== ‘undefined’ && _typeof(PARSELY.beacon) === ‘object’ && typeof PARSELY.beacon.trackPageView === ‘function’) { // set up for UTM Campaign tracking – FSCOM-12271 var metadata = _components_fsUtils_TrackingUtils__WEBPACK_IMPORTED_MODULE_1__[“default”].getTrackingMeta(this.player); // failover for utm_content (start with defined utmObj, metadata, videoinfo, categoryName) this.utmObj.utm_content = this.utmObj.utm_content || metadata.section || this.player.videoinfo.primary || this.playerData.categoryName; var trackingObj = { url: _components_fsUtils_TrackingUtils__WEBPACK_IMPORTED_MODULE_1__[“default”].addTrackingQuery(this.utmObj, this.player.url), // URL to be tracked urlref: location.href, js: 1 // flag indicating that this is a dynamic event, keep it “1” }; // TEMP(FOR STG/PROD): bug found on homepage “fox-five” tracking, but can’t recreate on DEV env // need reports of these two objects. window[‘utmProdTest’] = { ‘utmObj’: this.utmObj, ‘trackingObj’: trackingObj }; PARSELY.beacon.trackPageView(trackingObj); } this.playedVideos.add(this.player.videoinfo.id); } } }, { key: “setPlayerEvents”, value: function setPlayerEvents() { var _this3 = this; var player = this.player; if (this.playerData) { var playerData = this.playerData; } player.start = function () { performance.mark(“fs-videoplayer-startplayer”); return player.bind(), player; }; if (this.playerData) { if (typeof this.playerData.onMediaPause === ‘function’) { player.addEventListener(‘OnMediaPause’, function (e) { performance.mark(“fs-videoplayer-onmediapause”); playerData.onMediaPause(null, e, player); }); } } //check is free wheel enabled if (playerData && playerData.isFwEnabled == true) { player = this.setSiteSection(player, playerData.siteSection); } /** * @desc Fires when playback of the current clip is paused. */ player.addEventListener(‘OnMediaPause’, function (e) { if (this.player.wcEndcard) { _FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_2__[“default”].dispatchEvent(_FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_2__[“fsEvents”].videoPause, { e: e, player: this.player }); } try { //passing video clip OnMediaPause to check if it is an ad when setting video pause this.setPause(e.data.clip.baseClip.isAd); } catch (err) { console.log(‘Error OnMediaPause: ‘, err.message); } performance.mark(“fs-videoplayer-onmediapause”); if (playerData) playerData[“onMediaPause”] && typeof playerData.onMediaPause === ‘function’ && playerData.onMediaPause(null, e, player); }.bind(this)); /** * @desc Fires when the current clip resumes playback after having been paused. */ player.addEventListener(‘OnMediaUnpause’, function (e) { try { //passing video clip OnMediaUnpause to check if it is an ad when setting video play this.setPlay(e.data.clip.baseClip.isAd); } catch (err) { console.log(‘Error OnMediaUnpause: ‘, err.message); } }.bind(this)); /** * @desc Fires when a clip starts playing. This includes individual chapter starts within a media item. * The ClipInfo component listens for this event to update its content. This is the only event where video * or ad metadata is dispatched to the player. Video metadata can be pulled out of the event data object. */ player.addEventListener(_FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_2__[“fsEvents”].videoStart, function (e) { try { if (!e.data.baseClip.isAd && this.sendPageView) { _FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_2__[“default”].dispatchEvent(_FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_2__[“fsEvents”].videoStart, { e: e, player: this.player }); this.sendParselyTracking(); } //passing video clip OnMediaStart to check if it is an ad when setting video play this.setPlay(e.data.baseClip.isAd); } catch (err) { console.log(‘Error OnMediaStart: ‘, err.message); } if (playerData) playerData[_FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_2__[“fsEvents”].videoStart] && typeof playerData.onMediaStart === ‘function’ && playerData.onMediaStart(null, e, player); performance.mark(“fs-videoplayer-onmediastart”); }.bind(this)); /** * @desc Fries when clip ends */ player.addEventListener(_FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_2__[“fsEvents”].videoEnd, function (e) { _FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_2__[“default”].dispatchEvent(_FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_2__[“fsEvents”].videoEnd, { e: e, player: this.player }); }.bind(this)); /** * @desc Fires during clip playing */ player.addEventListener(_FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_2__[“fsEvents”].videoProgress, function (e) { if (player.wcEndcard) { _FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_2__[“default”].dispatchEvent(_FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_2__[“fsEvents”].videoProgress, { e: e, player: this.player }); } }.bind(this)); /** * @desc Fires when the player begins to load a new clip. */ player.addEventListener(_FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_2__[“fsEvents”].videoLoading, function (e) { performance.mark(“fs-videoplayer-onmedialoadstart”); }); /** * @desc Fires when the player loads */ player.addEventListener(_FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_2__[“fsEvents”].playerReady, function (e) { if (_this3.player.elem === e.originator.controlId) { performance.mark(“fs-videoplayer-onplayerloaded”); _FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_2__[“default”].dispatchEvent(_FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_2__[“fsEvents”].playerReady, { e: e, player: _this3.player, playerData: _this3.playerData }); window.currentPlayer = player; } }); /** * @desc Fires when the release url starts */ player.addEventListener(‘OnReleaseStart’, function (e) { performance.mark(“fs-videoplayer-onreleasestart”); this.isModalEnabled && this.pauseAllPlayers(); }.bind(this)); /** * @desc Fires when user clicks on the play button */ player.addEventListener(‘OnPlayButtonClicked’, function (e) { performance.mark(“fs-videoplayer-onplaybuttonclicked”); if (this.isIphone()) { var playerId = ‘#’ + e.originator.controlId; var vidTag = document.querySelector(playerId + ‘ video’); if (!vidTag.hasAttribute(‘playsinline’)) { vidTag.setAttribute(‘playsinline’, ”); } } }.bind(this)); /** * @desc Fires when the release url starts */ player.addEventListener(_FsVideoEventHandler__WEBPACK_IMPORTED_MODULE_2__[“fsEvents”].playerFullScreen, function (e) { performance.mark(“fs-videoplayer-onfullscreen”); //set if player is fullscreen this.isFullScreen = e.data; }.bind(this)); player.start(); this.player = player; this.playerData = playerData; return this; } }, { key: “setSiteSection”, value: function setSiteSection(player, siteSectionPath) { //freewheel if (typeof siteSectionPath !== ‘”undefined”‘) { console.log(‘has siteSection’); } else { siteSectionPath = ‘/nfl/test/default’; } var fwSiteSection = siteSectionPath; // condition if siteSection already sets ‘www.’ if (fwSiteSection.indexOf(‘www.’) > -1) { fwSiteSection = fwSiteSection.replace(‘www.’, ”); } fwSiteSection = this.getAdViewport(window.innerWidth) + ‘.’ + fwSiteSection; //get adzone var adZoneVal = this.getAdZoneParam(); //assign siteSection player.siteSection = adZoneVal !== “” ? adZoneVal : fwSiteSection; return player; } }, { key: “getAdZoneParam”, value: function getAdZoneParam() { function getParameterByName(name) { name = name.replace(/[\[]/, “\\[“).replace(/[\]]/, “\\]”); var regex = new RegExp(“[\\?&]” + name + “=([^]*)”), results = regex.exec(location.search); return results == null ? “” : decodeURIComponent(results[1].replace(/\+/g, ” “)); } var adzoneParam = getParameterByName(‘adzone’); if (adzoneParam !== “”) return adzoneParam;else return ”; } /* desktop = 1024 pixels and up tablet = 768 – 1023 handheld = 767 and below Touch detection for 1023 and below would override the breakpoints */ }, { key: “getAdViewport”, value: function getAdViewport(windowWidth) { var isTouch = this.isTouchDevice(); var viewportName = ‘www’; switch (true) { case !isTouch || windowWidth > 1023: viewportName = “www”; break; case windowWidth > 767 && isTouch: viewportName = “mtab”; break; default: viewportName = “mweb”; } return viewportName; } }, { key: “isTouchDevice”, value: function isTouchDevice() { return ‘ontouchstart’ in window; } }, { key: “getVideoUrl”, value: function getVideoUrl(id) { return this.getCleanedDomain() + ‘/’ + this.playerData.categoryName + ‘/video/’ + id; } }, { key: “setPlayerShare”, value: function setPlayerShare() { if (window.innerWidth > 1024) { // older implementations incorrectly return share as a boolean if (_typeof(this.playerData.share) === ‘object’ && this.playerData.share) { this.player.share = this.playerData.share; } else { this.player.share = { showembedfunc: function showembedfunc(mid, vi) { if (vi.primary == ‘nfl’ && vi.contentType == ‘highlights’ || _typeof(this.state.clip) === ‘object’ && typeof this.state.clip !== null && this.state.clip.baseClip.contentCustomData[“non-EmbeddableHighlights”] == “true”) { return false; } else { return true; } }, emailscript: ”, sharetargets: this.playerData.fdmsharetargetsArr }; } this.player.share = { embed: true, iframeurl: this.playerData.iframeUrl }; if (typeof this.playerData.share_deeplinkfunc === ‘function’) { this.player.share.deeplinkfunc = playerData.share_deeplinkfunc; } else { this.player.share.deeplinkfunc = function (mediaId, title, guid) { return this.getVideoUrl(mediaId); }.bind(this); } } return this; } }, { key: “getCleanedDomain”, value: function getCleanedDomain() { var l = window.location; return l.origin || l.protocol + ‘//’ + l.hostname + (l.port ? ‘:’ + l.port : ”); } }, { key: “defaultOpts”, value: function defaultOpts() { // disable autoplay for mobile var autoplay = this.viewports.isMobile ? false : true; return { autoplay: autoplay, share: false, share_embed: true, endcard: true, endcard_feed: ”, endcard_countdown: true, hideMeta: false, isFwEnabled: false, iu: ”, siteSection: ”, pageLocation: ‘index’, pageName: ‘fscom::videos:video page’, releaseUrl: ”, categoryName: ”, fdmsharetargetsArr: [{ name: “Facebook”, image: “”, urlTemplate: “http://www.facebook.com/sharer.php?u=” }, { name: “Twitter”, image: “”, urlTemplate: “http://twitter.com/share?url=” }] }; } }, { key: “preparePlayerData”, value: function preparePlayerData(opts) { var playerData = this.defaultOpts(); Object.keys(opts).map(function (key) { playerData[key] = opts[key]; }); // iu (interactive unit) is similar to a page path // ex., ‘/fscom/homepage/video’, ‘/fscom/nfl/video’ if (typeof playerData.iu === ‘string’) { playerData.releaseURL += ‘&iu=’ + playerData.iu; playerData.endcard_feed += ‘&params=iu=’ + playerData.iu; } return playerData; } }, { key: “getPlayerElement”, value: function getPlayerElement(opts) { return document.getElementById(‘Video’ + opts.id); } }]); return FsVideo;
}(_Pinner__WEBPACK_IMPORTED_MODULE_0__[“default”]); window.FsVideo = FsVideo;
/* harmony default export */ __webpack_exports__[“default”] = (FsVideo); /***/ }), /***/ “./assets/layouts/app/critical-video.js”:
/*!**********************************************!*\ !*** ./assets/layouts/app/critical-video.js ***! \**********************************************/
/*! no exports provided */
/***/ (function(module, __webpack_exports__, __webpack_require__) { “use strict”;
__webpack_require__.r(__webpack_exports__);
/* harmony import */ var usertiming__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! usertiming */ “./node_modules/usertiming/src/usertiming.js”);
/* harmony import */ var usertiming__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(usertiming__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _components_platformPlayer_criticalVideoLoader__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../components/platformPlayer/criticalVideoLoader */ “./assets/components/platformPlayer/criticalVideoLoader.js”);
/* harmony import */ var lazysizes__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! lazysizes */ “./node_modules/lazysizes/lazysizes.js”);
/* harmony import */ var lazysizes__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(lazysizes__WEBPACK_IMPORTED_MODULE_2__);
// user timing API // NEO Video Loader //Lazy Loading /***/ }), /***/ “./node_modules/@foxdcg/fs-segment-analytics/lib/helpers/SegmentAnalytics.js”:
/*!***********************************************************************************!*\ !*** ./node_modules/@foxdcg/fs-segment-analytics/lib/helpers/SegmentAnalytics.js ***! \***********************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) { “use strict”;
__webpack_require__.r(__webpack_exports__);
/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./utils */ “./node_modules/@foxdcg/fs-segment-analytics/lib/helpers/utils.js”); var SegmentAnalytics =
/*#__PURE__*/
function () { function SegmentAnalytics() { this.metaEl = document.querySelector(‘[fs-prop=”analytics”]’) != null ? Object(_utils__WEBPACK_IMPORTED_MODULE_0__[“getPageMetadata”])() : null; this.defaultSpaReferrer = window.location.href; this.segmentApiKey = null; // tracking functions this.trackPage = this.trackPage.bind(this); this.trackEvent = this.trackEvent.bind(this); this.trackVideoEvent = this.trackVideoEvent.bind(this); this.isCanTrackVideo = this.isCanTrackVideo.bind(this); this.setSegmentLoaded = this.setSegmentLoaded.bind(this); this.initScript = this.initScript.bind(this); // data retrieval functions this.sportsTypes = this.getSportsTypes(); this.duration = 0; this.secondsViewed = 0; this.adCurrentTime = 0; this.last_video_length = 0; this.current_video_length = 0; this.total_length = 0; this.getDefaultProps = this.getDefaultProps.bind(this); this.getPageProps = this.getPageProps.bind(this); this.getEventProps = this.getEventProps.bind(this); this.getCategory = this.getCategory.bind(this); this.getContentName = this.getContentName.bind(this); this.getLandingName = this.getLandingName.bind(this); this.getPageName = this.getPageName.bind(this); this.getPageType = this.getPageType.bind(this); this.getSubCategory = this.getSubCategory.bind(this); this.getPageSubType = this.getPageSubType.bind(this); this.getStoryTitle = this.getStoryTitle.bind(this); this.getPageContentLevels = this.getPageContentLevels.bind(this); this.getDuration = this.getDuration.bind(this); this.setSecondsViewed = this.setSecondsViewed.bind(this); this.getSecondsViewed = this.getSecondsViewed.bind(this); } var _proto = SegmentAnalytics.prototype; _proto.getSportsTypes = function getSportsTypes() { return [‘mlb’, ‘nfl’, ‘nascar’, ‘college-football’, ‘college-basketball’, ‘soccer’, ‘ufc’, ‘golf’, ‘nhl’, ‘nba’, ‘tennis’, ‘boxing’, ‘olympics’, ‘motor’, ‘horse-racing’, ‘other’, ‘baseball’, ‘basketball’, ‘bowling’, ‘cricket’, ‘cycling’, ‘football’, ‘gymnastics’, ‘hockey’, ‘mma’, ‘rugby’, ‘skiing’, ‘swimming’, ‘volleyball’, ‘water-polo’, ‘wnba’, ‘womens-college-basketball’, ‘wrestling’, ‘wwe’]; }; _proto.getCategory = function getCategory() { return this.metaEl[‘category’]; }; _proto.getSubCategory = function getSubCategory() { return this.metaEl[‘sub_category’]; }; _proto.getLandingName = function getLandingName() { var name = this.metaEl[‘landing_name’]; if (name) name = name.replace(/\s\s+/g, ‘ ‘); // CHECK: if page has hash string if (window.location.hash) { var hash = window.location.hash; if (hash.indexOf(‘nav-option’) > -1) { name = name.replace(‘Landing’, ‘Category’); } } return name; }; _proto.getPageName = function getPageName() { var pageName = this.metaEl ? this.metaEl[‘seg_page_name’] : “no page name”; if (pageName) return pageName.replace(‘::’, ‘:’); }; _proto.getPageSubType = function getPageSubType() { return this.metaEl ? this.metaEl[‘page_sub_type’] : “no page sub type”; }; _proto.getContentName = function getContentName() { return this.metaEl ? this.metaEl[‘content_name’] : “no content name”; }; _proto.getStoryTitle = function getStoryTitle() { return this.metaEl ? this.metaEl[‘story_title’] : “no story title”; }; _proto.getBuildVersion = function getBuildVersion() { return this.metaEl ? this.metaEl[‘build_version’] : “no build version”; }; _proto.getPageType = function getPageType() { var pageType = this.metaEl ? this.metaEl[‘page_type’] : “no page type”; if (pageType === ‘home’) return ‘section front’; return pageType; }; _proto.getPageContentLevels = function getPageContentLevels(props) { if (this.metaEl) { if (this.metaEl.page_content_level_1) props.properties.page_content_level_1 = this.metaEl.page_content_level_1.replace(‘::’, ‘:’); if (this.metaEl.page_content_level_2) props.properties.page_content_level_2 = this.metaEl.page_content_level_2.replace(‘::’, ‘:’); if (this.metaEl.page_content_level_3) props.properties.page_content_level_3 = this.metaEl.page_content_level_3.replace(‘::’, ‘:’); if (this.metaEl.page_content_level_4) props.properties.page_content_level_4 = this.metaEl.page_content_level_4.replace(‘::’, ‘:’); } else { props.properties.page_content_level_1 = “no content level 1”; props.properties.page_content_level_2 = “no content level 2”; props.properties.page_content_level_3 = “no content level 3”; props.properties.page_content_level_4 = “no content level 4”; } return props; }; _proto.getPosition = function getPosition(position, adTime) { if (adTime === void 0) { adTime = 0; } return parseInt(position – adTime, 10); }; _proto.getDuration = function getDuration(duration) { if (duration) { duration = parseInt(duration, 10); if (duration > 0 && duration != this.duration) this.duration = duration; } return this.duration; }; _proto.setSecondsViewed = function setSecondsViewed(secondsViewed) { if (secondsViewed && secondsViewed > 0) this.secondsViewed = secondsViewed; }; _proto.getSecondsViewed = function getSecondsViewed(eventName) { if (eventName.indexOf(‘Playing’) > -1) return 10; return Math.floor(this.secondsViewed % 10); }; _proto.setCampaignTraits = function setCampaignTraits(props) { var campaignTraits = Object(_utils__WEBPACK_IMPORTED_MODULE_0__[“getSessionCampaignTraits”])(); if (campaignTraits) { for (var trait in campaignTraits) { props.properties[trait] = campaignTraits[trait]; } } return props; }; _proto.getDefaultProps = function getDefaultProps(type, eventName) { var traits = { dcg_profile_id: ”, appsflyer_id: ”, network_entitlement_list: ”, lastKnownProfileId: ”, lastAnonymousProfileId: ”, mvpd: ” }; var defaultProps = { primary_business_unit: ‘fng’, secondary_business_unit: ‘fox sports’, app_name: ‘foxsports.com’, app_platform: ‘web’, app_version: ”, app_build: ”, referrer: this.defaultSpaReferrer, page_test_name: ”, page_timePartingDay: ”, page_timePartingHour: ”, campaign_tracking_code: ”, campaign_organization: ”, campaign_marketing_channel: ”, campaign_source: ”, campaign_name: ”, campaign_additional: ”, campaign_agency: ”, page_name: ”, page_type: ”, page_content_level_1: ”, page_content_level_2: ”, page_content_level_3: ”, page_content_level_4: ”, favorites_length: ”, favorites_list: ”, favorites_sports_length: ”, favorites_sports_list: ”, favorites_teams_length: ”, favorites_teams_list: ”, rivals_sports_length: ”, rivals_sports_list: ”, rivals_teams_length: ”, rivals_teams_list: ”, subscriptions_length: ”, subscriptions_list: ”, push_enabled: ” }; var props; // for page view if (type === ‘page’) { props = Object.assign(defaultProps, { keywords: ”, page_content_author: ”, page_content_original_publish_date: ”, page_content_major_publish_date: ”, page_content_modified_date: ”, page_content_original_publish_time: ”, page_content_major_publish_time: ”, page_content_modified_time: ”, page_content_version: ”, page_content_title: ”, page_content_id: ”, page_content_type: ”, page_content_type_of_story: ”, page_content_tags: ”, page_content_category: ”, page_content_subcategory: ”, page_content_language: ”, page_login_state: ”, page_content_originator: ” }); return { name: ‘no page name’, context: { traits: traits }, properties: props }; } // for event if (type === ‘video’ && eventName) { // for video events props = Object.assign(defaultProps, this.getVideoEventDefaultProps(eventName)); } else { // for custom/other events props = defaultProps; } return { event: eventName || ‘no event name’, context: { traits: traits }, properties: props }; }; _proto.getVideoEventDefaultProps = function getVideoEventDefaultProps(eventName) { // main default props for video events var props = { session_id: ”, position: 0, total_length: ”, video_player_state: ”, video_player_content_type: ”, video_asset_title: ”, video_asset_id: ”, video_channel_group_id: ”, video_primary_business_unit: ‘fng’, video_secondary_business_unit: ‘fox sports’, video_series_id: ”, video_series_name: ”, video_fox_profile: false, video_content_length: 86400, video_content_type: ”, video_ad_supported: false, video_ad_model: ”, video_content_length_format: ”, video_rating: ”, video_asset_category: ”, video_genre: ”, video_season_number: ”, video_episode_number: ”, video_tms_id: ”, video_station_id: ”, video_network: ”, video_affiliate_window: ”, video_authorizing_network: ”, video_player_type: ”, video_content_channel: ”, video_ugc_clip: ”, video_sports_type: ”, video_sponsor: ”, video_screen_layout: ”, video_airplay: false, video_first_air_date: ”, video_first_digital_date: ”, video_originator: ”, video_cross_device_play: false, video_cast_source_name: ”, video_cast_source_platform: ”, video_cast_source_version: ”, video_cast_source_build: ”, video_content_subscription_type: ”, video_feed: ”, video_is_resume: false, video_is_continuous: false, video_is_restart: false, video_is_autoplay: false, video_is_fullscreen: false, video_is_livestream: false, video_volume: ” }; // other props, segregated to subtypes (playback, content, ad) var subtypesProps = { playback: { bitrate: ”, framerate: ”, livestream: false, ad_type: ”, ad_asset_id: ”, ad_pod_id: ”, video_player: ”, sound: ”, full_screen: false, ad_enabled: true, quality: ” }, content: { bitrate: ”, framerate: ”, livestream: false, asset_id: ”, pod_id: ”, title: ”, publisher: ”, description: ”, keywords: ”, season: ”, episode: ”, genre: ”, program: ”, channel: ”, full_episode: false, airdate: ” }, ad: { asset_id: ”, pod_id: ”, title: ”, publisher: ”, content: null, pod_position: ”, pod_length: ”, type: ”, load_type: ”, video_ad_name: ”, video_ad_length: ”, video_ad_id: ”, video_fw_vcid2: ”, video_fw_sitesection: ”, video_ad_break_type: ”, video_ad_break_name: ”, video_ad_break_position: ”, video_ad_pod_id: ”, video_ad_pod_type: ”, video_ad_pod_name: ”, video_ad_pod_position: ”, video_ad_in_pod_position: ”, video_ad_campaign_id: ”, video_ad_creative_id: ”, video_ad_site_id: ”, video_ad_placement_id: ”, video_ad_advertiser: ”, video_ad_creative_url: ” } }; switch (eventName) { case ‘Video Playback Seek Started’: props = Object.assign(props, { seek_position: ” }); break; case ‘Video Playback Started’: props = Object.assign(props, { content_asset_ids: ”, content_pod_ids: ” }); break; case ‘Video Playback Interrupted’: props = Object.assign(props, { method: ” }); break; case ‘Video Ad Playing’: props = Object.assign(props, { video_seconds_viewed: 0, quartile: null }); break; case ‘Video Content Playing’: case ‘Video Content Completed’: props = Object.assign(props, { video_seconds_viewed: 0 }); break; default: break; } var subtype = this.getVideoSubType(eventName); if (subtype) props = Object.assign(props, subtypesProps[subtype]); return props; }; _proto.getSegmentEventName = function getSegmentEventName(eventName) { var eventsEnum = { ‘OnPlaybackStart’: ‘Video Playback Started’, ‘OnPlaybackComplete’: ‘Video Playback Completed’, ‘OnContentStart’: ‘Video Content Started’, ‘OnContentComplete’: ‘Video Content Completed’, ‘OnContentPlaying’: ‘Video Content Playing’, // TODO: delete once JW player is implemented 100% // TODO: un-comment video ads-related events once its ready for tracking // ‘OnMediaPlay’: ‘Video Playback Started’, // ‘OnMediaPause’: ‘Video Playback Paused’, // ‘OnMediaUnpause’: ‘Video Playback Resumed’, // ‘OnMediaEnd’: ‘Video Playback Completed’, // ‘OnMediaBuffer’: ‘Video Playback Buffer Started’, // ‘OnMediaSeek’: ‘Video Playback Seek Started’, // ‘OnMediaPlaying’: ‘Video Content Playing’, // ‘OnMediaStart’: ‘Video Content Started’, // ‘OnMediaComplete’: ‘Video Content Completed’, ‘OnAdStart’: ‘Video Ad Started’, ‘OnAdPlaying’: ‘Video Ad Playing’, ‘OnAdComplete’: ‘Video Ad Completed’ // ‘onSeekStart’: ‘Video Playback Seek Started’, // ‘onSeekComplete’: ‘Video Playback Seek Completed’, // videoLoad: ‘OnLoadReleaseUrl’, // videoError: ‘OnMediaError’, // videoLoading: ‘OnMediaLoadStart’, // videoReady: ‘OnLoadRelease’, // videoMute: ‘OnMute’, // playerReady: ‘OnPlayerLoaded’, // playerOverlayUp: ‘OnShowPlayOverlay’ // playerFullScreen: ‘OnShowFullScreen’, // adPodStart: ‘onAdPodStart’, // adPodComplete: ‘onAdPodComplete’, }; return eventsEnum[eventName] ? eventsEnum[eventName] : null; }; _proto.getVideoSubType = function getVideoSubType(eventName) { var subTypesEnum = { ‘Video Playback Started’: ‘playback’, ‘Video Playback Paused’: ‘playback’, ‘Video Playback Buffer Started’: ‘playback’, ‘Video Playback Buffer Completed’: ‘playback’, ‘Video Playback Resumed’: ‘playback’, ‘Video Playback Completed’: ‘playback’, ‘Video Playback Interrupted’: ‘playback’, ‘Video Playback Seek Started’: ‘playback’, ‘Video Playback Seek Completed’: ‘playback’, ‘Video Content Started’: ‘content’, ‘Video Content Playing’: ‘content’, ‘Video Content Completed’: ‘content’, ‘Video Ad Started’: ‘ad’, ‘Video Ad Playing’: ‘ad’, ‘Video Ad Completed’: ‘ad’, ‘Video Ad Break Started’: ‘ad’, ‘Video Ad Break Completed’: ‘ad’, ‘Video Ad Paused’: ‘ad’, ‘Video Ad Resumed’: ‘ad’ }; return subTypesEnum[eventName] ? subTypesEnum[eventName] : null; } /** * sets global trais and custom properties * @param {*} props – segment global props * @param {*} data – player config */ ; _proto.setGlobalProps = function setGlobalProps(props) { var pageName = this.getPageName(); var pageType = this.getPageType(); var storyTitle = this.getStoryTitle(); var buildVersion = this.getBuildVersion(); if (pageName) props.properties.page_name = pageName; if (pageType) props.properties.page_type = pageType; if (storyTitle) { props.properties.story_title = storyTitle; if (props.properties.title) props.properties.title = storyTitle; if (props.properties.program) props.properties.program = storyTitle; } if (buildVersion) { props.properties.app_build = buildVersion; props.properties.app_version = buildVersion; } props.context.traits = Object(_utils__WEBPACK_IMPORTED_MODULE_0__[“getProfileData”])(props.context.traits); if (this.auth) { props.context.traits.mvpd = this.auth.mvpdId || ”; props.context.traits.network_entitlement_list = this.auth.networkEntitlementList || ”; } props = this.getPageContentLevels(props); props = this.setCampaignTraits(props); return props; } /** * removes all empty/null custom properties * @param {Object} props – analytics props object * @return {Object} – returns object only if not empty/null */ ; _proto.updateAllProps = function updateAllProps(props) { var newProperties = {}; for (var prop in props.properties) { if (props.properties[prop] || typeof props.properties[prop] === “boolean” || typeof props.properties[prop] === “number”) { newProperties[prop] = props.properties[prop]; } } props.properties = newProperties; return props; }; _proto.getPageProps = function getPageProps(name, data) { var props = this.setGlobalProps(this.getDefaultProps(‘page’)); props.name = name || this.getLandingName(); if (data) { if (data.properties) { for (var prop in data.properties) { props.properties[prop] = data.properties[prop]; } } if (data.context && data.context.traits) { for (var trait in data.context.traits) { props.context.traits[trait] = data.context.traits[trait]; } } } props = this.updateAllProps(props); return props; }; _proto.getEventProps = function getEventProps(eventName, data) { eventName = this.getSegmentEventName(eventName); var props = this.setGlobalProps(this.getDefaultProps(‘event’, eventName)); props.event = eventName; if (data) { if (data.properties) { for (var prop in data.properties) { props.properties[prop] = data.properties[prop]; } } if (data.context && data.context.traits) { for (var trait in data.context.traits) { props.context.traits[trait] = data.context.traits[trait]; } } } props = this.updateAllProps(props); return props; }; _proto.getVideoEventProps = function getVideoEventProps(eventName, data) { var props = this.setGlobalProps(this.getDefaultProps(‘video’, eventName)); props.event = eventName; props.properties.session_id = data.player.guid; props.properties.position = eventName.indexOf(‘Started’) > -1 ? 0 : this.getPosition(data.player.playerGetPosition(), data.player.priorAdTime); this.current_video_length = this.getDuration(data.player.duration); if (this.current_video_length != this.last_video_length && data.player.contentType == ‘main’) { this.last_video_length = this.current_video_length; this.total_length += this.current_video_length; } if (this.total_length > 0) props.properties.total_length = this.total_length; if (data.player.options.mode) { props.properties.livestream = data.player.isLive; if (props.properties.livestream) { props.properties.video_content_type = ‘LIVE’; } else { props.properties.video_content_type = data.player.options.mode.toUpperCase(); } } props.properties.video_fox_profile = props.context.traits.dcg_profile_id != null; props.properties.video_player_state = function (playerState) { if (playerState === ‘Started’) return ‘start’; if (playerState === ‘Completed’) return ‘end’; if (playerState === ‘Playing’) return ‘play’; return ‘no player state’; }(eventName.split(/[\s,]+/).pop()); // conditional props if (data.player.contentAssetId) props.properties.content_asset_ids = [data.player.contentAssetId]; if (data.player.currentId) props.properties.video_asset_id = data.player.currentId; if (data.player.currentId) props.properties.asset_id = data.player.currentId; if (data.player.contentType) props.properties.video_player_content_type = data.player.contentType; if (!data.player.isLive && this.current_video_length > 0) { props.properties.video_content_length = this.current_video_length; } props.properties.video_content_length_format = props.properties.video_content_type && props.properties.video_content_type === ‘LIVE’ ? ‘long-form’ : ‘short-form’; if (data.network) props.properties.video_network = data.network; if (data.sportsTag) props.properties.video_sports_type = data.sportsTag; if (typeof props.properties.video_seconds_viewed !== ‘undefined’) { props.properties.video_seconds_viewed = this.getSecondsViewed(eventName); } if (data.event) { var event = data.event; var trackingData = event.trackingData; if (event.chapter) { props.properties.pod_id = event.chapter.index + 1 + ”; if (event.chapters && !data.player.isLive && props.properties.hasOwnProperty(‘content_pod_ids’)) { var contentPodIds = event.chapters.map(function (c, i) { return i + 1 + ”; }).slice(event.chapter.index); props.properties.content_pod_ids = contentPodIds; } } if (eventName === ‘Video Ad Playing’) { this.adCurrentTime = event.currentTime; props.properties.video_seconds_viewed = 1; } if (eventName === ‘Video Ad Completed’) { this.adCurrentTime = 0; props.properties.video_seconds_viewed = 1; } if (trackingData) { var eventType = trackingData.content || trackingData.ad; if (eventType) { props.properties.title = eventType.title; } if (trackingData.content) { props.properties.program = trackingData.content.program; } } } if (data.data) { props.properties.program = data.data.categoryName || props.properties.program; } props = this.updateAllProps(props); return props; }; _proto.setSegmentLoaded = function setSegmentLoaded(flag) { return window.segmentLoaded = flag; }; _proto.check = function check() { return typeof window.segmentLoaded === ‘undefined’ ? false : window.segmentLoaded; }; _proto.trackPage = function trackPage(name, props) { var self = this; return new Promise(function (resolve, reject) { /* https://segment.com/docs/sources/website/analytics.js/#page */ if (!self.check()) { try { self.initScript(self.segmentApiKey, false); } catch (e) { return reject(‘SEGMENT ANALYTICS !! – Segment Analytics is not initialized’); } } var meta = props || self.metaEl; if (!meta) { return reject(‘SEGMENT ANALYTICS !! – analytics meta tag or props are required and are missing’); } props = self.getPageProps(name, meta); name = name || props.name; /* NOTE: `trackPage` params takes priority over default/meta values from getPageProps */ console.debug(“Segment page tracking (” + name + “): ” + JSON.stringify(props)); window.analytics.page(name, props.properties, { context: props.context }); resolve(); }); }; _proto.isCanTrackVideo = function isCanTrackVideo(eventName, data) { if (eventName === ‘Video Ad Playing’ && data.event) { return Math.floor(this.adCurrentTime) !== Math.floor(data.event.currentTime); } return true; }; _proto.trackVideoEvent = function trackVideoEvent(eventName, data) { var _this = this; var self = this; return new Promise(function (resolve, reject) { /* https://segment.com/docs/sources/website/analytics.js/#track */ if (!self.check()) { try { self.initScript(self.segmentApiKey, false); } catch (e) { return reject(‘SEGMENT ANALYTICS !! – Segment Analytics is not initialized’); } } if (!eventName) return reject(‘SEGMENT ANALYTICS !! – video event name is required’); if (!data) return reject(‘SEGMENT ANALYTICS !! – video event data is required’); eventName = self.getSegmentEventName(eventName); if (eventName == null) { return reject(“SEGMENT ANALYTICS !! – event(” + eventName + “) is not recognized as a segment event.”); } if (!_this.isCanTrackVideo(eventName, data)) { return resolve(); } self.auth = data.auth; var props = self.getVideoEventProps(eventName, data); console.debug(“Segment video event tracking (” + eventName + “) – ” + JSON.stringify(props)); window.analytics.track(eventName, props.properties, { context: props.context }); resolve(); }); }; _proto.trackEvent = function trackEvent(eventName, data) { var self = this; return new Promise(function (resolve, reject) { /* https://segment.com/docs/sources/website/analytics.js/#track */ if (!self.check()) { try { self.initScript(self.segmentApiKey, false); } catch (e) { return reject(‘SEGMENT ANALYTICS !! – Segment Analytics is not initialized’); } } if (!eventName) return reject(‘SEGMENT ANALYTICS !! – event name is required’); if (!data) return reject(‘SEGMENT ANALYTICS !! – event data is required’); var props = self.getEventProps(eventName, data); console.debug(“Segment event tracking (” + eventName + “) – ” + JSON.stringify(props)); window.analytics.track(eventName, props.properties, { context: props.context }); resolve(); }); }; _proto.initScript = function initScript(segmentApiKey, enablePageLoadTracking) { if (segmentApiKey === void 0) { segmentApiKey = null; } if (enablePageLoadTracking === void 0) { enablePageLoadTracking = true; } var self = this; if (!self.check()) { self.segmentApiKey = function (key) { if (typeof key === ‘string’ && key.length > 0) return key; return self.metaEl != null && self.metaEl.hasOwnProperty(‘segment_api_key’) && self.metaEl[‘segment_api_key’] ? self.metaEl[‘segment_api_key’] : null; }(segmentApiKey); !function () { var analytics = window.analytics = window.analytics || []; if (!analytics.initialize) if (analytics.invoked) window.console && console.error && console.error(“Segment snippet included twice.”);else { analytics.invoked = !0; analytics.methods = [“trackSubmit”, “trackClick”, “trackLink”, “trackForm”, “pageview”, “identify”, “reset”, “group”, “track”, “ready”, “alias”, “debug”, “page”, “once”, “off”, “on”]; analytics.factory = function (t) { return function () { var e = Array.prototype.slice.call(arguments); e.unshift(t); analytics.push(e); return analytics; }; }; for (var t = 0; t = 0 ? att.replace(/-/g, ‘_’) : att; data[att] = val.trim(); } } return data;
} // query string helpers function setCampaignTraitsSession() { if (window.location.search.length == 0) return; var queryStr = window.location.search; var campaignTraits = { “org”: “campaign_organization”, “ag”: “campaign_agency”, “mc”: “campaign_type”, “src”: “campaign_source”, “cmp”: “campaign_name”, “add”: “campaign_additional”, “cmpid”: “campaign_tracking_code” }; var query = new URLSearchParams(queryStr); var params = Object.keys(campaignTraits); var result; for (var _iterator = query.keys(), _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) { var _ref; if (_isArray) { if (_i >= _iterator.length) break; _ref = _iterator[_i++]; } else { _i = _iterator.next(); if (_i.done) break; _ref = _i.value; } var key = _ref; if (key in params) { if (!result) result = {}; result[campaignTraits[key]] = query.get(key); } } if (result) { window.sessionStorage.setItem(‘sessionCampaignTraits’, JSON.stringify(result)); } return result;
}
;
function getSessionCampaignTraits() { var result; try { result = JSON.parse(window.sessionStorage.getItem(‘sessionCampaignTraits’)); if (!result) { result = setCampaignTraitsSession(); } } catch (e) { return; } return result;
}
;
/*
`lastAnonymousProfileId` + populate when user hasn’t logged in + pass blank on tracking when user is logged in + pass last anon id if user is logged out (?) `lastKnownProfileId` + pass blank when user hasn’t logged in + populate when user logs out + pass blank when user logs back in (?)
*/ function isObjectEmpty(obj) { for (var key in obj) { if (obj.hasOwnProperty(key)) return false; } return true;
} function getProfileData(objData) { if (objData === void 0) { objData = {}; } var wisReg = window.wisRegistration; if (wisReg) { var isLoggedIn = isUserLoggedIn(); if (isLoggedIn) { var profileId = wisReg.getProfileId(); objData.dcg_profile_id = profileId || ”; sessionStorage.setItem(‘lastKnownProfileId’, profileId); } objData.lastKnownProfileId = sessionStorage.getItem(‘lastKnownProfileId’) || ”; var lastAnonProfileId = getAnonProfileId(wisReg) || sessionStorage.getItem(‘lastAnonymousProfileId’); objData.lastAnonymousProfileId = lastAnonProfileId || ”; sessionStorage.setItem(‘lastAnonymousProfileId’, objData.lastAnonymousProfileId); } return objData;
}
function getJWT() { return _getJWT.apply(this, arguments);
} function _getJWT() { _getJWT = _asyncToGenerator( /*#__PURE__*/ regeneratorRuntime.mark(function _callee() { var wisReg; return regeneratorRuntime.wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: wisReg = window.wisRegistration; if (!wisReg) { _context.next = 3; break; } return _context.abrupt(“return”, wisReg.getJWT()); case 3: return _context.abrupt(“return”, null); case 4: case “end”: return _context.stop(); } } }, _callee); })); return _getJWT.apply(this, arguments);
} function getAnonProfileId(wisReg) { if (wisReg.getAnonProfileId === “function”) { return wisReg.getAnonProfileId(); } return null;
} function isUserLoggedIn() { var wisReg = window.wisRegistration; if (wisReg && wisReg.isUserLoggedIn === “function”) { return wisReg.isUserLoggedIn(); } return null;
} function getAuthData() { return _getAuthData.apply(this, arguments);
} function _getAuthData() { _getAuthData = _asyncToGenerator( /*#__PURE__*/ regeneratorRuntime.mark(function _callee2() { var profile, geo, auth; return regeneratorRuntime.wrap(function _callee2$(_context2) { while (1) { switch (_context2.prev = _context2.next) { case 0: profile = getProfileData(); geo = getGeoLocation(); _context2.t0 = isProfileAnon(); _context2.t1 = profile.dcg_profile_id || null; _context2.next = 6; return getJWT(); case 6: _context2.t2 = _context2.sent; _context2.t3 = profile.lastKnownProfileId; _context2.t4 = profile.lastAnonymousProfileId; _context2.t5 = { profileAnonymous: _context2.t0, profileId: _context2.t1, accessToken: _context2.t2, lastKnownProfileId: _context2.t3, lastAnonymousProfileId: _context2.t4 }; _context2.t6 = getMVPDId(); _context2.next = 13; return getUserEntitlementsList(); case 13: _context2.t7 = _context2.sent; _context2.t8 = _extends({}, geo); auth = { upstreamUserID: null, profile: _context2.t5, authorizingNetwork: null, mvpdId: _context2.t6, networkEntitlementList: _context2.t7, geo: _context2.t8 }; return _context2.abrupt(“return”, auth); case 17: case “end”: return _context2.stop(); } } }, _callee2); })); return _getAuthData.apply(this, arguments);
} function isProfileAnon() { var isLoggedIn = isUserLoggedIn(); if (isLoggedIn) { return !isLoggedIn; } return true;
}
/** * set geo location on session storage */ function setGeoLocation() { if (navigator.geolocation) { navigator.geolocation.getCurrentPosition(function (pos) { var geo = { geoLatitude: pos.coords.latitude, geoLongitude: pos.coords.longitude }; sessionStorage.setItem(‘fs_geolocation’, JSON.stringify(geo)); }); }
}
/**
* get geo location from session storage
*/ function getGeoLocation() { // Get geolocation data from sessionStorage var geo = sessionStorage.getItem(‘fs_geolocation’); if (geo) { return JSON.parse(geo); } return { geoLatitude: null, geoLongitude: null };
}
function getUserEntitlementsList() { return _getUserEntitlementsList.apply(this, arguments);
}
/** * returns mvpd id */ function _getUserEntitlementsList() { _getUserEntitlementsList = _asyncToGenerator( /*#__PURE__*/ regeneratorRuntime.mark(function _callee3() { var wisReg, entitlements, channels, ppvEvents, formmattedList; return regeneratorRuntime.wrap(function _callee3$(_context3) { while (1) { switch (_context3.prev = _context3.next) { case 0: wisReg = window.wisRegistration; if (!wisReg) { _context3.next = 13; break; } _context3.next = 4; return wisReg.getUserEntitlements(); case 4: entitlements = _context3.sent; if (entitlements) { _context3.next = 7; break; } return _context3.abrupt(“return”, null); case 7: channels = entitlements.channels.map(function (e) { return e.name; }); ppvEvents = entitlements.ppvEvents.map(function (e) { return e.uri; }); formmattedList = ”; if (channels) { formmattedList = channels.toString(); } if (ppvEvents && ppvEvents.length > 0) { formmattedList += “,” + ppvEvents.toString(); } return _context3.abrupt(“return”, formmattedList); case 13: return _context3.abrupt(“return”, null); case 14: case “end”: return _context3.stop(); } } }, _callee3); })); return _getUserEntitlementsList.apply(this, arguments);
} function getMVPDId() { var wisReg = window.wisRegistration; if (wisReg && typeof wisReg.getMVPDDetails === “function”) { var details = wisReg.getMVPDDetails(); if (details) { return details.providerId; } return null; }
} /***/ }), /***/ “./node_modules/@foxdcg/fs-segment-analytics/lib/index.js”:
/*!****************************************************************!*\ !*** ./node_modules/@foxdcg/fs-segment-analytics/lib/index.js ***! \****************************************************************/
/*! exports provided: SegmentAnalytics, getAuthData, setGeoLocation, getGeoLocation */
/***/ (function(module, __webpack_exports__, __webpack_require__) { “use strict”;
__webpack_require__.r(__webpack_exports__);
/* harmony import */ var _helpers_SegmentAnalytics__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./helpers/SegmentAnalytics */ “./node_modules/@foxdcg/fs-segment-analytics/lib/helpers/SegmentAnalytics.js”);
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, “SegmentAnalytics”, function() { return _helpers_SegmentAnalytics__WEBPACK_IMPORTED_MODULE_0__[“default”]; }); /* harmony import */ var _helpers_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./helpers/utils */ “./node_modules/@foxdcg/fs-segment-analytics/lib/helpers/utils.js”);
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, “getAuthData”, function() { return _helpers_utils__WEBPACK_IMPORTED_MODULE_1__[“getAuthData”]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, “setGeoLocation”, function() { return _helpers_utils__WEBPACK_IMPORTED_MODULE_1__[“setGeoLocation”]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, “getGeoLocation”, function() { return _helpers_utils__WEBPACK_IMPORTED_MODULE_1__[“getGeoLocation”]; }); /***/ }), /***/ “./node_modules/isomorphic-fetch/fetch-npm-browserify.js”:
/*!***************************************************************!*\ !*** ./node_modules/isomorphic-fetch/fetch-npm-browserify.js ***! \***************************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) { // the whatwg-fetch polyfill installs the fetch() function
// on the global object (window or self)
//
// Return that as the export for use in Webpack, Browserify etc.
__webpack_require__(/*! whatwg-fetch */ “./node_modules/whatwg-fetch/fetch.js”);
module.exports = self.fetch.bind(self); /***/ }), /***/ “./node_modules/lazysizes/lazysizes.js”:
/*!*********************************************!*\ !*** ./node_modules/lazysizes/lazysizes.js ***! \*********************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) { (function(window, factory) { var lazySizes = factory(window, window.document); window.lazySizes = lazySizes; if( true && module.exports){ module.exports = lazySizes; }
}(window, function l(window, document) { ‘use strict’; /*jshint eqnull:true */ if(!document.getElementsByClassName){return;} var lazySizesConfig; var docElem = document.documentElement; var Date = window.Date; var supportPicture = window.HTMLPictureElement; var _addEventListener = ‘addEventListener’; var _getAttribute = ‘getAttribute’; var addEventListener = window[_addEventListener]; var setTimeout = window.setTimeout; var requestAnimationFrame = window.requestAnimationFrame || setTimeout; var requestIdleCallback = window.requestIdleCallback; var regPicture = /^picture$/i; var loadEvents = [‘load’, ‘error’, ‘lazyincluded’, ‘_lazyloaded’]; var regClassCache = {}; var forEach = Array.prototype.forEach; var hasClass = function(ele, cls) { if(!regClassCache[cls]){ regClassCache[cls] = new RegExp(‘(\\s|^)’+cls+'(\\s|$)’); } return regClassCache[cls].test(ele[_getAttribute](‘class’) || ”) && regClassCache[cls]; }; var addClass = function(ele, cls) { if (!hasClass(ele, cls)){ ele.setAttribute(‘class’, (ele[_getAttribute](‘class’) || ”).trim() + ‘ ‘ + cls); } }; var removeClass = function(ele, cls) { var reg; if ((reg = hasClass(ele,cls))) { ele.setAttribute(‘class’, (ele[_getAttribute](‘class’) || ”).replace(reg, ‘ ‘)); } }; var addRemoveLoadEvents = function(dom, fn, add){ var action = add ? _addEventListener : ‘removeEventListener’; if(add){ addRemoveLoadEvents(dom, fn); } loadEvents.forEach(function(evt){ dom[action](evt, fn); }); }; var triggerEvent = function(elem, name, detail, noBubbles, noCancelable){ var event = document.createEvent(‘CustomEvent’); event.initCustomEvent(name, !noBubbles, !noCancelable, detail || {}); elem.dispatchEvent(event); return event; }; var updatePolyfill = function (el, full){ var polyfill; if( !supportPicture && ( polyfill = (window.picturefill || lazySizesConfig.pf) ) ){ polyfill({reevaluate: true, elements: [el]}); } else if(full && full.src){ el.src = full.src; } }; var getCSS = function (elem, style){ return (getComputedStyle(elem, null) || {})[style]; }; var getWidth = function(elem, parent, width){ width = width || elem.offsetWidth; while(width 0); if(visible && getCSS(parent, ‘overflow’) != ‘visible’){ outerRect = parent.getBoundingClientRect(); visible = eLright > outerRect.left && eLleft outerRect.top – 1 && eLtop 500 ? 500 : 400; } defaultExpand = lazySizesConfig.expand; preloadExpand = defaultExpand * lazySizesConfig.expFactor; } if(currentExpand 2 && loadMode > 2 && !document.hidden){ currentExpand = preloadExpand; lowRuns = 0; } else if(loadMode > 1 && lowRuns > 1 && isLoading = elemNegativeExpand && (eLtop = rect.top) = elemNegativeExpand * hFac && (eLleft = rect.left) 9){break;} } else if(!loadedSomething && isCompleted && !autoLoadElem && isLoading 2 && (preloadElems[0] || lazySizesConfig.preloadAfterLoad) && (preloadElems[0] || (!elemExpandVal && ((eLbottom || eLright || eLleft || eLtop) || lazyloadElems[i][_getAttribute](lazySizesConfig.sizesAttr) != ‘auto’)))){ autoLoadElem = preloadElems[0] || lazyloadElems[i]; } } if(autoLoadElem && !loadedSomething){ unveilElement(autoLoadElem); } } }; var throttledCheckElements = throttle(checkElements); var switchLoadingClass = function(e){ addClass(e.target, lazySizesConfig.loadedClass); removeClass(e.target, lazySizesConfig.loadingClass); addRemoveLoadEvents(e.target, rafSwitchLoadingClass); }; var rafedSwitchLoadingClass = rAFIt(switchLoadingClass); var rafSwitchLoadingClass = function(e){ rafedSwitchLoadingClass({target: e.target}); }; var changeIframeSrc = function(elem, src){ try { elem.contentWindow.location.replace(src); } catch(e){ elem.src = src; } }; var handleSources = function(source){ var customMedia, parent; var sourceSrcset = source[_getAttribute](lazySizesConfig.srcsetAttr); if( (customMedia = lazySizesConfig.customMedia[source[_getAttribute](‘data-media’) || source[_getAttribute](‘media’)]) ){ source.setAttribute(‘media’, customMedia); } if(sourceSrcset){ source.setAttribute(‘srcset’, sourceSrcset); } //https://bugzilla.mozilla.org/show_bug.cgi?id=1170572 if(customMedia){ parent = source.parentNode; parent.insertBefore(source.cloneNode(), source); parent.removeChild(source); } }; var lazyUnveil = rAFIt(function (elem, detail, isAuto, sizes, isImg){ var src, srcset, parent, isPicture, event, firesLoad; if(!(event = triggerEvent(elem, ‘lazybeforeunveil’, detail)).defaultPrevented){ if(sizes){ if(isAuto){ addClass(elem, lazySizesConfig.autosizesClass); } else { elem.setAttribute(‘sizes’, sizes); } } srcset = elem[_getAttribute](lazySizesConfig.srcsetAttr); src = elem[_getAttribute](lazySizesConfig.srcAttr); if(isImg) { parent = elem.parentNode; isPicture = parent && regPicture.test(parent.nodeName || ”); } firesLoad = detail.firesLoad || ((‘src’ in elem) && (srcset || src || isPicture)); event = {target: elem}; if(firesLoad){ addRemoveLoadEvents(elem, resetPreloading, true); clearTimeout(resetPreloadingTimer); resetPreloadingTimer = setTimeout(resetPreloading, 2500); addClass(elem, lazySizesConfig.loadingClass); addRemoveLoadEvents(elem, rafSwitchLoadingClass, true); } if(isPicture){ forEach.call(parent.getElementsByTagName(‘source’), handleSources); } if(srcset){ elem.setAttribute(‘srcset’, srcset); } else if(src && !isPicture){ if(regIframe.test(elem.nodeName)){ changeIframeSrc(elem, src); } else { elem.src = src; } } if(srcset || isPicture){ updatePolyfill(elem, {src: src}); } } rAF(function(){ if(elem._lazyRace){ delete elem._lazyRace; } removeClass(elem, lazySizesConfig.lazyClass); if( !firesLoad || elem.complete ){ if(firesLoad){ resetPreloading(event); } else { isLoading–; } switchLoadingClass(event); } }); }); var unveilElement = function (elem){ var detail; var isImg = regImg.test(elem.nodeName); //allow using sizes=”auto”, but don’t use. it’s invalid. Use data-sizes=”auto” or a valid value for sizes instead (i.e.: sizes=”80vw”) var sizes = isImg && (elem[_getAttribute](lazySizesConfig.sizesAttr) || elem[_getAttribute](‘sizes’)); var isAuto = sizes == ‘auto’; if( (isAuto || !isCompleted) && isImg && (elem.src || elem.srcset) && !elem.complete && !hasClass(elem, lazySizesConfig.errorClass)){return;} detail = triggerEvent(elem, ‘lazyunveilread’).detail; if(isAuto){ autoSizer.updateElem(elem, true, elem.offsetWidth); } elem._lazyRace = true; isLoading++; lazyUnveil(elem, detail, isAuto, sizes, isImg); }; var onload = function(){ if(isCompleted){return;} if(Date.now() – started 0); }, checkElems: throttledCheckElements, unveil: unveilElement }; })(); var autoSizer = (function(){ var autosizesElems; var sizeElement = rAFIt(function(elem, parent, event, width){ var sources, i, len; elem._lazysizesWidth = width; width += ‘px’; elem.setAttribute(‘sizes’, width); if(regPicture.test(parent.nodeName || ”)){ sources = parent.getElementsByTagName(‘source’); for(i = 0, len = sources.length; i 1) { for (var i = 1; i * @licence MIT * */ (function(self) { ‘use strict’; var nativeURLSearchParams = (self.URLSearchParams && self.URLSearchParams.prototype.get) ? self.URLSearchParams : null, isSupportObjectConstructor = nativeURLSearchParams && (new nativeURLSearchParams({a: 1})).toString() === ‘a=1’, // There is a bug in safari 10.1 (and earlier) that incorrectly decodes `%2B` as an empty space and not a plus. decodesPlusesCorrectly = nativeURLSearchParams && (new nativeURLSearchParams(‘s=%2B’).get(‘s’) === ‘+’), __URLSearchParams__ = “__URLSearchParams__”, // Fix bug in Edge which cannot encode ‘ &’ correctly encodesAmpersandsCorrectly = nativeURLSearchParams ? (function() { var ampersandTest = new nativeURLSearchParams(); ampersandTest.append(‘s’, ‘ &’); return ampersandTest.toString() === ‘s=+%26’; })() : true, prototype = URLSearchParamsPolyfill.prototype, iterable = !!(self.Symbol && self.Symbol.iterator); if (nativeURLSearchParams && isSupportObjectConstructor && decodesPlusesCorrectly && encodesAmpersandsCorrectly) { return; } /** * Make a URLSearchParams instance * * @param {object|string|URLSearchParams} search * @constructor */ function URLSearchParamsPolyfill(search) { search = search || “”; // support construct object with another URLSearchParams instance if (search instanceof URLSearchParams || search instanceof URLSearchParamsPolyfill) { search = search.toString(); } this [__URLSearchParams__] = parseToDict(search); } /** * Appends a specified key/value pair as a new search parameter. * * @param {string} name * @param {string} value */ prototype.append = function(name, value) { appendTo(this [__URLSearchParams__], name, value); }; /** * Deletes the given search parameter, and its associated value, * from the list of all search parameters. * * @param {string} name */ prototype[‘delete’] = function(name) { delete this [__URLSearchParams__] [name]; }; /** * Returns the first value associated to the given search parameter. * * @param {string} name * @returns {string|null} */ prototype.get = function(name) { var dict = this [__URLSearchParams__]; return name in dict ? dict[name][0] : null; }; /** * Returns all the values association with a given search parameter. * * @param {string} name * @returns {Array} */ prototype.getAll = function(name) { var dict = this [__URLSearchParams__]; return name in dict ? dict [name].slice(0) : []; }; /** * Returns a Boolean indicating if such a search parameter exists. * * @param {string} name * @returns {boolean} */ prototype.has = function(name) { return name in this [__URLSearchParams__]; }; /** * Sets the value associated to a given search parameter to * the given value. If there were several values, delete the * others. * * @param {string} name * @param {string} value */ prototype.set = function set(name, value) { this [__URLSearchParams__][name] = [” + value]; }; /** * Returns a string containg a query string suitable for use in a URL. * * @returns {string} */ prototype.toString = function() { var dict = this[__URLSearchParams__], query = [], i, key, name, value; for (key in dict) { name = encode(key); for (i = 0, value = dict[key]; i -1 }
} function normalizeName(name) { if (typeof name !== ‘string’) { name = String(name) } if (/[^a-z0-9\-#$%&’*+.^_`|~]/i.test(name)) { throw new TypeError(‘Invalid character in header field name’) } return name.toLowerCase()
} function normalizeValue(value) { if (typeof value !== ‘string’) { value = String(value) } return value
} // Build a destructive iterator for the value list
function iteratorFor(items) { var iterator = { next: function() { var value = items.shift() return {done: value === undefined, value: value} } } if (support.iterable) { iterator[Symbol.iterator] = function() { return iterator } } return iterator
} function Headers(headers) { this.map = {} if (headers instanceof Headers) { headers.forEach(function(value, name) { this.append(name, value) }, this) } else if (Array.isArray(headers)) { headers.forEach(function(header) { this.append(header[0], header[1]) }, this) } else if (headers) { Object.getOwnPropertyNames(headers).forEach(function(name) { this.append(name, headers[name]) }, this) }
} Headers.prototype.append = function(name, value) { name = normalizeName(name) value = normalizeValue(value) var oldValue = this.map[name] this.map[name] = oldValue ? oldValue + ‘, ‘ + value : value
} Headers.prototype[‘delete’] = function(name) { delete this.map[normalizeName(name)] } Headers.prototype.get = function(name) { name = normalizeName(name) return this.has(name) ? this.map[name] : null
} Headers.prototype.has = function(name) { return this.map.hasOwnProperty(normalizeName(name))
} Headers.prototype.set = function(name, value) { this.map[normalizeName(name)] = normalizeValue(value)
} Headers.prototype.forEach = function(callback, thisArg) { for (var name in this.map) { if (this.map.hasOwnProperty(name)) { callback.call(thisArg, this.map[name], name, this) } }
} Headers.prototype.keys = function() { var items = [] this.forEach(function(value, name) { items.push(name) }) return iteratorFor(items)
} Headers.prototype.values = function() { var items = [] this.forEach(function(value) { items.push(value) }) return iteratorFor(items)
} Headers.prototype.entries = function() { var items = [] this.forEach(function(value, name) { items.push([name, value]) }) return iteratorFor(items)
} if (support.iterable) { Headers.prototype[Symbol.iterator] = Headers.prototype.entries
} function consumed(body) { if (body.bodyUsed) { return Promise.reject(new TypeError(‘Already read’)) } body.bodyUsed = true
} function fileReaderReady(reader) { return new Promise(function(resolve, reject) { reader.onload = function() { resolve(reader.result) } reader.onerror = function() { reject(reader.error) } })
} function readBlobAsArrayBuffer(blob) { var reader = new FileReader() var promise = fileReaderReady(reader) reader.readAsArrayBuffer(blob) return promise
} function readBlobAsText(blob) { var reader = new FileReader() var promise = fileReaderReady(reader) reader.readAsText(blob) return promise
} function readArrayBufferAsText(buf) { var view = new Uint8Array(buf) var chars = new Array(view.length) for (var i = 0; i -1 ? upcased : method
} function Request(input, options) { options = options || {} var body = options.body if (input instanceof Request) { if (input.bodyUsed) { throw new TypeError(‘Already read’) } this.url = input.url this.credentials = input.credentials if (!options.headers) { this.headers = new Headers(input.headers) } this.method = input.method this.mode = input.mode this.signal = input.signal if (!body && input._bodyInit != null) { body = input._bodyInit input.bodyUsed = true } } else { this.url = String(input) } this.credentials = options.credentials || this.credentials || ‘same-origin’ if (options.headers || !this.headers) { this.headers = new Headers(options.headers) } this.method = normalizeMethod(options.method || this.method || ‘GET’) this.mode = options.mode || this.mode || null this.signal = options.signal || this.signal this.referrer = null if ((this.method === ‘GET’ || this.method === ‘HEAD’) && body) { throw new TypeError(‘Body not allowed for GET or HEAD requests’) } this._initBody(body)
} Request.prototype.clone = function() { return new Request(this, {body: this._bodyInit})
} function decode(body) { var form = new FormData() body .trim() .split(‘&’) .forEach(function(bytes) { if (bytes) { var split = bytes.split(‘=’) var name = split.shift().replace(/\+/g, ‘ ‘) var value = split.join(‘=’).replace(/\+/g, ‘ ‘) form.append(decodeURIComponent(name), decodeURIComponent(value)) } }) return form
} function parseHeaders(rawHeaders) { var headers = new Headers() // Replace instances of \r\n and \n followed by at least one space or horizontal tab with a space // https://tools.ietf.org/html/rfc7230#section-3.2 var preProcessedHeaders = rawHeaders.replace(/\r?\n[\t ]+/g, ‘ ‘) preProcessedHeaders.split(/\r?\n/).forEach(function(line) { var parts = line.split(‘:’) var key = parts.shift().trim() if (key) { var value = parts.join(‘:’).trim() headers.append(key, value) } }) return headers
} Body.call(Request.prototype) function Response(bodyInit, options) { if (!options) { options = {} } this.type = ‘default’ this.status = options.status === undefined ? 200 : options.status this.ok = this.status >= 200 && this.status 3 && arguments[3] !== undefined ? arguments[3] : _utils__WEBPACK_IMPORTED_MODULE_1__[“headers”]; var options = Object.assign({ method: ‘GET’ }, customHeaders); return fetchData(url, options, callback, error);
}
function post(url, data, callback, error) { var customHeaders = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : _utils__WEBPACK_IMPORTED_MODULE_1__[“headers”]; var options = Object.assign({ method: ‘POST’, body: JSON.stringify(data) }, customHeaders); return sendPost(url, options, callback, error);
} /***/ }), /***/ “./react-app-src/shared/services/FsPlaylistService.js”:
/*!************************************************************!*\ !*** ./react-app-src/shared/services/FsPlaylistService.js ***! \************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) { “use strict”;
__webpack_require__.r(__webpack_exports__);
/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../constants */ “./react-app-src/shared/constants.js”);
/* harmony import */ var _FetchService__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./FetchService */ “./react-app-src/shared/services/FetchService.js”);
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(“Cannot call a class as a function”); } } function _defineProperties(target, props) { for (var i = 0; i 0 && arguments[0] !== undefined ? arguments[0] : ”; var defaultVideoTags = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ”; var postId = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0; if (this.parselyPlaylist) { return this.parselyPlaylist; } var tags = ‘?parselytags=’ + parselyFeedTags + (defaultVideoTags && ‘&defaulttags=’ + defaultVideoTags) + ‘&postid=’ + postId; this.parselyPlaylist = Object(_FetchService__WEBPACK_IMPORTED_MODULE_1__[“get”])(_constants__WEBPACK_IMPORTED_MODULE_0__[“settings”].PARSELY_URL_V2 + tags, function (json) { if (!json.success) return []; var data = json.data; return Array.isArray(data) ? data : [data]; }, function () { return []; }); return this.parselyPlaylist; } }, { key: “getParselyContentByFeed”, value: function getParselyContentByFeed(feedUrl) { var postId = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0; if (this.playlist) { return this.playlist; } var url = ‘?feedurl=’ + encodeURIComponent(feedUrl) + ‘&postid=’ + postId; this.playlist = Object(_FetchService__WEBPACK_IMPORTED_MODULE_1__[“get”])(_constants__WEBPACK_IMPORTED_MODULE_0__[“settings”].PARSELY_URL_V2 + url, function (json) { if (!json.success) return []; var data = json.data; return Array.isArray(data) ? data : [data]; }, function () { return []; }); return this.playlist; } }]); return FsPlaylistService;
}(); /* harmony default export */ __webpack_exports__[“default”] = (FsPlaylistService); /***/ }), /***/ “./react-app-src/shared/utils.js”:
/*!***************************************!*\ !*** ./react-app-src/shared/utils.js ***! \***************************************/
/*! exports provided: headers, handleFetchedErrors, getPostId, assetsDomain, decodeHtmlEntities, getOrderedChannels, parseImagesTag, parseSeconds, isFlashEnabled, isTabletOrMobile, isAndroid, getQueryString, getCookie, getAuthStatus */
/***/ (function(module, __webpack_exports__, __webpack_require__) { “use strict”;
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, “headers”, function() { return headers; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, “handleFetchedErrors”, function() { return handleFetchedErrors; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, “getPostId”, function() { return getPostId; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, “assetsDomain”, function() { return assetsDomain; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, “decodeHtmlEntities”, function() { return decodeHtmlEntities; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, “getOrderedChannels”, function() { return getOrderedChannels; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, “parseImagesTag”, function() { return parseImagesTag; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, “parseSeconds”, function() { return parseSeconds; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, “isFlashEnabled”, function() { return isFlashEnabled; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, “isTabletOrMobile”, function() { return isTabletOrMobile; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, “isAndroid”, function() { return isAndroid; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, “getQueryString”, function() { return getQueryString; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, “getCookie”, function() { return getCookie; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, “getAuthStatus”, function() { return getAuthStatus; });
var headers = { headers: { Accept: ‘application/json’, ‘Content-Type’: ‘application/json’ }, credentials: ‘include’
};
function handleFetchedErrors(response) { if (!response.ok) { throw Error(response.statusText); } return response;
}
function getPostId() { var pageInfo = document.getElementById(‘page-information’); if (pageInfo) { var body = document.querySelector(‘.fox_sectionfront .body-content’); if (body) { return body.getAttribute(‘post-id’); } } return document.body.getAttribute(‘post-id’);
} function getAssetsDomain() { var locationName = location.hostname; if (locationName.match(/www.foxsports.com/)) { return ‘https://b.fssta.com/sta/’; } if (locationName.match(/wp.foxsports.com/)) { return ‘https://b.dev.fssta.com/sta/’; } return ‘/wp-content/themes/foxsports/assets/dist/’;
} var assetsDomain = getAssetsDomain();
function decodeHtmlEntities(text) { if (!text) return ”; return text.replace(/\&(\w*|#\d*)\;/g, function (s) { return decodeTable[s] || ”; });
}
/** * * @param {*} chans – channels coming from ddp entitlements res */ function getOrderedChannels(chans) { // channels are defined as per priority var channels = [{ name: “fbc-fox” }, { name: “fs1” }, { name: “fs2” }, { name: “btn” }, { name: “foxdep” }]; var result = channels.filter(function (el) { return chans.some(function (el2) { return el.name === el2.name; }); }); return result;
}
var decodeTable = { ‘&’: ‘&’, ‘”‘: ‘”‘, ‘<‘: ”, ‘ ‘: ‘ ‘, ‘!’: ‘!’, ‘”‘: ‘”‘, ‘#’: ‘#’, ‘$’: ‘$’, ‘%’: ‘%’, ‘&’: ‘&’, ”’: ‘\”, ”’: ‘\”, ‘(‘: ‘(‘, ‘)’: ‘)’, ‘*’: ‘*’, ‘+’: ‘+’, ‘,’: ‘,’, ‘-‘: ‘-‘, ‘.’: ‘.’, ‘/’: ‘/’, ‘–’: ‘–’, ‘—’: ‘—’, ‘‘’: ‘‘’, ‘’’: ‘’’, ‘‚’: ‘‚’, ‘“’: ‘“’, ‘”’: ‘”’, ‘„’: ‘„’, ‘†’: ‘†’, ‘‡’: ‘‡’, ‘•’: ‘•’, ‘…’: ‘…’, ‘‰’: ‘‰’, ‘€’: ‘€’, ‘™’: ‘™’
};
function parseImagesTag(text) { text = “

“.concat(text, “

“); var parser = new DOMParser(); var result = { srcSet: ”, sizes: ”, src: ”, noscript: ” }; try { var el = parser.parseFromString(text, ‘text/html’); var images = el.getElementsByTagName(‘img’); if (images.length > 0) { var img = images[0]; result.sizes = img.getAttribute(‘data-sizes’) || img.getAttribute(‘sizes’); result.srcSet = img.getAttribute(‘data-srcset’) || img.getAttribute(‘srcset’); result.src = img.getAttribute(‘data-src’) || img.getAttribute(‘src’); } var noscripts = el.getElementsByTagName(‘noscript’); if (noscripts.length > 0) { var noscript = noscripts[0]; result.noscript = noscript.innerHTML; } } finally { return result; }
}
function parseSeconds(time) { if (!time || time.indexOf(‘.’) === -1) { return time; } var minutes = Math.floor(time / 60); var seconds = Math.floor(time – minutes * 60); return minutes + ‘:’ + (seconds

90001-90068+90070-90084+90086-90089+90091+90093-90096+90099+90189

803

26496

Source: Fox Sports

Previous Radioactive: Charlotte – “This is the kind of (expletive) that you get wrecked for”
Next Marc Savard Knows Exactly How Dustin Pedroia Feels About His Injury