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.
		
		
		
		
		
			
		
			
				
					
					
						
							50 lines
						
					
					
						
							2.2 KiB
						
					
					
				
			
		
		
	
	
							50 lines
						
					
					
						
							2.2 KiB
						
					
					
				import Metadata from '../metadata.js';
 | 
						|
import matchesEntirely from './matchesEntirely.js';
 | 
						|
import extractNationalNumber from './extractNationalNumber.js';
 | 
						|
import checkNumberLength from './checkNumberLength.js';
 | 
						|
import getCountryCallingCode from '../getCountryCallingCode.js';
 | 
						|
/**
 | 
						|
 * Sometimes some people incorrectly input international phone numbers
 | 
						|
 * without the leading `+`. This function corrects such input.
 | 
						|
 * @param  {string} number — Phone number digits.
 | 
						|
 * @param  {string?} country
 | 
						|
 * @param  {string?} callingCode
 | 
						|
 * @param  {object} metadata
 | 
						|
 * @return {object} `{ countryCallingCode: string?, number: string }`.
 | 
						|
 */
 | 
						|
 | 
						|
export default function extractCountryCallingCodeFromInternationalNumberWithoutPlusSign(number, country, callingCode, metadata) {
 | 
						|
  var countryCallingCode = country ? getCountryCallingCode(country, metadata) : callingCode;
 | 
						|
 | 
						|
  if (number.indexOf(countryCallingCode) === 0) {
 | 
						|
    metadata = new Metadata(metadata);
 | 
						|
    metadata.selectNumberingPlan(country, callingCode);
 | 
						|
    var possibleShorterNumber = number.slice(countryCallingCode.length);
 | 
						|
 | 
						|
    var _extractNationalNumbe = extractNationalNumber(possibleShorterNumber, metadata),
 | 
						|
        possibleShorterNationalNumber = _extractNationalNumbe.nationalNumber;
 | 
						|
 | 
						|
    var _extractNationalNumbe2 = extractNationalNumber(number, metadata),
 | 
						|
        nationalNumber = _extractNationalNumbe2.nationalNumber; // If the number was not valid before but is valid now,
 | 
						|
    // or if it was too long before, we consider the number
 | 
						|
    // with the country calling code stripped to be a better result
 | 
						|
    // and keep that instead.
 | 
						|
    // For example, in Germany (+49), `49` is a valid area code,
 | 
						|
    // so if a number starts with `49`, it could be both a valid
 | 
						|
    // national German number or an international number without
 | 
						|
    // a leading `+`.
 | 
						|
 | 
						|
 | 
						|
    if (!matchesEntirely(nationalNumber, metadata.nationalNumberPattern()) && matchesEntirely(possibleShorterNationalNumber, metadata.nationalNumberPattern()) || checkNumberLength(nationalNumber, metadata) === 'TOO_LONG') {
 | 
						|
      return {
 | 
						|
        countryCallingCode: countryCallingCode,
 | 
						|
        number: possibleShorterNumber
 | 
						|
      };
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  return {
 | 
						|
    number: number
 | 
						|
  };
 | 
						|
}
 | 
						|
//# sourceMappingURL=extractCountryCallingCodeFromInternationalNumberWithoutPlusSign.js.map
 |