added emoji shortcode

This commit is contained in:
supertiger 2019-03-11 20:22:50 +00:00
parent f452451cfa
commit c371d31143
5 changed files with 45 additions and 5 deletions

10
package-lock.json generated
View file

@ -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",

View file

@ -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",

View file

@ -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;

View file

@ -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
View 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
}
}
}
}