diff options
author | feld <feld@feld.me> | 2020-07-13 15:43:46 +0000 |
---|---|---|
committer | feld <feld@feld.me> | 2020-07-13 15:43:46 +0000 |
commit | 8f9ee694ed47709231ffc852d2e82a06468cba06 (patch) | |
tree | e630406cab99481af192bbe3108ded6d460d5147 /lib | |
parent | 63fef0c0fb8e8d95b441d50e8dac3ef2c782a84f (diff) | |
parent | cc7153cd828afef1564b58649875b5529c078054 (diff) | |
download | pleroma-8f9ee694ed47709231ffc852d2e82a06468cba06.tar.gz pleroma-8f9ee694ed47709231ffc852d2e82a06468cba06.zip |
Merge branch 'features/profile-fields-emojo' into 'develop'
user: Add support for custom emojis in profile fields
See merge request pleroma/pleroma!2741
Diffstat (limited to 'lib')
-rw-r--r-- | lib/pleroma/user.ex | 18 |
1 files changed, 14 insertions, 4 deletions
diff --git a/lib/pleroma/user.ex b/lib/pleroma/user.ex index b9989f901..9240e912d 100644 --- a/lib/pleroma/user.ex +++ b/lib/pleroma/user.ex @@ -530,11 +530,21 @@ defmodule Pleroma.User do end defp put_emoji(changeset) do - bio = get_change(changeset, :bio) - name = get_change(changeset, :name) + emojified_fields = [:bio, :name, :raw_fields] + + if Enum.any?(changeset.changes, fn {k, _} -> k in emojified_fields end) do + bio = Emoji.Formatter.get_emoji_map(get_field(changeset, :bio)) + name = Emoji.Formatter.get_emoji_map(get_field(changeset, :name)) + + emoji = Map.merge(bio, name) + + emoji = + changeset + |> get_field(:raw_fields) + |> Enum.reduce(emoji, fn x, acc -> + Map.merge(acc, Emoji.Formatter.get_emoji_map(x["name"] <> x["value"])) + end) - if bio || name do - emoji = Map.merge(Emoji.Formatter.get_emoji_map(bio), Emoji.Formatter.get_emoji_map(name)) put_change(changeset, :emoji, emoji) else changeset |