119 lines
3.2 KiB
TypeScript
119 lines
3.2 KiB
TypeScript
import type { ActionContext } from 'vuex'
|
|
|
|
import {i18n} from '@/i18n'
|
|
import {success} from '@/message'
|
|
import LabelService from '@/services/label'
|
|
import {setLoading} from '@/store/helper'
|
|
import type { LabelState, RootStoreState } from '@/store/types'
|
|
import {getLabelsByIds, filterLabelsByQuery} from '@/helpers/labels'
|
|
import {createNewIndexer} from '@/indexes'
|
|
import type { ILabel } from '@/models/label'
|
|
|
|
const {add, remove, update} = createNewIndexer('labels', ['title', 'description'])
|
|
|
|
async function getAllLabels(page = 1): Promise<ILabel[]> {
|
|
const labelService = new LabelService()
|
|
const labels = await labelService.getAll({}, {}, page) as ILabel[]
|
|
if (page < labelService.totalPages) {
|
|
const nextLabels = await getAllLabels(page + 1)
|
|
return labels.concat(nextLabels)
|
|
} else {
|
|
return labels
|
|
}
|
|
}
|
|
|
|
export default {
|
|
namespaced: true,
|
|
state: (): LabelState => ({
|
|
labels: {},
|
|
loaded: false,
|
|
}),
|
|
mutations: {
|
|
setLabels(state: LabelState, labels: ILabel[]) {
|
|
labels.forEach(l => {
|
|
state.labels[l.id] = l
|
|
add(l)
|
|
})
|
|
},
|
|
setLabel(state: LabelState, label: ILabel) {
|
|
state.labels[label.id] = label
|
|
update(label)
|
|
},
|
|
removeLabelById(state: LabelState, label: ILabel) {
|
|
remove(label)
|
|
delete state.labels[label.id]
|
|
},
|
|
setLoaded(state: LabelState, loaded: boolean) {
|
|
state.loaded = loaded
|
|
},
|
|
},
|
|
getters: {
|
|
getLabelsByIds(state: LabelState) {
|
|
return (ids: ILabel['id'][]) => getLabelsByIds(state, ids)
|
|
},
|
|
filterLabelsByQuery(state: LabelState) {
|
|
return (labelsToHide: ILabel[], query: string) => filterLabelsByQuery(state, labelsToHide, query)
|
|
},
|
|
getLabelsByExactTitles(state: LabelState) {
|
|
return labelTitles => Object
|
|
.values(state.labels)
|
|
.filter(({title}) => labelTitles.some(l => l.toLowerCase() === title.toLowerCase()))
|
|
},
|
|
},
|
|
actions: {
|
|
async loadAllLabels(ctx: ActionContext<LabelState, RootStoreState>, {forceLoad} = {}) {
|
|
if (ctx.state.loaded && !forceLoad) {
|
|
return
|
|
}
|
|
|
|
const cancel = setLoading(ctx, 'labels')
|
|
|
|
try {
|
|
const labels = await getAllLabels()
|
|
ctx.commit('setLabels', labels)
|
|
ctx.commit('setLoaded', true)
|
|
return labels
|
|
} finally {
|
|
cancel()
|
|
}
|
|
},
|
|
async deleteLabel(ctx: ActionContext<LabelState, RootStoreState>, label: ILabel) {
|
|
const cancel = setLoading(ctx, 'labels')
|
|
const labelService = new LabelService()
|
|
|
|
try {
|
|
const result = await labelService.delete(label)
|
|
ctx.commit('removeLabelById', label)
|
|
success({message: i18n.global.t('label.deleteSuccess')})
|
|
return result
|
|
} finally {
|
|
cancel()
|
|
}
|
|
},
|
|
async updateLabel(ctx: ActionContext<LabelState, RootStoreState>, label: ILabel) {
|
|
const cancel = setLoading(ctx, 'labels')
|
|
const labelService = new LabelService()
|
|
|
|
try {
|
|
const newLabel = await labelService.update(label)
|
|
ctx.commit('setLabel', newLabel)
|
|
success({message: i18n.global.t('label.edit.success')})
|
|
return newLabel
|
|
} finally {
|
|
cancel()
|
|
}
|
|
},
|
|
async createLabel(ctx: ActionContext<LabelState, RootStoreState>, label: ILabel) {
|
|
const cancel = setLoading(ctx, 'labels')
|
|
const labelService = new LabelService()
|
|
|
|
try {
|
|
const newLabel = await labelService.create(label)
|
|
ctx.commit('setLabel', newLabel)
|
|
return newLabel
|
|
} finally {
|
|
cancel()
|
|
}
|
|
},
|
|
},
|
|
}
|