Shortcut button thingy works ... ish

This commit is contained in:
Tamius Han 2019-02-27 23:22:15 +01:00
parent f07a1e529e
commit be34838dba
3 changed files with 170 additions and 43 deletions

View File

@ -58,49 +58,27 @@
</div> </div>
<div class="flex flex-row"> <div class="flex flex-row">
<b>Scopes:</b> <b>Show this action in the following tabs:</b>
</div> </div>
<div class="flex flex-row"> <ScopeSettings :scopeOptions="globalScopeOptions"
Global: @show="updateScopes('global', 'show', $event)"
</div> @set-label="updateScopes('global', 'label', $event)"
@set-shortcut="updateScopes('global', 'shortcut', $event)"
/>
<ScopeSettings :scopeOptions="siteScopeOptions"
@show="updateScopes('site', 'show', $event)"
@set-label="updateScopes('site', 'label', $event)"
@set-shortcut="updateScopes('site', 'shortcut', $event)"
/>
<ScopeSettings :scopeOptions="pageScopeOptions"
@show="updateScopes('page', 'show', $event)"
@set-label="updateScopes('page', 'label', $event)"
@set-shortcut="updateScopes('page', 'shortcut', $event)"
/>
<div class="flex flex-row">
<div class="flex label-secondary form-label">
<span class="w100">
Show in popup
</span>
</div>
<div class="flex flex-input">
<input type="checkbox"
:value="actionIndex < 0 ? true : settings.active.actions[actionIndex].scopes.global && settings.active.actions[actionIndex].scopes.global.show"
@input="updateScopes('global', 'show', $event.target.value)"
>
</div>
</div>
<div class="flex flex-row">
<div class="flex label-secondary form-label">
<span class="w100">
Label <span class="hint"><small>(leave empty for default)</small></span>:
</span>
</div>
<div class="flex flex-input flex-grow">
<input type="text"
class="w100"
@input="updateScopes('global', 'label', $event.target.value)"
>
</div>
</div>
<div class="flex flex-row">
<div class="flex label-secondary form-label">
<span class="w100">
Shortcut:
</span>
</div>
<div class="flex flex-input flex-grow">
TODO: insert shortcut changing component
</div>
</div>
</div> </div>
</div> </div>
</template> </template>
@ -110,11 +88,17 @@ import Stretch from '../../common/enums/stretch.enum';
import KeyboardShortcutParser from '../../common/js/KeyboardShortcutParser'; import KeyboardShortcutParser from '../../common/js/KeyboardShortcutParser';
import CommandChain from './command-builder/command-chain'; import CommandChain from './command-builder/command-chain';
import CommandAddEdit from './command-builder/command-add-edit'; import CommandAddEdit from './command-builder/command-add-edit';
import ScopeSettings from './scope-settings-component/scope-settings';
export default { export default {
props: {
settings: Object,
actionIndex: Number,
},
components: { components: {
CommandChain: CommandChain, CommandChain: CommandChain,
CommandAddEdit: CommandAddEdit, CommandAddEdit: CommandAddEdit,
ScopeSettings,
}, },
data () { data () {
return { return {
@ -123,6 +107,9 @@ export default {
name: 'New action', name: 'New action',
label: 'New action', label: 'New action',
cmd: [], cmd: [],
scopes: {
}
}, },
addEditCommand: false, addEditCommand: false,
currentCmdIndex: -1, currentCmdIndex: -1,
@ -130,9 +117,28 @@ export default {
}, },
created () { created () {
}, },
props: { computed: {
settings: Object, globalScopeOptions: function() {
actionIndex: Number, return {
show: this.action.scopes.global && this.action.scopes.global.show || false,
label: (this.action.scopes.global && this.action.scopes.global.label) ? this.action.scopes.global.label : '',
shortcut: this.action.scopes.global && this.action.scopes.global.shortcut
}
},
siteScopeOptions: function() {
return {
show: this.action.scopes.site && this.action.scopes.site.show || false,
label: (this.action.scopes.site && this.action.scopes.site.label) ? this.action.scopes.site.label : '',
shortcut: this.action.scopes.site && this.action.scopes.site.shortcut
}
},
pageScopeOptions: function() {
return {
show: this.action.scopes.page && this.action.scopes.page.show || false,
label: (this.action.scopes.page && this.action.scopes.page.label) ? this.action.scopes.page.label : '',
shortcut: this.action.scopes.page && this.action.scopes.page.shortcut
}
}
}, },
methods: { methods: {
parseActionShortcut(action) { parseActionShortcut(action) {

View File

@ -0,0 +1,65 @@
<template>
<div>
<div class="flex flex-row">
<div class="flex label-secondary form-label">
Show in popup:
</div>
<div class="flex flex-input flex-grow">
<input type="checkbox"
:checked="scopeOptions.show"
@input="$emit('show', $event.target.value)"
/>
</div>
</div>
<div class="flex flex-row">
<div class="flex label-secondary form-label">
Custom label <small>(optional)</small>:
</div>
<div class="flex flex-input flex-grow">
<input type="text"
v-model="scopeOptions.label"
@input="setLabel"
/>
</div>
</div>
<div class="flex flex-row">
<div class="flex label-secondary form-label">
<span class="w100">
Shortcut:
</span>
</div>
<div class="flex flex-input flex-grow">
<SetShortcutButton
:shortcut="scopeOptions.shortcut"
@set-shortcut="$emit('set-shortcut', $event)"
/>
</div>
</div>
</div>
</template>
<script>
import SetShortcutButton from './set-shortcut-button';
export default {
props: {
scopeOptions: Object,
},
components: {
SetShortcutButton,
},
methods: {
setLabel(label) {
console.log("label")
if (label.trim() === '') {
label = undefined;
}
this.$emit(label.trim())
}
}
}
</script>
<style>
</style>

View File

@ -0,0 +1,56 @@
<template>
<div class="w100">
<input type="text"
:value="shortcutText"
@focus="initiateKeypress"
@keyup="processKeyup"
/>
</div>
</template>
<script>
import KeyboardShortcutParser from '../../../common/js/KeyboardShortcutParser'
export default {
props: {
shortcut: Object,
waitingForPress: false,
},
data() {
return {
shortcutText: '[click to add shortcut]'
}
},
created(){
if (shortcut) {
this.shortcutText = KeyboardShortcutParser.parseShortcut(shortcut);
}
},
methods: {
initiateKeypress() {
this.shortcutText = '[Press a key or key combination]';
this.waitingForPress = true;
},
processKeyup(event) {
if (this.waitingForPress) {
console.log("PROCESSING KEY UP", event)
$emit('set-shortcut', {
key: event.key,
ctrlKey: event.ctrlKey,
metaKey: event.metaKey,
altKey: event.altKey,
shiftKey: event.shiftKey,
onKeyUp: true,
onKeyDown: false,
});
}
this.waitingForPress = false;
}
}
}
</script>
<style>
</style>