You've already forked AstralRinth
forked from didirus/AstralRinth
* feat: abstract api-client DI into ui package * feat: cross platform page system * feat: tanstack as cross platform useAsyncData * feat: archon servers routes + labrinth billing routes * fix: dont use partial * feat: migrate server list page to tanstack + api-client + re-enabled broken features! * feat: migrate servers manage page to api-client before page system * feat: migrate manage page to page system * fix: type issues * fix: upgrade wrapper bugs * refactor: move state types into api-client * feat: disable financial stuff on app frontend * feat: finalize cross platform page system for now * fix: lint * fix: build issues * feat: remove papaparse * fix: lint * fix: interface error --------- Co-authored-by: Prospector <6166773+Prospector@users.noreply.github.com>
29 lines
850 B
TypeScript
29 lines
850 B
TypeScript
// https://tanstack.com/query/v5/docs/framework/vue/examples/nuxt3
|
|
import type { DehydratedState, VueQueryPluginOptions } from '@tanstack/vue-query'
|
|
import { dehydrate, hydrate, QueryClient, VueQueryPlugin } from '@tanstack/vue-query'
|
|
|
|
import { defineNuxtPlugin, useState } from '#imports'
|
|
|
|
export default defineNuxtPlugin((nuxt) => {
|
|
const vueQueryState = useState<DehydratedState | null>('vue-query')
|
|
|
|
const queryClient = new QueryClient({
|
|
defaultOptions: { queries: { staleTime: 5000 } },
|
|
})
|
|
const options: VueQueryPluginOptions = { queryClient }
|
|
|
|
nuxt.vueApp.use(VueQueryPlugin, options)
|
|
|
|
if (import.meta.server) {
|
|
nuxt.hooks.hook('app:rendered', () => {
|
|
vueQueryState.value = dehydrate(queryClient)
|
|
})
|
|
}
|
|
|
|
if (import.meta.client) {
|
|
nuxt.hooks.hook('app:created', () => {
|
|
hydrate(queryClient, vueQueryState.value)
|
|
})
|
|
}
|
|
})
|