Skip to content

Instantly share code, notes, and snippets.

@Merlin04
Created December 18, 2019 01:09
Show Gist options
  • Save Merlin04/a26dea6ceaf5e50c21850c1bc8b69c77 to your computer and use it in GitHub Desktop.
Save Merlin04/a26dea6ceaf5e50c21850c1bc8b69c77 to your computer and use it in GitHub Desktop.
Comcast/Xfinity JavaScript popup that they injected into my HTTP traffic
<script language="JavaScript" type="text/javascript">
// Copyright (C) 2019 Comcast Cable Communications, LLC
// Contact Us: http://customer.xfinity.com/contact-us/
// Intended use of this message is to display critical and time sensitive notifications to customers.
/*
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
http://www.gnu.org/licenses/old-licenses/lgpl-2.0.en.html
*/
var _ComcastAlert = (function(){
return {
SYS_URL: '/e8f6b078-0f35-11de-85c5-efc5ef23aa1f/aupm/notify.do'
, dragObj: {zIndex: 999999}
, browser: null
, comcastCheck: 1
, comcastTimer: null
, xmlhttp: null
, go: function(){
if(self.location !== top.location) return;
if(document.body){
_ComcastAlert.browser = _ComcastAlert.checkBrowser();
_ComcastAlert.ComcastBrowserNotice();
_ComcastAlert.getXmlhttp();
_ComcastAlert.checkBulletin();
_ComcastAlert.initResizeCheck();
_ComcastAlert.polyfillClassList();
return _ComcastAlert;
}else{
setTimeout(_ComcastAlert.go, 200);
}
}
, ComcastBrowserNotice: function(){
var image_url = 'https://bnp-service-alerts.gslb2.comcast.com/images/';
var comcastAlertAnalytics = 'comcastalert.png';
var noticeBMUID = '160296643';
var winObj = {
image_url: image_url
, comcastAlertAnalytics: comcastAlertAnalytics
, comcastlogo_url: '<img src="' + image_url + 'comcast-logo-115x50.png" height="50" width="115"/>'
, xfinitylogo_url: '<img src="' + image_url + 'Xfinity-Logo-White-221x124.png" height="55" width="99"/>'
, headertext1: '<b>We&#39;ve increased speeds in your area.</b>'
, headertext2: '<b>Update your device to take advantage of faster speeds.</b>'
, textline1: 'We&#39;re always working to improve our network and provide you with better service. As a result of our work, we&#39;re increasing speeds in your area. However, your current device is not compatible with our latest updates. Swap out your equipment today to take advantage of faster speeds.'
, textline2: 'Here&#39;s how:'
, textline3: '&#149; Visit <a class="cclink" href="https://mydeviceinfo.xfinity.com" target="_new"><b>mydeviceinfo.xfinity.com</b></a> to find compatible devices you can purchase.'
, textline4: '&#149; Call <b>1-800-xfinity</b> to lease an Xfinity modem, so you can automatically stay up&#45;to&#45;date with network improvements.'
, textline5: 'Thank you for being a Xfinity Customer.'
, textline6: 'Equipment Update'
, privacypolicylink: '<a class="privacystatement" href="http://my.xfinity.com/privacy/" target="_new" style="color: #000000">PRIVACY POLICY</a>'
, termslink: '<a class="termsofservice" href="http://my.xfinity.com/terms/" target="_new" style="color: #000000">TERMS OF SERVICE</a>'
, closebulletin: '<a href=\"#\" onClick=\"javascript:_ComcastAlert.close_comcast_alert()\"><img src="' + image_url + 'close_button_78x78.png" height="28" width="28"/></a>'
, analytics: '<img src="' + image_url + comcastAlertAnalytics + '?' + noticeBMUID + '_' + _ComcastAlert.comcastContentnoCache() + '">'
};
this.createWindow(winObj);
}
, createWindow: function(winObj){
var html = '<style type="text/css">';
html+= '@font-face {font-family: XfinityStandard;src: url(https://edge.static-assets.top.comcast.net/staticsites/fonts/latest/Xfinity_Standard/XfinityStandard-Thin.woff2) format("woff2"), url(https://edge.static-assets.top.comcast.net/staticsites/fonts/latest/Xfinity_Standard/XfinityStandard-Thin.woff) format("woff"), url(https://edge.static-assets.top.comcast.net/staticsites/fonts/latest/Xfinity_Standard/XfinityStandard-Thin.ttf) format("truetype");font-weight: 100;font-style: normal}'
html+= '@font-face {font-family: XfinityStandard;src: url(https://edge.static-assets.top.comcast.net/staticsites/fonts/latest/Xfinity_Standard/XfinityStandard-ExtraLight.woff2) format("woff2"), url(https://edge.static-assets.top.comcast.net/staticsites/fonts/latest/Xfinity_Standard/XfinityStandard-ExtraLight.woff) format("woff"), url(https://edge.static-assets.top.comcast.net/staticsites/fonts/latest/Xfinity_Standard/XfinityStandard-ExtraLight.ttf) format("truetype");font-weight: 200;font-style: normal}'
html+= '@font-face {font-family: XfinityStandard;src: url(https://edge.static-assets.top.comcast.net/staticsites/fonts/latest/Xfinity_Standard/XfinityStandard-Light.woff2) format("woff2"), url(https://edge.static-assets.top.comcast.net/staticsites/fonts/latest/Xfinity_Standard/XfinityStandard-Light.woff) format("woff"), url(https://edge.static-assets.top.comcast.net/staticsites/fonts/latest/Xfinity_Standard/XfinityStandard-Light.ttf) format("truetype");font-weight: 300;font-style: normal}'
html+= '@font-face {font-family: XfinityStandard;src: url(https://edge.static-assets.top.comcast.net/staticsites/fonts/latest/Xfinity_Standard/XfinityStandard-Regular.woff2) format("woff2"), url(https://edge.static-assets.top.comcast.net/staticsites/fonts/latest/Xfinity_Standard/XfinityStandard-Regular.woff) format("woff"), url(https://edge.static-assets.top.comcast.net/staticsites/fonts/latest/Xfinity_Standard/XfinityStandard-Regular.ttf) format("truetype");font-weight: 400;font-style: normal}'
html+= '@font-face {font-family: XfinityStandard;src: url(https://edge.static-assets.top.comcast.net/staticsites/fonts/latest/Xfinity_Standard/XfinityStandard-Medium.woff2) format("woff2"), url(https://edge.static-assets.top.comcast.net/staticsites/fonts/latest/Xfinity_Standard/XfinityStandard-Medium.woff) format("woff"), url(https://edge.static-assets.top.comcast.net/staticsites/fonts/latest/Xfinity_Standard/XfinityStandard-Medium.ttf) format("truetype");font-weight: 500;font-style: normal}'
html+='#comcast_content{width:650px;height:auto!important;height:450px;min-height:450px;max-height:100%;font-family: XfinityStandard,helvetica,arial,sans-serif;background:#fff;border:1px solid #454545;position:absolute;top:50vh;right:50%;-webkit-transform:translate(50%,-45%);-ms-transform:translate(50%,-45%);transform:translate(50%,-45%);zoom:1;z-index:9999999999;opacity:0;-webkit-animation:popup .4s ease-out 500ms;animation:popup .4s ease-out 500ms;-webkit-animation-fill-mode:forwards;animation-fill-mode:forwards;display:flex;flex-direction:column}@-webkit-keyframes popup{0%{-webkit-transform:translate(50%,-45%);opacity:0}100%{-webkit-transform:translate(50%,-50%);opacity:1}}@keyframes popup{0%{transform:translate(50%,-45%);opacity:0}100%{transform:translate(50%,-50%);opacity:1}}';
html+='#comcast_content .header{height:60px;min-height:60px;width:100%;background-color:#000;repeat-x;z-index:99999999}';
html+='#comcast_content .content-wrapper{padding:20px; margin:0; max-height:60vh;height:auto;overflow-y:auto;}';
html+='#comcast_content p{margin: 1em 0;}'
html+='#comcast_content .titletext1{margin: 10 0 0 0; font:22px/24px bold XfinityStandard,Helvetica,Geneva,sans-serif;color:#303030;text-align:left;padding:0;font-weight:200;}';
html+='#comcast_content .titletext2{color:#0000000;text-align:left;padding:0;font:16px/18px bold XfinityStandard,Helvetica,Geneva,sans-serif;font-weight:200}';
html+='#comcast_content .textcontent1{color:#303030;text-align:left;margin: 15 0 0 0;padding:0;font:15px/16px XfinityStandard,Helvetica,Geneva,sans-serif;font-weight:200;line-height:1.2}';
html+='#comcast_content .textcontent2{color:#303030;text-align:left;margin: 15 0 0 15; padding:0;font:15px/16px XfinityStandard,Helvetica,Geneva,sans-serif;font-weight:200;line-height:1.2}';
html+='#comcast_content .textcontent3{color:#808080;text-align:left;margin: 15 0 0 0;padding:0;font:15px/16px XfinityStandard,Helvetica,Geneva,sans-serif;font-weight:200;line-height:1.2}';
html+='#comcast_content .textcontent4{color:#303030;text-align:left;margin: 15 0 0 0;padding-left:12px;font:15px/16px XfinityStandard,Helvetica,Geneva,sans-serif;font-weight:200;line-height:1.2}';
html+='#comcast_content .privacystatement{display:inline-block;font:12px/12px XfinityStandard,Helvetica,Geneva,sans-serif;font-weight:200;text-align:bottom;white-space:nowrap}';
html+='#comcast_content .privacystatement:link{color:#000;text-decoration:none}';
html+='#comcast_content .privacystatement:visited{color:#000;text-decoration:none}';
html+='#comcast_content .privacystatement:hover{color:#000;text-decoration:underline}';
html+='#comcast_content .termsofservice{display:inline-block;font:12px/12px XfinityStandard,Helvetica,Geneva,sans-serif;font-weight:200;text-align:bottom;white-space:nowrap}';
html+='#comcast_content .termsofservice:link{color:#000;text-decoration:none}';
html+='#comcast_content .termsofservice:visited{color:#000;text-decoration:none}';
html+='#comcast_content .termsofservice:hover{color:#000;text-decoration:underline}';
html+='#comcast_content .ccsa{display:inline-block;margin-left: 15px; font:12px/12px XfinityStandard,Helvetica,Geneva,sans-serif;font-weight:200;text-align:bottom;white-space:nowrap}';
html+='#comcast_content .ccsa:link{color:#000;text-decoration:none}';
html+='#comcast_content .ccsa:visited{color:#000;text-decoration:none}';
html+='#comcast_content .ccsa:hover{color:#000;text-decoration:underline}';
html+='#comcast_content .comcastlogo{z-index:9999999999;height:50px;width:115px; margin:0 auto 50px;}';
html+='#comcast_content .comcastanalytics{float:right; height:1px; width:1px; z-index:-99999; margin:0; padding:0; auto 1px;}';
html+='#comcast_content .acknowledgebutton{margin: 0 0 0 0;color:#303030;text-align:center;padding-top:5px;padding-bottom:5px;font:14px/16px XfinityStandard,Helvetica,Geneva,sans-serif;line-height:1.2;z-index:9999999999}';
html+='#comcast_content .xfinitylogo{display:inline-block;position:absolute;z-index:9999999999;left:10px;top:5px;margin:0 0 0 0;height:62px;width:110px}';
html+='#comcast_content .closebn{display:inline-block;position:absolute;z-index:9999999999;right:0;top:16px;height:32px;width:32px;margin:0 10px 0 0}';
html+='#comcast_content #footer{height:50px;width:100%;padding:10px;margin-top:10px; padding:0; box-sizing:border-box;color:white;background-color: white;text-align: left;}';
html+='#comcast_content #footer .logo{float:right; width:115px; height:50px;}';
html+='#comcast_content #footer .links{float: left}';
html+='#comcast_content #footer .equipmentupdate{margin:0px; margin-top:18px; color:#303030;text-align:left;margin: 15 0 0 0;padding:0;font:15px/16px XfinityStandard,Helvetica,Geneva,sans-serif;font-weight:200;line-height:1.2}';
html+='#comcast_content #footer .termsofservice{margin-left:20px; margin-top:18px;}';
html+='#comcast_content .scroll-button {height:30px; padding:0; margin:0;background-color:black; position:absolute;bottom: 0; left: 0; width:100%; color:white;text-align:center;}';
html+='#comcast_content .phone{color:#008EC9; white-space:nowrap; text-decoration:none}';
html+='#comcast_content .phone:link{color:#008EC9;text-decoration:none}';
html+='#comcast_content .phone:visited{color:#008EC9;text-decoration:none}';
html+='#comcast_content .phone:hover{color:#008EC9;text-decoration:underline}';
html+='#comcast_content #down{transform: rotate(0deg);-ms-transform: rotate(0deg);-webkit-transform: rotate(0deg);width:25px; height:30px; margin:0 auto; background:url() no-repeat center center;}';
html+='#comcast_content #down.rotate{transform: rotate(180deg);-ms-transform: rotate(180deg);-webkit-transform: rotate(180deg);}';
html+='#comcast_content .cclink{color:#000; text-decoration:none;}';
html+='#comcast_content .cclink:hover{text-decoration:underline;}';
html+='#comcast_content .underline{text-decoration:underline;}';
html+='#comcast_content .buttonlink{color:#FFF; text-decoration: none !important;}';
html+='#comcast_content .button-row{text-align: center;}';
html+='#comcast_content .button.primary{text-decoration:none; -webkit-appearance: none; -moz-appearance: none;-ms-appearance: none;-o-appearance: none; appearance: none; color: #fff; font-family: XfinityStandard,Helvetica,Geneva,sans-serif;font-weight: 100; font-size: 16px; letter-spacing: .2px;display: inline-block;line-height: 28px; color: #fff; box-sizing: border-box;cursor: pointer;-webkit-tap-highlight-color: rgba(0,0,0,0); text-align: center;background: 0;border: 0;height: 35px;line-height: 35px;padding: 0 2em;margin-top: 10px; border-radius: 3ex; background: transparent; background-color: #0070b8;}';
html+='#comcast_content .button.primary:hover{text-decoration:none; background-color: #1a6992; border-color: #1a6992;}';
html +='#comcast_content.mobile-size { width: 80%; min-width: 300px; height:90%; top:40vh;}';
html += '#comcast_content.mobile-size .content-wrapper {padding: 10px 15px;overflow-y:scroll;-webkit-overflow-scrolling: touch;}';
html += '#comcast_content.mobile-size .titletext1 { font: 22px/24px bold XfinityStandard,Helvetica, Geneva, sans-serif;}';
html += '#comcast_content.mobile-size #footer .logo{width: 100%; margin: 0 auto;}';
html += '#comcast_content.mobile-size #footer .links {float: none;text-align: center;}';
html += '#comcast_content.mobile-size #footer .termsofservice {margin-left: 10px;}';
if (_ComcastAlert.browser.isIE && _ComcastAlert.browser.version<10){
html+='#comcast_content{opacity:1;}'
}
if (_ComcastAlert.browser.isIE && _ComcastAlert.browser.version<9){
html+='#comcast_content {max-height:none;}';
html+='#comcast_content .scroll-button{display: none;}';
}
html += '</style>';
if (_ComcastAlert.browser.isIE && _ComcastAlert.browser.version<9){
html += '<div class="main-wrapper" id="comcast_content">';
}else{
var mq = window.matchMedia("(max-width: 650px)");
if(mq.matches){
html += '<div class="main-wrapper mobile-size" id="comcast_content">';
}else{
html += '<div class="main-wrapper" id="comcast_content">';
}
}
html += '<div class="header" onmousedown="javascript:_ComcastAlert.dragStart(event,\'comcast_content\')">';
html += '<p class="xfinitylogo">';
html += winObj.xfinitylogo_url;
html += '</p>';
html += '<p class="closebn">';
html += winObj.closebulletin;
html += '</p>';
html += '</div>';
html += '<div class="content-wrapper">';
html += '<p class="titletext1">';
html += winObj.headertext1;
html += '</p>';
html += '<p class="titletext2">';
html += winObj.headertext2;
html += '</p>';
html += '<p class="textcontent1">';
html += winObj.textline1;
html += '</p>';
html += '<p class="textcontent1">';
html += winObj.textline2;
html += '</p>';
html += '<p class="textcontent4">';
html += winObj.textline3;
html += '</p>';
html += '<p class="textcontent4">';
html += winObj.textline4;
html += '</p>';
html += '<p class="textcontent1">';
html += winObj.textline5;
html += '</p>';
html += '<p class="textcontent3">';
html += winObj.textline6;
html += '</p>';
html += '<p class="comcastanalytics">';
html += winObj.analytics;
html += '</p>';
html += '<div id="footer">';
html += '<div class="links">';
html += '<p class="privacystatement">';
html += winObj.privacypolicylink;
html += '</p>';
html += '<p class="termsofservice">';
html += winObj.termslink;
html += '</p>';
html += '</div>';
html += '<div class="logo">';
html += '<p class="comcastlogo">';
html += winObj.comcastlogo_url;
html += '</p>';
html += '</div>';
html += '</div>';
html += '</div>';
html += '<div class="scroll-button" onmousedown="javascript:_ComcastAlert.scrollPopUp()"><div id="down"></div></div>';
html += '</div>';
html += '</div>';
document.body.innerHTML = document.body.innerHTML + html;
}
// Function to Determine browser and version. Copyright 2001 by Mike Hall.
, checkBrowser: function() {
var ua, s, i;
var browser = {
isIE: false
, isNS: false
, version: null
};
ua = navigator.userAgent;
s = "MSIE";
if ((i = ua.indexOf(s)) >= 1) {
browser.isIE = true; browser.version = parseFloat(ua.substr(i + s.length));
}
s = "Netscape6/";
if ((i = ua.indexOf(s)) >= 0) {
browser.isNS = true; browser.version = parseFloat(ua.substr(i + s.length));
}
s = "Gecko";
if ((i = ua.indexOf(s)) >= 0) {
browser.isNS = true; browser.version = 6.1;
}
return browser;
}
, dragStart: function(event, id) {
var browser1 = _ComcastAlert.browser;
var dragObj = _ComcastAlert.dragObj;
//console.log("dragObj="+ dragObj)
var el;
var x, y;
if (id) dragObj.elNode = document.getElementById(id);
else {
if (browser1.isIE) dragObj.elNode = window.event.srcElement;
if (browser1.isNS) dragObj.elNode = event.target;
if (dragObj.elNode.nodeType == 3) dragObj.elNode = dragObj.elNode.parentNode;
}
if (browser1.isIE) {
x = window.event.clientX + document.documentElement.scrollLeft + document.body.scrollLeft;
y = window.event.clientY + document.documentElement.scrollTop + document.body.scrollTop;
}
if (browser1.isNS) {
x = event.clientX + window.scrollX;
y = event.clientY + window.scrollY;
}
dragObj.cursorStartX = x;
dragObj.cursorStartY = y;
dragObj.elStartLeft = parseInt(dragObj.elNode.style.left, 10);
dragObj.elStartTop = parseInt(dragObj.elNode.style.top, 10);
if (isNaN(dragObj.elStartLeft)) dragObj.elStartLeft = dragObj.elNode.offsetLeft;//100;
if (isNaN(dragObj.elStartTop)) dragObj.elStartTop = dragObj.elNode.offsetTop;//400;
if (browser1.isIE) {
document.attachEvent("onmousemove", _ComcastAlert.dragGo);
document.attachEvent("onmouseup", _ComcastAlert.dragStop);
window.event.cancelBubble = true;
window.event.returnValue = false; }
if (browser1.isNS) {
document.addEventListener("mousemove", _ComcastAlert.dragGo, true);
document.addEventListener("mouseup", _ComcastAlert.dragStop, true);
event.preventDefault();
}
}
// End Function
, initResizeCheck: function() {
var browser1 = _ComcastAlert.browser;
if (browser1.isIE && browser1.version<10){
window.attachEvent("onresize", _ComcastAlert.onWindowResize);
_ComcastAlert.onWindowResize();
}else{
window.addEventListener('resize', _ComcastAlert.onWindowResize, false);
_ComcastAlert.monitorScroll();
}
}
, onWindowResize: function() {
var browser1 = _ComcastAlert.browser;
if (browser1.isIE && browser1.version<9){
var windowWidth = window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth;
var dragObj = document.getElementById("comcast_content");
dragObj.style.position = "absolute";
dragObj.style.left = (windowWidth-dragObj.offsetWidth)/2 +"px";
dragObj.style.top = '70px';
}else{
var popup = document.getElementById('comcast_content');
var obj = popup.classList.contains('mobile-size');
// console.log(obj)
var mq = window.matchMedia("(max-width: 650px)");
// console.log(mq)
if(mq.matches) {
//alert('match')
popup.classList.add('mobile-size');
} else{
popup.classList.remove('mobile-size');
}
}
}
, comcastContentnoCache: function() {
return Math.round(Math.random() * 96151252);
}
, dragGo: function(event) {
var browser1 = _ComcastAlert.browser;
var dragObj = _ComcastAlert.dragObj;
var x, y;
if (browser1.isIE) {
x = window.event.clientX + document.documentElement.scrollLeft + document.body.scrollLeft;
y = window.event.clientY + document.documentElement.scrollTop + document.body.scrollTop;
}
if (browser1.isNS) {
x = event.clientX + window.scrollX; y = event.clientY + window.scrollY;
}
dragObj.elNode.style.left = (dragObj.elStartLeft + x - dragObj.cursorStartX) + "px";
dragObj.elNode.style.top = (dragObj.elStartTop + y - dragObj.cursorStartY) + "px";
if (browser1.isIE) { window.event.cancelBubble = true; window.event.returnValue = false; }
if (browser1.isNS) event.preventDefault();
}
, dragStop: function(event) {
var browser1 = _ComcastAlert.browser;
if (browser1.isIE) {
document.detachEvent("onmousemove", _ComcastAlert.dragGo);
document.detachEvent("onmouseup", _ComcastAlert.dragStop);
}
if (browser1.isNS) {
document.removeEventListener("mousemove", _ComcastAlert.dragGo, true);
document.removeEventListener("mouseup", _ComcastAlert.dragStop, true);
}
}
, getXmlhttp: function(){
var xmlhttp=false; /*@cc_on @*/ /*@if (@_jscript_version >= 5) try { xmlhttp = new ActiveXObject("Msxml2.XMLHTTP"); } catch (e) { try { xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); } catch (E) { xmlhttp = false; } } @end @*/
if (!xmlhttp && typeof XMLHttpRequest!='undefined') {
try {
xmlhttp = new XMLHttpRequest();
} catch (e) {
xmlhttp=false;
}
}
if (!xmlhttp && window.createRequest) {
try {
xmlhttp = window.createRequest();
} catch (e) {
xmlhttp=false;
}
}
this.xmlhttp = xmlhttp;
}
, checkBulletin: function(){
if(_ComcastAlert.comcastCheck==0) { return; }
var xmlhttp = _ComcastAlert.xmlhttp;
xmlhttp.open("GET", _ComcastAlert.SYS_URL+'?dispatch=checkBulletin',true);
xmlhttp.onreadystatechange = function() {
if (xmlhttp.readyState == 4) {
if(xmlhttp.responseText.indexOf('43a1028c-7d11-11de-b687-1f15c5ad6a13') == -1){
document.getElementById('comcast_content').style.display="none";
_ComcastAlert.comcastCheck = 0;
}
_ComcastAlert.comcastTimer = setTimeout("_ComcastAlert.checkBulletin()",cal5000);
};
};
xmlhttp.send(null);
}
, close_comcast_alert: function() {
document.getElementById('comcast_content').style.display = "none";
_ComcastAlert.sendAck();
}
, acknowledge: function() {
_ComcastAlert.sendAck();
document.getElementById('comcast_content').style.display = "none";
}
, sendAck: function(){
var xmlhttp = _ComcastAlert.xmlhttp;
xmlhttp.open("GET", _ComcastAlert.SYS_URL+'?dispatch=ackBulletin',true);
xmlhttp.send(null)
}
, monitorScroll: function(){
var div = document.getElementsByClassName('content-wrapper')[0];
var downBtn = document.getElementById('down');
div.addEventListener("scroll", function(e) {
if (div.scrollTop + div.clientHeight >= div.scrollHeight){
downBtn.classList.add('rotate');
}else if (div.scrollTop==0){
downBtn.classList.remove('rotate');
}
});
}
, scrollPopUp: function() {
_ComcastAlert.scrollIt(
document.querySelector('.content-wrapper'),
100,
'easeOutQuad',
function(){
//console.log('end scroll')
}
// function(){console.log('end scroll')}
);
}
, scrollIt: function(destination, duration, easing, callback) {
//scrollIt: function(destination, duration=200, easing='linear', callback) {
var easings = {
linear: function(t) {
return t;
},
easeInQuad: function(t) {
return t * t;
},
easeOutQuad: function(t) {
return t * (2 - t);
},
easeInOutQuad: function(t) {
return t < 0.5 ? 2 * t * t : -1 + (4 - 2 * t) * t;
},
easeInCubic: function(t) {
return t * t * t;
},
easeOutCubic: function(t) {
return (--t) * t * t + 1;
},
easeInOutCubic: function(t) {
return t < 0.5 ? 4 * t * t * t : (t - 1) * (2 * t - 2) * (2 * t - 2) + 1;
},
easeInQuart: function(t) {
return t * t * t * t;
},
easeOutQuart: function(t) {
return 1 - (--t) * t * t * t;
},
easeInOutQuart: function(t) {
return t < 0.5 ? 8 * t * t * t * t : 1 - 8 * (--t) * t * t * t;
},
easeInQuint: function(t) {
return t * t * t * t * t;
},
easeOutQuint: function(t) {
return 1 + (--t) * t * t * t * t;
},
easeInOutQuint: function(t) {
return t < 0.5 ? 16 * t * t * t * t * t : 1 + 16 * (--t) * t * t * t * t;
}
};
var div = document.getElementsByClassName('content-wrapper')[0];
var downBtn = document.getElementById('down');
var aTop;
(div.scrollTop + div.clientHeight >= div.scrollHeight) ? atTop = false : atTop = true;
var start = div.pageYOffset;
var scrollPanels = Math.floor(div.scrollHeight/div.clientHeight);
var startTime = 'now' in window.performance ? performance.now() : new Date().getTime();
var distToEnd = div.scrollHeight - div.scrollTop;
var ratio = Math.ceil(div.scrollHeight/distToEnd);
var destinationOffsetToScroll = ratio*div.clientHeight;
if ('requestAnimationFrame' in window === false) {
if (atTop==true){
div.scrollTop +=destinationOffsetToScroll;
if (div.scrollTop >= destinationOffsetToScroll || div.scrollTop+div.clientHeight >= div.scrollHeight) {
if (callback) {
if (div.scrollTop+div.clientHeight >= div.scrollHeight){
atTop = false;
downBtn.classList.add('rotate');
}
callback();
}
return;
}
}else{
div.scrollTop =0;
if (div.scrollTop == 0 ) {
if (callback) {
atTop = true;
downBtn.classList.remove('rotate');
callback();
}
return;
}
}
}
function scroll() {
var now = 'now' in window.performance ? performance.now() : new Date().getTime();
var time = Math.min(1, ((now - startTime) / duration));
var timeFunction = easings[easing](time);
if (atTop==true){
div.scrollTop +=30;
if (div.scrollTop >= destinationOffsetToScroll || div.scrollTop+div.clientHeight >= div.scrollHeight) {
if (callback) {
if (div.scrollTop+div.clientHeight >= div.scrollHeight){
//alert(div.scrollTop >= destinationOffsetToScroll)
atTop = false;
downBtn.classList.add('rotate');
}
callback();
}
return;
}
}else{
div.scrollTop -=60;
if (div.scrollTop == 0 ) {
if (callback) {
atTop = true;
downBtn.classList.remove('rotate');
callback();
}
return;
}
}
requestAnimationFrame(scroll);
}
scroll();
}
// Function for Cross-browser full element.classList implementation.
/*
* By Eli Grey, http://eligrey.com
* License: Dedicated to the public domain.
* See https://github.com/eligrey/classList.js/blob/master/LICENSE.md
*/
/*! @source http://purl.eligrey.com/github/classList.js/blob/master/classList.js */
,polyfillClassList: function(){
"document"in self&&("classList"in document.createElement("_")&&(!document.createElementNS||"classList"in document.createElementNS("http://www.w3.org/2000/svg","g"))||!function(t){"use strict";if("Element"in t){var e="classList",n="prototype",i=t.Element[n],s=Object,r=String[n].trim||function(){return this.replace(/^\s+|\s+$/g,"")},o=Array[n].indexOf||function(t){for(var e=0,n=this.length;n>e;e++)if(e in this&&this[e]===t)return e;return-1},a=function(t,e){this.name=t,this.code=DOMException[t],this.message=e},c=function(t,e){if(""===e)throw new a("SYNTAX_ERR","An invalid or illegal string was specified");if(/\s/.test(e))throw new a("INVALID_CHARACTER_ERR","String contains an invalid character");return o.call(t,e)},l=function(t){for(var e=r.call(t.getAttribute("class")||""),n=e?e.split(/\s+/):[],i=0,s=n.length;s>i;i++)this.push(n[i]);this._updateClassName=function(){t.setAttribute("class",""+this)}},u=l[n]=[],h=function(){return new l(this)};if(a[n]=Error[n],u.item=function(t){return this[t]||null},u.contains=function(t){return t+="",-1!==c(this,t)},u.add=function(){var t,e=arguments,n=0,i=e.length,s=!1;do t=e[n]+"",-1===c(this,t)&&(this.push(t),s=!0);while(++n<i);s&&this._updateClassName()},u.remove=function(){var t,e,n=arguments,i=0,s=n.length,r=!1;do for(t=n[i]+"",e=c(this,t);-1!==e;)this.splice(e,1),r=!0,e=c(this,t);while(++i<s);r&&this._updateClassName()},u.toggle=function(t,e){t+="";var n=this.contains(t),i=n?e!==!0&&"remove":e!==!1&&"add";return i&&this[i](t),e===!0||e===!1?e:!n},u.toString=function(){return this.join(" ")},s.defineProperty){var f={get:h,enumerable:!0,configurable:!0};try{s.defineProperty(i,e,f)}catch(g){(void 0===g.number||-2146823252===g.number)&&(f.enumerable=!1,s.defineProperty(i,e,f))}}else s[n].__defineGetter__&&i.__defineGetter__(e,h)}}(self),function(){"use strict";var t=document.createElement("_");if(t.classList.add("c1","c2"),!t.classList.contains("c2")){var e=function(t){var e=DOMTokenList.prototype[t];DOMTokenList.prototype[t]=function(t){var n,i=arguments.length;for(n=0;i>n;n++)t=arguments[n],e.call(this,t)}};e("add"),e("remove")}if(t.classList.toggle("c3",!1),t.classList.contains("c3")){var n=DOMTokenList.prototype.toggle;DOMTokenList.prototype.toggle=function(t,e){return 1 in arguments&&!this.contains(t)==!e?e:n.call(this,t)}}t=null}());
}
}
}());
_ComcastAlert.go();
</script>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment