Fixed emoji detection problem to append border (#14020)
* Fixed emoji detection problem to append border * Add tests * Add missing semicolon * Fixed wrong result when includes different variation selector * Add missing semicolon * Remove grapheme-splitter and Change emoji list to array from string * Update comment * Remove spaces Co-authored-by: ThibG <thib@sitedethib.com>
This commit is contained in:
		
							parent
							
								
									91055f497f
								
							
						
					
					
						commit
						b1484cf3ce
					
				
					 2 changed files with 21 additions and 6 deletions
				
			
		|  | @ -78,5 +78,15 @@ describe('emoji', () => { | |||
|       expect(emojify('✴︎')) // This is U+2734 EIGHT POINTED BLACK STAR then U+FE0E VARIATION SELECTOR-15
 | ||||
|         .toEqual('<img draggable="false" class="emojione" alt="✴" title=":eight_pointed_black_star:" src="/emoji/2734_border.svg" />'); | ||||
|     }); | ||||
| 
 | ||||
|     it('does an simple emoji properly', () => { | ||||
|       expect(emojify('♀♂')) | ||||
|         .toEqual('<img draggable="false" class="emojione" alt="♀" title=":female_sign:" src="/emoji/2640.svg" /><img draggable="false" class="emojione" alt="♂" title=":male_sign:" src="/emoji/2642.svg" />'); | ||||
|     }); | ||||
| 
 | ||||
|     it('does an emoji containing ZWJ properly', () => { | ||||
|       expect(emojify('💂♀️💂♂️')) | ||||
|         .toEqual('<img draggable="false" class="emojione" alt="💂\u200D♀️" title=":female-guard:" src="/emoji/1f482-200d-2640-fe0f_border.svg" /><img draggable="false" class="emojione" alt="💂\u200D♂️" title=":male-guard:" src="/emoji/1f482-200d-2642-fe0f_border.svg" />'); | ||||
|     }); | ||||
|   }); | ||||
| }); | ||||
|  |  | |||
|  | @ -6,13 +6,18 @@ const trie = new Trie(Object.keys(unicodeMapping)); | |||
| 
 | ||||
| const assetHost = process.env.CDN_HOST || ''; | ||||
| 
 | ||||
| // Emoji requiring extra borders depending on theme
 | ||||
| const darkEmoji = '🎱🐜⚫🖤⬛◼️◾◼️✒️▪️💣🎳📷📸♣️🕶️✴️🔌💂♀️📽️🍳🦍💂🔪🕳️🕹️🕋🖊️🖋️💂♂️🎤🎓🎥🎼♠️🎩🦃📼📹🎮🐃🏴'; | ||||
| const lightEmoji = '👽⚾🐔☁️💨🕊️👀🍥👻🐐❕❔⛸️🌩️🔊🔇📃🌧️🐏🍚🍙🐓🐑💀☠️🌨️🔉🔈💬💭🏐🏳️⚪⬜◽◻️▫️'; | ||||
| // Convert to file names from emojis. (For different variation selector emojis)
 | ||||
| const emojiFilenames = (emojis) => { | ||||
|   return emojis.map(v => unicodeMapping[v].filename); | ||||
| }; | ||||
| 
 | ||||
| const emojiFilename = (filename, match) => { | ||||
| // Emoji requiring extra borders depending on theme
 | ||||
| const darkEmoji = emojiFilenames(['🎱', '🐜', '⚫', '🖤', '⬛', '◼️', '◾', '◼️', '✒️', '▪️', '💣', '🎳', '📷', '📸', '♣️', '🕶️', '✴️', '🔌', '💂♀️', '📽️', '🍳', '🦍', '💂', '🔪', '🕳️', '🕹️', '🕋', '🖊️', '🖋️', '💂♂️', '🎤', '🎓', '🎥', '🎼', '♠️', '🎩', '🦃', '📼', '📹', '🎮', '🐃', '🏴']); | ||||
| const lightEmoji = emojiFilenames(['👽', '⚾', '🐔', '☁️', '💨', '🕊️', '👀', '🍥', '👻', '🐐', '❕', '❔', '⛸️', '🌩️', '🔊', '🔇', '📃', '🌧️', '🐏', '🍚', '🍙', '🐓', '🐑', '💀', '☠️', '🌨️', '🔉', '🔈', '💬', '💭', '🏐', '🏳️', '⚪', '⬜', '◽', '◻️', '▫️']); | ||||
| 
 | ||||
| const emojiFilename = (filename) => { | ||||
|   const borderedEmoji = (document.body && document.body.classList.contains('theme-mastodon-light')) ? lightEmoji : darkEmoji; | ||||
|   return borderedEmoji.includes(match) ? (filename + '_border') : filename; | ||||
|   return borderedEmoji.includes(filename) ? (filename + '_border') : filename; | ||||
| }; | ||||
| 
 | ||||
| const emojify = (str, customEmojis = {}) => { | ||||
|  | @ -69,7 +74,7 @@ const emojify = (str, customEmojis = {}) => { | |||
|     } else { // matched to unicode emoji
 | ||||
|       const { filename, shortCode } = unicodeMapping[match]; | ||||
|       const title = shortCode ? `:${shortCode}:` : ''; | ||||
|       replacement = `<img draggable="false" class="emojione" alt="${match}" title="${title}" src="${assetHost}/emoji/${emojiFilename(filename, match)}.svg" />`; | ||||
|       replacement = `<img draggable="false" class="emojione" alt="${match}" title="${title}" src="${assetHost}/emoji/${emojiFilename(filename)}.svg" />`; | ||||
|       rend = i + match.length; | ||||
|       // If the matched character was followed by VS15 (for selecting text presentation), skip it.
 | ||||
|       if (str.codePointAt(rend) === 65038) { | ||||
|  |  | |||
		Reference in a new issue