From 1c0e0933b0899e97a354df4bad98dbe9099ae330 Mon Sep 17 00:00:00 2001 From: Sami Mazouz Date: Sat, 11 Nov 2023 19:31:53 +0100 Subject: [PATCH] feat: improve emoji autocomplete (#3923) * feat: improve emoji autocomplete * chore: improve dropdown header --- extensions/emoji/js/.prettierrc.json | 6 --- .../js/src/forum/addComposerAutocomplete.js | 44 +++++++++++++------ extensions/emoji/less/forum.less | 27 ++++++------ 3 files changed, 43 insertions(+), 34 deletions(-) delete mode 100644 extensions/emoji/js/.prettierrc.json diff --git a/extensions/emoji/js/.prettierrc.json b/extensions/emoji/js/.prettierrc.json deleted file mode 100644 index 944d65352b..0000000000 --- a/extensions/emoji/js/.prettierrc.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "printWidth": 150, - "singleQuote": true, - "tabWidth": 2, - "trailingComma": "es5" -} diff --git a/extensions/emoji/js/src/forum/addComposerAutocomplete.js b/extensions/emoji/js/src/forum/addComposerAutocomplete.js index 95c8741874..30a8626850 100644 --- a/extensions/emoji/js/src/forum/addComposerAutocomplete.js +++ b/extensions/emoji/js/src/forum/addComposerAutocomplete.js @@ -1,6 +1,7 @@ import { extend } from 'flarum/common/extend'; import TextEditorButton from 'flarum/common/components/TextEditorButton'; import KeyboardNavigatable from 'flarum/common/utils/KeyboardNavigatable'; +import Tooltip from 'flarum/common/components/Tooltip'; import AutocompleteDropdown from './fragments/AutocompleteDropdown'; import getEmojiIconCode from './helpers/getEmojiIconCode'; @@ -11,6 +12,13 @@ export default function addComposerAutocomplete() { extend('flarum/common/components/TextEditor', 'oninit', function () { this._loaders.push(async () => await import('./emojiMap').then((m) => (emojiMap = m.default))); + // prettier-ignore + this.commonEmoji = [ + '😀', '😁', '😂', '😃', '😄', '😅', '😆', '😇', '😈', '😉', '😊', '😋', '😌', '😍', '😎', '😏', '😐️', '😑', '😒', + '😓', '😔', '😕', '😖', '😗', '😘', '😙', '😚', '😛', '😜', '😝', '😞', '😟', '😠', '😡', '😢', '😣', '😤', '😥', + '😦', '😧', '😨', '😩', '😪', '😫', '😬', '😭', '😮', '😮‍💨', '😯', '😰', '😱', '😲', '😳', '😴', '😵', '😵‍💫', + '😶', '😶‍🌫️', '😷', '😸', '😹', '😺', '😻', '😼', '😽', '😾', '😿', '🙀', '🙁', '🙂', '🙃', '🙄', + ]; }); extend('flarum/common/components/TextEditor', 'onbuild', function () { @@ -75,16 +83,17 @@ export default function addComposerAutocomplete() { const makeSuggestion = function ({ emoji, name, code }) { return ( - + + + ); }; @@ -98,7 +107,7 @@ export default function addComposerAutocomplete() { }; const regTyped = fuzzyRegexp(typed); - let maxSuggestions = 7; + let maxSuggestions = 40; const findMatchingEmojis = (matcher) => { for (let i = 0; i < emojiKeys.length && maxSuggestions > 0; i++) { @@ -107,7 +116,7 @@ export default function addComposerAutocomplete() { if (similarEmoji.indexOf(curEmoji) === -1) { const names = emojiMap[curEmoji]; for (let name of names) { - if (matcher(name)) { + if (matcher(name, curEmoji)) { --maxSuggestions; similarEmoji.push(curEmoji); break; @@ -118,10 +127,17 @@ export default function addComposerAutocomplete() { }; // First, try to find all emojis starting with the given string - findMatchingEmojis((emoji) => emoji.indexOf(typed) === 0); + findMatchingEmojis((emojiName, emoji) => { + // If no input is provided yet, match the most common emojis. + if (!typed) { + return this.commonEmoji?.includes(emoji); + } + + return emojiName.indexOf(typed) === 0; + }); // If there are still suggestions left, try for some fuzzy matches - findMatchingEmojis((emoji) => regTyped.test(emoji)); + findMatchingEmojis((emojiName) => regTyped.test(emojiName)); const suggestions = similarEmoji .map((emoji) => ({ diff --git a/extensions/emoji/less/forum.less b/extensions/emoji/less/forum.less index 2b52ba4773..a74ec1f861 100644 --- a/extensions/emoji/less/forum.less +++ b/extensions/emoji/less/forum.less @@ -7,29 +7,28 @@ img.emoji { .EmojiDropdown { max-width: 500px; max-height: 200px; - overflow: auto; + overflow: visible; position: absolute; - margin: 5px 0 !important; + padding: 8px; - > li > button { - color: var(--text-color); - font-weight: bold; - padding-top: 6px; - padding-bottom: 6px; - padding-left: 45px; + > li { + display: inline-block; - .emoji { - float: left; - margin-left: -30px; + > button { + color: var(--text-color); + font-weight: bold; + padding: 8px; + border-radius: var(--border-radius); } } - .Dropdown-header { + > .Dropdown-header { + display: block; color: var(--muted-more-color); text-transform: none; font-weight: normal; - padding-bottom: 5px; - font-size: 11px; + padding: 4px 8px; + margin: 0 0 4px 0; } }