bring back eslint and stylelint on compilation, fix almost all warnings, ignore some Signed-off-by: Julien Veyssier <eneiluj@posteo.net>
131 lines
3.9 KiB
JavaScript
131 lines
3.9 KiB
JavaScript
/*
|
|
* @copyright Copyright (c) 2018 Julius Härtl <jus@bitgrid.net>
|
|
*
|
|
* @author Julius Härtl <jus@bitgrid.net>
|
|
*
|
|
* @license GNU AGPL version 3 or any later version
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
* License, or (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Affero General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
*/
|
|
|
|
import { CommentApi } from '../services/CommentApi.js'
|
|
import Vue from 'vue'
|
|
|
|
const apiClient = new CommentApi()
|
|
|
|
const COMMENT_FETCH_LIMIT = 10
|
|
|
|
export default {
|
|
state: {
|
|
comments: {},
|
|
replyTo: null,
|
|
},
|
|
getters: {
|
|
getCommentsForCard: (state) => (id) => {
|
|
if (state.comments[id]) {
|
|
return [...state.comments[id].comments].sort((a, b) => b.id - a.id)
|
|
}
|
|
return []
|
|
},
|
|
hasMoreComments: (state) => (cardId) => {
|
|
return state.comments[cardId] && state.comments[cardId].hasMore
|
|
},
|
|
},
|
|
mutations: {
|
|
endReached(state, { cardId }) {
|
|
if (state.comments[cardId]) {
|
|
state.comments[cardId].hasMore = false
|
|
}
|
|
},
|
|
addComments(state, { comments, cardId }) {
|
|
if (state.comments[cardId] === undefined) {
|
|
Vue.set(state.comments, cardId, {
|
|
hasMore: comments.length > 0,
|
|
comments: [...comments],
|
|
})
|
|
} else {
|
|
const newComments = comments.filter((comment) => {
|
|
return state.comments[cardId].comments.findIndex((item) => item.id === comment.id) === -1
|
|
})
|
|
state.comments[cardId].comments.push(...newComments)
|
|
}
|
|
},
|
|
updateComment(state, { cardId, comment }) {
|
|
const existingIndex = state.comments[cardId].comments.findIndex(c => c.id === comment.id)
|
|
if (existingIndex !== -1) {
|
|
Object.assign(state.comments[cardId].comments[existingIndex], comment)
|
|
}
|
|
},
|
|
deleteComment(state, comment) {
|
|
const existingIndex = state.comments[comment.cardId].comments.findIndex(_comment => _comment.id === comment.id)
|
|
if (existingIndex !== -1) {
|
|
state.comments[comment.cardId].comments.splice(existingIndex, 1)
|
|
}
|
|
},
|
|
markCommentsAsRead(state, cardId) {
|
|
state.comments[cardId].comments.forEach(_comment => {
|
|
Vue.set(_comment, 'isUnread', false)
|
|
})
|
|
},
|
|
setReplyTo(state, comment) {
|
|
Vue.set(state, 'replyTo', comment)
|
|
},
|
|
},
|
|
actions: {
|
|
async fetchComments({ commit }, { cardId, offset }) {
|
|
const comments = await apiClient.loadComments({
|
|
cardId,
|
|
limit: COMMENT_FETCH_LIMIT,
|
|
offset: offset || 0,
|
|
})
|
|
|
|
commit('addComments', {
|
|
cardId,
|
|
comments,
|
|
})
|
|
|
|
if (comments.length < COMMENT_FETCH_LIMIT) {
|
|
commit('endReached', { cardId })
|
|
|
|
}
|
|
},
|
|
async fetchMore({ commit, dispatch, getters }, { cardId }) {
|
|
// fetch newer comments first
|
|
await dispatch('fetchComments', { cardId })
|
|
await dispatch('fetchComments', { cardId, offset: getters.getCommentsForCard(cardId).length })
|
|
|
|
},
|
|
async createComment({ commit, dispatch, state }, { cardId, comment }) {
|
|
await apiClient.createComment({ cardId, comment, replyTo: state.replyTo })
|
|
await dispatch('fetchComments', { cardId })
|
|
},
|
|
async deleteComment({ commit }, data) {
|
|
await apiClient.deleteComment(data)
|
|
commit('deleteComment', data)
|
|
},
|
|
async updateComment({ commit }, data) {
|
|
const comment = await apiClient.updateComment(data)
|
|
await commit('updateComment', { cardId: data.cardId, comment })
|
|
},
|
|
async markCommentsAsRead({ commit }, cardId) {
|
|
await apiClient.markCommentsAsRead(cardId)
|
|
await commit('markCommentsAsRead', cardId)
|
|
},
|
|
setReplyTo({ commit }, comment) {
|
|
commit('setReplyTo', comment)
|
|
},
|
|
},
|
|
}
|