jormungandr-bite/src/client/app/desktop/views/components/renote-form-window.vue

67 lines
1.2 KiB
Vue
Raw Normal View History

2018-04-07 11:30:37 -06:00
<template>
2018-09-17 23:50:13 -06:00
<mk-window ref="window" is-modal @closed="onWindowClosed" :animation="animation">
<span slot="header" :class="$style.header"><fa icon="retweet"/>{{ $t('title') }}</span>
<mk-renote-form ref="form" :note="note" @posted="onPosted" @canceled="onCanceled" v-hotkey.global="keymap"/>
2018-04-07 11:30:37 -06:00
</mk-window>
</template>
<script lang="ts">
import Vue from 'vue';
import i18n from '../../../i18n';
2018-04-07 11:30:37 -06:00
export default Vue.extend({
i18n: i18n('desktop/views/components/renote-form-window.vue'),
2018-09-17 23:50:13 -06:00
props: {
note: {
type: Object,
required: true
},
animation: {
type: Boolean,
required: false,
default: true
}
},
computed: {
keymap(): any {
return {
'esc': this.close,
2018-09-17 23:39:18 -06:00
'enter': this.post,
'q': this.quote,
};
}
2018-04-07 11:30:37 -06:00
},
2018-04-07 11:30:37 -06:00
methods: {
post() {
(this.$refs.form as any).ok();
},
2018-09-17 23:39:18 -06:00
quote() {
(this.$refs.form as any).onQuote();
},
close() {
(this.$refs.window as any).close();
2018-04-07 11:30:37 -06:00
},
onPosted() {
(this.$refs.window as any).close();
},
onCanceled() {
(this.$refs.window as any).close();
},
onWindowClosed() {
this.$emit('closed');
this.destroyDom();
2018-04-07 11:30:37 -06:00
}
}
});
</script>
<style lang="stylus" module>
.header
> [data-icon]
2018-04-07 11:30:37 -06:00
margin-right 4px
</style>