💾🔗🖥️ Share, synchronize and persist state between multiple tabs with this plugin for Vuex. TypeScript types included.
This Vuex plugin allows you to sync and share the status of your Vue application
across multiple tabs or windows using the local storage.
This repository has a gitter chat where you can ask questions and propose new features:
The plugin has been tested with Vue 3 and Vuex 4 and no problems have been found.
There is an issue
where you can find how the plugin has been used using the new Vue 3 Composition
API. If you encounter a problem using the plugin with Vue 3 and Vuex 4, please
post it there.
vuex-multi-tab-state is available in npm and can be installed with the following command:
npm i vuex-multi-tab-state
Just import vuex-multi-tab-state and add it in the plugins list of your Vuex Store object.
import Vue from 'vue';
import Vuex from 'vuex';
import createMultiTabState from 'vuex-multi-tab-state';
Vue.use(Vuex);
export default new Vuex.Store({
state: { ... },
mutations: { ... },
actions: { ... },
getters: { ... },
plugins: [
createMultiTabState(),
],
});
You can check the example provided here
Integrating the plugin in NuxtJS requires a little more effort than in Vue. First
of all, we have to create a file inside the plugins
directory.
// ~/plugins/multiTabState.client.js
import createMultiTabState from 'vuex-multi-tab-state';
export default ({ store }) => {
createMultiTabState()(store);
};
Note that the filename must have the following format *.client.js
. The next
step is to add this plugin to NuxtJS in nuxt.config.js
:
// nuxt.config.js
export default {
...
plugins: [{ src: '~/plugins/multiTabState.client.js' }],
...
}
If you didn’t name the file according to the specified format, you can add the
plugin this way:
// nuxt.config.js
export default {
...
plugins: [{ src: '~/plugins/multiTabState.client.js', mode: 'client' }],
...
}
Both ways tell NuxtJS that the plugin should only be run client-side
(because the plugin uses window
, not available server-side).
createMultiTabState({options})
Creates a new instance of the plugin with the given options. The possible options
are as follows:
statesPaths Array<String>
: contains the name of the states to be synchronized
with dot notation. If the param is not provided, the whole state of your app will
be sync. Defaults to []
.
Example: Only the oranges will be synchronized.
export default new Vuex.Store({
state: {
fruits: {
oranges: 0,
apples: 0,
},
},
plugins: [createMultiTabState({
statesPaths: ['fruits.oranges'],
})],
});
key? <String>
: key of the local storage in which the state will be stored.
Defaults to 'vuex-multi-tab'
.
onBeforeReplace? <Function>
: hook function that receives the state and allows to modify it before replacing it. The function can return either a modified state or a falsy
value (which means that no modifications has been done inside the hook).onBeforeSave? <Function>
: hook function that receives the state and allows to modify it before saving it in local storage. The function can return either a modified state or a falsy
value (which means that no modifications has been done inside the hook).
export default new Vuex.Store({
state: {
fruits: {
oranges: 0,
apples: 0,
},
},
plugins: [createMultiTabState({
statesPaths: ['fruits.oranges'],
onBeforeSave: (state) => {
// Modify state here
return state;
},
onBeforeReplace: (state) => {
// Modify state here
return state;
}
})],
});
The tests have been written with mocha and chai.
npm install
npm run test
If you feel that something can be improved, go on, create a pull request! Please
follow the programming style and document your changes correctly.
This project is under the MIT license. More information here.