mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-26 03:52:24 +00:00 
			
		
		
		
	- Replace all default exports with named exports, except for Vue SFCs - Remove names from Vue SFCs, they are automatically inferred from the filename - Misc whitespace-related tweaks
		
			
				
	
	
		
			38 lines
		
	
	
	
		
			992 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			38 lines
		
	
	
	
		
			992 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import emojis from '../../../assets/emoji.json';
 | |
| 
 | |
| const {assetUrlPrefix, customEmojis} = window.config;
 | |
| 
 | |
| const tempMap = {...customEmojis};
 | |
| for (const {emoji, aliases} of emojis) {
 | |
|   for (const alias of aliases || []) {
 | |
|     tempMap[alias] = emoji;
 | |
|   }
 | |
| }
 | |
| 
 | |
| export const emojiKeys = Object.keys(tempMap).sort((a, b) => {
 | |
|   if (a === '+1' || a === '-1') return -1;
 | |
|   if (b === '+1' || b === '-1') return 1;
 | |
|   return a.localeCompare(b);
 | |
| });
 | |
| 
 | |
| const emojiMap = {};
 | |
| for (const key of emojiKeys) {
 | |
|   emojiMap[key] = tempMap[key];
 | |
| }
 | |
| 
 | |
| // retrieve HTML for given emoji name
 | |
| export function emojiHTML(name) {
 | |
|   let inner;
 | |
|   if (Object.prototype.hasOwnProperty.call(customEmojis, name)) {
 | |
|     inner = `<img alt=":${name}:" src="${assetUrlPrefix}/img/emoji/${name}.png">`;
 | |
|   } else {
 | |
|     inner = emojiString(name);
 | |
|   }
 | |
| 
 | |
|   return `<span class="emoji" title=":${name}:">${inner}</span>`;
 | |
| }
 | |
| 
 | |
| // retrieve string for given emoji name
 | |
| export function emojiString(name) {
 | |
|   return emojiMap[name] || `:${name}:`;
 | |
| }
 |