Tyler Reddick has a funny way of describing how good Kyle Larson is
‘, ‘‘, ‘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 += ‘¶ms=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(/ss+/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 rn 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