@kasvith/electron-vuex
v1.0.0
Published
Share vuex state between main and renderer
Downloads
11
Maintainers
Readme
Electron Vuex
A fork of vuex-electron. We replaced the JSON store with a memory store which allows high rate of mutations without creating temp files
The easiest way to share your Vuex Store between all processes (including main).
Features
:star: Persisted state
:star: Shared mutations
Requirements
Installation
Installation of the Vuex Electron easy as 1-2-3.
Install package with using of yarn or npm:
yarn install @kasvith/electron-vuex
or
npm install @kasvith/electron-vuex
Include plugins in your Vuex store::
import Vue from "vue" import Vuex from "vuex" import { createPersistedState, createSharedMutations } from "@kasvith/electron-vuex" Vue.use(Vuex) export default new Vuex.Store({ // ... plugins: [ createPersistedState(), createSharedMutations() ], // ... })
In case if you enabled
createSharedMutations()
plugin you need to create an instance of store in the main process. To do it just add this line into your main process (for examplesrc/main.js
):import './path/to/your/store'
Well done you did it! The last step is to add the star to this repo :smile:
Usage example: Vuex Electron Example
IMPORTANT
In renderer process to call actions you need to use dispatch
or mapActions
. Don't use commit
because actions fired via commit
will not be shared between processes.
Options
Available options for createPersistedState()
createPersistedState({
whitelist: ["whitelistedMutation", "anotherWhitelistedMutation"],
// or
whitelist: (mutation) => {
return true
},
// or
blacklist: ["ignoredMutation", "anotherIgnoredMutation"],
// or
blacklist: (mutation) => {
return true
}
})