Cropping now also works from in-player UI

This commit is contained in:
Tamius Han 2021-10-19 22:49:13 +02:00
parent 2a747e11af
commit 3846d1a926
3 changed files with 67 additions and 12 deletions

View File

@ -49,6 +49,7 @@ import CropModePersistence from '../../common/enums/CropModePersistence.enum';
export default { export default {
data() { data() {
return { return {
exec: null,
scope: 'page', scope: 'page',
CropModePersistence: CropModePersistence, CropModePersistence: CropModePersistence,
} }
@ -63,7 +64,7 @@ export default {
'cropModePersistence', 'cropModePersistence',
], ],
created() { created() {
this.exec = new ExecAction(this.settings); this.exec = new ExecAction(this.settings, window.location.hostname, window.ultrawidify);
}, },
components: { components: {
ShortcutButton, ShortcutButton,
@ -78,7 +79,13 @@ export default {
BrowserDetect.runtime.openOptionsPage(); BrowserDetect.runtime.openOptionsPage();
}, },
execAction(action) { execAction(action) {
this.exec.exec(action, 'page', this.frame); console.log('execing action:', action, window.ultrawidify);
try {
this.exec.exec(action, 'page', this.frame, true);
} catch (error) {
console.error('[uw:VideoSettings.vue::execAction] failed to execute action. Error:', error);
}
}, },
parseShortcut(action) { parseShortcut(action) {
if (! action.scopes.page.shortcut) { if (! action.scopes.page.shortcut) {
@ -98,9 +105,6 @@ export default {
// this.frame // this.frame
// ); // );
}, },
testAction() {
window.ultrawidify.videos[0].setAr({type: AspectRatioType.FitWidth});
}
} }
} }
</script> </script>

View File

@ -13,9 +13,11 @@ class ExecAction {
this.site = site; this.site = site;
} }
async exec(action, scope, frame) {
async exec(action, scope, frame, useBus) {
console.log('execing actioN!');
for (var cmd of action.cmd) { for (var cmd of action.cmd) {
if (scope === 'page') { if (!scope || scope === 'page') {
const message = { const message = {
forwardToContentScript: true, forwardToContentScript: true,
targetFrame: frame, targetFrame: frame,
@ -24,7 +26,11 @@ class ExecAction {
arg: cmd.arg, arg: cmd.arg,
customArg: cmd.customArg customArg: cmd.customArg
} }
if (useBus) {
window.ultrawidify.bus.sendMessage(message.cmd, message);
} else {
Comms.sendMessage(message); Comms.sendMessage(message);
}
} else { } else {
// set-ar-persistence sends stuff to content scripts as well (!) // set-ar-persistence sends stuff to content scripts as well (!)
@ -41,8 +47,12 @@ class ExecAction {
} }
// this hopefully delays settings.save() until current crops are saved on the site // this hopefully delays settings.save() until current crops are saved on the site
// and thus avoid any fucky-wuckies // and thus avoid any fucky-wuckies
if (useBus) {
window.ultrawidify.bus.sendMessage(message.cmd, message);
} else {
await Comms.sendMessage(message); await Comms.sendMessage(message);
} }
}
let site = this.site; let site = this.site;
if (scope === 'global') { if (scope === 'global') {

View File

@ -1,6 +1,14 @@
export default class UWGlobals { export default class UWGlobals {
constructor() { constructor() {
this.videos = []; this.videos = [];
this.busSubscriptions = [];
this.actionSubscriptions = {};
this.bus = {
sendMessage: (action, config) => this.propagateMessages(action, config),
subscribe: this.subscribeToAny,
subscribeToAction: this.subscribeToAction
}
} }
getNewVideoID() { getNewVideoID() {
@ -27,6 +35,39 @@ export default class UWGlobals {
return this.videos.find(x => x.vdid === id); return this.videos.find(x => x.vdid === id);
} }
importSubscriptionsFromCommsHandlers(commands) {
for (const action in commands) {
for (const command of commands[action]) {
this.subscribeToAction(action, command);
}
}
}
subscribeToAction(action, callback) {
if (!this.actionSubscriptions[action]) {
this.actionSubscriptions[action] = [];
}
this.actionSubscriptions[action].push(callback);
}
subscribeToAny(callback) {
this.busSubscriptions.push(callback);
}
propagateMessages(action, config) {
if (this.busSubscriptions) {
for (const subscription of this.busSubscriptions) {
subscription(action, config);
}
}
if (this.actionSubscriptions && this.actionSubscriptions[action]) {
for (const subscription of this.actionSubscriptions[action]) {
subscription(config);
}
}
}
destroy() { destroy() {
// todo: implement // todo: implement
} }