gradido/frontend/src/components/ContributionMessages/ContributionMessagesFormular.vue
2022-08-30 12:54:16 +02:00

68 lines
1.6 KiB
Vue

<template>
<div class="contribution-messages-formular">
<div>
<b-form @submit.prevent="onSubmit" @reset="onReset">
<b-form-textarea
id="textarea"
v-model="form.text"
:placeholder="$t('form.memo')"
rows="3"
max-rows="6"
></b-form-textarea>
<b-row class="mt-4 mb-6">
<b-col>
<b-button type="reset" variant="danger">{{ $t('form.cancel') }}</b-button>
</b-col>
<b-col class="text-right">
<b-button type="submit" variant="primary">{{ $t('form.reply') }}</b-button>
</b-col>
</b-row>
</b-form>
</div>
</div>
</template>
<script>
import { createContributionMessage } from '../../graphql/mutations.js'
export default {
name: 'ContributionMessagesFormular',
props: {
contributionId: {
type: Number,
required: true,
},
},
data() {
return {
form: {
text: '',
},
}
},
methods: {
onSubmit() {
this.$apollo
.mutate({
mutation: createContributionMessage,
variables: {
contributionId: this.contributionId,
message: this.form.text,
},
})
.then((result) => {
this.$emit('get-list-contribution-messages', this.contributionId)
this.$emit('update-state', this.contributionId)
this.form.text = ''
this.toastSuccess(this.$t('message.reply'))
})
.catch((error) => {
this.toastError(error.message)
})
},
onReset() {
this.form.text = ''
},
},
}
</script>