2017-03-29 14:11:22 +00:00
|
|
|
defmodule AutoLinker do
|
|
|
|
@moduledoc """
|
2017-03-29 14:36:21 +00:00
|
|
|
Create url links from text containing urls.
|
|
|
|
|
|
|
|
Turns an input string like `"Check out google.com"` into
|
2019-02-18 16:49:08 +00:00
|
|
|
`Check out "<a href=\"http://google.com\" target=\"_blank\" rel=\"noopener noreferrer\">google.com</a>"`
|
2017-03-29 14:36:21 +00:00
|
|
|
|
|
|
|
## Examples
|
|
|
|
|
|
|
|
iex> AutoLinker.link("google.com")
|
2019-02-18 16:49:08 +00:00
|
|
|
~s(<a href="http://google.com" class="auto-linker" target="_blank" rel="noopener noreferrer">google.com</a>)
|
2017-03-29 14:36:21 +00:00
|
|
|
|
|
|
|
iex> AutoLinker.link("google.com", new_window: false, rel: false)
|
2019-02-18 16:49:08 +00:00
|
|
|
~s(<a href="http://google.com" class="auto-linker">google.com</a>)
|
2017-03-29 14:36:21 +00:00
|
|
|
|
|
|
|
iex> AutoLinker.link("google.com", new_window: false, rel: false, class: false)
|
2019-02-18 16:49:08 +00:00
|
|
|
~s(<a href="http://google.com">google.com</a>)
|
2017-03-29 14:11:22 +00:00
|
|
|
"""
|
|
|
|
|
2017-03-29 14:58:06 +00:00
|
|
|
import AutoLinker.Parser
|
|
|
|
|
2017-03-29 14:36:21 +00:00
|
|
|
@doc """
|
|
|
|
Auto link a string.
|
2017-03-29 20:27:13 +00:00
|
|
|
|
|
|
|
Options:
|
|
|
|
|
|
|
|
* `class: "auto-linker"` - specify the class to be added to the generated link. false to clear
|
|
|
|
* `rel: "noopener noreferrer"` - override the rel attribute. false to clear
|
|
|
|
* `new_window: true` - set to false to remove `target='_blank'` attribute
|
|
|
|
* `truncate: false` - Set to a number to truncate urls longer then the number. Truncated urls will end in `..`
|
|
|
|
* `strip_prefix: true` - Strip the scheme prefix
|
|
|
|
* `exclude_class: false` - Set to a class name when you don't want urls auto linked in the html of the give class
|
|
|
|
* `exclude_id: false` - Set to an element id when you don't want urls auto linked in the html of the give element
|
2019-02-07 05:32:50 +00:00
|
|
|
* `exclude_patterns: ["```"]` - Don't link anything between the the pattern
|
2019-02-08 09:10:22 +00:00
|
|
|
* `email: false` - link email links
|
|
|
|
* `mention: false` - link @mentions (when `true`, requires `mention_prefix` or `mention_handler` options to be set)
|
|
|
|
* `mention_prefix: nil` - a prefix to build a link for a mention (example: `https://example.com/user/`)
|
|
|
|
* `mention_handler: nil` - a custom handler to validate and formart a mention
|
|
|
|
* `hashtag: false` - link #hashtags (when `true`, requires `hashtag_prefix` or `hashtag_handler` options to be set)
|
|
|
|
* `hashtag_prefix: nil` - a prefix to build a link for a hashtag (example: `https://example.com/tag/`)
|
|
|
|
* `hashtag_handler: nil` - a custom handler to validate and formart a hashtag
|
|
|
|
* `extra: false` - link urls with rarely used schemes (magnet, ipfs, irc, etc.)
|
2019-06-18 10:25:44 +00:00
|
|
|
* `validate_tld: true` - Set to false to disable TLD validation for urls/emails, also can be set to :no_scheme to validate TLDs only for urls without a scheme (e.g `example.com` will be validated, but `http://example.loki` won't)
|
2017-03-29 20:27:13 +00:00
|
|
|
|
|
|
|
Each of the above options can be specified when calling `link(text, opts)`
|
2019-02-07 05:32:50 +00:00
|
|
|
or can be set in the `:auto_linker`'s configuration. For example:
|
2017-03-29 20:27:13 +00:00
|
|
|
|
|
|
|
config :auto_linker,
|
|
|
|
class: false,
|
|
|
|
new_window: false
|
|
|
|
|
|
|
|
Note that passing opts to `link/2` will override the configuration settings.
|
2017-03-29 14:36:21 +00:00
|
|
|
"""
|
2017-03-29 14:11:22 +00:00
|
|
|
def link(text, opts \\ []) do
|
2019-02-08 09:43:06 +00:00
|
|
|
parse(text, opts)
|
2019-02-08 08:21:07 +00:00
|
|
|
end
|
|
|
|
|
2019-02-08 09:10:02 +00:00
|
|
|
def link_map(text, acc, opts \\ []) do
|
|
|
|
parse({text, acc}, opts)
|
2017-03-29 14:11:22 +00:00
|
|
|
end
|
|
|
|
end
|