-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathdp.js
252 lines (244 loc) · 18.4 KB
/
dp.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
// (c) Andrew
// Icon by dunedhel: http://dunedhel.deviantart.com/
// Supporting functions by AdThwart - T. Joseph
var origtitle;
var postloaddelay;
var dphotkeylistener;
var timestamp = Math.round(new Date().getTime()/1000.0);
function addCloak(sfw, f, fsize, u, bg, text, table, link, bold, o1, o2, collapseimage, customcss) {
// Inject CSS into page
var cssinject = document.createElement("style");
cssinject.setAttribute("__decreased__", "productivity"+timestamp);
var curlocation = document.location.href;
var boldcss = '';
var fontType = '';
if (f != 'Serif' && f != 'Monospace' && f != '-Unchanged-') f = '"' + f + '", sans-serif';
if (f != '-Unchanged-') fontType = 'font-size: ' + fsize + 'px !important; font-family: ' + f + ' !important; h1, h2, h3, h4, h5, h6, h7, h8 { font-size: ' + fsize + 'px !important; font-weight: bold !important; } ';
if (bold == 'true') boldcss = 'font-weight: normal !important; ';
// The code that does the magic
var magic = 'html, html *, html *[style], body *:before, body *:after { background-color: #' + bg + ' !important; border-color: #' + table + ' !important; border-collapse: collapse !important; color: #' + text + ' !important; stroke: #' + text + ' !important; fill: #' + bg + ' !important; ' + fontType + 'text-decoration: none !important; -webkit-filter: initial !important; box-shadow: none !important; -webkit-box-shadow: none !important; text-shadow: none !important; ' + boldcss + '} ';
if (curlocation.match(/^https?:\/\/www\.facebook\.com\//i)) {
magic += 'html, html *:not(.img), body *:not(.img):before, body *:not(.img):after { background-image: none !important; } ';
magic += '*:after { content: initial !important; } ';
if (sfw == 'SFW' || sfw == 'SFW1' || sfw == 'SFW2') magic += 'i.img { opacity: '+o1+' !important; } i.img:hover { opacity: '+o2+' !important; } ';
else if (o1 == 0 && collapseimage == 'true') magic += 'i.img { display: none !important; } ';
else if (sfw == 'Paranoid') magic += 'i.img { visibility: hidden !important; opacity: 0 !important; } ';
} else {
if (!curlocation.match(/^https?:\/\/web\.whatsapp\.com\//i)) magic += 'html, html *, body *:before, body *:after { background-image: none !important; } ';
}
if (curlocation.match(/^https?:\/\/www\.engadget\.com\//i)) {
magic += 'html, html *, html *[style], body *:before, body *:after { border-width: 0px !important; }';
} else {
magic += 'html, html *, html *[style], body *:before, body *:after { border-width: 1px !important; }';
}
magic += 'input[type=text],input[type=password],input[type=file],input[type=search],textarea,input[type=button],input[type=submit],#lastpass-notification button[type="button"] { border: 1px dotted #' + table + ' !important; background-color: #' + bg + ' !important; color: #' + text + ' !important; } html::selection, html *::selection { background: #888888 !important; color: #fff !important; } a { color: #' + link + ' !important; text-decoration: ';
if (u == 'true') magic += 'underline !important; }';
else magic += 'none !important; }';
if (sfw == 'SFW' || sfw == 'SFW1' || sfw == 'SFW2') {
if (o1 == 0 && collapseimage == 'true') magic += ' iframe, img, canvas, input[type=image], path, polygon, picture { display: none !important; }';
else magic += ' iframe, img, canvas, input[type=image], path, polygon, picture { opacity: '+o1+' !important; } iframe:hover, img:hover, input[type=image]:hover, path:hover, polygon:hover { opacity: '+o2+' !important; }';
}
if (sfw == 'SFW') {
if (o1 == 0 && collapseimage == 'true') magic += ' object, embed, param, video, audio { display: none !important; }';
else magic += ' object, embed, param, video, audio { opacity: '+o1+' !important; } object:hover, embed:hover, param:hover, video:hover, audio:hover { opacity: '+o2+' !important; }';
}
if (sfw == 'SFW1') magic += ' object, embed, param, video, audio { display: none !important; opacity: 0 !important; }';
if (sfw == 'Paranoid') magic += ' img, canvas, input[type=image], path, polygon, object, embed, param, video, audio, picture { display: none !important; opacity: 0 !important; } iframe { opacity: 0.05 !important; } iframe:hover { opacity: 0.5 !important; }';
magic += ' .dp'+timestamp+'_visible { visibility: visible !important; opacity: 1 !important; }';
magic += ' .dp'+timestamp+'_unbold { font-weight: normal !important }';
magic += ' .dp'+timestamp+'_link { color: #'+link+' !important; background-color: #'+bg+' !important; background-image: none !important; }';
if (curlocation.match(/^https?:\/\/web\.whatsapp\.com\//i)) magic += ' .dp'+timestamp+'_text { color: #'+text+' !important; background-color: #'+bg+' !important; }';
else magic += ' .dp'+timestamp+'_text { color: #'+text+' !important; background-color: #'+bg+' !important; background-image: none !important; }';
magic += ' .dp'+timestamp+'_hide { display: none !important }';
if (curlocation.match(/^https?:\/\/www\.(?:facebook\.com|facebookcorewwwi\.onion)\//i)) {
magic += " ._52c6, ._5ine, .__cy, .fbPhotosPhotoTagboxes, ._jfi, ._5vb_ ._5aqh::before { position: initial !important; } "; // fix link caption, event cover photo, full-screen photo mode (._jfi = uploaded image thumbnail), instagram
magic += " ._4zoz._4zoz._4zoz, ._559p { clear: both !important; } "; // fix main timeline post status box
magic += " ._2yq ._4-u2::before { background-color: transparent !important; } "; // fix main timeline post title bars
magic += " ._2-sx { position: absolute !important; top: 0 !important; left: 0 !important; } "; // fix spotlight photo positioning
magic += " ._4d3w._2nw8 ._4g9v, ._4d3w._2nw8 ._4g9v *, ._4d3w._2nw8 .snowliftOverlayBar, ._4d3w .rightButtons .overlayBarButtons, ._4d3w .rightButtons .overlayBarButtons * { background-color: transparent !important; } "; // make spotlight top/bottom bars transparent
magic += " ._1ift { pointer-events: initial !important; } "; // make chat icons react to hover
magic += " ._3htz { display: none !important; } "; // hide video overlay
}
else if (curlocation.match(/^https?:\/\/www\.youtube\.com\//i)) {
magic += " .ytp-gradient-top, .ytp-gradient-bottom { display: none !important; } "; // improve embedded youtube display
magic += " .ytp-chrome-top, .ytp-title, .ytp-title *, .ytp-chrome-bottom[style], .ytp-chrome-bottom * { background-color: transparent !important; } "; // improve embedded youtube display
magic += " .ytp-play-button:not(.ytp-play-button-playlist)::before, .ytp-fullscreen-button::after { display: none !important; } "; // improve embedded youtube display
magic += " .like-button-renderer-like-button:before, .like-button-renderer-dislike-button:before, .yt-high-contrast-mode-white .yt-uix-button-subscribe-branded:before { content: '' !important; } ";
}
else if (curlocation.match(/^https?:\/\/www\.instagram\.com\//i)) {
magic += " ._ovg3g, ._njmhc { position: initial !important; } ._sppa1 { display: none !important; } ";
}
else if (curlocation.match(/^https?:\/\/web\.whatsapp\.com\//i)) {
magic += " .app > div, .app > div > div, .app > div > div > span { background-color: transparent !important; } "; // fix blank white screen
magic += " .message-in { float: none !important; } "; // fix incoming message display
magic += " .msg { clear: both !important; } "; // fix outgoing message display
magic += ' .copyable-text, .copyable-text > div { background-color: transparent !important; } '; // fix message timestamping
magic += ' .message-in, .message-out { border: 1px dotted #' + table + ' !important; } '; // distinguish bubbles
magic += ' .drawer-manager, .drawer-manager > .pane { background-color: transparent !important; } '; // fix white screen bug
magic += ' .video-thumb, .video-thumb > div { background-color: transparent !important; } '; // show video thumbnails
magic += ' .message-out .tail-container { display: none !important; } '; // hide message out tail
if (sfw == 'SFW' || sfw == 'SFW1' || sfw == 'SFW2') {
magic += ' div[data-asset-intro-image="true"] { opacity: '+o1+' !important; } div[data-asset-intro-image="true"]:hover { opacity: '+o2+' !important; } '; // add cloak support for welcome graphic
magic += ' .icon { opacity: '+o1+' !important; } .icon:hover { opacity: '+o2+' !important; } '; // add cloak support for welcome graphic
magic += ' .video-thumb > div { opacity: '+o1+' !important; } .video-thumb > div:hover { opacity: '+o2+' !important; } '; // add cloak support for video thumbnails
magic += ' .emojik { opacity: '+o1+' !important; } .emojik:hover { opacity: '+o2+' !important; } '; // add cloak support for emoji list
} else if (sfw == 'Paranoid') magic += ' div[data-asset-intro-image="true"] { display: none !important; } '; // hide welcome graphic
magic += ' .copyable-text img { pointer-events: initial !important; } '; // make emojis and icons at cloak-hover opacity
}
else if (curlocation.match(/^https?:\/\/twitter\.com\//i)) {
magic += " .QuoteTweet, .QuoteTweet *, #playerContainer, #playerContainer *, .Gallery, .Gallery * { background-color: transparent !important; } ";
if (sfw != 'Paranoid' && sfw != 'SFW1') magic += " #playerContainer video { opacity: 1 !important; } ";
magic += " .Grid--withGutter>.Grid-cell { margin-right: -1px !important; margin-left: -1px !important; } ";
}
else if (curlocation.match(/^https?:\/\/plus\.google\.com\//i)) {
magic += " .x2 { position: initial !important; } ";
}
else if (curlocation.match(/^https?:\/\/www\.engadget\.com\//i)) {
magic += " .o-hit { cursor: initial !important; } ";
magic += " .o-hit .o-hit__link { position: initial !important; } ";
}
else if (curlocation.match(/^https?:\/\/.+\.wikia\.com\//i)) {
magic += " body.background-dynamic.skin-oasis::after, body.background-dynamic.skin-oasis::before { background-image: none !important; } ";
}
else if (curlocation.match(/^https?:\/\/.*\.?((lifehack|gawk)er|deadspin|jalopnik|gizmodo|jezebel|kotaku)\.com\//i)) {
magic += " .img-border:after { position: initial !important; } ";
}
else if (curlocation.match(/^https?:\/\/www\.reddit\.com\//i)) {
magic += ' .res-nightmode #header-bottom-right { background-color: #' + bg + ' !important; border-color: #' + table + ' !important; } ';
magic += ' .RES-keyNav-activeElement, .RES-keyNav-activeElement .md-container, .res-commentBoxes .comment, .res-commentBoxes .comment .comment, .res-commentBoxes .comment .comment .comment, .res-commentBoxes .comment .comment .comment .comment, .res-commentBoxes .comment .comment .comment .comment .comment, .res-commentBoxes .comment .comment .comment .comment .comment .comment, .res-commentBoxes .comment .comment .comment .comment .comment .comment .comment, .res-commentBoxes .comment .comment .comment .comment .comment .comment .comment .comment, .res-commentBoxes .comment .comment .comment .comment .comment .comment .comment .comment .comment, .res-commentBoxes .comment .comment .comment .comment .comment .comment .comment .comment .comment .comment { background-color: #' + bg + ' !important; border-color: #' + table + ' !important; } ';
magic += ' .res-nightmode .link, .res-nightmode .RES-keyNav-activeElement, .res-nightmode .RES-keyNav-activeElement .md-container, .res-nightmode.res-commentBoxes .comment, .res-nightmode.res-commentBoxes .comment .comment, .res-nightmode.res-commentBoxes .comment .comment .comment, .res-nightmode.res-commentBoxes .comment .comment .comment .comment, .res-nightmode.res-commentBoxes .comment .comment .comment .comment .comment, .res-nightmode.res-commentBoxes .comment .comment .comment .comment .comment .comment, .res-nightmode.res-commentBoxes .comment .comment .comment .comment .comment .comment .comment, .res-nightmode.res-commentBoxes .comment .comment .comment .comment .comment .comment .comment .comment, .res-nightmode.res-commentBoxes .comment .comment .comment .comment .comment .comment .comment .comment .comment, .res-nightmode.res-commentBoxes .comment .comment .comment .comment .comment .comment .comment .comment .comment .comment { background-color: #' + bg + ' !important; border-color: #' + table + ' !important; } ';
magic += ' .res-nightmode #header-bottom-right a, .res-nightmode a.title, .res-nightmode a.title:visited, .res-nightmode .RES-keyNav-activeElement > .tagline, .res-nightmode .RES-keyNav-activeElement .md-container > .md, .res-nightmode .RES-keyNav-activeElement .md-container > .md p, .res-nightmode #search input[type="text"] { color: #' + text + ' !important; } ';
magic += ' .usertext-edit textarea { border: 1px dotted #' + table + ' !important; } ';
}
if (customcss) magic += customcss.replace(/(?:\r\n|\r|\n)/g, ' ');
removeCss('initialstealth'+timestamp);
if (jQuery("style[__decreased__='productivity"+timestamp+"']").length) {
jQuery("style[__decreased__='productivity"+timestamp+"']").remove();
jQuery("[__decreased__]").each(function() {
jQuery(this).removeClass('dp'+timestamp+'_visible dp'+timestamp+'_unbold dp'+timestamp+'_link dp'+timestamp+'_text dp'+timestamp+'_hide').removeAttr("__decreased__");
});
}
cssinject.innerText = magic;
document.documentElement.appendChild(cssinject, null);
}
function dpPostLoad(dpheight, dpwidth, sfwmode, bold) {
if (dpwidth > 0 && dpheight > 0) {
jQuery("img:not([__decreased__='image"+timestamp+"'])").each(function() {
jQuery(this).attr('__decreased__', 'image'+timestamp);
if (this.width <= dpwidth && this.height <= dpheight)
jQuery(this).addClass('dp'+timestamp+'_visible');
else
if (sfwmode == "Paranoid") jQuery(this).addClass('dp'+timestamp+'_hide');
});
}
if (bold == 'true') {
jQuery("a:not([__decreased__='link"+timestamp+"'])").addClass('dp'+timestamp+'_link dp'+timestamp+'_unbold').attr('__decreased__', 'link'+timestamp);
jQuery("body *:not([__decreased__])").addClass('dp'+timestamp+'_text dp'+timestamp+'_unbold').attr('__decreased__', 'element'+timestamp);
} else {
jQuery("a:not([__decreased__='link"+timestamp+"'])").addClass('dp'+timestamp+'_link').attr('__decreased__', 'link'+timestamp);
jQuery("body *:not([__decreased__])").addClass('dp'+timestamp+'_text').attr('__decreased__', 'element'+timestamp);
}
}
function removeCss(name) {
if (typeof(name) === 'undefined') jQuery("style[__decreased__='productivity"+timestamp+"']").remove();
else jQuery("style[__decreased__='"+name+"']").remove();
if (typeof(name) === 'undefined') {
faviconrestore();
titleRestore();
jQuery('body').unbind('DOMSubtreeModified.decreasedproductivity'+timestamp);
jQuery("[__decreased__]").each(function() {
jQuery(this).removeClass('dp'+timestamp+'_visible dp'+timestamp+'_unbold dp'+timestamp+'_link dp'+timestamp+'_text dp'+timestamp+'_hide').removeAttr("__decreased__");
});
}
}
function init() {
chrome.runtime.sendMessage({reqtype: "get-settings"}, function(response) {
if (response.enable == "true") {
addCloak(response.sfwmode, response.font, response.fontsize, response.underline, response.background, response.text, response.table, response.link, response.bold, response.opacity1, response.opacity2, response.collapseimage, response.customcss);
dpPostLoad(response.maxheight, response.maxwidth, response.sfwmode, response.bold);
jQuery('body').unbind('DOMSubtreeModified.decreasedproductivity'+timestamp);
jQuery('body').bind('DOMSubtreeModified.decreasedproductivity'+timestamp, function() {
clearTimeout(postloaddelay);
postloaddelay = setTimeout(function(){ dpPostLoad(response.maxheight, response.maxwidth, response.sfwmode, response.bold) }, 500);
});
}
});
}
// Favicon.js - Change favicon dynamically [http://ajaxify.com/run/favicon].
// Copyright (c) 2006 Michael Mahemoff
// Modifications - Andrew Y.
function faviconblank() {
jQuery(document).ready(function() {
if (!jQuery("link#decreasedproductivity"+timestamp).length) {
var link = document.createElement("link");
link.type = "image/x-icon";
link.rel = "shortcut icon";
link.id = "decreasedproductivity"+timestamp;
link.href = ''; // transparent png
faviconclear();
document.getElementsByTagName("head")[0].appendChild(link);
}
});
}
function faviconclear() {
jQuery("link[rel='shortcut icon'], link[rel='icon']").each(function() {
jQuery(this).attr('data-rel', jQuery(this).attr('rel')).removeAttr('rel');
});
}
function faviconrestore() {
jQuery("link#decreasedproductivity"+timestamp).remove();
jQuery("link[data-rel='shortcut icon'], link[data-rel='icon']").each(function() {
jQuery(this).attr('rel', jQuery(this).attr('data-rel')).removeAttr('data-rel');
});
}
// Favicon Blanking Code END
function replaceTitle(text) {
if (document.title != text) {
if (document.title && !origtitle) origtitle = document.title;
document.title=text;
}
}
function titleBind(text) {
jQuery('title').unbind('DOMSubtreeModified.decreasedproductivity'+timestamp);
jQuery('title').bind('DOMSubtreeModified.decreasedproductivity'+timestamp, function() {
replaceTitle(text);
});
}
function titleRestore() {
jQuery('title').unbind('DOMSubtreeModified.decreasedproductivity'+timestamp);
if (origtitle) document.title = origtitle;
}
function hotkeySet(hotkeyenabled, hotkey, paranoidhotkey) {
if (dphotkeylistener) dphotkeylistener.reset();
if (hotkeyenabled == 'true') {
dphotkeylistener = new window.keypress.Listener();
if (hotkey) {
dphotkeylistener.simple_combo(hotkey.toLowerCase(), function() {
chrome.runtime.sendMessage({reqtype: "toggle"});
});
}
if (paranoidhotkey) {
dphotkeylistener.simple_combo(paranoidhotkey.toLowerCase(), function() {
chrome.runtime.sendMessage({reqtype: "toggleparanoid"});
});
}
}
}
// Initially hide all elements on page (injected code is removed when page is loaded)
chrome.runtime.sendMessage({reqtype: "get-enabled"}, function(response) {
jQuery(document).ready(function() {
hotkeySet(response.enableToggle, response.hotkey, response.paranoidhotkey);
});
if (response.enable == "true") {
if (response.favicon == 'true') faviconblank();
if (response.hidePageTitles == 'true') {
replaceTitle(response.pageTitleText);
titleBind(response.pageTitleText);
}
var stealth = document.createElement("style");
stealth.setAttribute("__decreased__", "initialstealth"+timestamp);
stealth.innerText += "html, html *, html *[style], body *:before, body *:after { background-color: #" + response.background + " !important; background-image: none !important; background: #" + response.background+ " !important; } html * { visibility: hidden !important; }";
document.documentElement.appendChild(stealth, null);
init();
}
});