Include unpacked emojis in emoji picker
This commit is contained in:
parent
da7d24b5c2
commit
876e51603a
|
@ -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]
|
||||||
|
|
|
@ -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",
|
||||||
|
|
|
@ -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]) => {
|
||||||
|
|
Loading…
Reference in a new issue