-
Notifications
You must be signed in to change notification settings - Fork 67
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Inertia #68
Comments
I think easier for this is to publish them as if they were a composer package (within a tag using Laravel's I was thinking about this as well to one of my projects as its the only one based on Inertia Anyway to the matter, I think the Laravel vite plugin actually support an array of inputs, tho I think it produces different files at the output so the problem is they aren't linked together |
App.ts File ...
createInertiaApp({
title: (title) => `${title}`,
resolve: (name) => {
let isModule = name.split("::");
if (isModule.length > 1) {
console.log(isModule);
let moduleName = isModule[0].toString().toLowerCase();
let fileName = isModule[1];
console.log(isModule, moduleName, fileName)
console.log(moduleName, fileName);
return resolvePageComponent(
`../../Modules/${moduleName}/resources/views/${fileName}.vue`,
import.meta.glob<DefineComponent>(
"../../Modules/*/resources/views/**/*.vue",
),
);
} else {
return resolvePageComponent(
`./Pages/${name}.vue`,
import.meta.glob<DefineComponent>("./Pages/**/*.vue"),
);
}
},
setup({el, App, props, plugin}) {
createApp({render: () => h(App, props)})
... Vite.config.ts* ...
export default defineConfig({
plugins: [
laravel({
input: ["resources/js/app.ts", "resources/css/errors.css"],
refresh: true,
}),
....
alias: {
"@": "/resources/js",
"@images": "/resources/js/images",
"@modules": path.resolve(__dirname + '/Modules' ) //aliases for helping IDE....
}, And don't forgot to add |
Did anyone manage to make it work with React + TypeScript? The code below renders the page components under the modules, but it still looks for the page component under the default createInertiaApp({
title: (title) => `${title} - ${appName}`,
resolve: (name) => {
const pages = import.meta.glob([
"./Pages/**/*.tsx",
"../../app-modules/*/resources/js/Pages/**/*.tsx",
]);
const regex = /([^:]+)::(.+)/;
const matches = regex.exec(name);
if (matches && matches.length > 2) {
const module = matches[1].toLowerCase();
const pageName = matches[2];
return pages[`../../app-modules/${moduleName}/resources/js/Pages/${pageName}.tsx`]();
} else {
return pages[`./Pages/${name}.tsx`]();
}
},
setup({ el, App, props }) {
const root = createRoot(el);
root.render(<App {...props} />);
},
progress: {
color: "#4B5563",
},
}); |
It turned out that the 404 issue on the initial page load was caused by the <!DOCTYPE html>
<html lang="{{ str_replace('_', '-', app()->getLocale()) }}">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title inertia>{{ config('app.name', 'Laravel') }}</title>
<!-- Fonts -->
<link rel="preconnect" href="https://fonts.bunny.net">
<link href="https://fonts.bunny.net/css?family=figtree:400,500,600&display=swap" rel="stylesheet" />
<!-- Scripts -->
@routes
@viteReactRefresh
@vite(['resources/js/app.tsx', "resources/js/Pages/{$page['component']}.tsx"]) <-- this!
@inertiaHead
</head>
<body class="font-sans antialiased">
@inertia
</body>
</html> |
@avosalmon @routes
@if(count(explode('::',$page['component'])) > 1)
@php
$module = explode('::',$page['component'])[0];
$moduleLower = strtolower($module);
$path = explode('::',$page['component'])[1];
@endphp
@vite(['resources/js/app.tsx', "app-modules/$moduleLower/resources/js/Pages/$path.tsx" ])
@else
@vite(['resources/js/app.tsx', "resources/js/Pages/{$page['component']}.tsx"])
@endif
@inertiaHead |
@inkomomutane It worked. Thanks! |
How are you guys handling (React/Vue) components and being able to import them? I would love to have a setup like:
Do you have an internal npm package or a different pattern? |
@ahinkle I have the same directory structure. You need to append the module name when you render the page component in the controller. For example, if you want to render the Inertia::render('Auth::Login'); Also, you might want to add a path alias to {
"compilerOptions": {
"allowJs": true,
"module": "ESNext",
"moduleResolution": "bundler",
"jsx": "react-jsx",
"strict": true,
"isolatedModules": true,
"target": "ESNext",
"esModuleInterop": true,
"forceConsistentCasingInFileNames": true,
"noEmit": true,
"paths": {
"@/*": ["./resources/js/*"],
"@auth/*": ["./app-modules/auth/resources/js/*"]
},
"types": ["@testing-library/jest-dom"]
},
"include": [
"resources/js/**/*.ts",
"resources/js/**/*.tsx",
"resources/js/**/*.d.ts",
"app-modules/*/resources/js/**/*.ts",
"app-modules/*/resources/js/**/*.tsx",
"app-modules/*/resources/js/**/*.d.ts"
]
} In your import react from "@vitejs/plugin-react";
import laravel from "laravel-vite-plugin";
import { defineConfig } from "vite";
import tsconfigPaths from "vite-tsconfig-paths";
export default defineConfig({
plugins: [
laravel({
input: "resources/js/app.tsx",
refresh: true,
}),
react(),
tsconfigPaths(), // Required to resolve path aliases defined in tsconfig.json.
],
...
}); |
please help share repository of example modular inertia js with vue js. |
Thanks for the great library. I know Inertia should work out well since you have the resources folder and what not.
Just curious if anyone has examples of package.json or vite.config to make sure everything builds with the main application.
I assume it might be like Nova and how they do it.
The text was updated successfully, but these errors were encountered: