summaryrefslogtreecommitdiff
path: root/src/client/app/desktop/views/widgets/channel.channel.form.vue
blob: f2744268bb621f81d6e59ee3334bc1bb682ba448 (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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
<template>
<div class="form">
	<input v-model="text" :disabled="wait" @keydown="onKeydown" placeholder="書いて">
</div>
</template>

<script lang="ts">
import Vue from 'vue';
export default Vue.extend({
	data() {
		return {
			text: '',
			wait: false
		};
	},
	methods: {
		onKeydown(e) {
			if (e.which == 10 || e.which == 13) this.post();
		},
		post() {
			this.wait = true;

			let reply = null;

			if (/^>>([0-9]+) /.test(this.text)) {
				const index = this.text.match(/^>>([0-9]+) /)[1];
				reply = (this.$parent as any).notes.find(p => p.index.toString() == index);
				this.text = this.text.replace(/^>>([0-9]+) /, '');
			}

			(this as any).api('notes/create', {
				text: this.text,
				replyId: reply ? reply.id : undefined,
				channelId: (this.$parent as any).channel.id
			}).then(data => {
				this.text = '';
			}).catch(err => {
				alert('失敗した');
			}).then(() => {
				this.wait = false;
			});
		}
	}
});
</script>

<style lang="stylus" scoped>
.form
	width 100%
	height 38px
	padding 4px
	border-top solid 1px #ddd

	> input
		padding 0 8px
		width 100%
		height 100%
		font-size 14px
		color #55595c
		border solid 1px #dadada
		border-radius 4px

		&:hover
		&:focus
			border-color #aeaeae

</style>