Commit c01d1105 authored by JC Brand's avatar JC Brand

Avoid interference between username and emoji autocomplete

parent a59510bb
...@@ -60,7 +60,7 @@ ...@@ -60,7 +60,7 @@
} }
view.onKeyDown(tab_event); view.onKeyDown(tab_event);
await u.waitUntil(() => u.isVisible(view.el.querySelector('.toggle-smiley .emoji-picker__container'))); await u.waitUntil(() => u.isVisible(view.el.querySelector('.toggle-smiley .emoji-picker__container')));
const picker = await u.waitUntil(() => view.el.querySelector('.toggle-smiley .emoji-picker__container')); let picker = await u.waitUntil(() => view.el.querySelector('.toggle-smiley .emoji-picker__container'));
const input = picker.querySelector('.emoji-search'); const input = picker.querySelector('.emoji-search');
expect(input.value).toBe(':gri'); expect(input.value).toBe(':gri');
let visible_emojis = sizzle('.insert-emoji:not(.hidden)', picker); let visible_emojis = sizzle('.insert-emoji:not(.hidden)', picker);
...@@ -81,6 +81,28 @@ ...@@ -81,6 +81,28 @@
view.emoji_picker_view.onKeyDown(enter_event); view.emoji_picker_view.onKeyDown(enter_event);
expect(input.value).toBe(''); expect(input.value).toBe('');
expect(textarea.value).toBe(':grimacing: '); expect(textarea.value).toBe(':grimacing: ');
// Test that username starting with : doesn't cause issues
const presence = $pres({
'from': `${muc_jid}/:username`,
'id': '27C55F89-1C6A-459A-9EB5-77690145D624',
'to': _converse.jid
})
.c('x', { 'xmlns': 'http://jabber.org/protocol/muc#user'})
.c('item', {
'jid': 'some1@montague.lit',
'affiliation': 'member',
'role': 'participant'
});
_converse.connection._dataRecv(test_utils.createRequest(presence));
textarea.value = ':use';
view.onKeyDown(tab_event);
await u.waitUntil(() => u.isVisible(view.el.querySelector('.toggle-smiley .emoji-picker__container')));
picker = await u.waitUntil(() => view.el.querySelector('.toggle-smiley .emoji-picker__container'));
expect(input.value).toBe(':use');
visible_emojis = sizzle('.insert-emoji:not(.hidden)', picker);
expect(visible_emojis.length).toBe(0);
done(); done();
})); }));
......
...@@ -883,8 +883,6 @@ converse.plugins.add('converse-chatview', { ...@@ -883,8 +883,6 @@ converse.plugins.add('converse-chatview', {
if (ev.keyCode === _converse.keycodes.FORWARD_SLASH) { if (ev.keyCode === _converse.keycodes.FORWARD_SLASH) {
// Forward slash is used to run commands. Nothing to do here. // Forward slash is used to run commands. Nothing to do here.
return; return;
} else if (ev.keyCode === _converse.keycodes.TAB) {
return this.onTabPressed(ev);
} else if (ev.keyCode === _converse.keycodes.ESCAPE) { } else if (ev.keyCode === _converse.keycodes.ESCAPE) {
return this.onEscapePressed(ev); return this.onEscapePressed(ev);
} else if (ev.keyCode === _converse.keycodes.ENTER) { } else if (ev.keyCode === _converse.keycodes.ENTER) {
...@@ -924,8 +922,6 @@ converse.plugins.add('converse-chatview', { ...@@ -924,8 +922,6 @@ converse.plugins.add('converse-chatview', {
return this.onFormSubmitted(ev); return this.onFormSubmitted(ev);
}, },
onTabPressed (ev) {}, // noop, overridden in other plugins
onEscapePressed (ev) { onEscapePressed (ev) {
ev.preventDefault(); ev.preventDefault();
const idx = this.model.messages.findLastIndex('correcting'), const idx = this.model.messages.findLastIndex('correcting'),
......
...@@ -42,35 +42,26 @@ converse.plugins.add('converse-emoji-views', { ...@@ -42,35 +42,26 @@ converse.plugins.add('converse-emoji-views', {
this.emoji_dropdown.toggle(); this.emoji_dropdown.toggle();
} }
this.__super__.onEnterPressed.apply(this, arguments); this.__super__.onEnterPressed.apply(this, arguments);
}
}, },
async onTabPressed (ev) { ChatRoomView: {
events: {
'click .toggle-smiley': 'toggleEmojiMenu'
},
onKeyDown (ev) {
const { _converse } = this.__super__; const { _converse } = this.__super__;
const input = ev.target; if (ev.keyCode === _converse.keycodes.TAB) {
const value = u.getCurrentWord(input, null, /(:.*?:)/g); const value = u.getCurrentWord(ev.target, null, /(:.*?:)/g);
if (value.startsWith(':')) { if (value.startsWith(':')) {
ev.preventDefault(); ev.preventDefault();
ev.stopPropagation(); ev.stopPropagation();
if (this.emoji_dropdown === undefined) { return this.autocompleteInPicker(ev.target, value);
this.createEmojiDropdown();
} }
await _converse.api.waitUntil('emojisInitialized');
this.emoji_picker_view.model.set({
'autocompleting': value,
'position': ev.target.selectionStart
}, {'silent': true});
this.emoji_picker_view.filter(value, true);
this.emoji_dropdown.toggle();
} else {
this.__super__.onTabPressed.apply(this, arguments);
} }
return this.__super__.onKeyDown.call(this, ev);
} }
},
ChatRoomView: {
events: {
'click .toggle-smiley': 'toggleEmojiMenu'
},
} }
}, },
...@@ -92,6 +83,19 @@ converse.plugins.add('converse-emoji-views', { ...@@ -92,6 +83,19 @@ converse.plugins.add('converse-emoji-views', {
const emoji_aware_chat_view = { const emoji_aware_chat_view = {
async autocompleteInPicker (input, value) {
if (this.emoji_dropdown === undefined) {
this.createEmojiDropdown();
}
await _converse.api.waitUntil('emojisInitialized');
this.emoji_picker_view.model.set({
'autocompleting': value,
'position': input.selectionStart
}, {'silent': true});
this.emoji_picker_view.filter(value, true);
this.emoji_dropdown.toggle();
},
createEmojiPicker () { createEmojiPicker () {
if (!_converse.emojipicker) { if (!_converse.emojipicker) {
const storage = _converse.config.get('storage'), const storage = _converse.config.get('storage'),
......
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