Reorder some methods around into logical sections

This commit is contained in:
Tamius Han 2022-04-09 15:37:23 +02:00
parent 872b0dea6e
commit 09cf3ce54e

View File

@ -37,13 +37,14 @@
<h1>Crop video:</h1> <h1>Crop video:</h1>
</div> </div>
<div class="sub-panel-content flex flex-row flex-wrap"> <div class="sub-panel-content flex flex-row flex-wrap">
<ShortcutButton v-for="(command, index) of settings?.active.commands.crop" <ShortcutButton
class="flex b3 button" v-for="(command, index) of settings?.active.commands.crop"
:class="{active: isActiveCrop(command)}" class="flex b3 button"
:key="index" :class="{active: isActiveCrop(command)}"
:label="command.label" :key="index"
:shortcut="parseShortcut(command)" :label="command.label"
@click="execAction(command)" :shortcut="getKeyboardShortcutLabel(command)"
@click="execAction(command)"
> >
</ShortcutButton> </ShortcutButton>
</div> </div>
@ -96,7 +97,7 @@
class="flex b3 flex-grow button" class="flex b3 flex-grow button"
:key="index" :key="index"
:label="command.label" :label="command.label"
:shortcut="parseShortcut(command)" :shortcut="getKeyboardShortcutLabel(command)"
@click="execAction(command)" @click="execAction(command)"
> >
</ShortcutButton> </ShortcutButton>
@ -350,16 +351,7 @@ export default {
async openOptionsPage() { async openOptionsPage() {
BrowserDetect.runtime.openOptionsPage(); BrowserDetect.runtime.openOptionsPage();
}, },
execAction(command) {
const cmd = JSON.parse(JSON.stringify(command));
this.eventBus?.sendToTunnel(cmd.action, cmd.arguments);
},
parseShortcut(command) {
if (! command.shortcut) {
return '';
}
return KeyboardShortcutParser.parseShortcut(command.shortcut);
},
toggleZoomAr() { toggleZoomAr() {
this.zoomAspectRatioLocked = !this.zoomAspectRatioLocked; this.zoomAspectRatioLocked = !this.zoomAspectRatioLocked;
@ -386,6 +378,7 @@ export default {
newZoom = Math.pow(2, newZoom); newZoom = Math.pow(2, newZoom);
}, },
//#region cropping
/** /**
* Sets default crop, for either site or global * Sets default crop, for either site or global
*/ */
@ -431,17 +424,6 @@ export default {
this.settings.saveWithoutReload(); this.settings.saveWithoutReload();
}, },
/**
* Handles 'uw-config-broadcast' messages
*/
handleConfigBroadcast(message) {
if (message.type === 'ar') {
this.resizerConfig.crop = message.config;
}
this.$nextTick( () => this.$forceUpdate() );
},
/** /**
* Determines whether a given crop command is the currently active one * Determines whether a given crop command is the currently active one
*/ */
@ -467,7 +449,47 @@ export default {
} }
// only legacy options (fitw, fith) left to handle: // only legacy options (fitw, fith) left to handle:
return cropCommand.arguments.type === this.resizerConfig.crop.type; return cropCommand.arguments.type === this.resizerConfig.crop.type;
} },
//#endregion cropping
//#region edit mode
//#endregion
//#region comms and bus
/**
* Handles 'uw-config-broadcast' messages coming to our
*/
handleConfigBroadcast(message) {
if (message.type === 'ar') {
this.resizerConfig.crop = message.config;
}
this.$nextTick( () => this.$forceUpdate() );
},
/**
* Sends commands to main content script in parent iframe
* @param {*} command
*/
execAction(command) {
const cmd = JSON.parse(JSON.stringify(command));
this.eventBus?.sendToTunnel(cmd.action, cmd.arguments);
},
//#endregion
/**
* Parses command's keyboard shortcut into human-readable label
*/
getKeyboardShortcutLabel(command) {
if (! command.shortcut) {
return '';
}
return KeyboardShortcutParser.getKeyboardShortcutLabel(command.shortcut);
},
} }
} }
</script> </script>