66 lines
1.2 KiB
JavaScript
66 lines
1.2 KiB
JavaScript
|
|
||
|
// Composable with all the logic to encapsulate a default content store
|
||
|
|
||
|
export const useContentStore = (mapKey = 'id') => {
|
||
|
|
||
|
const content = ref(new Map())
|
||
|
const loading = ref(false)
|
||
|
|
||
|
// Computed
|
||
|
const getAll = computed(() => {
|
||
|
return [...content.value.values()]
|
||
|
})
|
||
|
const getByKey = (key) => {
|
||
|
if (Array.isArray(key)) {
|
||
|
return key.map((k) => content.value.get(k)).filter((item) => item !== undefined)
|
||
|
}
|
||
|
return content.value.get(key)
|
||
|
}
|
||
|
|
||
|
const length = computed(() => content.value.size)
|
||
|
|
||
|
// Actions
|
||
|
function set(items) {
|
||
|
content.value = new Map
|
||
|
save(items)
|
||
|
}
|
||
|
|
||
|
function save(items) {
|
||
|
if (!items) return
|
||
|
if (!Array.isArray(items)) items = [items]
|
||
|
items.forEach((item) => {
|
||
|
content.value.set(item[mapKey], item)
|
||
|
})
|
||
|
}
|
||
|
function remove(item) {
|
||
|
content.value.delete( typeof item === 'object' ? item[mapKey] : item)
|
||
|
}
|
||
|
|
||
|
function startLoading() {
|
||
|
loading.value = true
|
||
|
}
|
||
|
|
||
|
function stopLoading() {
|
||
|
loading.value = false
|
||
|
}
|
||
|
|
||
|
function resetState() {
|
||
|
set([])
|
||
|
stopLoading()
|
||
|
}
|
||
|
|
||
|
return {
|
||
|
content,
|
||
|
loading,
|
||
|
getAll,
|
||
|
getByKey,
|
||
|
length,
|
||
|
set,
|
||
|
save,
|
||
|
remove,
|
||
|
startLoading,
|
||
|
stopLoading,
|
||
|
resetState
|
||
|
}
|
||
|
}
|