mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-26 09:04:38 +01:00 
			
		
		
		
	Fixes 79 typescript errors. Discovered at least two bugs in `notifications.ts`, and I'm pretty sure this feature was at least partially broken and may still be, I don't really know how to test it. After this, only like ~10 typescript errors remain in the codebase but those are harder to solve. --------- Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
		
			
				
	
	
		
			39 lines
		
	
	
		
			989 B
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
		
			989 B
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import emojis from '../../../assets/emoji.json' with {type: '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.hasOwn(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}:`;
 | |
| }
 |