Include unpacked emojis in emoji picker

This commit is contained in:
tusooa 2022-12-31 12:29:33 -05:00
parent da7d24b5c2
commit 876e51603a
No known key found for this signature in database
GPG key ID: 7B467EDE43A08224
3 changed files with 37 additions and 6 deletions

View file

@ -287,7 +287,11 @@ const EmojiPicker = {
return 0 return 0
}, },
allCustomGroups () { allCustomGroups () {
return this.$store.getters.groupedCustomEmojis const emojis = this.$store.getters.groupedCustomEmojis
if (emojis.unpacked) {
emojis.unpacked.text = this.$t('emoji.unpacked')
}
return emojis
}, },
defaultGroup () { defaultGroup () {
return Object.keys(this.allCustomGroups)[0] return Object.keys(this.allCustomGroups)[0]

View file

@ -225,6 +225,7 @@
"search_emoji": "Search for an emoji", "search_emoji": "Search for an emoji",
"add_emoji": "Insert emoji", "add_emoji": "Insert emoji",
"custom": "Custom emoji", "custom": "Custom emoji",
"unpacked": "Unpacked emoji",
"unicode": "Unicode emoji", "unicode": "Unicode emoji",
"unicode_groups": { "unicode_groups": {
"activities": "Activities", "activities": "Activities",

View file

@ -181,15 +181,28 @@ const instance = {
}, },
groupedCustomEmojis (state) { groupedCustomEmojis (state) {
const packsOf = emoji => { const packsOf = emoji => {
return emoji.tags const packs = emoji.tags
.filter(k => k.startsWith('pack:')) .filter(k => k.startsWith('pack:'))
.map(k => k.slice(5)) // remove 'pack:' prefix .map(k => {
const packName = k.slice(5) // remove 'pack:' prefix
return {
id: `custom-${packName}`,
text: packName
}
})
if (!packs.length) {
return [{
id: 'unpacked'
}]
} else {
return packs
}
} }
return state.customEmoji return state.customEmoji
.reduce((res, emoji) => { .reduce((res, emoji) => {
packsOf(emoji).forEach(packName => { packsOf(emoji).forEach(({ id: packId, text: packName }) => {
const packId = `custom-${packName}`
if (!res[packId]) { if (!res[packId]) {
res[packId] = ({ res[packId] = ({
id: packId, id: packId,
@ -290,9 +303,22 @@ const instance = {
const lb = b.toLowerCase() const lb = b.toLowerCase()
return la > lb ? 1 : (la < lb ? -1 : 0) return la > lb ? 1 : (la < lb ? -1 : 0)
} }
const noPackLast = (a, b) => {
const aNull = a === ''
const bNull = b === ''
if (aNull === bNull) {
return 0
} else if (aNull && !bNull) {
return 1
} else {
return -1
}
}
const byPackThenByName = (a, b) => { const byPackThenByName = (a, b) => {
const packOf = emoji => (emoji.tags.filter(k => k.startsWith('pack:'))[0] || '').slice(5) const packOf = emoji => (emoji.tags.filter(k => k.startsWith('pack:'))[0] || '').slice(5)
return caseInsensitiveStrCmp(packOf(a), packOf(b)) || caseInsensitiveStrCmp(a.displayText, b.displayText) const packOfA = packOf(a)
const packOfB = packOf(b)
return noPackLast(packOfA, packOfB) || caseInsensitiveStrCmp(packOfA, packOfB) || caseInsensitiveStrCmp(a.displayText, b.displayText)
} }
const emoji = Object.entries(values).map(([key, value]) => { const emoji = Object.entries(values).map(([key, value]) => {