Commit 4e6827db authored by JC Brand's avatar JC Brand

Match a message of only emojis (instead of just a single emoji)

parent 691846bf
...@@ -221,6 +221,25 @@ ...@@ -221,6 +221,25 @@
expect(view.model.messages.models.length).toBe(3); expect(view.model.messages.models.length).toBe(3);
message = chat_content.querySelector('.message:last-child .chat-msg__text'); message = chat_content.querySelector('.message:last-child .chat-msg__text');
expect(u.hasClass('chat-msg__text--larger', message)).toBe(false); expect(u.hasClass('chat-msg__text--larger', message)).toBe(false);
textarea.value = ':smile: Hello world!';
view.onKeyDown({
target: textarea,
preventDefault: function preventDefault () {},
keyCode: 13 // Enter
});
await new Promise(resolve => view.once('messageInserted', resolve));
textarea.value = ':smile: :smiley: :imp:';
view.onKeyDown({
target: textarea,
preventDefault: function preventDefault () {},
keyCode: 13 // Enter
});
await new Promise(resolve => view.once('messageInserted', resolve));
message = chat_content.querySelector('.message:last-child .chat-msg__text');
expect(u.hasClass('chat-msg__text--larger', message)).toBe(true);
done() done()
})); }));
}); });
......
...@@ -757,7 +757,7 @@ converse.plugins.add('converse-chatboxes', { ...@@ -757,7 +757,7 @@ converse.plugins.add('converse-chatboxes', {
'origin_id': origin_id, 'origin_id': origin_id,
'fullname': _converse.xmppstatus.get('fullname'), 'fullname': _converse.xmppstatus.get('fullname'),
'from': _converse.bare_jid, 'from': _converse.bare_jid,
'is_single_emoji': text ? u.isSingleEmoji(text) : false, 'is_single_emoji': text ? u.isOnlyEmojis(text) : false,
'sender': 'me', 'sender': 'me',
'time': (new Date()).toISOString(), 'time': (new Date()).toISOString(),
'message': text ? u.httpToGeoUri(u.shortnameToUnicode(text), _converse) : undefined, 'message': text ? u.httpToGeoUri(u.shortnameToUnicode(text), _converse) : undefined,
...@@ -820,7 +820,7 @@ converse.plugins.add('converse-chatboxes', { ...@@ -820,7 +820,7 @@ converse.plugins.add('converse-chatboxes', {
'message': attrs.message, 'message': attrs.message,
'older_versions': older_versions, 'older_versions': older_versions,
'references': attrs.references, 'references': attrs.references,
'is_single_emoji': attrs.message ? u.isSingleEmoji(attrs.message) : false, 'is_single_emoji': attrs.message ? u.isOnlyEmojis(attrs.message) : false,
'origin_id': _converse.connection.getUniqueId(), 'origin_id': _converse.connection.getUniqueId(),
'received': undefined 'received': undefined
}); });
...@@ -999,7 +999,7 @@ converse.plugins.add('converse-chatboxes', { ...@@ -999,7 +999,7 @@ converse.plugins.add('converse-chatboxes', {
'chat_state': chat_state, 'chat_state': chat_state,
'is_archived': this.isArchived(original_stanza), 'is_archived': this.isArchived(original_stanza),
'is_delayed': !!delay, 'is_delayed': !!delay,
'is_single_emoji': text ? await u.isSingleEmoji(text) : false, 'is_single_emoji': text ? await u.isOnlyEmojis(text) : false,
'is_spoiler': !!spoiler, 'is_spoiler': !!spoiler,
'message': text, 'message': text,
'msgid': msgid, 'msgid': msgid,
......
...@@ -291,18 +291,21 @@ converse.plugins.add('converse-emoji', { ...@@ -291,18 +291,21 @@ converse.plugins.add('converse-emoji', {
/** /**
* Determines whether the passed in string is just a single emoji shortname; * Determines whether the passed in string is just a single emoji shortname;
* @method u.isSingleEmoji * @method u.isOnlyEmojis
* @param {string} shortname - A string which migh be just an emoji shortname * @param {string} shortname - A string which migh be just an emoji shortname
* @returns {boolean} * @returns {boolean}
*/ */
isSingleEmoji (shortname) { isOnlyEmojis (text) {
shortname = shortname.trim(); const words = text.trim().split(/\s+/);
if (!shortname || (shortname.length > 2 && !shortname.startsWith(':'))) { if (words.length === 0 || words.length > 3) {
return; return false;
} }
const result = twemoji.default.parse(u.shortnameToUnicode(shortname)); const rejects = words.filter(text => {
const match = result.match(/<img class="emoji" draggable="false" alt=".*?" src=".*?\.png"\/>/); const result = twemoji.default.parse(u.shortnameToUnicode(text));
return match && match.length === 1; const match = result.match(/<img class="emoji" draggable="false" alt=".*?" src=".*?\.png"\/>/);
return !match || match.length !== 1;
});
return rejects.length === 0;
}, },
/** /**
......
...@@ -736,7 +736,7 @@ converse.plugins.add('converse-muc', { ...@@ -736,7 +736,7 @@ converse.plugins.add('converse-muc', {
'origin_id': origin_id, 'origin_id': origin_id,
'from': `${this.get('jid')}/${this.get('nick')}`, 'from': `${this.get('jid')}/${this.get('nick')}`,
'fullname': this.get('nick'), 'fullname': this.get('nick'),
'is_single_emoji': text ? u.isSingleEmoji(text) : false, 'is_single_emoji': text ? u.isOnlyEmojis(text) : false,
'is_spoiler': is_spoiler, 'is_spoiler': is_spoiler,
'message': text ? u.httpToGeoUri(u.shortnameToUnicode(text), _converse) : undefined, 'message': text ? u.httpToGeoUri(u.shortnameToUnicode(text), _converse) : undefined,
'nick': this.get('nick'), 'nick': this.get('nick'),
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment