8e6ce3a813
Fixes #2275
50 lines
1 KiB
Vue
50 lines
1 KiB
Vue
<template>
|
|
<note-list
|
|
:is-fetching="uiFlags.isFetching"
|
|
:notes="notes"
|
|
@add="onAdd"
|
|
@delete="onDelete"
|
|
/>
|
|
</template>
|
|
|
|
<script>
|
|
import { mapGetters } from 'vuex';
|
|
import NoteList from './components/NoteList';
|
|
|
|
export default {
|
|
components: {
|
|
NoteList,
|
|
},
|
|
props: {
|
|
contactId: {
|
|
type: Number,
|
|
required: true,
|
|
},
|
|
},
|
|
computed: {
|
|
...mapGetters({ uiFlags: 'contactNotes/getUIFlags' }),
|
|
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>
|