pinia-plugin-persistedstate
Version:
Configurable persistence and rehydration of Pinia stores.
32 lines (31 loc) • 1.11 kB
JavaScript
import { defineNuxtPlugin, useRuntimeConfig } from "#app";
import { destr } from "destr";
import { createPersistence } from "./core.js";
import { storages } from "./storages.js";
function piniaPlugin(context) {
const config = useRuntimeConfig();
const options = config.public.piniaPluginPersistedstate;
createPersistence(
context,
(p) => ({
key: options.key ? options.key.replace(/%id/g, p.key ?? context.store.$id) : p.key ?? context.store.$id,
debug: p.debug ?? options.debug ?? false,
serializer: p.serializer ?? {
serialize: (data) => JSON.stringify(data),
deserialize: (data) => destr(data)
},
storage: p.storage ?? (options.storage ? options.storage === "cookies" ? storages.cookies(options.cookieOptions) : storages[options.storage]() : storages.cookies()),
beforeHydrate: p.beforeHydrate,
afterHydrate: p.afterHydrate,
pick: p.pick,
omit: p.omit
}),
options.auto ?? false
);
}
export default defineNuxtPlugin({
name: "pinia-plugin-persistedstate",
setup({ $pinia }) {
$pinia.use(piniaPlugin);
}
});