Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/khusnetdinov/phoenix_routes_js
Phoenix routes helpers in JavaScript code.
https://github.com/khusnetdinov/phoenix_routes_js
helpers javascript phoenix-framework routes
Last synced: about 2 months ago
JSON representation
Phoenix routes helpers in JavaScript code.
- Host: GitHub
- URL: https://github.com/khusnetdinov/phoenix_routes_js
- Owner: khusnetdinov
- License: mit
- Created: 2017-08-26T20:22:13.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2022-03-24T14:58:41.000Z (over 2 years ago)
- Last Synced: 2024-10-09T13:12:30.317Z (2 months ago)
- Topics: helpers, javascript, phoenix-framework, routes
- Language: Elixir
- Size: 11.7 KB
- Stars: 21
- Watchers: 4
- Forks: 4
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- freaking_awesome_elixir - Elixir - Phoenix routes helpers in JavaScript code and browser console. (ECMAScript)
- fucking-awesome-elixir - phoenix_routes_js - Phoenix routes helpers in JavaScript code and browser console. (ECMAScript)
- awesome-elixir - phoenix_routes_js - Phoenix routes helpers in JavaScript code and browser console. (ECMAScript)
README
# PhoenixRoutesJs [![Hex.pm](https://img.shields.io/hexpm/v/plug.svg)](https://hex.pm/packages/phoenix_routes_js) [![Build Status](https://travis-ci.org/khusnetdinov/phoenix_routes_js.svg?branch=master)](https://travis-ci.org/khusnetdinov/phoenix_routes_js) [![Open Source Helpers](https://www.codetriage.com/khusnetdinov/phoenix_routes_js/badges/users.svg)](https://www.codetriage.com/khusnetdinov/phoenix_routes_js)
## Phoenix routes helpers in javascript code## Installation
If [available in Hex](https://hex.pm/docs/publish), the package can be installed
by adding `phoenix_routes_js` to your list of dependencies in `mix.exs`:```elixir
def deps do
[{:phoenix_routes_js, "~> 0.1.1"}]
end
```## Usage
### Two steps configuration:
1) Add possibility to use view helper by adding `use PhoenixRoutesJs.View` in template `**_web/views/layout_view.ex` file:
```elixir
defmodule Project.LayoutView do
...
import PhoenixRoutesJs.View
...
end```
2) Add helper `render_routes_script` to you layout in `**_web/templates/layout/app.html.eex` before main javascript file:
```elixir
...
<%= render_routes_script(@conn) %>
">
...
```### Examples
```
render_routes_script(@conn)
render_routes_script(Project.Router)
```Now you can use phoenix routes helpers in browser console and javascript code.
### Helpers
```
user_path GET /users UserController :index Routes.user_path('index')
user_path GET /users/:id/edit UserController :edit Routes.user_path('edit', ':id')
user_path GET /users/new UserController :new Routes.user_path('new')
user_path GET /users/:id UserController :show Routes.user_path('show', ':id')
user_path POST /users UserController :create Routes.user_path('create')
user_path PATCH /users/:id UserController :update Routes.user_path('update', ':id')
PUT /users/:id UserController :update
user_path DELETE /users/:id UserController :delete Routes.user_path('delete', ':id')
```### JavaScript
Routes object is kept in `window`.
#### Browser
Now you can access to you helpers in console:
```javascript
// browser consoleRoutes.user_path('edit', 1)
//=> /users/1/edit
```#### JavaScript assets
```JavaScript
// Somewhere in javascript moduleswindow.Routes.user_path('edit', 1)
//=> /users/1/edit
```#### JavaScript options:
Routes options:
- `format` - Add '.format' to request path string.
- `params` - Add query string to request path.```JavaScript
Routes.user_path('index', {format: 'json', params: {filter: 'query', sort: 'acs'}})//=> "/users.json?filter=query&sort=acs"
```## License
The library is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).