@alikmanukian/momentum-modal-react
v1.0.0
Published
A react package that lets you implement backend-driven modal dialogs for Inertia apps.
Downloads
446
Maintainers
Readme
Momentum Modal (React)
Momentum Modal is a package that lets you implement backend-driven modal dialogs for Inertia apps with React.
Installation
First you need to install the Laravel package. You can find the full documentation of Momentum Modal here.
Then install the react adapter:
npm i momentum-modal-react
Warning The package utilizes
axios
under the hood. If your app is already usingaxios
as a dependency, make sure to lock it to the same version Inertia uses.npm i [email protected]
Setup
Modal is a headless component, meaning you have full control over its look, whether it's a modal dialog or a slide-over panel. You are free to use any 3rd-party solutions to power your modals, such as Headless UI or Radix.
Put the Modal
component somewhere within the layout. Also, you can pass the component resolver to the Modal
component, or use it globally.
Global
// app.jsx
// without chunks
...
globalThis.resolveMomentumModal = (name) => {
const modals = import.meta.glob("./modals/**/*.jsx", {eager: true});
return modals[`./modals/${name}.jsx`];
};
createInertiaApp(...)
...
// without chunks
...
globalThis.resolveMomentumModal = (name) => {
const modals = import.meta.glob("./modals/**/*.jsx");
return modals[`./modals/${name}.jsx`]();
};
createInertiaApp(...)
...
// YourLayout.jsx
import {Modal} from 'momentum-modal-react';
export function YourLayout({children}) {
return <>
{children}
<Modal/>
</>
}
The resolver can be the same you use to render Inertia pages.
Usage
Modals have their own routes, letting you access them even via direct URLs. Define routes for your modal pages.
// background context / base page
Route::get('{user}', ShowUser::class)
->name('users.show');
// modal route
Route::get('{user}/{tweet}', ShowTweet::class)
->name('users.tweets.show');
Render a modal from a controller. Specify the base
route to render the background when the modal is accessed directly.
class ShowTweet extends Controller
{
public function __invoke(User $user, Tweet $tweet)
{
return Inertia::modal('Tweets/Show')
->with([
'user' => $user,
'tweet' => $tweet,
])
->baseRoute('users.show', $user);
}
}
Credits
- Creator of the original Laravel and Vue 3 packages Boris Lepikhin
- Jose María Gómez
- All Contributors
License
The MIT License (MIT). Please see License File for more information.