56 lines
1.5 KiB
JavaScript
56 lines
1.5 KiB
JavaScript
/* eslint-disable object-shorthand, func-names, camelcase, no-restricted-syntax, guard-for-in, comma-dangle, max-len, no-param-reassign */
|
|
/* global DiscussionModel */
|
|
|
|
import Vue from 'vue';
|
|
|
|
window.CommentsStore = {
|
|
state: {},
|
|
get: function (discussionId, noteId) {
|
|
return this.state[discussionId].getNote(noteId);
|
|
},
|
|
createDiscussion: function (discussionId, canResolve) {
|
|
let discussion = this.state[discussionId];
|
|
if (!this.state[discussionId]) {
|
|
discussion = new DiscussionModel(discussionId);
|
|
Vue.set(this.state, discussionId, discussion);
|
|
}
|
|
|
|
if (canResolve !== undefined) {
|
|
discussion.canResolve = canResolve;
|
|
}
|
|
|
|
return discussion;
|
|
},
|
|
create: function (noteObj) {
|
|
const discussion = this.createDiscussion(noteObj.discussionId);
|
|
|
|
discussion.createNote(noteObj);
|
|
},
|
|
update: function (discussionId, noteId, resolved, resolved_by) {
|
|
const discussion = this.state[discussionId];
|
|
const note = discussion.getNote(noteId);
|
|
note.resolved = resolved;
|
|
note.resolved_by = resolved_by;
|
|
},
|
|
delete: function (discussionId, noteId) {
|
|
const discussion = this.state[discussionId];
|
|
discussion.deleteNote(noteId);
|
|
|
|
if (discussion.notesCount() === 0) {
|
|
Vue.delete(this.state, discussionId);
|
|
}
|
|
},
|
|
unresolvedDiscussionIds: function () {
|
|
const ids = [];
|
|
|
|
for (const discussionId in this.state) {
|
|
const discussion = this.state[discussionId];
|
|
|
|
if (!discussion.isResolved()) {
|
|
ids.push(discussion.id);
|
|
}
|
|
}
|
|
|
|
return ids;
|
|
}
|
|
};
|