@vueuse/nuxt
Version:
VueUse Nuxt Module
41 lines (37 loc) • 968 B
JavaScript
import { defineNuxtPlugin, useCookie, useHead } from '#imports'
import { setSSRHandler } from '@vueuse/core'
setSSRHandler('getDefaultStorage', () => {
const cookieMap = new Map()
const get = (key) => {
if (!cookieMap.get(key))
cookieMap.set(key, useCookie(key, { maxAge: 2147483646 }))
return cookieMap.get(key)
}
return {
getItem: key => get(key).value,
setItem: (key, value) => get(key).value = value,
removeItem: key => get(key).value = undefined,
}
})
if (import.meta.server) {
setSSRHandler('updateHTMLAttrs', (selector, attr, value) => {
if (selector === 'html') {
useHead({
htmlAttrs: {
[attr]: value,
},
})
}
else if (selector === 'body') {
useHead({
bodyAttrs: {
[attr]: value,
},
})
}
else {
throw new Error(`Unsupported meta selector "${selector}" in SSR`)
}
})
}
export default defineNuxtPlugin(() => { })