mirror of
https://github.com/vitodeploy/vito.git
synced 2025-07-02 22:46:16 +00:00
Setup Inertia (#593)
This commit is contained in:
30
resources/js/ssr.tsx
Normal file
30
resources/js/ssr.tsx
Normal file
@ -0,0 +1,30 @@
|
||||
import { createInertiaApp } from '@inertiajs/react';
|
||||
import createServer from '@inertiajs/react/server';
|
||||
import { resolvePageComponent } from 'laravel-vite-plugin/inertia-helpers';
|
||||
import ReactDOMServer from 'react-dom/server';
|
||||
import { type RouteName, route } from 'ziggy-js';
|
||||
|
||||
const appName = import.meta.env.VITE_APP_NAME || 'Vito';
|
||||
|
||||
createServer((page) =>
|
||||
createInertiaApp({
|
||||
page,
|
||||
render: ReactDOMServer.renderToString,
|
||||
title: (title) => `${title} - ${appName}`,
|
||||
resolve: (name) => resolvePageComponent(`./pages/${name}.tsx`, import.meta.glob('./pages/**/*.tsx')),
|
||||
setup: ({ App, props }) => {
|
||||
/* eslint-disable */
|
||||
// @ts-expect-error
|
||||
global.route<RouteName> = (name, params, absolute) =>
|
||||
route(name, params as any, absolute, {
|
||||
// @ts-expect-error
|
||||
...page.props.ziggy,
|
||||
// @ts-expect-error
|
||||
location: new URL(page.props.ziggy.location),
|
||||
});
|
||||
/* eslint-enable */
|
||||
|
||||
return <App {...props} />;
|
||||
},
|
||||
}),
|
||||
);
|
Reference in New Issue
Block a user