- Fix emoji not being replaced in issue title change text - Make the image attributes consistent, add alt, remove align Co-authored-by: zeripath <art27@cantab.net> Co-authored-by: techknowlogick <techknowlogick@gitea.io>
		
			
				
	
	
		
			39 lines
		
	
	
		
			946 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
		
			946 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import emojis from '../../../assets/emoji.json';
 | |
| 
 | |
| const {StaticUrlPrefix} = window.config;
 | |
| 
 | |
| const tempMap = {gitea: ':gitea:'};
 | |
| 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);
 | |
| });
 | |
| 
 | |
| export const emojiMap = {};
 | |
| for (const key of emojiKeys) {
 | |
|   emojiMap[key] = tempMap[key];
 | |
| }
 | |
| 
 | |
| // retrieve HTML for given emoji name
 | |
| export function emojiHTML(name) {
 | |
|   let inner;
 | |
|   if (name === 'gitea') {
 | |
|     inner = `<img alt=":${name}:" src="${StaticUrlPrefix}/img/emoji/gitea.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}:`;
 | |
| }
 |