42 lines
1.2 KiB
Vue
42 lines
1.2 KiB
Vue
<template lang="pug">
|
|
.service-header
|
|
.title(@click="showSettings = !showSettings")
|
|
slot(name="title")
|
|
.settings(v-show="showSettings")
|
|
input.position(
|
|
@keyup.up.ctrl.exact="onMove('x', -1)" @keyup.down.ctrl.exact="onMove('x', 1)"
|
|
@keyup.left.ctrl.exact="onMove('y', -1)" @keyup.right.ctrl.exact="onMove('y', 1)"
|
|
@keyup.up.alt.exact="onMove('h', -1)" @keyup.down.alt.exact="onMove('h', 1)"
|
|
@keyup.left.alt.exact="onMove('w', -1)" @keyup.right.alt.exact="onMove('w', 1)"
|
|
@keyup.delete.ctrl.exact="onRemove" @keyup.delete.alt.exact="onRemoveService"
|
|
)
|
|
slot(name="settings")
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import { Component, Mixins } from 'vue-property-decorator'
|
|
|
|
import ServiceEmiter from './ServiceEmiter'
|
|
import { MoveType, MoveDirection } from '@/types/App';
|
|
import { LayoutsModule, ServicesModule } from '../store';
|
|
|
|
@Component
|
|
export default class ServiceHeader extends Mixins(ServiceEmiter) {
|
|
|
|
showSettings = false
|
|
|
|
onMove(type: MoveType, direction: MoveDirection) {
|
|
LayoutsModule.moveTile(this.tileKey, type, direction)
|
|
}
|
|
|
|
onRemove() {
|
|
LayoutsModule.removeTile(this.tileKey)
|
|
}
|
|
|
|
onRemoveService() {
|
|
ServicesModule.remove(LayoutsModule.getTile(this.tileKey).service)
|
|
}
|
|
|
|
}
|
|
</script>
|