1
1
mirror of https://github.com/aelve/guide.git synced 2024-11-22 20:01:36 +03:00

Helper set function for vuex

This commit is contained in:
avele 2019-11-04 02:28:47 +04:00
parent 93f8f25672
commit ede4f678dd
3 changed files with 26 additions and 29 deletions

View File

@ -0,0 +1,6 @@
// Set property on state
// setUser: set('user')
// commit('setUser', { name: 'foo' })
export const set = key => (state, val) => { state[key] = val }
// https://gist.github.com/rhythnic/6521495650a215ccab8bf7120949fb7d more helpers

View File

@ -1,6 +1,7 @@
import { ActionTree, GetterTree, MutationTree, ActionContext, Module } from 'vuex'
import { ICategoryInfo, ICategoryFull, CategoryService } from 'client/service/Category'
import { ICategoryItem } from 'client/service/CategoryItem'
import { set } from '../helpers'
interface ICategoryState {
categoryList: ICategoryInfo[],
@ -97,12 +98,8 @@ const actions: ActionTree<ICategoryState, any> = {
}
const mutations: MutationTree<ICategoryState> = {
setCategoryList: (state: ICategoryState, payload: ICategoryInfo[]) => {
state.categoryList = payload
},
setCategory: (state: ICategoryState, payload: ICategoryFull) => {
state.category = payload
},
setCategoryList: set('categoryList'),
setCategory: set('category'),
toggleSectionEditState (state, { sectionName, itemId }) {
const sectionEditState = state.itemsSectionsInEdit[sectionName]

View File

@ -7,19 +7,14 @@ import {
ITrait
} from 'client/service/CategoryItem'
interface ICategoryItemState {
categoryItemList: ICategoryItem[]
}
const state = (): ICategoryItemState => ({
categoryItemList: []
const state = (): {} => ({
})
const getters: GetterTree<ICategoryItemState, any> = {}
const getters: GetterTree<{}, any> = {}
const actions: ActionTree<ICategoryItemState, any> = {
const actions: ActionTree<{}, any> = {
async createItem (
{ dispatch }: ActionContext<ICategoryItemState, any>,
{ dispatch }: ActionContext<{}, any>,
{
category,
name,
@ -39,37 +34,37 @@ const actions: ActionTree<ICategoryItemState, any> = {
await CategoryItemService.deleteItemById(id)
},
async updateItemInfo (
context: ActionContext<ICategoryItemState, any>,
context: ActionContext<{}, any>,
{ id, body }: { id: ICategoryItem['id'], body: ICategoryItemInfo }
): Promise<void> {
await CategoryItemService.updateItemInfo(id, body)
},
async moveItem (
context: ActionContext<ICategoryItemState, any>,
context: ActionContext<{}, any>,
{ id, direction }: { id: ICategoryItem['id'], direction: string }
): Promise<void> {
await CategoryItemService.moveItem(id, direction)
},
async updateItemSummary (
context: ActionContext<ICategoryItemState, any>,
context: ActionContext<{}, any>,
{ id, original, modified }: { id: ICategoryItem['id'], original: ICategoryItem['summary'], modified: ICategoryItem['summary'] }
): Promise<void> {
await CategoryItemService.updateItemSummary(id, original, modified)
},
async updateItemEcosystem (
context: ActionContext<ICategoryItemState, any>,
context: ActionContext<{}, any>,
{ id, original, modified }: { id: ICategoryItem['id'], original: ICategoryItem['ecosystem'], modified: ICategoryItem['ecosystem'] }
): Promise<void> {
await CategoryItemService.updateItemEcosystem(id, original, modified)
},
async updateItemNotes (
context: ActionContext<ICategoryItemState, any>,
context: ActionContext<{}, any>,
{ id, original, modified }: { id: ICategoryItem['id'], original: ICategoryItem['notes'], modified: ICategoryItem['notes'] }
): Promise<void> {
await CategoryItemService.updateItemNotes(id, original, modified)
},
async updateItemTrait (
context: ActionContext<ICategoryItemState, any>,
context: ActionContext<{}, any>,
{
itemId,
traitId,
@ -85,7 +80,7 @@ const actions: ActionTree<ICategoryItemState, any> = {
await CategoryItemService.updateItemTrait(itemId, traitId, original, modified)
},
async moveItemTrait (
context: ActionContext<ICategoryItemState, any>,
context: ActionContext<{}, any>,
{
itemId,
traitId,
@ -99,7 +94,7 @@ const actions: ActionTree<ICategoryItemState, any> = {
await CategoryItemService.moveItemTrait(itemId, traitId, direction)
},
async deleteItemTrait (
context: ActionContext<ICategoryItemState, any>,
context: ActionContext<{}, any>,
{
itemId,
traitId,
@ -111,7 +106,7 @@ const actions: ActionTree<ICategoryItemState, any> = {
await CategoryItemService.deleteItemTrait(itemId, traitId)
},
async createItemTrait (
context: ActionContext<ICategoryItemState, any>,
context: ActionContext<{}, any>,
{ itemId,
type,
content
@ -125,13 +120,12 @@ const actions: ActionTree<ICategoryItemState, any> = {
}
}
const mutations: MutationTree<ICategoryItemState> = {
setCategoryItem: (state: ICategoryItemState, payload: ICategoryItem[]) => {
state.categoryItemList = payload
}
const mutations: MutationTree<{}> = {
}
const categoryItem: Module<ICategoryItemState, any> = {
const categoryItem: Module<{}, any> = {
namespaced: true,
state,
getters,