mirror of
https://github.com/danbulant/Nertivia-Client
synced 2026-06-19 22:31:25 +00:00
added emoji shortcode
This commit is contained in:
parent
f452451cfa
commit
c371d31143
5 changed files with 45 additions and 5 deletions
10
package-lock.json
generated
10
package-lock.json
generated
|
|
@ -3620,6 +3620,16 @@
|
|||
"minimalistic-crypto-utils": "^1.0.0"
|
||||
}
|
||||
},
|
||||
"emojibase-data": {
|
||||
"version": "3.2.1",
|
||||
"resolved": "https://registry.npmjs.org/emojibase-data/-/emojibase-data-3.2.1.tgz",
|
||||
"integrity": "sha512-6BbqwDbAGxbd+5YM82qlpb9Mr3SaS/rSffc6bREqUW9RWcqOclv0q9/P3MwOompIu+QSEDBAOBEbWgLQVhFxSw=="
|
||||
},
|
||||
"emojibase-regex": {
|
||||
"version": "2.0.1",
|
||||
"resolved": "https://registry.npmjs.org/emojibase-regex/-/emojibase-regex-2.0.1.tgz",
|
||||
"integrity": "sha512-prb7DjhYxlWOhqmLTbqd30ZA6P+o5onn3WZwe5V0LxwG6bar2o8TsXH4xTPpaQt5rTCyZFR1nPqUNRtOk8vvOg=="
|
||||
},
|
||||
"emojis-list": {
|
||||
"version": "2.1.0",
|
||||
"resolved": "https://registry.npmjs.org/emojis-list/-/emojis-list-2.1.0.tgz",
|
||||
|
|
|
|||
|
|
@ -9,6 +9,8 @@
|
|||
},
|
||||
"dependencies": {
|
||||
"axios": "^0.18.0",
|
||||
"emojibase-data": "^3.2.1",
|
||||
"emojibase-regex": "^2.0.1",
|
||||
"filesize": "^4.1.2",
|
||||
"futoji": "^0.2.4",
|
||||
"jquery": "^3.3.1",
|
||||
|
|
|
|||
|
|
@ -80,6 +80,7 @@ import Message from "../../components/app/MessageTemplate.vue";
|
|||
import Spinner from "@/components/Spinner.vue";
|
||||
import TypingStatus from "@/components/app/TypingStatus.vue";
|
||||
import uploadsQueue from "@/components/app/uploadsQueue.vue";
|
||||
import shortcodeToEmoji from "@/shortcodeToEmoji.js";
|
||||
|
||||
export default {
|
||||
components: {
|
||||
|
|
@ -127,15 +128,16 @@ export default {
|
|||
this.postTimerID = null;
|
||||
this.messageLength = 0;
|
||||
|
||||
const msg = this.message;
|
||||
const msg = shortcodeToEmoji(this.message);;
|
||||
const tempID = this.generateNum(25);
|
||||
|
||||
|
||||
this.$store.dispatch("addMessage", {
|
||||
sender: true,
|
||||
channelID: this.selectedChannelID,
|
||||
message: {
|
||||
tempID,
|
||||
message: this.message,
|
||||
message: msg,
|
||||
channelID: this.selectedChannelID,
|
||||
created: new Date()
|
||||
}
|
||||
|
|
@ -483,8 +485,6 @@ export default {
|
|||
transition: 0.3s;
|
||||
display: flex;
|
||||
flex-shrink: 0;
|
||||
|
||||
|
||||
}
|
||||
.send-button .material-icons {
|
||||
margin: auto;
|
||||
|
|
|
|||
|
|
@ -3,9 +3,10 @@ import twemoji from 'twemoji'
|
|||
|
||||
|
||||
export default (message) => {
|
||||
|
||||
|
||||
message = twemoji.parse(escapeHtml(message),
|
||||
function (icon, options, variant) {
|
||||
console.log(icon)
|
||||
return require("twemoji/2/svg/" + icon + ".svg")
|
||||
})
|
||||
|
||||
|
|
|
|||
27
src/shortcodeToEmoji.js
Normal file
27
src/shortcodeToEmoji.js
Normal file
|
|
@ -0,0 +1,27 @@
|
|||
import emojis from "emojibase-data/en/compact.json";
|
||||
import {
|
||||
groups
|
||||
} from "emojibase-data/meta/groups.json";
|
||||
|
||||
export default message => {
|
||||
const regex = /:([\w]+):/g;
|
||||
|
||||
return message.replace(regex, (x) => {
|
||||
const emoji = emojiExists(x.replace(/[::]+/g, ''))
|
||||
|
||||
if (emoji) return emoji.unicode
|
||||
return x
|
||||
});
|
||||
};
|
||||
|
||||
function emojiExists(shortCode) {
|
||||
for (let index = 0; index < emojis.length; index++) {
|
||||
const element = emojis[index];
|
||||
for (let i = 0; i < element.shortcodes.length; i++) {
|
||||
const el2 = element.shortcodes[i];
|
||||
if (el2 === shortCode) {
|
||||
return element
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Loading…
Reference in a new issue