Torch is a rapid admin generator for Phoenix apps. It uses generators rather than DSLs to ensure that the code remains maintainable.
To install Torch, perform the following steps:
- Add
torch
to your list of dependencies inmix.exs
. Then, runmix deps.get
:
def deps do
[{:torch, "~> 1.0.0-rc.5"}]
end
- Ensure
:torch
is started in your applications list inmix.exs
:
def application do
[applications: [:torch]]
end
- Add
torch
to yourpackage.json
dependencies. Then, runnpm install
.
"dependencies": {
"phoenix": "file:deps/phoenix",
"phoenix_html": "file:deps/phoenix_html",
+ "torch": "file:deps/torch"
},
- Import
torch.js
in yourapp.js
:
import "torch"
-
Run
mix torch.install (eex|slim)
to install the relevant Torch files. You can choose betweeneex
templates andslim
templates. If you choose to useslim
templates, you will need to install Phoenix Slim. -
Set up CSS as described below.
Torch provides its CSS in two ways:
- A precompiled css file in
priv/static/css/torch.css
. - SASS styles in
assets/css/torch.sass
If you want to customize the look and feel of your admin, you should use the SASS styles. Update your app.scss
file to look like this:
@import "admin_variables";
@import "../../../node_modules/torch/assets/css/torch";
Then, update your brunch-config.js
sass settings to make Brunch watch your node_modules directory:
plugins: {
sass: {
mode: 'native',
includePaths: ['node_modules']
}
}
Then, simply uncomment and customize the variables in web/static/css/_admin_variables.scss
to change how Torch is styled.
If you're not using SASS, then you will need to configure your asset pipeline to compile the precompiled torch.css
. Brunch can be configured to do this like so:
- Add
node_modules
to the watched directories forstylesheets
.
stylesheets: {
joinTo: {
'css/app.css': /^(web|node_modules)/
}
}
- Add
torch
to the npm configuration:
npm: {
enabled: true
styles: {
torch: [
'priv/static/torch.css'
]
}
}
Run mix torch.gen (eex|slim)
to generate admin controllers and views for a given Ecto schema module. Torch expects you to have already defined the schema in your project.
For example, if we wanted to generate an admin area for a Post
model we already have using eex
templates, we could run this command:
$ mix torch.gen eex Admin Post posts title:string body:text inserted_at:date
And the output would be:
Success!
You should now add a route to the new controller to your `router.ex`, within the `:admin` scope:
scope "/admin", Example.Admin, as: :admin do
pipe_through :browser
resources "/posts", PostController
end
And update the `layout/admin.html.eex` navigation:
<header id="main-header">
<nav>
<h1>Torch Admin</h1>
<ul>
<li><%= Torch.NavigationView.nav_link @conn, "Posts", admin_post_path(@conn, :index) %></a>
</ul>
</nav>
</header>
The command created the following files for us:
web/templates/admin/post/index.html.eex
web/templates/admin/post/edit.html.eex
web/templates/admin/post/new.html.eex
web/templates/admin/post/_form.html.eex
web/templates/admin/post/_filters.html.eex
web/controllers/admin/post_controller.ex
web/views/admin/post_view.ex
If you hook up the routes as described above, you'll see a fully featured CRUD interface for posts, including sophisticated filtering, sorting and search at http://localhost:4000/admin/posts.
To learn more about the torch.gen
task, run:
mix help torch.gen
Torch, as open source projects, is free to use and always will be. Infinite Red offers premium Torch support and general web app design/development services. Email us at hello@infinite.red to get in touch with us for more details.