44 lines
920 B
Vue
44 lines
920 B
Vue
|
<template>
|
||
|
<note-list :notes="notes" @add="onAdd" @delete="onDelete" />
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
import NoteList from './components/NoteList';
|
||
|
|
||
|
export default {
|
||
|
components: {
|
||
|
NoteList,
|
||
|
},
|
||
|
props: {
|
||
|
contactId: {
|
||
|
type: Number,
|
||
|
required: true,
|
||
|
},
|
||
|
},
|
||
|
computed: {
|
||
|
notes() {
|
||
|
return this.$store.getters['contactNotes/getAllNotesByContact'](
|
||
|
this.contactId
|
||
|
);
|
||
|
},
|
||
|
},
|
||
|
mounted() {
|
||
|
this.fetchContactNotes();
|
||
|
},
|
||
|
methods: {
|
||
|
fetchContactNotes() {
|
||
|
const { contactId } = this;
|
||
|
if (contactId) this.$store.dispatch('contactNotes/get', { contactId });
|
||
|
},
|
||
|
onAdd(content) {
|
||
|
const { contactId } = this;
|
||
|
this.$store.dispatch('contactNotes/create', { content, contactId });
|
||
|
},
|
||
|
onDelete(noteId) {
|
||
|
const { contactId } = this;
|
||
|
this.$store.dispatch('contactNotes/delete', { noteId, contactId });
|
||
|
},
|
||
|
},
|
||
|
};
|
||
|
</script>
|