You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					35 lines
				
				2.0 KiB
			
		
		
			
		
	
	
					35 lines
				
				2.0 KiB
			| 
											3 years ago
										 | import { VALID_PUNCTUATION } from '../constants.js' | ||
|  | 
 | ||
|  | // Removes brackets and replaces dashes with spaces.
 | ||
|  | //
 | ||
|  | // E.g. "(999) 111-22-33" -> "999 111 22 33"
 | ||
|  | //
 | ||
|  | // For some reason Google's metadata contains `<intlFormat/>`s with brackets and dashes.
 | ||
|  | // Meanwhile, there's no single opinion about using punctuation in international phone numbers.
 | ||
|  | //
 | ||
|  | // For example, Google's `<intlFormat/>` for USA is `+1 213-373-4253`.
 | ||
|  | // And here's a quote from WikiPedia's "North American Numbering Plan" page:
 | ||
|  | // https://en.wikipedia.org/wiki/North_American_Numbering_Plan
 | ||
|  | //
 | ||
|  | // "The country calling code for all countries participating in the NANP is 1.
 | ||
|  | // In international format, an NANP number should be listed as +1 301 555 01 00,
 | ||
|  | // where 301 is an area code (Maryland)."
 | ||
|  | //
 | ||
|  | // I personally prefer the international format without any punctuation.
 | ||
|  | // For example, brackets are remnants of the old age, meaning that the
 | ||
|  | // phone number part in brackets (so called "area code") can be omitted
 | ||
|  | // if dialing within the same "area".
 | ||
|  | // And hyphens were clearly introduced for splitting local numbers into memorizable groups.
 | ||
|  | // For example, remembering "5553535" is difficult but "555-35-35" is much simpler.
 | ||
|  | // Imagine a man taking a bus from home to work and seeing an ad with a phone number.
 | ||
|  | // He has a couple of seconds to memorize that number until it passes by.
 | ||
|  | // If it were spaces instead of hyphens the man wouldn't necessarily get it,
 | ||
|  | // but with hyphens instead of spaces the grouping is more explicit.
 | ||
|  | // I personally think that hyphens introduce visual clutter,
 | ||
|  | // so I prefer replacing them with spaces in international numbers.
 | ||
|  | // In the modern age all output is done on displays where spaces are clearly distinguishable
 | ||
|  | // so hyphens can be safely replaced with spaces without losing any legibility.
 | ||
|  | //
 | ||
|  | export default function applyInternationalSeparatorStyle(formattedNumber) { | ||
|  | 	return formattedNumber.replace(new RegExp(`[${VALID_PUNCTUATION}]+`, 'g'), ' ').trim() | ||
|  | } |