pinafore/src/routes/_utils/emojifyText.js

24 lines
784 B
JavaScript
Raw Normal View History

import { replaceAll } from './strings'
import { replaceEmoji } from './replaceEmoji'
export function emojifyText (text, emojis, autoplayGifs) {
// replace native emoji with wrapped spans so we can give them the proper font-family
text = replaceEmoji(text, substring => `<span class="inline-emoji">${substring}</span>`)
// replace custom emoji
if (emojis) {
for (let emoji of emojis) {
let urlToUse = autoplayGifs ? emoji.url : emoji.static_url
let shortcodeWithColons = `:${emoji.shortcode}:`
text = replaceAll(
text,
shortcodeWithColons,
`<img class="inline-custom-emoji" draggable="false" src="${urlToUse}"
alt="${shortcodeWithColons}" title="${shortcodeWithColons}" />`
)
}
}
return text
}