Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/maicol07/inertia-mithril
The Mithril.js client-side adapter for Inertia.js.
https://github.com/maicol07/inertia-mithril
Last synced: about 1 month ago
JSON representation
The Mithril.js client-side adapter for Inertia.js.
- Host: GitHub
- URL: https://github.com/maicol07/inertia-mithril
- Owner: maicol07
- License: mit
- Created: 2021-07-30T21:28:35.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2023-03-14T13:28:05.000Z (almost 2 years ago)
- Last Synced: 2024-11-21T08:45:56.996Z (2 months ago)
- Language: TypeScript
- Homepage:
- Size: 64.5 KB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-inertiajs - Mithril
README
# Inertia.js Mithril Adapter
This is the [Mithril.js](https://mithril.js.org) client-side adapter for [Inertia](https://inertiajs.com).
Inertia.js lets you quickly build modern single-page apps using classic server-side routing and controllers, without building an API.To use Inertia.js you need both a server-side adapter as well as a client-side adapter.## Server-side setup
Be sure to follow the installation instructions for the [server-side framework](https://inertiajs.com/server-side-setup) you use.
## Client-side setup
### Install dependencies
Install the Mithril adapter using your preferred package manager (NPM is provided below for reference).
~~~shell
npm install @maicol07/inertia-mithril
~~~### Initialize app
Next, update your main JavaScript file to boot your Inertia app. To accomplish this, we'll initialize Mithril with the base Inertia component.
~~~js
import m from 'mithril'
import { createInertiaApp } from '@maicol07/inertia-mithril'createInertiaApp({
resolve: name => {
const pages = import.meta.glob('./Pages/**/*.jsx', { eager: true })
return pages[`./Pages/${name}.jsx`]
},
setup({ el, App, props }) {
if (!el) {
throw new Error("No mounting HTMLElement found");
}m.mount(el, {
view: () => m(App, props) // or with JSX: m.mount(el, )
});
},
})
~~~The `setup` callback receives everything necessary to initialize Mithril, including the root Inertia App component.
The `resolve` callback tells Inertia how to load a page component. It receives a page name (string), and returns a page component module. How you implement this callback depends on which bundler (Vite or Webpack) you're using.
Visit the Inertia [Client-side setup](https://inertiajs.com/client-side-setup) page to learn more.
## Shared data
To share data between server and Mithril, it's pretty simple:
1. Follow the [Shared data](https://inertiajs.com/shared-data) instructions for the server
2. You can access data via the `vnode.attrs.page.props` in your page component.## Title & meta
_To be developed_
## Links
To create links to other pages within an Inertia app, you will typically use the Inertia `` component. This component is a light wrapper around a standard anchor `` link that intercepts click events and prevents full page reloads from occurring. This is [how Inertia provides a single-page app experience](https://inertiajs.com/how-it-works) once your application has been loaded.
### Creating links
To create an Inertia link, use the Inertia `Link` component.
Note, any attributes you provide will be proxied to the underlying HTML tag.~~~js
import {Link} from '@maicol07/inertia-mithril'm(Link, {href: '/'}, 'Home')
// or use JSX:
//
~~~Almost all the other features are explained in [Inertia docs](https://inertiajs.com/links) (the React adapter syntax is very similar to Mithril one).
## Demo (outdated)
Here is a working demo using this adapter.
[https://pingcrm-mithril.tebe.ch](https://pingcrm-mithril.tebe.ch)
## More about Inertia
Visit [inertiajs.com](https://inertiajs.com/) to learn more.