summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorfeld <feld@feld.me>2020-07-13 15:43:46 +0000
committerfeld <feld@feld.me>2020-07-13 15:43:46 +0000
commit8f9ee694ed47709231ffc852d2e82a06468cba06 (patch)
treee630406cab99481af192bbe3108ded6d460d5147 /lib
parent63fef0c0fb8e8d95b441d50e8dac3ef2c782a84f (diff)
parentcc7153cd828afef1564b58649875b5529c078054 (diff)
downloadpleroma-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.ex18
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