mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-15 03:25:49 +00:00
5cc0801de9
The first step of the plan * #23290 Thanks to @silverwind for the first try in #15394 . Close #10729 and a lot of related issues. The EasyMDE is not removed, now it works as a fallback, users can switch between these two editors. Editor list: * Issue / PR comment * Issue / PR comment edit * Issue / PR comment quote reply * PR diff view, inline comment * PR diff view, inline comment edit * PR diff view, inline comment quote reply * Release editor * Wiki editor Some editors have attached dropzone Screenshots: <details> ![image](https://user-images.githubusercontent.com/2114189/229363558-7e44dcd4-fb6d-48a0-92f8-bd12f57bb0a0.png) ![image](https://user-images.githubusercontent.com/2114189/229363566-781489c8-5306-4347-9714-d71af5d5b0b1.png) ![image](https://user-images.githubusercontent.com/2114189/229363771-1717bf5c-0f2a-4fc2-ba84-4f5b2a343a11.png) ![image](https://user-images.githubusercontent.com/2114189/229363793-ad362d0f-a045-47bd-8f9d-05a9a842bb39.png) </details> --------- Co-authored-by: silverwind <me@silverwind.io>
57 lines
1.7 KiB
JavaScript
57 lines
1.7 KiB
JavaScript
import {emojiKeys, emojiHTML, emojiString} from './emoji.js';
|
|
import {htmlEscape} from 'escape-goat';
|
|
|
|
function makeCollections({mentions, emoji}) {
|
|
const collections = [];
|
|
|
|
if (emoji) {
|
|
collections.push({
|
|
trigger: ':',
|
|
requireLeadingSpace: true,
|
|
values: (query, cb) => {
|
|
const matches = [];
|
|
for (const name of emojiKeys) {
|
|
if (name.includes(query)) {
|
|
matches.push(name);
|
|
if (matches.length > 5) break;
|
|
}
|
|
}
|
|
cb(matches);
|
|
},
|
|
lookup: (item) => item,
|
|
selectTemplate: (item) => {
|
|
if (item === undefined) return null;
|
|
return emojiString(item.original);
|
|
},
|
|
menuItemTemplate: (item) => {
|
|
return `<div class="tribute-item">${emojiHTML(item.original)}<span>${htmlEscape(item.original)}</span></div>`;
|
|
}
|
|
});
|
|
}
|
|
|
|
if (mentions) {
|
|
collections.push({
|
|
values: window.config.tributeValues,
|
|
requireLeadingSpace: true,
|
|
menuItemTemplate: (item) => {
|
|
return `
|
|
<div class="tribute-item">
|
|
<img src="${htmlEscape(item.original.avatar)}" class="gt-mr-3"/>
|
|
<span class="name">${htmlEscape(item.original.name)}</span>
|
|
${item.original.fullname && item.original.fullname !== '' ? `<span class="fullname">${htmlEscape(item.original.fullname)}</span>` : ''}
|
|
</div>
|
|
`;
|
|
}
|
|
});
|
|
}
|
|
|
|
return collections;
|
|
}
|
|
|
|
export async function attachTribute(element, {mentions, emoji} = {}) {
|
|
const {default: Tribute} = await import(/* webpackChunkName: "tribute" */'tributejs');
|
|
const collections = makeCollections({mentions, emoji});
|
|
const tribute = new Tribute({collection: collections, noMatchTemplate: ''});
|
|
tribute.attach(element);
|
|
return tribute;
|
|
}
|