| Install | |
|---|---|
composer require crmdesenvolvimentos/modules-inertia |
|
| Latest Version: | 12.0 |
| PHP: | >=8.1.0 |
The package is designed to be used by Vue/InertiaJs in conjunction with Laravel-Modules
| Laravel | modules-inertia |
|---|---|
| 10.0-12.x | 1.0.x - 2.0.x |
Install the package via composer.
composer require crmdesenvolvimentos/modules-inertia
In order to edit the default configuration you may execute:
php artisan vendor:publish --provider="Crmdesenvolvimentos\ModulesInertia\ModulesInertiaServiceProvider"
By default, the module classes are not loaded automatically. You can autoload your modules using psr-4. For example:
{
"autoload": {
"psr-4": {
"App\\": "app/",
"Modules\\": "Modules/",
"Database\\Factories\\": "database/factories/",
"Database\\Seeders\\": "database/seeders/"
}
}
Tip: don't forget to run composer dump-autoload afterwards.
By default, Vue module files are created in the module directory Resources/Pages
You can change the default directory in config/modules.php
'Pages/Index' => 'Resources/Pages/Index.vue',
//...
'source' => 'Resources/Pages',
The default value of Inertia::render() in a module has been changed to Inertia::module().
Inertia::render() is still available by default. It can be used outside of modules
module_name - real name of the current modulefile_name - real name of the file (no extension .vue)directory_name - if you have nested display folder structure ( you can specify the file path separating by a dot )For example:
public function some_method()
{
return Inertia::module('module_name::file_name');
//
return Inertia::module('module_name::file_name', ['data'=>'some data']);
//
return Inertia::module('module_name::directory_name.file_name', ['data'=>'some data']);
}
import { createApp, h } from "vue";
import { createInertiaApp } from "@inertiajs/inertia-vue3";
createInertiaApp({
resolve: (name) => {
const pages = import.meta.glob("./Pages/**/*.vue", { eager: true });
let isModule = name.split("::");
if (isModule.length > 1) {
const pageModules = import.meta.glob("/Modules/**/*.vue", { eager: true });
let module = isModule[0];
let pathTo = isModule[1];
return pageModules[`/Modules/${module}/${pathTo}.vue`];
} else {
return pages[`./Pages/${name}.vue`];
}
},
setup({ el, App, props, plugin }) {
createApp({ render: () => h(App, props) })
.use(plugin)
.mount(el);
},
});
You can run php artisan module:publish-stubs to publish stubs.
And override the generation of default files
To be VueJS able to find the created module, you need to rebuild the script
npm run dev
You'll find installation instructions and full documentation on https://docs.laravelmodules.com/.
The MIT License (MIT). Please see License File for more information.