2018-01-13 23:33:03 +01:00
|
|
|
defmodule Eventos.Events.Tag.TitleSlug do
|
|
|
|
alias Eventos.Events.Tag
|
|
|
|
import Ecto.Query
|
|
|
|
alias Eventos.Repo
|
|
|
|
use EctoAutoslugField.Slug, from: :title, to: :slug
|
|
|
|
|
|
|
|
def build_slug(sources, changeset) do
|
|
|
|
slug = super(sources, changeset)
|
|
|
|
build_unique_slug(slug, changeset)
|
|
|
|
end
|
|
|
|
|
|
|
|
defp build_unique_slug(slug, changeset) do
|
|
|
|
query = from t in Tag,
|
|
|
|
where: t.slug == ^slug
|
|
|
|
|
|
|
|
case Repo.one(query) do
|
|
|
|
nil -> slug
|
|
|
|
_story ->
|
|
|
|
slug
|
|
|
|
|> increment_slug
|
|
|
|
|> build_unique_slug(changeset)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
defp increment_slug(slug) do
|
|
|
|
case List.pop_at(String.split(slug, "-"), -1) do
|
|
|
|
{nil, _} ->
|
|
|
|
slug
|
|
|
|
{suffix, slug_parts} ->
|
|
|
|
case Integer.parse(suffix) do
|
|
|
|
{id, _} -> Enum.join(slug_parts, "-") <> "-" <> Integer.to_string(id + 1)
|
|
|
|
:error -> slug <> "-1"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-12-08 09:58:14 +01:00
|
|
|
defmodule Eventos.Events.Tag do
|
|
|
|
use Ecto.Schema
|
|
|
|
import Ecto.Changeset
|
|
|
|
alias Eventos.Events.Tag
|
2018-01-13 23:33:03 +01:00
|
|
|
alias Eventos.Events.Tag.TitleSlug
|
2017-12-08 09:58:14 +01:00
|
|
|
|
|
|
|
schema "tags" do
|
|
|
|
field :title, :string
|
2018-01-13 23:33:03 +01:00
|
|
|
field :slug, TitleSlug.Type
|
2017-12-08 09:58:14 +01:00
|
|
|
|
|
|
|
timestamps()
|
|
|
|
end
|
|
|
|
|
|
|
|
@doc false
|
|
|
|
def changeset(%Tag{} = tag, attrs) do
|
|
|
|
tag
|
2018-01-13 23:33:03 +01:00
|
|
|
|> cast(attrs, [:title])
|
|
|
|
|> validate_required([:title])
|
|
|
|
|> TitleSlug.maybe_generate_slug()
|
|
|
|
|> TitleSlug.unique_constraint()
|
2017-12-08 09:58:14 +01:00
|
|
|
end
|
2018-01-13 23:33:03 +01:00
|
|
|
end
|