mirror of
https://github.com/torrentpier/torrentpier
synced 2025-07-16 10:03:11 -07:00
* feat: initialize Laravel project with React 19 starter kit - Add Laravel backend with Inertia.js integration - Set up React 19 with TypeScript frontend - Configure shadcn/ui component library - Add Vite build tooling and development setup - Include authentication scaffolding with Inertia - Set up responsive layouts and UI components * Potential fix for code scanning alert no. 595: Workflow does not contain permissions Co-authored-by: Copilot Autofix powered by AI <62310815+github-advanced-security[bot]@users.noreply.github.com>
30 lines
1.1 KiB
TypeScript
30 lines
1.1 KiB
TypeScript
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 || 'Laravel';
|
|
|
|
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} />;
|
|
},
|
|
}),
|
|
);
|