diff options
author | Joas Schilling <coding@schilljs.com> | 2022-03-24 15:13:09 +0100 |
---|---|---|
committer | Joas Schilling <coding@schilljs.com> | 2022-03-24 15:13:09 +0100 |
commit | 367be7c55fd48583e0fdcd058b813a2f6e3fe5e1 (patch) | |
tree | c45ee460ec76579595be91a85abfb50605b73807 /lib/private/Comments/Manager.php | |
parent | fbf1334dc8c192ebdd335663cacfb810daf4d841 (diff) | |
download | nextcloud-server-367be7c55fd48583e0fdcd058b813a2f6e3fe5e1.tar.gz nextcloud-server-367be7c55fd48583e0fdcd058b813a2f6e3fe5e1.zip |
Allow reactions also with other combined emojis
Honerful copying the EmojiService from UserStatus for now
I think this should be put into a decent place and then reused,
but I couldn't find somethin short term before beta1
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'lib/private/Comments/Manager.php')
-rw-r--r-- | lib/private/Comments/Manager.php | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/lib/private/Comments/Manager.php b/lib/private/Comments/Manager.php index 384187accf3..123e4f6988d 100644 --- a/lib/private/Comments/Manager.php +++ b/lib/private/Comments/Manager.php @@ -59,6 +59,9 @@ class Manager implements ICommentsManager { /** @var ITimeFactory */ protected $timeFactory; + /** @var EmojiHelper */ + protected $emojiHelper; + /** @var IInitialStateService */ protected $initialStateService; @@ -78,11 +81,13 @@ class Manager implements ICommentsManager { LoggerInterface $logger, IConfig $config, ITimeFactory $timeFactory, + EmojiHelper $emojiHelper, IInitialStateService $initialStateService) { $this->dbConn = $dbConn; $this->logger = $logger; $this->config = $config; $this->timeFactory = $timeFactory; + $this->emojiHelper = $emojiHelper; $this->initialStateService = $initialStateService; } @@ -148,8 +153,9 @@ class Manager implements ICommentsManager { throw new \UnexpectedValueException('Actor, Object and Verb information must be provided for saving'); } - if ($comment->getVerb() === 'reaction' && mb_strlen($comment->getMessage()) > 2) { - throw new \UnexpectedValueException('Reactions cannot be longer than 2 chars (emoji with skin tone have two chars)'); + if ($comment->getVerb() === 'reaction' && !$this->emojiHelper->isValidEmoji($comment->getMessage())) { + // 4 characters: laptop + person + gender + skin color => "🧑🏽💻" is a single emoji from the picker + throw new \UnexpectedValueException('Reactions can only be a single emoji'); } if ($comment->getId() === '') { |