mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-03 04:16:20 +01:00 
			
		
		
		
	Improve emoji and mention matching (#24255)
Prioritize matches that start with the given text, then matches that contain the given text. I wanted to add a heart emoji on a pull request comment so I started writing `:`, `h`, `e`, `a`, `r` (at this point I still couldn't find the heart), `t`... The heart was not on the list, that's weird - it feels like I made a typo or a mistake. This fixes that. This also feels more like GitHub's emoji auto-complete. # Before  # After  --------- Signed-off-by: Yarden Shoham <git@yardenshoham.com> Co-authored-by: silverwind <me@silverwind.io>
This commit is contained in:
		
							
								
								
									
										47
									
								
								web_src/js/utils/match.test.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								web_src/js/utils/match.test.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,47 @@
 | 
			
		||||
import {test, expect} from 'vitest';
 | 
			
		||||
import {matchEmoji, matchMention} from './match.js';
 | 
			
		||||
 | 
			
		||||
test('matchEmoji', () => {
 | 
			
		||||
  expect(matchEmoji('')).toEqual([
 | 
			
		||||
    '+1',
 | 
			
		||||
    '-1',
 | 
			
		||||
    '100',
 | 
			
		||||
    '1234',
 | 
			
		||||
    '1st_place_medal',
 | 
			
		||||
    '2nd_place_medal',
 | 
			
		||||
  ]);
 | 
			
		||||
 | 
			
		||||
  expect(matchEmoji('hea')).toEqual([
 | 
			
		||||
    'headphones',
 | 
			
		||||
    'headstone',
 | 
			
		||||
    'health_worker',
 | 
			
		||||
    'hear_no_evil',
 | 
			
		||||
    'heard_mcdonald_islands',
 | 
			
		||||
    'heart',
 | 
			
		||||
  ]);
 | 
			
		||||
 | 
			
		||||
  expect(matchEmoji('hear')).toEqual([
 | 
			
		||||
    'hear_no_evil',
 | 
			
		||||
    'heard_mcdonald_islands',
 | 
			
		||||
    'heart',
 | 
			
		||||
    'heart_decoration',
 | 
			
		||||
    'heart_eyes',
 | 
			
		||||
    'heart_eyes_cat',
 | 
			
		||||
  ]);
 | 
			
		||||
 | 
			
		||||
  expect(matchEmoji('poo')).toEqual([
 | 
			
		||||
    'poodle',
 | 
			
		||||
    'hankey',
 | 
			
		||||
    'spoon',
 | 
			
		||||
    'bowl_with_spoon',
 | 
			
		||||
  ]);
 | 
			
		||||
 | 
			
		||||
  expect(matchEmoji('1st_')).toEqual([
 | 
			
		||||
    '1st_place_medal',
 | 
			
		||||
  ]);
 | 
			
		||||
});
 | 
			
		||||
 | 
			
		||||
test('matchMention', () => {
 | 
			
		||||
  expect(matchMention('')).toEqual(window.config.tributeValues.slice(0, 6));
 | 
			
		||||
  expect(matchMention('user4')).toEqual([window.config.tributeValues[3]]);
 | 
			
		||||
});
 | 
			
		||||
		Reference in New Issue
	
	Block a user