mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-26 20:11:02 +00:00 
			
		
		
		
	* Move tributejs to npm/webpack - Move vendored bundle to npm and webpack - Rewrote initialization to single function - Restyled it (made it a bit smaller) - Fixed it for arc-green * fix mention * also include emoji on #content * Update web_src/less/_tribute.less Co-authored-by: mrsdizzie <info@mrsdizzie.com> * rewrite to only use one instance of Tribute * refactor * fix copy/paste error Co-authored-by: mrsdizzie <info@mrsdizzie.com> Co-authored-by: techknowlogick <techknowlogick@gitea.io>
		
			
				
	
	
		
			77 lines
		
	
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import {emojiKeys, emojiHTML, emojiString} from './emoji.js';
 | |
| import {uniq} from '../utils.js';
 | |
| 
 | |
| function makeCollections({mentions, emoji}) {
 | |
|   const collections = [];
 | |
| 
 | |
|   if (mentions) {
 | |
|     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 (typeof item === 'undefined') return null;
 | |
|         return emojiString(item.original);
 | |
|       },
 | |
|       menuItemTemplate: (item) => {
 | |
|         return `<div class="tribute-item">${emojiHTML(item.original)}<span>${item.original}</span></div>`;
 | |
|       }
 | |
|     });
 | |
|   }
 | |
| 
 | |
|   if (emoji) {
 | |
|     collections.push({
 | |
|       values: window.config.tributeValues,
 | |
|       noMatchTemplate: () => null,
 | |
|       menuItemTemplate: (item) => {
 | |
|         return `
 | |
|           <div class="tribute-item">
 | |
|             <img src="${item.original.avatar}"/>
 | |
|             <span class="name">${item.original.name}</span>
 | |
|             ${item.original.fullname && item.original.fullname !== '' ? `<span class="fullname">${item.original.fullname}</span>` : ''}
 | |
|           </div>
 | |
|         `;
 | |
|       }
 | |
|     });
 | |
|   }
 | |
| 
 | |
|   return collections;
 | |
| }
 | |
| 
 | |
| export default async function attachTribute(elementOrNodeList, {mentions, emoji} = {}) {
 | |
|   if (!window.config.Tribute || !elementOrNodeList) return;
 | |
|   const nodes = Array.from('length' in elementOrNodeList ? elementOrNodeList : [elementOrNodeList]);
 | |
|   if (!nodes.length) return;
 | |
| 
 | |
|   const mentionNodes = nodes.filter((node) => {
 | |
|     return mentions || node.id === 'content';
 | |
|   });
 | |
|   const emojiNodes = nodes.filter((node) => {
 | |
|     return emoji || node.id === 'content' || node.classList.contains('emoji-input');
 | |
|   });
 | |
|   const uniqueNodes = uniq([...mentionNodes, ...emojiNodes]);
 | |
|   if (!uniqueNodes.length) return;
 | |
| 
 | |
|   const {default: Tribute} = await import(/* webpackChunkName: "tribute" */'tributejs');
 | |
| 
 | |
|   const collections = makeCollections({
 | |
|     mentions: mentions || mentionNodes.length > 0,
 | |
|     emoji: emoji || emojiNodes.length > 0,
 | |
|   });
 | |
| 
 | |
|   const tribute = new Tribute({collection: collections});
 | |
|   for (const node of uniqueNodes) {
 | |
|     tribute.attach(node);
 | |
|   }
 | |
|   return tribute;
 | |
| }
 |