Don't insert CSS on player element. Insert CSS into page instead. Popup doesn't work, still.

This commit is contained in:
Tamius Han 2019-06-14 02:15:24 +02:00
parent afefed7f34
commit 2df3c3c9be
8 changed files with 94 additions and 36 deletions

View File

@ -940,7 +940,8 @@ var ExtensionConf = {
videoAncestor: 1, videoAncestor: 1,
// additionalCss: '', // additionalCss: '',
} }
} },
css: '',
// videoElement: { // extra stuff for video tag // videoElement: { // extra stuff for video tag
// querySelectors: [], // array of strings with css selectors // querySelectors: [], // array of strings with css selectors
// userCss: [], // additional styles that user can define for video element // userCss: [], // additional styles that user can define for video element

View File

@ -151,6 +151,10 @@ class CommsClient {
return Promise.resolve(true); return Promise.resolve(true);
} }
async sendMessage(message) {
await this.sendMessage_nonpersistent(message);
}
registerVideo(){ registerVideo(){
if (Debug.debug && Debug.comms) { if (Debug.debug && Debug.comms) {
console.log(`[CommsClient::registerVideo] <${this.commsId}>`, "Registering video for current page."); console.log(`[CommsClient::registerVideo] <${this.commsId}>`, "Registering video for current page.");

View File

@ -13,7 +13,7 @@ class CommsServer {
if (BrowserDetect.firefox) { if (BrowserDetect.firefox) {
browser.runtime.onConnect.addListener(p => ths.onConnect(p)); browser.runtime.onConnect.addListener(p => ths.onConnect(p));
browser.runtime.onMessage.addListener(m => ths.processReceivedMessage_nonpersistent(m)); browser.runtime.onMessage.addListener((m, sender) => ths.processReceivedMessage_nonpersistent(m, sender));
} else { } else {
chrome.runtime.onConnect.addListener(p => ths.onConnect(p)); chrome.runtime.onConnect.addListener(p => ths.onConnect(p));
chrome.runtime.onMessage.addListener((m, sender, callback) => ths.processReceivedMessage_nonpersistent(m, sender, callback)); chrome.runtime.onMessage.addListener((m, sender, callback) => ths.processReceivedMessage_nonpersistent(m, sender, callback));
@ -214,6 +214,14 @@ class CommsServer {
processReceivedMessage_nonpersistent(message, sender, sendResponse){ processReceivedMessage_nonpersistent(message, sender, sendResponse){
if (Debug.debug && Debug.comms) { if (Debug.debug && Debug.comms) {
console.log("%c[CommsServer.js::processMessage_nonpersistent] Received message from background script!", "background-color: #11D; color: #aad", message, sender); console.log("%c[CommsServer.js::processMessage_nonpersistent] Received message from background script!", "background-color: #11D; color: #aad", message, sender);
if (message.cmd === 'inject-css') {
this.server.injectCss(message.cssString, sender);
return;
}
if (message.cmd === 'remove-css') {
this.server.removeCss(message.cssString, sender);
return;
} }
if (message.forwardToContentScript) { if (message.forwardToContentScript) {

View File

@ -27,6 +27,18 @@ class PageInfo {
this.scheduleUrlCheck(); this.scheduleUrlCheck();
this.currentZoomScale = 1; this.currentZoomScale = 1;
try {
const playerStyleString = this.settings.active.sites[window.location.host].css;
if (playerStyleString) {
this.comms.sendMessage({
cmd: 'inject-css',
cssString: playerStyleString
});
}
} catch (e) {
// do nothing. It's ok if there's no special settings for the player element
}
} }
destroy() { destroy() {
@ -40,6 +52,18 @@ class PageInfo {
this.comms.unregisterVideo(video.id) this.comms.unregisterVideo(video.id)
video.destroy(); video.destroy();
} }
try {
playerStyleString = this.settings.active.sites[window.location.host].css;
if (playerStyleString) {
this.comms.sendMessage({
cmd: 'remove-css',
cssString: playerStyleString
});
}
} catch (e) {
// do nothing. It's ok if there's no special settings for the player element
}
} }
reset() { reset() {

View File

@ -621,32 +621,14 @@ class Resizer {
} }
const styleString = this.buildStyleString(styleArray); const styleString = this.buildStyleString(styleArray);
// see if we have any extra css for the player element:
let playerStyleString;
try {
playerStyleString = this.settings.active.sites[window.location.host].DOM.player.additionalCss;
if (playerStyleString) {
const playerStyleArrayString = this.player.eleemnt.getAttribute('style');
const playerStyleArray = this.buildStyleArray(playerStyleString, playerStyleString);
playerStyleString = this.buildStyleString(playerStyleArray);
}
} catch (e) {
// do nothing. It's ok if there's no special settings for the player element
}
// build style string back // build style string back
this.setStyleString(styleString, playerStyleString); this.setStyleString(styleString);
} }
setStyleString (styleString, playerStyleString) { setStyleString (styleString) {
this.video.setAttribute("style", styleString); this.video.setAttribute("style", styleString);
this.currentStyleString = styleString; this.currentStyleString = styleString;
if (playerStyleString) {
this.player.element.setAttribute('style', styleString);
this.currentPlayerStyleString = playerStyleString;
}
this.currentCssValidFor = this.conf.player.dimensions; this.currentCssValidFor = this.conf.player.dimensions;
if (this.restore_wd) { if (this.restore_wd) {
@ -713,7 +695,6 @@ class Resizer {
// first, a quick test: // first, a quick test:
cssValid &= this.currentVideoSettings.validFor.width === this.conf.player.dimensions.width; cssValid &= this.currentVideoSettings.validFor.width === this.conf.player.dimensions.width;
cssValid &= this.currentVideoSettings.validFor.height === this.conf.player.dimensions.height;
if (cssValid) { if (cssValid) {
const styleString = this.video.getAttribute('style'); const styleString = this.video.getAttribute('style');

View File

@ -52,6 +52,30 @@ class UWServer {
}); });
} }
async injectCss(css, sender) {
try {
if (Debug.debug) {
console.log("[uwbg::injectCss] Injecting CSS:", css, sender);
}
if (BrowserDetect.firefox || BrowserDetect.edge) {
await browser.tabs.insertCSS(sender.tab.id, {code: css, cssOrigin: 'user', frameId: sender.frameId});
} else if (BrowserDetect.chrome) {
chrome.tabs.insertCSS(sender.tab.id, {code: css, cssOrigin: 'user', frameId: sender.frameId});
}
} catch (e) {
if (Debug.debug) {
console.error("Error while injecting css:", {error: e, css, sender});
}
}
}
removetCss(css, sender) {
if (BrowserDetect.firefox || BrowserDetect.edge) {
browser.tabs.removeCSS(sender.tab.idd, {code: css, cssOrigin: 'user', frameId: sender.frameId});
} else if (BrowserDetect.chrome) {
chrome.tabs.removeCSS(sender.tab.id, {code: css, cssOrigin: 'user', frameId: sender.frameId});
}
}
scheduleGc(timeout) { scheduleGc(timeout) {
if (this._gctimeout) { if (this._gctimeout) {
return; return;

View File

@ -72,15 +72,23 @@
type="number" type="number"
/> />
</div> </div>
<div class="flex flex-column">
<div class="flex label-secondary form-label">Additional css</div> </div>
<input type="text"
<div class="label">
Additional css<br/><small>for {{site}}</small>
</div>
<div class="description">
This css will be inserted into webpage every time it loads.
</div>
<div class="flex flex-column">
<textarea
v-model="playerCss" v-model="playerCss"
@change="updatePlayerCss" @change="updatePlayerCss"
@blur="updatePlayerCss" @blur="updatePlayerCss"
/> >
</textarea>
</div> </div>
</div>
</div> </div>
</template> </template>
@ -121,12 +129,17 @@ export default {
try { try {
this.playerManualQs = settings.active.sites[this.site].DOM.player.manual || this.playerManualQs; this.playerManualQs = settings.active.sites[this.site].DOM.player.manual || this.playerManualQs;
this.playerQs = settings.active.sites[this.site].DOM.player.querySelectors; this.playerQs = settings.active.sites[this.site].DOM.player.querySelectors;
this.playerCss = settings.active.sites[this.site].DOM.player.additionalCss; this.playerByNodeIndex = settings.active.sites[this.site].DOM.player.useRelativeAncestor || this.playerByNodeIndex;
this.playerByNodeIndex = settings.active.sites[this.site].DOM.player.useRelativeAncestor;
this.playerParentNodeIndex = settings.active.sites[this.site].DOM.player.videoAncestor; this.playerParentNodeIndex = settings.active.sites[this.site].DOM.player.videoAncestor;
} catch (e) { } catch (e) {
// that's here just in case relevant settings for this site don't exist yet // that's here just in case relevant settings for this site don't exist yet
} }
try {
this.playerCss = settings.active.sites[this.site].css || '';
} catch (e) {
// that's here just in case relevant settings for this site don't exist yet
}
}, },
methods: { methods: {
ensureSettings(scope) { ensureSettings(scope) {
@ -169,9 +182,9 @@ export default {
this.settings.active.sites[this.site].DOM.player.querySelectors = this.playerQs; this.settings.active.sites[this.site].DOM.player.querySelectors = this.playerQs;
this.settings.save(); this.settings.save();
}, },
updateVideoCss() { updatePlayerCss() {
this.ensureSettings('player'); this.ensureSettings('player');
this.settings.active.sites[this.site].DOM.player.additionalCss = this.playerCss; this.settings.active.sites[this.site].css = this.playerCss;
this.settings.save(); this.settings.save();
}, },
updatePlayerParentNodeIndex() { updatePlayerParentNodeIndex() {
@ -181,20 +194,20 @@ export default {
}, },
toggleVideoManualQs() { toggleVideoManualQs() {
this.ensureSettings('video'); this.ensureSettings('video');
this.settings.active.sites[this.site].DOM.video.enabled = !this.settings.active.sites[this.site].DOM.video.enabled;
this.videoManualQs = !this.videoManualQs; this.videoManualQs = !this.videoManualQs;
this.settings.active.sites[this.site].DOM.video.enabled = this.videoManualQs;
this.settings.save(); this.settings.save();
}, },
togglePlayerManualQs() { togglePlayerManualQs() {
this.ensureSettings('player'); this.ensureSettings('player');
this.settings.active.sites[this.site].DOM.player.enabled = !this.settings.active.sites[this.site].DOM.player.enabled;
this.playerManualQs = !this.playerManualQs; this.playerManualQs = !this.playerManualQs;
this.settings.active.sites[this.site].DOM.player.enabled = this.playerManualQs;
this.settings.save(); this.settings.save();
}, },
toggleByNodeIndex() { toggleByNodeIndex() {
this.ensureSettings('player'); this.ensureSettings('player');
this.settings.active.sites[this.site].DOM.player.useRelativeAncestor = !this.settings.active.sites[this.site].DOM.player.useRelativeAncestor;
this.playerByNodeIndex = !this.playerByNodeIndex; this.playerByNodeIndex = !this.playerByNodeIndex;
this.settings.active.sites[this.site].DOM.player.useRelativeAncestor = this.playerByNodeIndex;
this.settings.save(); this.settings.save();
}, },
} }

View File

@ -93,7 +93,6 @@ a:hover {
} }
/* INPUT FORMATTING */ /* INPUT FORMATTING */
input[type="number"], input[type="text"], input { input[type="number"], input[type="text"], input {
outline: none; outline: none;
background-color: $input-background; background-color: $input-background;
@ -105,6 +104,10 @@ input[type="number"], input[type="text"], input {
border: 1px solid $input-border; border: 1px solid $input-border;
} }
input:disabled {
background: #444444;
color: darken($text-normal, 50%);
}
/* ELEMENT POSITIONING */ /* ELEMENT POSITIONING */