Drop phone links support

This commit is contained in:
Egor Kislitsyn 2019-06-21 19:05:47 +07:00
parent b044a63910
commit 529014c8f4
5 changed files with 4 additions and 161 deletions

View file

@ -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

View file

@ -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)

View file

@ -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,

View file

@ -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>"

View file

@ -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/",