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.
		
		
		
		
		
			
		
			
				
					203 lines
				
				11 KiB
			
		
		
			
		
	
	
					203 lines
				
				11 KiB
			| 
											3 years ago
										 | "use strict"; | ||
|  | 
 | ||
|  | function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } | ||
|  | 
 | ||
|  | Object.defineProperty(exports, "__esModule", { | ||
|  |   value: true | ||
|  | }); | ||
|  | exports["default"] = formatNumber; | ||
|  | 
 | ||
|  | var _matchesEntirely = _interopRequireDefault(require("./helpers/matchesEntirely.js")); | ||
|  | 
 | ||
|  | var _formatNationalNumberUsingFormat = _interopRequireDefault(require("./helpers/formatNationalNumberUsingFormat.js")); | ||
|  | 
 | ||
|  | var _metadata = _interopRequireWildcard(require("./metadata.js")); | ||
|  | 
 | ||
|  | var _getIddPrefix = _interopRequireDefault(require("./helpers/getIddPrefix.js")); | ||
|  | 
 | ||
|  | var _RFC = require("./helpers/RFC3966.js"); | ||
|  | 
 | ||
|  | function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } | ||
|  | 
 | ||
|  | function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; } | ||
|  | 
 | ||
|  | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } | ||
|  | 
 | ||
|  | function _createForOfIteratorHelperLoose(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (it) return (it = it.call(o)).next.bind(it); if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; return function () { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } | ||
|  | 
 | ||
|  | function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } | ||
|  | 
 | ||
|  | function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } | ||
|  | 
 | ||
|  | function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } | ||
|  | 
 | ||
|  | function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } | ||
|  | 
 | ||
|  | function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } | ||
|  | 
 | ||
|  | var DEFAULT_OPTIONS = { | ||
|  |   formatExtension: function formatExtension(formattedNumber, extension, metadata) { | ||
|  |     return "".concat(formattedNumber).concat(metadata.ext()).concat(extension); | ||
|  |   } | ||
|  | }; // Formats a phone number
 | ||
|  | //
 | ||
|  | // Example use cases:
 | ||
|  | //
 | ||
|  | // ```js
 | ||
|  | // formatNumber('8005553535', 'RU', 'INTERNATIONAL')
 | ||
|  | // formatNumber('8005553535', 'RU', 'INTERNATIONAL', metadata)
 | ||
|  | // formatNumber({ phone: '8005553535', country: 'RU' }, 'INTERNATIONAL')
 | ||
|  | // formatNumber({ phone: '8005553535', country: 'RU' }, 'INTERNATIONAL', metadata)
 | ||
|  | // formatNumber('+78005553535', 'NATIONAL')
 | ||
|  | // formatNumber('+78005553535', 'NATIONAL', metadata)
 | ||
|  | // ```
 | ||
|  | //
 | ||
|  | 
 | ||
|  | function formatNumber(input, format, options, metadata) { | ||
|  |   // Apply default options.
 | ||
|  |   if (options) { | ||
|  |     options = _objectSpread(_objectSpread({}, DEFAULT_OPTIONS), options); | ||
|  |   } else { | ||
|  |     options = DEFAULT_OPTIONS; | ||
|  |   } | ||
|  | 
 | ||
|  |   metadata = new _metadata["default"](metadata); | ||
|  | 
 | ||
|  |   if (input.country && input.country !== '001') { | ||
|  |     // Validate `input.country`.
 | ||
|  |     if (!metadata.hasCountry(input.country)) { | ||
|  |       throw new Error("Unknown country: ".concat(input.country)); | ||
|  |     } | ||
|  | 
 | ||
|  |     metadata.country(input.country); | ||
|  |   } else if (input.countryCallingCode) { | ||
|  |     metadata.selectNumberingPlan(input.countryCallingCode); | ||
|  |   } else return input.phone || ''; | ||
|  | 
 | ||
|  |   var countryCallingCode = metadata.countryCallingCode(); | ||
|  |   var nationalNumber = options.v2 ? input.nationalNumber : input.phone; // This variable should have been declared inside `case`s
 | ||
|  |   // but Babel has a bug and it says "duplicate variable declaration".
 | ||
|  | 
 | ||
|  |   var number; | ||
|  | 
 | ||
|  |   switch (format) { | ||
|  |     case 'NATIONAL': | ||
|  |       // Legacy argument support.
 | ||
|  |       // (`{ country: ..., phone: '' }`)
 | ||
|  |       if (!nationalNumber) { | ||
|  |         return ''; | ||
|  |       } | ||
|  | 
 | ||
|  |       number = formatNationalNumber(nationalNumber, input.carrierCode, 'NATIONAL', metadata, options); | ||
|  |       return addExtension(number, input.ext, metadata, options.formatExtension); | ||
|  | 
 | ||
|  |     case 'INTERNATIONAL': | ||
|  |       // Legacy argument support.
 | ||
|  |       // (`{ country: ..., phone: '' }`)
 | ||
|  |       if (!nationalNumber) { | ||
|  |         return "+".concat(countryCallingCode); | ||
|  |       } | ||
|  | 
 | ||
|  |       number = formatNationalNumber(nationalNumber, null, 'INTERNATIONAL', metadata, options); | ||
|  |       number = "+".concat(countryCallingCode, " ").concat(number); | ||
|  |       return addExtension(number, input.ext, metadata, options.formatExtension); | ||
|  | 
 | ||
|  |     case 'E.164': | ||
|  |       // `E.164` doesn't define "phone number extensions".
 | ||
|  |       return "+".concat(countryCallingCode).concat(nationalNumber); | ||
|  | 
 | ||
|  |     case 'RFC3966': | ||
|  |       return (0, _RFC.formatRFC3966)({ | ||
|  |         number: "+".concat(countryCallingCode).concat(nationalNumber), | ||
|  |         ext: input.ext | ||
|  |       }); | ||
|  |     // For reference, here's Google's IDD formatter:
 | ||
|  |     // https://github.com/google/libphonenumber/blob/32719cf74e68796788d1ca45abc85dcdc63ba5b9/java/libphonenumber/src/com/google/i18n/phonenumbers/PhoneNumberUtil.java#L1546
 | ||
|  |     // Not saying that this IDD formatter replicates it 1:1, but it seems to work.
 | ||
|  |     // Who would even need to format phone numbers in IDD format anyway?
 | ||
|  | 
 | ||
|  |     case 'IDD': | ||
|  |       if (!options.fromCountry) { | ||
|  |         return; // throw new Error('`fromCountry` option not passed for IDD-prefixed formatting.')
 | ||
|  |       } | ||
|  | 
 | ||
|  |       var formattedNumber = formatIDD(nationalNumber, input.carrierCode, countryCallingCode, options.fromCountry, metadata); | ||
|  |       return addExtension(formattedNumber, input.ext, metadata, options.formatExtension); | ||
|  | 
 | ||
|  |     default: | ||
|  |       throw new Error("Unknown \"format\" argument passed to \"formatNumber()\": \"".concat(format, "\"")); | ||
|  |   } | ||
|  | } | ||
|  | 
 | ||
|  | function formatNationalNumber(number, carrierCode, formatAs, metadata, options) { | ||
|  |   var format = chooseFormatForNumber(metadata.formats(), number); | ||
|  | 
 | ||
|  |   if (!format) { | ||
|  |     return number; | ||
|  |   } | ||
|  | 
 | ||
|  |   return (0, _formatNationalNumberUsingFormat["default"])(number, format, { | ||
|  |     useInternationalFormat: formatAs === 'INTERNATIONAL', | ||
|  |     withNationalPrefix: format.nationalPrefixIsOptionalWhenFormattingInNationalFormat() && options && options.nationalPrefix === false ? false : true, | ||
|  |     carrierCode: carrierCode, | ||
|  |     metadata: metadata | ||
|  |   }); | ||
|  | } | ||
|  | 
 | ||
|  | function chooseFormatForNumber(availableFormats, nationalNnumber) { | ||
|  |   for (var _iterator = _createForOfIteratorHelperLoose(availableFormats), _step; !(_step = _iterator()).done;) { | ||
|  |     var format = _step.value; | ||
|  | 
 | ||
|  |     // Validate leading digits.
 | ||
|  |     // The test case for "else path" could be found by searching for
 | ||
|  |     // "format.leadingDigitsPatterns().length === 0".
 | ||
|  |     if (format.leadingDigitsPatterns().length > 0) { | ||
|  |       // The last leading_digits_pattern is used here, as it is the most detailed
 | ||
|  |       var lastLeadingDigitsPattern = format.leadingDigitsPatterns()[format.leadingDigitsPatterns().length - 1]; // If leading digits don't match then move on to the next phone number format
 | ||
|  | 
 | ||
|  |       if (nationalNnumber.search(lastLeadingDigitsPattern) !== 0) { | ||
|  |         continue; | ||
|  |       } | ||
|  |     } // Check that the national number matches the phone number format regular expression
 | ||
|  | 
 | ||
|  | 
 | ||
|  |     if ((0, _matchesEntirely["default"])(nationalNnumber, format.pattern())) { | ||
|  |       return format; | ||
|  |     } | ||
|  |   } | ||
|  | } | ||
|  | 
 | ||
|  | function addExtension(formattedNumber, ext, metadata, formatExtension) { | ||
|  |   return ext ? formatExtension(formattedNumber, ext, metadata) : formattedNumber; | ||
|  | } | ||
|  | 
 | ||
|  | function formatIDD(nationalNumber, carrierCode, countryCallingCode, fromCountry, metadata) { | ||
|  |   var fromCountryCallingCode = (0, _metadata.getCountryCallingCode)(fromCountry, metadata.metadata); // When calling within the same country calling code.
 | ||
|  | 
 | ||
|  |   if (fromCountryCallingCode === countryCallingCode) { | ||
|  |     var formattedNumber = formatNationalNumber(nationalNumber, carrierCode, 'NATIONAL', metadata); // For NANPA regions, return the national format for these regions
 | ||
|  |     // but prefix it with the country calling code.
 | ||
|  | 
 | ||
|  |     if (countryCallingCode === '1') { | ||
|  |       return countryCallingCode + ' ' + formattedNumber; | ||
|  |     } // If regions share a country calling code, the country calling code need
 | ||
|  |     // not be dialled. This also applies when dialling within a region, so this
 | ||
|  |     // if clause covers both these cases. Technically this is the case for
 | ||
|  |     // dialling from La Reunion to other overseas departments of France (French
 | ||
|  |     // Guiana, Martinique, Guadeloupe), but not vice versa - so we don't cover
 | ||
|  |     // this edge case for now and for those cases return the version including
 | ||
|  |     // country calling code. Details here:
 | ||
|  |     // http://www.petitfute.com/voyage/225-info-pratiques-reunion
 | ||
|  |     //
 | ||
|  | 
 | ||
|  | 
 | ||
|  |     return formattedNumber; | ||
|  |   } | ||
|  | 
 | ||
|  |   var iddPrefix = (0, _getIddPrefix["default"])(fromCountry, undefined, metadata.metadata); | ||
|  | 
 | ||
|  |   if (iddPrefix) { | ||
|  |     return "".concat(iddPrefix, " ").concat(countryCallingCode, " ").concat(formatNationalNumber(nationalNumber, null, 'INTERNATIONAL', metadata)); | ||
|  |   } | ||
|  | } | ||
|  | //# sourceMappingURL=format_.js.map
 |