2021-06-03 22:23:04 +02:00
|
|
|
import LabelService from '@/services/label'
|
|
|
|
import {setLoading} from '@/store/helper'
|
|
|
|
|
2021-10-06 22:25:06 +02:00
|
|
|
/**
|
|
|
|
* Returns the labels by id if found
|
|
|
|
* @param {Object} state
|
|
|
|
* @param {Array} ids
|
|
|
|
* @returns {Array}
|
|
|
|
*/
|
|
|
|
function getLabelsByIds(state, ids) {
|
|
|
|
return Object.values(state.labels).filter(({id}) => ids.includes(id))
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Checks if a list of labels is available in the store and filters them then query
|
|
|
|
* @param {Object} state
|
|
|
|
* @param {Array} labels
|
|
|
|
* @param {String} query
|
|
|
|
* @returns {Array}
|
|
|
|
*/
|
|
|
|
function filterLabelsByQuery(state, labels, query) {
|
|
|
|
const labelIds = labels.map(({id}) => id)
|
|
|
|
const foundLabels = getLabelsByIds(state, labelIds)
|
|
|
|
const labelQuery = query.toLowerCase()
|
|
|
|
|
|
|
|
return foundLabels.filter(({title}) => {
|
|
|
|
return !title.toLowerCase().includes(labelQuery)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2021-06-03 22:23:04 +02:00
|
|
|
export default {
|
|
|
|
namespaced: true,
|
|
|
|
state: () => ({
|
2021-10-06 22:25:06 +02:00
|
|
|
// The labels are stored as an object which has the label ids as keys.
|
2021-06-03 22:23:04 +02:00
|
|
|
labels: {},
|
|
|
|
loaded: false,
|
|
|
|
}),
|
|
|
|
mutations: {
|
|
|
|
setLabels(state, labels) {
|
|
|
|
labels.forEach(l => {
|
2021-08-19 21:35:38 +02:00
|
|
|
state.labels[l.id] = l
|
2021-06-03 22:23:04 +02:00
|
|
|
})
|
|
|
|
},
|
|
|
|
setLabel(state, label) {
|
2021-08-19 21:35:38 +02:00
|
|
|
state.labels[label.id] = label
|
2021-06-03 22:23:04 +02:00
|
|
|
},
|
|
|
|
removeLabelById(state, label) {
|
2021-08-19 21:35:38 +02:00
|
|
|
delete state.labels[label.id]
|
2021-06-03 22:23:04 +02:00
|
|
|
},
|
|
|
|
setLoaded(state, loaded) {
|
|
|
|
state.loaded = loaded
|
|
|
|
},
|
|
|
|
},
|
2021-10-06 22:25:06 +02:00
|
|
|
getters: {
|
|
|
|
getLabelsByIds(state) {
|
|
|
|
return (ids) => getLabelsByIds(state, ids)
|
|
|
|
},
|
|
|
|
filterLabelsByQuery(state) {
|
|
|
|
return (...arr) => filterLabelsByQuery(state, ...arr)
|
|
|
|
},
|
|
|
|
},
|
2021-06-03 22:23:04 +02:00
|
|
|
actions: {
|
|
|
|
loadAllLabels(ctx, {forceLoad} = {}) {
|
|
|
|
if (ctx.state.loaded && !forceLoad) {
|
|
|
|
return Promise.resolve()
|
|
|
|
}
|
|
|
|
|
|
|
|
const cancel = setLoading(ctx, 'labels')
|
|
|
|
const labelService = new LabelService()
|
|
|
|
|
|
|
|
const getAllLabels = (page = 1) => {
|
|
|
|
return labelService.getAll({}, {}, page)
|
|
|
|
.then(labels => {
|
|
|
|
if (page < labelService.totalPages) {
|
|
|
|
return getAllLabels(page + 1)
|
|
|
|
.then(nextLabels => {
|
|
|
|
return labels.concat(nextLabels)
|
|
|
|
})
|
|
|
|
} else {
|
|
|
|
return labels
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.catch(e => {
|
|
|
|
return Promise.reject(e)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return getAllLabels()
|
|
|
|
.then(r => {
|
|
|
|
ctx.commit('setLabels', r)
|
|
|
|
ctx.commit('setLoaded', true)
|
|
|
|
return Promise.resolve(r)
|
|
|
|
})
|
|
|
|
.finally(() => cancel())
|
|
|
|
},
|
|
|
|
deleteLabel(ctx, label) {
|
|
|
|
const cancel = setLoading(ctx, 'labels')
|
|
|
|
const labelService = new LabelService()
|
|
|
|
|
|
|
|
return labelService.delete(label)
|
|
|
|
.then(r => {
|
|
|
|
ctx.commit('removeLabelById', label)
|
|
|
|
return Promise.resolve(r)
|
|
|
|
})
|
|
|
|
.finally(() => cancel())
|
|
|
|
},
|
|
|
|
updateLabel(ctx, label) {
|
|
|
|
const cancel = setLoading(ctx, 'labels')
|
|
|
|
const labelService = new LabelService()
|
|
|
|
|
|
|
|
return labelService.update(label)
|
|
|
|
.then(r => {
|
|
|
|
ctx.commit('setLabel', r)
|
|
|
|
return Promise.resolve(r)
|
|
|
|
})
|
|
|
|
.finally(() => cancel())
|
|
|
|
},
|
|
|
|
createLabel(ctx, label) {
|
|
|
|
const cancel = setLoading(ctx, 'labels')
|
|
|
|
const labelService = new LabelService()
|
|
|
|
|
|
|
|
return labelService.create(label)
|
|
|
|
.then(r => {
|
|
|
|
ctx.commit('setLabel', r)
|
|
|
|
return Promise.resolve(r)
|
|
|
|
})
|
|
|
|
.finally(() => cancel())
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|