Don't insert CSS on player element. Insert CSS into page instead. Popup doesn't work, still.
This commit is contained in:
parent
afefed7f34
commit
2df3c3c9be
@ -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
|
||||||
|
@ -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.");
|
||||||
|
@ -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) {
|
||||||
|
@ -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() {
|
||||||
|
@ -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');
|
||||||
|
@ -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;
|
||||||
|
@ -72,14 +72,22 @@
|
|||||||
type="number"
|
type="number"
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<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">
|
<div class="flex flex-column">
|
||||||
<div class="flex label-secondary form-label">Additional css</div>
|
<textarea
|
||||||
<input type="text"
|
|
||||||
v-model="playerCss"
|
v-model="playerCss"
|
||||||
@change="updatePlayerCss"
|
@change="updatePlayerCss"
|
||||||
@blur="updatePlayerCss"
|
@blur="updatePlayerCss"
|
||||||
/>
|
>
|
||||||
</div>
|
</textarea>
|
||||||
</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();
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -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 */
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user