// We set __webpack_public_path via this import with webpack builder import { createApp, createSSRApp, nextTick } from 'vue' import { $fetch } from 'ofetch' import type { $Fetch, NitroFetchRequest } from 'nitropack' // This file must be imported first for webpack as we set __webpack_public_path__ there // @ts-expect-error virtual file import { baseURL } from '#build/paths.mjs' import type { CreateOptions } from '#app' import { applyPlugins, createNuxtApp } from '#app/nuxt' import '#build/css' // @ts-expect-error virtual file import plugins from '#build/plugins' // @ts-expect-error virtual file import RootComponent from '#build/root-component.mjs' // @ts-expect-error virtual file import { vueAppRootContainer } from '#build/nuxt.config.mjs' if (!globalThis.$fetch) { globalThis.$fetch = $fetch.create({ baseURL: baseURL() }) as $Fetch } let entry: Function if (import.meta.server) { entry = async function createNuxtAppServer (ssrContext: CreateOptions['ssrContext']) { const vueApp = createApp(RootComponent) const nuxt = createNuxtApp({ vueApp, ssrContext }) try { await applyPlugins(nuxt, plugins) await nuxt.hooks.callHook('app:created', vueApp) } catch (err) { await nuxt.hooks.callHook('app:error', err) nuxt.payload.error = (nuxt.payload.error || err) as any } if (ssrContext?._renderResponse) { throw new Error('skipping render') } return vueApp } } if (import.meta.client) { // TODO: temporary webpack 5 HMR fix // https://github.com/webpack-contrib/webpack-hot-middleware/issues/390 if (import.meta.dev && import.meta.webpackHot) { import.meta.webpackHot.accept() } // eslint-disable-next-line let vueAppPromise: Promise entry = async function initApp () { if (vueAppPromise) { return vueAppPromise } const isSSR = Boolean( window.__NUXT__?.serverRendered || document.getElementById('__NUXT_DATA__')?.dataset.ssr === 'true' ) const vueApp = isSSR ? createSSRApp(RootComponent) : createApp(RootComponent) const nuxt = createNuxtApp({ vueApp }) try { await applyPlugins(nuxt, plugins) } catch (err) { await nuxt.callHook('app:error', err) nuxt.payload.error = (nuxt.payload.error || err) as any } try { await nuxt.hooks.callHook('app:created', vueApp) await nuxt.hooks.callHook('app:beforeMount', vueApp) vueApp.mount(vueAppRootContainer) await nuxt.hooks.callHook('app:mounted', vueApp) await nextTick() } catch (err) { await nuxt.callHook('app:error', err) nuxt.payload.error = (nuxt.payload.error || err) as any } return vueApp } vueAppPromise = entry().catch((error: unknown) => { console.error('Error while mounting app:', error) }) } export default (ctx?: CreateOptions['ssrContext']) => entry(ctx)