mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-03 08:02:36 +09:00 
			
		
		
		
	To keep blame info accurate and to avoid [changes like this](https://github.com/go-gitea/gitea/pull/29977/files#diff-c3422631a14edbe1e508c4b22f0c718db318be08a6e889427802f9b6165d88d6R359), it's good to always have a trailing comma, so let's enforce it in JS. This rule is completely automatically fixable with `make lint-js-fix` and that's what I did here.
		
			
				
	
	
		
			58 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			1.8 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.mentionValues ?? [],
 | 
						|
      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;
 | 
						|
}
 |