27 lines
		
	
	
		
			947 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			27 lines
		
	
	
		
			947 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
/** Used to compose unicode character classes. */
 | 
						|
var rsAstralRange = '\\ud800-\\udfff',
 | 
						|
    rsComboMarksRange = '\\u0300-\\u036f',
 | 
						|
    reComboHalfMarksRange = '\\ufe20-\\ufe2f',
 | 
						|
    rsComboSymbolsRange = '\\u20d0-\\u20ff',
 | 
						|
    rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,
 | 
						|
    rsVarRange = '\\ufe0e\\ufe0f';
 | 
						|
 | 
						|
/** Used to compose unicode capture groups. */
 | 
						|
var rsZWJ = '\\u200d';
 | 
						|
 | 
						|
/** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */
 | 
						|
var reHasUnicode = RegExp('[' + rsZWJ + rsAstralRange  + rsComboRange + rsVarRange + ']');
 | 
						|
 | 
						|
/**
 | 
						|
 * Checks if `string` contains Unicode symbols.
 | 
						|
 *
 | 
						|
 * @private
 | 
						|
 * @param {string} string The string to inspect.
 | 
						|
 * @returns {boolean} Returns `true` if a symbol is found, else `false`.
 | 
						|
 */
 | 
						|
function hasUnicode(string) {
 | 
						|
  return reHasUnicode.test(string);
 | 
						|
}
 | 
						|
 | 
						|
export default hasUnicode;
 |