Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/devato/inertia_phoenix
Inertiajs Adapter for Elixir Phoenix
https://github.com/devato/inertia_phoenix
elixir-phoenix inertia-phoenix inertiajs inertiajs-adapter reactjs vuejs
Last synced: 2 days ago
JSON representation
Inertiajs Adapter for Elixir Phoenix
- Host: GitHub
- URL: https://github.com/devato/inertia_phoenix
- Owner: devato
- License: mit
- Created: 2020-02-14T18:34:14.000Z (almost 5 years ago)
- Default Branch: main
- Last Pushed: 2023-09-18T10:11:03.000Z (over 1 year ago)
- Last Synced: 2025-01-02T09:11:47.341Z (9 days ago)
- Topics: elixir-phoenix, inertia-phoenix, inertiajs, inertiajs-adapter, reactjs, vuejs
- Language: Elixir
- Homepage: https://devato.com
- Size: 213 KB
- Stars: 87
- Watchers: 3
- Forks: 11
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.txt
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-inertiajs - Phoenix
README
# Inertia Phoenix
Maintained by [Devato](https://devato.com)
[![CI](https://github.com/devato/inertia_phoenix/actions/workflows/ci.yml/badge.svg?branch=main)](https://github.com/devato/inertia_phoenix/actions/workflows/ci.yml)
![Coverage](https://img.shields.io/coveralls/github/devato/inertia_phoenix/master)
[![Codacy Badge](https://api.codacy.com/project/badge/Grade/2aafaf190f434aca97c9734ae2395bcc)](https://app.codacy.com/gh/devato/inertia_phoenix?utm_source=github.com&utm_medium=referral&utm_content=devato/inertia_phoenix&utm_campaign=Badge_Grade_Dashboard)
[![Hex.pm](https://img.shields.io/hexpm/v/inertia_phoenix)](https://hex.pm/packages/inertia_phoenix)Inertiajs Adapter for Elixir Phoenix
- [Usage](#usage)
- [Installation](#installation)
- [Configuration](#configuration)
- [Render from Controller](#render-from-controller)
- [Layout/Templates](#layouttemplates)
- [Shared Data / Props](#shared-data--props)
- [Shared Data Custom Plug](#shared-data-custom-plug)
- [Handle Form Errors](#handle-form-errors)
- [Configure Axios](#configure-axios)
- [Features](#features)
- [Complete](#complete)
- [In Progress](#in-progress)
- [Example Apps](#example-apps)
- [Contributing](#contributing)# Usage
Getting started with Inertia.js in a few steps.
## Installation
Add to mix.exs:
```elixir
{:inertia_phoenix, "~> 0.4.0"}
```Add Plug to `WEB_PATH/router.ex`
```elixir
pipeline :browser do
...
plug InertiaPhoenix.Plug
end
```Import render_inertia `lib/active_web.ex`
```elixir
def controller do
quote do
...
import InertiaPhoenix.Controller
end
end
```## Configuration
Add to `config/config.exs`
```elixir
config :inertia_phoenix,
assets_version: 1, # default 1
inertia_layout: "app.html" # default app.html
```- Asset Versioning Docs: https://inertiajs.com/asset-versioning
## Render from Controller
NOTE: Flash data is automatically passed through to the page props.
```elixir
def index(conn, _params) do
render_inertia(conn, "Home", props: %{hello: "world"})# OR
render_inertia(conn, "Home")
end
```## Layout/Templates
- Doesn't require templates as Inertia Pages are templates.
- `div#app` is rendered automatically.An example layout:
```eex
...
<%= @inner_content %>
">
```
## Shared Data / Props
Inertia.js Docs: https://inertiajs.com/shared-data
To share data:
```elixir
InertiaPhoenix.share(:hello, fn -> :world end)
InertiaPhoenix.share(:foo, :baz)
InertiaPhoenix.share("user", %{name: "José"})
```NOTE: `props` will overwrite shared data.
### Shared Data Custom Plug
For more complex data, you can create a custom plug.
Here's an example from the PingCRM app:
```elixir
defmodule PingWeb.Plugs.InertiaShare dodef init(default), do: default
def call(conn, _) do
InertiaPhoenix.share(conn, :auth, build_auth_map(conn))
enddefp build_auth_map(conn) do
# build complex auth map
end
end
```
Then add it to any pipeline that makes sense in `myapp_web/router.ex`:```elixir
pipeline :browser do
...
plug PingWeb.Plugs.InertiaShare # put before main Plug
plug InertiaPhoenix.Plug
end
```
## Handle Form ErrorsWe can use Shared Data and the Phoenix Session to store server side errors.
See [PingCRM](https://github.com/devato/pingcrm) for examples.
## Configure Axios
`XSRF-TOKEN` cookie is set automatically.
To configure axios to use it by default, in `app.js`
```javascript
import axios from "axios";
axios.defaults.xsrfHeaderName = "x-csrf-token";
```# Features
## Complete
- Render React/Vue/Svelte from controllers
- Flash data passed to props via Plug
- Assets Versioning: https://inertiajs.com/asset-versioning
- Lazy Evaluation: https://inertiajs.com/responses#lazy-evaluation
- Auto put response cookie for crsf token: https://inertiajs.com/security#csrf-protection
- Override redirect codes: https://inertiajs.com/redirects#303-response-code
- Partial reloads: https://inertiajs.com/requests#partial-reloads
- Shared data interface: https://inertiajs.com/shared-data## In Progress
[See Issue Tracker](https://github.com/devato/inertia_phoenix/issues)
# Example Apps
- N/A
# Contributing
[Contribution guidelines for this project](CONTRIBUTING.md)