mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-04 06:15:01 +00:00
2cf0cf0de1
- Replace all default exports with named exports, except for Vue SFCs - Remove names from Vue SFCs, they are automatically inferred from the filename - Misc whitespace-related tweaks
39 lines
992 B
JavaScript
39 lines
992 B
JavaScript
import emojis from '../../../assets/emoji.json';
|
|
|
|
const {assetUrlPrefix, customEmojis} = window.config;
|
|
|
|
const tempMap = {...customEmojis};
|
|
for (const {emoji, aliases} of emojis) {
|
|
for (const alias of aliases || []) {
|
|
tempMap[alias] = emoji;
|
|
}
|
|
}
|
|
|
|
export const emojiKeys = Object.keys(tempMap).sort((a, b) => {
|
|
if (a === '+1' || a === '-1') return -1;
|
|
if (b === '+1' || b === '-1') return 1;
|
|
return a.localeCompare(b);
|
|
});
|
|
|
|
const emojiMap = {};
|
|
for (const key of emojiKeys) {
|
|
emojiMap[key] = tempMap[key];
|
|
}
|
|
|
|
// retrieve HTML for given emoji name
|
|
export function emojiHTML(name) {
|
|
let inner;
|
|
if (Object.prototype.hasOwnProperty.call(customEmojis, name)) {
|
|
inner = `<img alt=":${name}:" src="${assetUrlPrefix}/img/emoji/${name}.png">`;
|
|
} else {
|
|
inner = emojiString(name);
|
|
}
|
|
|
|
return `<span class="emoji" title=":${name}:">${inner}</span>`;
|
|
}
|
|
|
|
// retrieve string for given emoji name
|
|
export function emojiString(name) {
|
|
return emojiMap[name] || `:${name}:`;
|
|
}
|