Drop phone links support
This commit is contained in:
parent
b044a63910
commit
529014c8f4
5 changed files with 4 additions and 161 deletions
|
@ -75,34 +75,6 @@ defmodule AutoLinker.Builder do
|
||||||
|
|
||||||
defp strip_prefix(url, _), do: url
|
defp strip_prefix(url, _), do: url
|
||||||
|
|
||||||
def create_phone_link([], buffer, _), do: buffer
|
|
||||||
|
|
||||||
def create_phone_link([h | t], buffer, opts) do
|
|
||||||
create_phone_link(t, format_phone_link(h, buffer, opts), opts)
|
|
||||||
end
|
|
||||||
|
|
||||||
def format_phone_link([h | _], buffer, opts) do
|
|
||||||
val =
|
|
||||||
h
|
|
||||||
|> String.replace(~r/[\.\+\- x\(\)]+/, "")
|
|
||||||
|> format_phone_link(h, opts)
|
|
||||||
|
|
||||||
# val = ~s'<a href="#" class="phone-number" data-phone="#{number}">#{h}</a>'
|
|
||||||
String.replace(buffer, h, val)
|
|
||||||
end
|
|
||||||
|
|
||||||
def format_phone_link(number, original, opts) do
|
|
||||||
tag = opts[:tag] || "a"
|
|
||||||
class = opts[:class] || "phone-number"
|
|
||||||
data_phone = opts[:data_phone] || "data-phone"
|
|
||||||
attrs = format_attributes(opts[:attributes] || [])
|
|
||||||
href = opts[:href] || "#"
|
|
||||||
|
|
||||||
~s'<#{tag} href="#{href}" class="#{class}" #{data_phone}="#{number}"#{attrs}>#{original}</#{
|
|
||||||
tag
|
|
||||||
}>'
|
|
||||||
end
|
|
||||||
|
|
||||||
def create_mention_link("@" <> name, _buffer, opts) do
|
def create_mention_link("@" <> name, _buffer, opts) do
|
||||||
mention_prefix = opts[:mention_prefix]
|
mention_prefix = opts[:mention_prefix]
|
||||||
|
|
||||||
|
@ -164,10 +136,4 @@ defmodule AutoLinker.Builder do
|
||||||
attrs = format_attrs(attrs)
|
attrs = format_attrs(attrs)
|
||||||
~s(<a #{attrs}>#{uri}</a>)
|
~s(<a #{attrs}>#{uri}</a>)
|
||||||
end
|
end
|
||||||
|
|
||||||
defp format_attributes(attrs) do
|
|
||||||
Enum.reduce(attrs, "", fn {name, value}, acc ->
|
|
||||||
acc <> ~s' #{name}="#{value}"'
|
|
||||||
end)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -9,8 +9,6 @@ defmodule AutoLinker.Parser do
|
||||||
|
|
||||||
@match_url ~r{^(?:\W*)?(?<url>(?:https?:\/\/)?[\w.-]+(?:\.[\w\.-]+)+[\w\-\._~%:\/?#[\]@!\$&'\(\)\*\+,;=.]+$)}u
|
@match_url ~r{^(?:\W*)?(?<url>(?:https?:\/\/)?[\w.-]+(?:\.[\w\.-]+)+[\w\-\._~%:\/?#[\]@!\$&'\(\)\*\+,;=.]+$)}u
|
||||||
|
|
||||||
@match_phone ~r"((?:x\d{2,7})|(?:(?:\+?1\s?(?:[.-]\s?)?)?(?:\(\s?(?:[2-9]1[02-9]|[2-9][02-8]1|[2-9][02-8][02-9])\s?\)|(?:[2-9]1[02-9]|[2-9][02-8]1|[2-9][02-8][02-9]))\s?(?:[.-]\s?)?)(?:[2-9]1[02-9]|[2-9][02-9]1|[2-9][02-9]{2})\s?(?:[.-]\s?)?(?:[0-9]{4}))"
|
|
||||||
|
|
||||||
@match_hostname ~r{^\W*(?<scheme>https?:\/\/)?(?:[^@\n]+\\w@)?(?<host>[^:#~\/\n?]+)}u
|
@match_hostname ~r{^\W*(?<scheme>https?:\/\/)?(?:[^@\n]+\\w@)?(?<host>[^:#~\/\n?]+)}u
|
||||||
|
|
||||||
@match_ip ~r"^(([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])$"
|
@match_ip ~r"^(([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])$"
|
||||||
|
@ -51,15 +49,6 @@ defmodule AutoLinker.Parser do
|
||||||
|
|
||||||
iex> AutoLinker.Parser.parse("Check out google.com")
|
iex> AutoLinker.Parser.parse("Check out google.com")
|
||||||
~s{Check out <a href="http://google.com" class="auto-linker" target="_blank" rel="noopener noreferrer">google.com</a>}
|
~s{Check out <a href="http://google.com" class="auto-linker" target="_blank" rel="noopener noreferrer">google.com</a>}
|
||||||
|
|
||||||
iex> AutoLinker.Parser.parse("call me at x9999", phone: true)
|
|
||||||
~s{call me at <a href="#" class="phone-number" data-phone="9999">x9999</a>}
|
|
||||||
|
|
||||||
iex> AutoLinker.Parser.parse("or at home on 555.555.5555", phone: true)
|
|
||||||
~s{or at home on <a href="#" class="phone-number" data-phone="5555555555">555.555.5555</a>}
|
|
||||||
|
|
||||||
iex> AutoLinker.Parser.parse(", work (555) 555-5555", phone: true)
|
|
||||||
~s{, work <a href="#" class="phone-number" data-phone="5555555555">(555) 555-5555</a>}
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def parse(input, opts \\ %{})
|
def parse(input, opts \\ %{})
|
||||||
|
@ -88,15 +77,8 @@ defmodule AutoLinker.Parser do
|
||||||
do_parse(input, Map.merge(config, opts))
|
do_parse(input, Map.merge(config, opts))
|
||||||
end
|
end
|
||||||
|
|
||||||
defp do_parse(input, %{phone: false} = opts), do: do_parse(input, Map.delete(opts, :phone))
|
|
||||||
defp do_parse(input, %{url: false} = opts), do: do_parse(input, Map.delete(opts, :url))
|
defp do_parse(input, %{url: false} = opts), do: do_parse(input, Map.delete(opts, :url))
|
||||||
|
|
||||||
defp do_parse(input, %{phone: _} = opts) do
|
|
||||||
input
|
|
||||||
|> do_parse(opts, {"", "", :parsing}, &check_and_link_phone/3)
|
|
||||||
|> do_parse(Map.delete(opts, :phone))
|
|
||||||
end
|
|
||||||
|
|
||||||
defp do_parse(input, %{hashtag: true} = opts) do
|
defp do_parse(input, %{hashtag: true} = opts) do
|
||||||
input
|
input
|
||||||
|> do_parse(opts, {"", "", :parsing}, &check_and_link_hashtag/3)
|
|> do_parse(opts, {"", "", :parsing}, &check_and_link_hashtag/3)
|
||||||
|
@ -210,15 +192,6 @@ defmodule AutoLinker.Parser do
|
||||||
do_parse({text, user_acc}, opts, {"", acc <> buffer, {:attrs, level}}, handler)
|
do_parse({text, user_acc}, opts, {"", acc <> buffer, {:attrs, level}}, handler)
|
||||||
end
|
end
|
||||||
|
|
||||||
# default cases where state is not important
|
|
||||||
defp do_parse(
|
|
||||||
{" " <> text, user_acc},
|
|
||||||
%{phone: _} = opts,
|
|
||||||
{buffer, acc, state},
|
|
||||||
handler
|
|
||||||
),
|
|
||||||
do: do_parse({text, user_acc}, opts, {buffer <> " ", acc, state}, handler)
|
|
||||||
|
|
||||||
defp do_parse(
|
defp do_parse(
|
||||||
{<<char::bytes-size(1), text::binary>>, user_acc},
|
{<<char::bytes-size(1), text::binary>>, user_acc},
|
||||||
opts,
|
opts,
|
||||||
|
@ -273,12 +246,6 @@ defmodule AutoLinker.Parser do
|
||||||
if email?(buffer, opts), do: link_email(buffer, opts), else: buffer
|
if email?(buffer, opts), do: link_email(buffer, opts), else: buffer
|
||||||
end
|
end
|
||||||
|
|
||||||
def check_and_link_phone(buffer, opts, _user_acc) do
|
|
||||||
buffer
|
|
||||||
|> match_phone
|
|
||||||
|> link_phone(buffer, opts)
|
|
||||||
end
|
|
||||||
|
|
||||||
def check_and_link_mention(buffer, opts, user_acc) do
|
def check_and_link_mention(buffer, opts, user_acc) do
|
||||||
buffer
|
buffer
|
||||||
|> match_mention
|
|> match_mention
|
||||||
|
@ -340,14 +307,6 @@ defmodule AutoLinker.Parser do
|
||||||
|
|
||||||
def ip?(buffer), do: Regex.match?(@match_ip, buffer)
|
def ip?(buffer), do: Regex.match?(@match_ip, buffer)
|
||||||
|
|
||||||
@doc false
|
|
||||||
def match_phone(buffer) do
|
|
||||||
case Regex.scan(@match_phone, buffer) do
|
|
||||||
[] -> nil
|
|
||||||
other -> other
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def match_mention(buffer) do
|
def match_mention(buffer) do
|
||||||
case Regex.run(@match_mention, buffer) do
|
case Regex.run(@match_mention, buffer) do
|
||||||
[mention] -> mention
|
[mention] -> mention
|
||||||
|
@ -402,12 +361,6 @@ defmodule AutoLinker.Parser do
|
||||||
|
|
||||||
defp maybe_update_buffer(out, _match, _buffer), do: out
|
defp maybe_update_buffer(out, _match, _buffer), do: out
|
||||||
|
|
||||||
def link_phone(nil, buffer, _), do: buffer
|
|
||||||
|
|
||||||
def link_phone(list, buffer, opts) do
|
|
||||||
Builder.create_phone_link(list, buffer, opts)
|
|
||||||
end
|
|
||||||
|
|
||||||
@doc false
|
@doc false
|
||||||
def link_url(buffer, opts) do
|
def link_url(buffer, opts) do
|
||||||
Builder.create_link(buffer, opts)
|
Builder.create_link(buffer, opts)
|
||||||
|
|
|
@ -2,11 +2,6 @@ defmodule AutoLinkerTest do
|
||||||
use ExUnit.Case, async: true
|
use ExUnit.Case, async: true
|
||||||
doctest AutoLinker
|
doctest AutoLinker
|
||||||
|
|
||||||
test "phone number" do
|
|
||||||
assert AutoLinker.link(", work (555) 555-5555", phone: true) ==
|
|
||||||
~s{, work <a href="#" class="phone-number" data-phone="5555555555">(555) 555-5555</a>}
|
|
||||||
end
|
|
||||||
|
|
||||||
test "default link" do
|
test "default link" do
|
||||||
assert AutoLinker.link("google.com") ==
|
assert AutoLinker.link("google.com") ==
|
||||||
"<a href=\"http://google.com\" class=\"auto-linker\" target=\"_blank\" rel=\"noopener noreferrer\">google.com</a>"
|
"<a href=\"http://google.com\" class=\"auto-linker\" target=\"_blank\" rel=\"noopener noreferrer\">google.com</a>"
|
||||||
|
@ -18,13 +13,12 @@ defmodule AutoLinkerTest do
|
||||||
end
|
end
|
||||||
|
|
||||||
test "all kinds of links" do
|
test "all kinds of links" do
|
||||||
text = "hello google.com https://ddg.com 888 888-8888 user@email.com irc:///mIRC"
|
text = "hello google.com https://ddg.com user@email.com irc:///mIRC"
|
||||||
|
|
||||||
expected =
|
expected =
|
||||||
"hello <a href=\"http://google.com\">google.com</a> <a href=\"https://ddg.com\">ddg.com</a> <a href=\"#\" class=\"phone-number\" data-phone=\"8888888888\">888 888-8888</a> <a href=\"mailto:user@email.com\">user@email.com</a> <a href=\"irc:///mIRC\">irc:///mIRC</a>"
|
"hello <a href=\"http://google.com\">google.com</a> <a href=\"https://ddg.com\">ddg.com</a> <a href=\"mailto:user@email.com\">user@email.com</a> <a href=\"irc:///mIRC\">irc:///mIRC</a>"
|
||||||
|
|
||||||
assert AutoLinker.link(text,
|
assert AutoLinker.link(text,
|
||||||
phone: true,
|
|
||||||
email: true,
|
email: true,
|
||||||
extra: true,
|
extra: true,
|
||||||
class: false,
|
class: false,
|
||||||
|
|
|
@ -46,31 +46,6 @@ defmodule AutoLinker.BuilderTest do
|
||||||
assert format_mention(%{href: "url"}, "user@host", nil) == expected
|
assert format_mention(%{href: "url"}, "user@host", nil) == expected
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "create_phone_link" do
|
|
||||||
test "finishes" do
|
|
||||||
assert create_phone_link([], "", []) == ""
|
|
||||||
end
|
|
||||||
|
|
||||||
test "handles one link" do
|
|
||||||
phrase = "my exten is x888. Call me."
|
|
||||||
|
|
||||||
expected =
|
|
||||||
~s'my exten is <a href="#" class="phone-number" data-phone="888" test=\"test\">x888</a>. Call me.'
|
|
||||||
|
|
||||||
assert create_phone_link([["x888", ""]], phrase, attributes: [test: "test"]) == expected
|
|
||||||
end
|
|
||||||
|
|
||||||
test "handles multiple links" do
|
|
||||||
phrase = "555.555.5555 or (555) 888-8888"
|
|
||||||
|
|
||||||
expected =
|
|
||||||
~s'<a href="#" class="phone-number" data-phone="5555555555">555.555.5555</a> or ' <>
|
|
||||||
~s'<a href="#" class="phone-number" data-phone="5558888888">(555) 888-8888</a>'
|
|
||||||
|
|
||||||
assert create_phone_link([["555.555.5555", ""], ["(555) 888-8888"]], phrase, []) == expected
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
test "create_mention_link/3" do
|
test "create_mention_link/3" do
|
||||||
expected =
|
expected =
|
||||||
"<a href=\"/u/navi\" class=\"auto-linker\" target=\"_blank\" rel=\"noopener noreferrer\">@navi</a>"
|
"<a href=\"/u/navi\" class=\"auto-linker\" target=\"_blank\" rel=\"noopener noreferrer\">@navi</a>"
|
||||||
|
|
|
@ -106,22 +106,6 @@ defmodule AutoLinker.ParserTest do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "match_phone" do
|
|
||||||
test "valid" do
|
|
||||||
valid_phone_nunbers()
|
|
||||||
|> Enum.each(fn number ->
|
|
||||||
assert number |> match_phone() |> valid_number?(number)
|
|
||||||
end)
|
|
||||||
end
|
|
||||||
|
|
||||||
test "invalid" do
|
|
||||||
invalid_phone_numbers()
|
|
||||||
|> Enum.each(fn number ->
|
|
||||||
assert number |> match_phone() |> is_nil
|
|
||||||
end)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
describe "parse" do
|
describe "parse" do
|
||||||
test "handle line breakes" do
|
test "handle line breakes" do
|
||||||
text = "google.com\r\nssss"
|
text = "google.com\r\nssss"
|
||||||
|
@ -157,7 +141,7 @@ defmodule AutoLinker.ParserTest do
|
||||||
|
|
||||||
expected = "<div><a href=\"http://google.com\">google.com</a></div>"
|
expected = "<div><a href=\"http://google.com\">google.com</a></div>"
|
||||||
|
|
||||||
assert parse(text, class: false, rel: false, new_window: false, phone: false) == expected
|
assert parse(text, class: false, rel: false, new_window: false) == expected
|
||||||
|
|
||||||
text = "Check out <div class='section'>google.com</div>"
|
text = "Check out <div class='section'>google.com</div>"
|
||||||
|
|
||||||
|
@ -196,7 +180,7 @@ defmodule AutoLinker.ParserTest do
|
||||||
|
|
||||||
test "do not link urls" do
|
test "do not link urls" do
|
||||||
text = "google.com"
|
text = "google.com"
|
||||||
assert parse(text, url: false, phone: true) == text
|
assert parse(text, url: false) == text
|
||||||
end
|
end
|
||||||
|
|
||||||
test "do not link `:test.test`" do
|
test "do not link `:test.test`" do
|
||||||
|
@ -260,35 +244,6 @@ defmodule AutoLinker.ParserTest do
|
||||||
"555.555.5555"
|
"555.555.5555"
|
||||||
]
|
]
|
||||||
|
|
||||||
def valid_phone_nunbers,
|
|
||||||
do: [
|
|
||||||
"x55",
|
|
||||||
"x555",
|
|
||||||
"x5555",
|
|
||||||
"x12345",
|
|
||||||
"+1 555 555-5555",
|
|
||||||
"555 555-5555",
|
|
||||||
"555.555.5555",
|
|
||||||
"613-555-5555",
|
|
||||||
"1 (555) 555-5555",
|
|
||||||
"(555) 555-5555",
|
|
||||||
"1.555.555.5555",
|
|
||||||
"800 555-5555",
|
|
||||||
"1.800.555.5555",
|
|
||||||
"1 (800) 555-5555",
|
|
||||||
"888 555-5555",
|
|
||||||
"887 555-5555",
|
|
||||||
"1-877-555-5555",
|
|
||||||
"1 800 710-5515"
|
|
||||||
]
|
|
||||||
|
|
||||||
def invalid_phone_numbers,
|
|
||||||
do: [
|
|
||||||
"5555",
|
|
||||||
"x5",
|
|
||||||
"(555) 555-55"
|
|
||||||
]
|
|
||||||
|
|
||||||
def custom_tld_scheme_urls,
|
def custom_tld_scheme_urls,
|
||||||
do: [
|
do: [
|
||||||
"http://whatever.null/",
|
"http://whatever.null/",
|
||||||
|
|
Reference in a new issue