import {emojiKeys, emojiHTML, emojiString} from './emoji.ts'; import {htmlEscape} from 'escape-goat'; type TributeItem = Record; export async function attachTribute(element: HTMLElement) { const {default: Tribute} = await import(/* webpackChunkName: "tribute" */'tributejs'); const collections = [ { // emojis trigger: ':', requireLeadingSpace: true, values: (query: string, cb: (matches: Array) => void) => { const matches = []; for (const name of emojiKeys) { if (name.includes(query)) { matches.push(name); if (matches.length > 5) break; } } cb(matches); }, lookup: (item: TributeItem) => item, selectTemplate: (item: TributeItem) => { if (item === undefined) return null; return emojiString(item.original); }, menuItemTemplate: (item: TributeItem) => { return `
${emojiHTML(item.original)}${htmlEscape(item.original)}
`; }, }, { // mentions values: window.config.mentionValues ?? [], requireLeadingSpace: true, menuItemTemplate: (item: TributeItem) => { return `
${htmlEscape(item.original.name)} ${item.original.fullname && item.original.fullname !== '' ? `${htmlEscape(item.original.fullname)}` : ''}
`; }, }, ]; // @ts-expect-error TS2351: This expression is not constructable (strange, why) const tribute = new Tribute({collection: collections, noMatchTemplate: ''}); tribute.attach(element); return tribute; }