summaryrefslogtreecommitdiff
path: root/src/web/app/desktop/views/components/ui.vue
blob: 39ec057f88bc299e0e15f8aba9b9aa5da47ed5d3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
<template>
<div>
	<mk-ui-header/>
	<div class="content">
		<slot></slot>
	</div>
	<mk-stream-indicator v-if="$root.$data.os.isSignedIn"/>
</div>
</template>

<script lang="ts">
import Vue from 'vue';
import MkPostFormWindow from './post-form-window.vue';

export default Vue.extend({
	mounted() {
		document.addEventListener('keydown', this.onKeydown);
	},
	beforeDestroy() {
		document.removeEventListener('keydown', this.onKeydown);
	},
	methods: {
		openPostForm() {
			document.body.appendChild(new MkPostFormWindow().$mount().$el);
		},
		onKeydown(e) {
			if (e.target.tagName == 'INPUT' || e.target.tagName == 'TEXTAREA') return;

			if (e.which == 80 || e.which == 78) { // p or n
				e.preventDefault();
				this.openPostForm();
			}
		}
	}
});
</script>