34 lines
1.1 KiB
TypeScript
34 lines
1.1 KiB
TypeScript
import { createInertiaApp } from '@inertiajs/vue3';
|
|
import createServer from '@inertiajs/vue3/server';
|
|
import { renderToString } from 'vue/server-renderer';
|
|
import { resolvePageComponent } from 'laravel-vite-plugin/inertia-helpers';
|
|
import { createSSRApp, DefineComponent, h } from 'vue';
|
|
import { ZiggyVue } from 'ziggy-js';
|
|
import pinia from './lib/pinia';
|
|
|
|
const appName = import.meta.env.VITE_APP_NAME || 'Laravel';
|
|
|
|
createServer((page) =>
|
|
createInertiaApp({
|
|
page,
|
|
render: renderToString,
|
|
title: (title) => title ? `${title} - ${appName}` : appName,
|
|
resolve: resolvePage,
|
|
setup: ({ App, props, plugin }) =>
|
|
createSSRApp({ render: () => h(App, props) })
|
|
.use(plugin)
|
|
.use(pinia)
|
|
.use(ZiggyVue, {
|
|
...page.props.ziggy,
|
|
location: new URL(page.props.ziggy.location),
|
|
}),
|
|
}),
|
|
{ cluster: true },
|
|
);
|
|
|
|
function resolvePage(name: string) {
|
|
const pages = import.meta.glob<DefineComponent>('./pages/**/*.vue');
|
|
|
|
return resolvePageComponent<DefineComponent>(`./pages/${name}.vue`, pages);
|
|
}
|