add new search to reaction picker and make hardcoded set... better

This commit is contained in:
Henry Jameson 2022-10-17 22:45:38 +03:00
parent 3bdff6e6ee
commit 87a78aae57
2 changed files with 59 additions and 16 deletions

View file

@ -1,4 +1,5 @@
import Popover from '../popover/popover.vue' import Popover from '../popover/popover.vue'
import { ensureFinalFallback } from '../../i18n/languages.js'
import { library } from '@fortawesome/fontawesome-svg-core' import { library } from '@fortawesome/fontawesome-svg-core'
import { faPlus, faTimes } from '@fortawesome/free-solid-svg-icons' import { faPlus, faTimes } from '@fortawesome/free-solid-svg-icons'
import { faSmileBeam } from '@fortawesome/free-regular-svg-icons' import { faSmileBeam } from '@fortawesome/free-regular-svg-icons'
@ -43,31 +44,73 @@ const ReactButton = {
const input = this.$el.querySelector('input') const input = this.$el.querySelector('input')
if (input) input.focus() if (input) input.focus()
}) })
},
// Vaguely adjusted copypaste from emoji_input and emoji_picker!
maybeLocalizedEmojiNamesAndKeywords (emoji) {
const names = [emoji.displayText]
const keywords = []
if (emoji.displayTextI18n) {
names.push(this.$t(emoji.displayTextI18n.key, emoji.displayTextI18n.args))
}
if (emoji.annotations) {
this.languages.forEach(lang => {
names.push(emoji.annotations[lang]?.name)
keywords.push(...(emoji.annotations[lang]?.keywords || []))
})
}
return {
names: names.filter(k => k),
keywords: keywords.filter(k => k)
}
},
maybeLocalizedEmojiName (emoji) {
if (!emoji.annotations) {
return emoji.displayText
}
if (emoji.displayTextI18n) {
return this.$t(emoji.displayTextI18n.key, emoji.displayTextI18n.args)
}
for (const lang of this.languages) {
if (emoji.annotations[lang]?.name) {
return emoji.annotations[lang].name
}
}
return emoji.displayText
} }
}, },
computed: { computed: {
commonEmojis () { commonEmojis () {
return [ const hardcodedSet = new Set(['👍', '😠', '👀', '😂', '🔥'])
{ displayText: 'thumbsup', replacement: '👍' }, return this.$store.getters.standardEmojiList.filter(emoji => hardcodedSet.has(emoji.replacement))
{ displayText: 'angry', replacement: '😠' }, },
{ displayText: 'eyes', replacement: '👀' }, languages () {
{ displayText: 'joy', replacement: '😂' }, return ensureFinalFallback(this.$store.getters.mergedConfig.interfaceLanguage)
{ displayText: 'fire', replacement: '🔥' }
]
}, },
emojis () { emojis () {
if (this.filterWord !== '') { if (this.filterWord !== '') {
const filterWordLowercase = trim(this.filterWord.toLowerCase()) const keywordLowercase = trim(this.filterWord.toLowerCase())
const orderedEmojiList = [] const orderedEmojiList = []
for (const emoji of this.$store.getters.standardEmojiList) { for (const emoji of this.$store.getters.standardEmojiList) {
if (emoji.replacement === this.filterWord) return [emoji] const indices = this.maybeLocalizedEmojiNamesAndKeywords(emoji)
.keywords
.map(k => k.toLowerCase().indexOf(keywordLowercase))
.filter(k => k > -1)
const indexOfFilterWord = emoji.displayText.toLowerCase().indexOf(filterWordLowercase) const indexOfKeyword = indices.length ? Math.min(...indices) : -1
if (indexOfFilterWord > -1) {
if (!Array.isArray(orderedEmojiList[indexOfFilterWord])) { if (indexOfKeyword > -1) {
orderedEmojiList[indexOfFilterWord] = [] if (!Array.isArray(orderedEmojiList[indexOfKeyword])) {
orderedEmojiList[indexOfKeyword] = []
} }
orderedEmojiList[indexOfFilterWord].push(emoji) orderedEmojiList[indexOfKeyword].push(emoji)
} }
} }
return orderedEmojiList.flat() return orderedEmojiList.flat()

View file

@ -24,7 +24,7 @@
v-for="emoji in commonEmojis" v-for="emoji in commonEmojis"
:key="emoji.replacement" :key="emoji.replacement"
class="emoji-button" class="emoji-button"
:title="emoji.displayText" :title="maybeLocalizedEmojiName(emoji)"
@click="addReaction($event, emoji.replacement, close)" @click="addReaction($event, emoji.replacement, close)"
> >
{{ emoji.replacement }} {{ emoji.replacement }}
@ -34,7 +34,7 @@
v-for="(emoji, key) in emojis" v-for="(emoji, key) in emojis"
:key="key" :key="key"
class="emoji-button" class="emoji-button"
:title="emoji.displayText" :title="maybeLocalizedEmojiName(emoji)"
@click="addReaction($event, emoji.replacement, close)" @click="addReaction($event, emoji.replacement, close)"
> >
{{ emoji.replacement }} {{ emoji.replacement }}