Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ikeikeikeike/phoenix_html_simplified_helpers
Some helpers for phoenix html( truncate, time_ago_in_words, number_with_delimiter, url_for, current_page? )
https://github.com/ikeikeikeike/phoenix_html_simplified_helpers
elixir helper html phoenix
Last synced: 5 days ago
JSON representation
Some helpers for phoenix html( truncate, time_ago_in_words, number_with_delimiter, url_for, current_page? )
- Host: GitHub
- URL: https://github.com/ikeikeikeike/phoenix_html_simplified_helpers
- Owner: ikeikeikeike
- License: mit
- Created: 2016-02-23T14:16:51.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2021-05-25T08:13:18.000Z (over 3 years ago)
- Last Synced: 2025-02-02T10:33:02.639Z (18 days ago)
- Topics: elixir, helper, html, phoenix
- Language: Elixir
- Homepage: https://github.com/ikeikeikeike/phoenix_html_simplified_helpers
- Size: 57.6 KB
- Stars: 31
- Watchers: 2
- Forks: 11
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- freaking_awesome_elixir - Elixir - Some helpers for phoenix html (truncate, time_ago_in_words, number_with_delimiter). (Framework Components)
- fucking-awesome-elixir - phoenix_html_simplified_helpers - Some helpers for phoenix html (truncate, time_ago_in_words, number_with_delimiter). (Framework Components)
- awesome-elixir - phoenix_html_simplified_helpers - Some helpers for phoenix html (truncate, time_ago_in_words, number_with_delimiter). (Framework Components)
README
# PhoenixHtmlSimplifiedHelpers
[data:image/s3,"s3://crabby-images/24019/240191c632701339033c19b5c84fb14c07c4af65" alt="Build Status"](http://travis-ci.org/ikeikeikeike/phoenix_html_simplified_helpers)
[data:image/s3,"s3://crabby-images/4e9da/4e9da55e8bdac1078e7ae41b6fb26353f2dabbd9" alt="Hex version"](https://hex.pm/packages/phoenix_html_simplified_helpers)
[data:image/s3,"s3://crabby-images/d4dee/d4dee515d05766fd7156518a3e94be7eb7352934" alt="Hex downloads"](https://hex.pm/packages/phoenix_html_simplified_helpers)
[data:image/s3,"s3://crabby-images/20cbd/20cbd20c9c106b2e43cd489439b6758701a4f588" alt="Deps Status"](https://beta.hexfaktor.org/github/ikeikeikeike/phoenix_html_simplified_helpers)
[data:image/s3,"s3://crabby-images/6a00d/6a00da51e057c6c71e176a15b1a7da6d1f04eb29" alt="Inline docs"](http://inch-ci.org/github/ikeikeikeike/phoenix_html_simplified_helpers)
[data:image/s3,"s3://crabby-images/84f50/84f5024d1889c338fb93c3af38d05601a29ebbd5" alt="hex.pm"](https://github.com/ikeikeikeike/phoenix_html_simplified_helpers/blob/master/LICENSE)## Installation
If [available in Hex](https://hex.pm/docs/publish), the package can be installed as:
1. Add phoenix_html_simplified_helpers to your list of dependencies in `mix.exs`:
```elixir
def deps do
[{:phoenix_html_simplified_helpers, "~> x.x.x"}]
end
```2. Ensure phoenix_html_simplified_helpers is started before your application:
```elixir
def application do
[applications: [:phoenix_html_simplified_helpers]]
end
```3. phoenix_html_simplified_helpers need to import(use) your Phoenix project. The following description is adding 'use syntax' into web.ex.
```elixir
def view do
quote do
use Phoenix.View, root: "web/templates"# Import convenience functions from controllers
import Phoenix.Controller, only: [get_csrf_token: 0, get_flash: 2, view_module: 1]# Use all HTML functionality (forms, tags, etc)
use Phoenix.HTML
use Phoenix.HTML.SimplifiedHelpers # <- this line.import MyApp.Router.Helpers
import MyApp.ErrorHelpers
import MyApp.Gettext
end
end
```It is also able to import(use) in each view helper files.
```elixir
defmodule MyApp.LayoutView do
use MyApp.Web, :view
import Phoenix.HTML.SimplifiedHelpers.Truncate # <- this line.
import Phoenix.HTML.SimplifiedHelpers.TimeAgoInWords # <- this line.
end
```4. time_ago_in_words has Gettext module that is changed translation file from project's locale.
```elixir
Gettext.put_locale(Phoenix.HTML.SimplifiedHelpers.Gettext, "en")
Gettext.put_locale(Phoenix.HTML.SimplifiedHelpers.Gettext, "ja")
Gettext.put_locale(Phoenix.HTML.SimplifiedHelpers.Gettext, "es")
```# Usage
## truncate
```elixir
<%= truncate entity.content %>
```
```elixir
truncate "Once upon a time in a world far far away"
# Once upon a time in a world...
truncate "Once upon a time in a world far far away", length: 27
# Once upon a time in a wo...
truncate "And they found that many people were sleeping better.", length: 25, omission: "... (continued)"
# And they f... (continued)
truncate("Once upon a time in a world far far away", length: 17, separator: " ")
# Once upon a...
```## time_ago_in_words
```elixir
<%= time_ago_in_words entity.published_at %> ago
``````elixir
time_ago_in_words :os.system_time
# less than 5 seconds
time_ago_in_words Timex.now
# less than 5 seconds
time_ago_in_words DateTime.utc_now
# less than 5 seconds
time_ago_in_words Ecto.DateTime.utc
# less than 5 seconds
time_ago_in_words NaiveDateTime.utc_now
# less than 5 seconds
time_ago_in_words ~N[2017-08-14 04:40:12.101212]
# ......
```### distance_of_time_in_words
```elixir
from = Timex.to_datetime({{2015, 10, 31}, {0, 0, 0}})
to = Timex.shift(from, days: 45)
distance_of_time_in_words(from, to)
# about 2 monthsGettext.put_locale(Phoenix.HTML.SimplifiedHelpers.Gettext, "ja")
from = Timex.to_datetime({{2015, 10, 31}, {0, 0, 0}})
to = Timex.shift(from, months: 1)
distance_of_time_in_words(from, to)
# 約1ヶ月Gettext.put_locale(Phoenix.HTML.SimplifiedHelpers.Gettext, "es")
from = Timex.to_datetime({{2015, 10, 31}, {0, 0, 0}})
to = Timex.shift(from, months: 18)
distance_of_time_in_words(from, to)
# más de 1 año
```Or uses `Timex.format!("{relative}", :relative)` instead, like this.
```elixir
Timex.shift(datetime, hours: -3) |> Timex.format!("{relative}", :relative)
"3 hours ago"
```## number_with_delimiter
```elixir
number_with_delimiter 1234567
# 1,234,567
```## url_for
Routes setting is [Here](https://github.com/ikeikeikeike/phoenix_html_simplified_helpers/blob/master/test/test_helper.exs).
```elixir
url_for(conn, "home.index")
# /url_for(conn, "entry.release:")
# /release/url_for(conn, "entry.release:percent")
# /release/percenturl_for(conn, "entry.release:", some: "query")
# /release/?some=queryurl_for(conn, "entry.release:", some: "query", unko: "query2")
# /release/?some=query&unko=query2
```## current_page?
```elixir
conn = conn(:get, "/release/")current_page?(conn, "entry.release:")
# truecurrent_page?(conn, "home.index")
# false