vuex management module\
- vuex typescript decorations
- vuex mapHelpers
- vuex local typescript decorations
- vuex local mapHelpers
import Vue from 'vue'
import Vuex from 'vuex'
import {setLocalStore, mapLocalActions, mapLocalGetters, mapLocalState, mapLocalMutations} from './'
Vue.use(Vuex)
const store = new Vuex.Store({
state: {}
})
const component = new Vue(setLocalStore(
{
store,
methods: {
...mapLocalActions({
increase: 'increase'
}),
...mapLocalMutations({
mIncrease: 'increase'
}),
},
computed: {
...mapLocalGetters({
oValue: 'oppositeValue'
}),
...mapLocalState({
value: 'value'
}),
}
}, // vue
{
state: {
value: 1,
},
actions: {
increase({commit}) {
commit('increase')
}
},
getters: {
oppositeValue(state){
return state.value * -1
}
},
mutations: {
increase(state) {
state.value += 1
}
}
} // store
))
component.increase()
expect(component.value).to.equal(2)
component.mIncrease()
expect(component.oValue).to.equal(-3)
import Vue from 'vue'
import Vuex from 'vuex'
import Vuexl, {mapLocalActions, mapLocalGetters, mapLocalState, mapLocalMutations} from './src'
Vue.use(Vuex)
Vue.use(Vuexl)
const store = new Vuex.Store({
state: {}
})
const component = new Vue({
store,
localStore() {
return {
store: {
state: {
value: 1,
},
actions: {
increase({commit}) {
commit('increase')
}
},
getters: {
oppositeValue(state){
return state.value * -1
}
},
mutations: {
increase(state) {
state.value += 1
}
}
}
}
},
methods: {
...mapLocalActions({
increase: 'increase'
}),
...mapLocalMutations({
mIncrease: 'increase'
}),
},
computed: {
...mapLocalGetters({
oValue: 'oppositeValue'
}),
...mapLocalState({
value: 'value'
}),
}
})
component.increase()
expect(component.value).to.equal(2)
component.mIncrease()
expect(component.oValue).to.equal(-3)
import Vue from 'vue'
import Vuex from 'vuex'
import {expect} from 'chai'
import Vuexl, {
LocalAction,
LocalStore,
LocalState,
LocalMutation,
LocalGetter,
} from './src'
import {Component} from 'vue-property-decorator'
Vue.use(Vuex)
Vue.use(Vuexl)
@Component
class VuexlComponent extends Vue {
@LocalState value: number
@LocalGetter opposite: number
@LocalMutation('increase') mutIncrease: () => void
@LocalAction increase: () => void
@LocalStore({
state: {value: 1},
getters: {
opposite(state) {
return state.value * -1
}
},
actions: {
increase({commit}){
commit('increase')
}
},
mutations: {
increase(state){
state.value += 1
}
}
}) VuexlName: string
}
const component = new VuexlComponent()
component.increase()
expect(component.value).to.equal(2)
component.mutIncrease()
expect(component.opposite).to.equal(-3)
in case of having local root name\
way to use
import Vue from 'vue'
import Vuex from 'vuex'
import Vuexl from './src'
Vue.use(Vuex)
Vue.use(Vuexl, {name: 'myLocalName'})