@kne-components/components-core 0.4.39 → 0.4.40

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (151) hide show
  1. package/build/asset-manifest.json +101 -105
  2. package/build/index.html +1 -1
  3. package/build/remoteEntry.js +1 -1
  4. package/build/remoteEntry.js.map +1 -1
  5. package/build/static/css/1742.fef10b56.chunk.css +2 -0
  6. package/build/static/css/{1742.0d695953.chunk.css.map → 1742.fef10b56.chunk.css.map} +1 -1
  7. package/build/static/css/{1996.ca84a80c.chunk.css → 1996.7bc5bcf7.chunk.css} +2 -2
  8. package/build/static/css/{1996.ca84a80c.chunk.css.map → 1996.7bc5bcf7.chunk.css.map} +1 -1
  9. package/build/static/css/2004.bd9a4a93.chunk.css +2 -0
  10. package/build/static/css/{2004.f30987e0.chunk.css.map → 2004.bd9a4a93.chunk.css.map} +1 -1
  11. package/build/static/css/2307.617a5d99.chunk.css +2 -0
  12. package/build/static/css/{2307.a8273c29.chunk.css.map → 2307.617a5d99.chunk.css.map} +1 -1
  13. package/build/static/css/254.d80175e8.chunk.css +2 -0
  14. package/build/static/css/{254.7802310a.chunk.css.map → 254.d80175e8.chunk.css.map} +1 -1
  15. package/build/static/css/3404.9c125d00.chunk.css +2 -0
  16. package/build/static/css/{3404.5755777d.chunk.css.map → 3404.9c125d00.chunk.css.map} +1 -1
  17. package/build/static/css/{3771.eb333843.chunk.css → 3771.1d19be0e.chunk.css} +2 -2
  18. package/build/static/css/{3771.eb333843.chunk.css.map → 3771.1d19be0e.chunk.css.map} +1 -1
  19. package/build/static/css/{3790.f92d7658.chunk.css → 3790.395a0e69.chunk.css} +2 -2
  20. package/build/static/css/{3790.f92d7658.chunk.css.map → 3790.395a0e69.chunk.css.map} +1 -1
  21. package/build/static/css/4834.798c673f.chunk.css +2 -0
  22. package/build/static/css/{4834.ab40675f.chunk.css.map → 4834.798c673f.chunk.css.map} +1 -1
  23. package/build/static/css/5195.63ecacac.chunk.css +2 -0
  24. package/build/static/css/{5195.29fb391a.chunk.css.map → 5195.63ecacac.chunk.css.map} +1 -1
  25. package/build/static/css/{6763.b0b78a75.chunk.css → 6763.2ebdb6d0.chunk.css} +2 -2
  26. package/build/static/css/{6763.b0b78a75.chunk.css.map → 6763.2ebdb6d0.chunk.css.map} +1 -1
  27. package/build/static/css/6956.9db8843a.chunk.css +2 -0
  28. package/build/static/css/{6956.d28bfd77.chunk.css.map → 6956.9db8843a.chunk.css.map} +1 -1
  29. package/build/static/css/7227.b6d935c3.chunk.css +2 -0
  30. package/build/static/css/{7227.dd7c675a.chunk.css.map → 7227.b6d935c3.chunk.css.map} +1 -1
  31. package/build/static/css/7371.ced39ce7.chunk.css +2 -0
  32. package/build/static/css/{7371.2abb5289.chunk.css.map → 7371.ced39ce7.chunk.css.map} +1 -1
  33. package/build/static/css/7548.1f050084.chunk.css +12 -0
  34. package/build/static/css/{7548.290a057e.chunk.css.map → 7548.1f050084.chunk.css.map} +1 -1
  35. package/build/static/css/7569.d0338e03.chunk.css +2 -0
  36. package/build/static/css/7569.d0338e03.chunk.css.map +1 -0
  37. package/build/static/css/{760.0662f4a4.chunk.css → 760.54cd6d81.chunk.css} +2 -2
  38. package/build/static/css/{760.0662f4a4.chunk.css.map → 760.54cd6d81.chunk.css.map} +1 -1
  39. package/build/static/css/833.4b4414cb.chunk.css +2 -0
  40. package/build/static/css/{833.d533fba3.chunk.css.map → 833.4b4414cb.chunk.css.map} +1 -1
  41. package/build/static/css/{8593.715903c7.chunk.css → 8593.3cf54be7.chunk.css} +2 -2
  42. package/build/static/css/{8593.715903c7.chunk.css.map → 8593.3cf54be7.chunk.css.map} +1 -1
  43. package/build/static/css/9556.b702777c.chunk.css +2 -0
  44. package/build/static/css/{9556.27ba8731.chunk.css.map → 9556.b702777c.chunk.css.map} +1 -1
  45. package/build/static/js/1125.d307a210.chunk.js +2 -0
  46. package/build/static/js/1125.d307a210.chunk.js.map +1 -0
  47. package/build/static/js/1742.a420998d.chunk.js +2 -0
  48. package/build/static/js/{1742.b4f4b704.chunk.js.map → 1742.a420998d.chunk.js.map} +1 -1
  49. package/build/static/js/{196.8370bf58.chunk.js → 196.6fac5cd3.chunk.js} +1 -1
  50. package/build/static/js/{1996.b3b3091e.chunk.js → 1996.3c2883f9.chunk.js} +2 -2
  51. package/build/static/js/{1996.b3b3091e.chunk.js.map → 1996.3c2883f9.chunk.js.map} +1 -1
  52. package/build/static/js/{2004.415ec569.chunk.js → 2004.597e684c.chunk.js} +3 -3
  53. package/build/static/js/{2004.415ec569.chunk.js.map → 2004.597e684c.chunk.js.map} +1 -1
  54. package/build/static/js/2086.49b16ee8.chunk.js +3 -0
  55. package/build/static/js/2086.49b16ee8.chunk.js.map +1 -0
  56. package/build/static/js/{2242.7df7a936.chunk.js → 2242.5dc84c52.chunk.js} +2 -2
  57. package/build/static/js/{2242.7df7a936.chunk.js.map → 2242.5dc84c52.chunk.js.map} +1 -1
  58. package/build/static/js/254.730cbef5.chunk.js +2 -0
  59. package/build/static/js/{254.74a183e3.chunk.js.map → 254.730cbef5.chunk.js.map} +1 -1
  60. package/build/static/js/2635.5e09af98.chunk.js +3 -0
  61. package/build/static/js/2635.5e09af98.chunk.js.map +1 -0
  62. package/build/static/js/2931.2ad9df38.chunk.js.map +1 -1
  63. package/build/static/js/{3404.7563c64f.chunk.js → 3404.d72d469f.chunk.js} +3 -3
  64. package/build/static/js/{3404.7563c64f.chunk.js.map → 3404.d72d469f.chunk.js.map} +1 -1
  65. package/build/static/js/3771.7b17e936.chunk.js +2 -0
  66. package/build/static/js/{3771.6e798324.chunk.js.map → 3771.7b17e936.chunk.js.map} +1 -1
  67. package/build/static/js/{3790.3f96b374.chunk.js → 3790.5e45cab0.chunk.js} +2 -2
  68. package/build/static/js/{3790.3f96b374.chunk.js.map → 3790.5e45cab0.chunk.js.map} +1 -1
  69. package/build/static/js/3856.7c253a55.chunk.js +2 -0
  70. package/build/static/js/{3856.b2c0f91a.chunk.js.map → 3856.7c253a55.chunk.js.map} +1 -1
  71. package/build/static/js/4474.54b6dbc5.chunk.js +2 -0
  72. package/build/static/js/{4474.afbb9500.chunk.js.map → 4474.54b6dbc5.chunk.js.map} +1 -1
  73. package/build/static/js/{4834.aa9f99eb.chunk.js → 4834.4e0afb79.chunk.js} +2 -2
  74. package/build/static/js/{4834.aa9f99eb.chunk.js.map → 4834.4e0afb79.chunk.js.map} +1 -1
  75. package/build/static/js/5195.a76d89e7.chunk.js +2 -0
  76. package/build/static/js/{5195.98fd8eb2.chunk.js.map → 5195.a76d89e7.chunk.js.map} +1 -1
  77. package/build/static/js/6453.92eff892.chunk.js +2 -0
  78. package/build/static/js/6453.92eff892.chunk.js.map +1 -0
  79. package/build/static/js/6763.02a19c95.chunk.js +2 -0
  80. package/build/static/js/{6763.4903b74a.chunk.js.map → 6763.02a19c95.chunk.js.map} +1 -1
  81. package/build/static/js/{6956.75686d06.chunk.js → 6956.b30f0baf.chunk.js} +2 -2
  82. package/build/static/js/{6956.75686d06.chunk.js.map → 6956.b30f0baf.chunk.js.map} +1 -1
  83. package/build/static/js/{7227.0a0dc1ac.chunk.js → 7227.2eea005d.chunk.js} +3 -3
  84. package/build/static/js/{7227.0a0dc1ac.chunk.js.map → 7227.2eea005d.chunk.js.map} +1 -1
  85. package/build/static/js/{7371.33b6b89a.chunk.js → 7371.25528aac.chunk.js} +2 -2
  86. package/build/static/js/{7371.33b6b89a.chunk.js.map → 7371.25528aac.chunk.js.map} +1 -1
  87. package/build/static/js/{7548.5dad90a3.chunk.js → 7548.572562c0.chunk.js} +2 -2
  88. package/build/static/js/{7548.5dad90a3.chunk.js.map → 7548.572562c0.chunk.js.map} +1 -1
  89. package/build/static/js/{2054.0c582959.chunk.js → 7569.5d4cf447.chunk.js} +2 -2
  90. package/build/static/js/{2054.0c582959.chunk.js.map → 7569.5d4cf447.chunk.js.map} +1 -1
  91. package/build/static/js/{7591.83d402a4.chunk.js → 7591.72cd06f6.chunk.js} +2 -2
  92. package/build/static/js/7591.72cd06f6.chunk.js.map +1 -0
  93. package/build/static/js/{760.09016d75.chunk.js → 760.2e4b9746.chunk.js} +2 -2
  94. package/build/static/js/{760.09016d75.chunk.js.map → 760.2e4b9746.chunk.js.map} +1 -1
  95. package/build/static/js/{833.5161bd8a.chunk.js → 833.2a8d0e1d.chunk.js} +2 -2
  96. package/build/static/js/{833.5161bd8a.chunk.js.map → 833.2a8d0e1d.chunk.js.map} +1 -1
  97. package/build/static/js/8593.a7729eeb.chunk.js +2 -0
  98. package/build/static/js/{8593.cf0415d0.chunk.js.map → 8593.a7729eeb.chunk.js.map} +1 -1
  99. package/build/static/js/8706.b5cfdf89.chunk.js +2 -0
  100. package/build/static/js/8706.b5cfdf89.chunk.js.map +1 -0
  101. package/build/static/js/{9556.26768f27.chunk.js → 9556.f591f290.chunk.js} +3 -3
  102. package/build/static/js/{9556.26768f27.chunk.js.map → 9556.f591f290.chunk.js.map} +1 -1
  103. package/build/static/js/main.3ebd96a6.js +2 -0
  104. package/build/static/js/main.3ebd96a6.js.map +1 -0
  105. package/package.json +2 -2
  106. package/build/static/css/1742.0d695953.chunk.css +0 -2
  107. package/build/static/css/2004.f30987e0.chunk.css +0 -2
  108. package/build/static/css/2054.730ac615.chunk.css +0 -2
  109. package/build/static/css/2054.730ac615.chunk.css.map +0 -1
  110. package/build/static/css/2307.a8273c29.chunk.css +0 -2
  111. package/build/static/css/254.7802310a.chunk.css +0 -2
  112. package/build/static/css/3404.5755777d.chunk.css +0 -2
  113. package/build/static/css/4834.ab40675f.chunk.css +0 -2
  114. package/build/static/css/5195.29fb391a.chunk.css +0 -2
  115. package/build/static/css/6956.d28bfd77.chunk.css +0 -2
  116. package/build/static/css/7227.dd7c675a.chunk.css +0 -2
  117. package/build/static/css/7371.2abb5289.chunk.css +0 -2
  118. package/build/static/css/7548.290a057e.chunk.css +0 -12
  119. package/build/static/css/833.d533fba3.chunk.css +0 -2
  120. package/build/static/css/9556.27ba8731.chunk.css +0 -2
  121. package/build/static/js/1125.991180cf.chunk.js +0 -2
  122. package/build/static/js/1125.991180cf.chunk.js.map +0 -1
  123. package/build/static/js/1742.b4f4b704.chunk.js +0 -2
  124. package/build/static/js/1815.badeac0c.chunk.js +0 -1
  125. package/build/static/js/182.435f5645.chunk.js +0 -2
  126. package/build/static/js/182.435f5645.chunk.js.map +0 -1
  127. package/build/static/js/2086.3ca70084.chunk.js +0 -3
  128. package/build/static/js/2086.3ca70084.chunk.js.map +0 -1
  129. package/build/static/js/254.74a183e3.chunk.js +0 -2
  130. package/build/static/js/3237.777b99ba.chunk.js +0 -1
  131. package/build/static/js/3771.6e798324.chunk.js +0 -2
  132. package/build/static/js/3856.b2c0f91a.chunk.js +0 -2
  133. package/build/static/js/4474.afbb9500.chunk.js +0 -2
  134. package/build/static/js/5195.98fd8eb2.chunk.js +0 -2
  135. package/build/static/js/6671.e04efa14.chunk.js +0 -1
  136. package/build/static/js/6763.4903b74a.chunk.js +0 -2
  137. package/build/static/js/7492.b5d8b8c4.chunk.js +0 -1
  138. package/build/static/js/7591.83d402a4.chunk.js.map +0 -1
  139. package/build/static/js/8593.cf0415d0.chunk.js +0 -2
  140. package/build/static/js/8706.aa4dfbf5.chunk.js +0 -2
  141. package/build/static/js/8706.aa4dfbf5.chunk.js.map +0 -1
  142. package/build/static/js/8970.4a7ef88e.chunk.js +0 -3
  143. package/build/static/js/8970.4a7ef88e.chunk.js.map +0 -1
  144. package/build/static/js/main.eb7a565d.js +0 -2
  145. package/build/static/js/main.eb7a565d.js.map +0 -1
  146. /package/build/static/js/{2004.415ec569.chunk.js.LICENSE.txt → 2004.597e684c.chunk.js.LICENSE.txt} +0 -0
  147. /package/build/static/js/{2086.3ca70084.chunk.js.LICENSE.txt → 2086.49b16ee8.chunk.js.LICENSE.txt} +0 -0
  148. /package/build/static/js/{3404.7563c64f.chunk.js.LICENSE.txt → 2635.5e09af98.chunk.js.LICENSE.txt} +0 -0
  149. /package/build/static/js/{7227.0a0dc1ac.chunk.js.LICENSE.txt → 3404.d72d469f.chunk.js.LICENSE.txt} +0 -0
  150. /package/build/static/js/{8970.4a7ef88e.chunk.js.LICENSE.txt → 7227.2eea005d.chunk.js.LICENSE.txt} +0 -0
  151. /package/build/static/js/{9556.26768f27.chunk.js.LICENSE.txt → 9556.f591f290.chunk.js.LICENSE.txt} +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"static/js/2931.2ad9df38.chunk.js","mappings":"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","sources":["../node_modules/libphonenumber-js/source/helpers/getCountryByCallingCode.js","../node_modules/libphonenumber-js/source/helpers/applyInternationalSeparatorStyle.js","../node_modules/libphonenumber-js/source/constants.js","../node_modules/libphonenumber-js/source/helpers/isObject.js","../node_modules/libphonenumber-js/source/helpers/formatNationalNumberUsingFormat.js","../node_modules/libphonenumber-js/source/isValidPhoneNumber.js","../node_modules/libphonenumber-js/source/normalizeArguments.js","../node_modules/libphonenumber-js/source/ParseError.js","../node_modules/libphonenumber-js/source/helpers/matchesEntirely.js","../node_modules/libphonenumber-js/source/helpers/extractNationalNumberFromPossiblyIncompleteNumber.js","../node_modules/libphonenumber-js/source/parsePhoneNumberWithError_.js","../node_modules/libphonenumber-js/source/helpers/parseDigits.js","../node_modules/libphonenumber-js/source/helpers/extractCountryCallingCode.js","../node_modules/libphonenumber-js/source/helpers/getPossibleCountriesForNumber.js","../node_modules/libphonenumber-js/source/PhoneNumber.js","../node_modules/libphonenumber-js/source/helpers/extension/createExtensionPattern.js","../node_modules/libphonenumber-js/source/helpers/stripIddPrefix.js","../node_modules/libphonenumber-js/source/helpers/extension/extractExtension.js","../node_modules/libphonenumber-js/source/helpers/extractPhoneContext.js","../node_modules/libphonenumber-js/source/helpers/extractFormattedPhoneNumberFromPossibleRfc3966NumberUri.js","../node_modules/libphonenumber-js/source/parse.js","../node_modules/libphonenumber-js/source/helpers/checkNumberLength.js","../node_modules/libphonenumber-js/source/helpers/mergeArrays.js","../node_modules/libphonenumber-js/source/helpers/extractCountryCallingCodeFromInternationalNumberWithoutPlusSign.js","../node_modules/libphonenumber-js/source/helpers/getIddPrefix.js","../node_modules/libphonenumber-js/source/format.js","../node_modules/libphonenumber-js/source/isPossible.js","../node_modules/libphonenumber-js/source/helpers/extractNationalNumber.js","../node_modules/libphonenumber-js/source/helpers/isViablePhoneNumber.js","../node_modules/libphonenumber-js/source/parseIncompletePhoneNumber.js","../node_modules/libphonenumber-js/source/helpers/RFC3966.js","../node_modules/libphonenumber-js/source/parsePhoneNumber_.js","../node_modules/libphonenumber-js/source/isValid.js","../node_modules/libphonenumber-js/source/tools/semver-compare.js","../node_modules/libphonenumber-js/source/metadata.js","../node_modules/libphonenumber-js/source/helpers/getCountryByNationalNumber.js","../node_modules/libphonenumber-js/source/helpers/getNumberType.js"],"sourcesContent":["import getCountryByNationalNumber from './getCountryByNationalNumber.js'\r\n\r\nconst USE_NON_GEOGRAPHIC_COUNTRY_CODE = false\r\n\r\n// Returns the exact country for the `nationalNumber`\r\n// that belongs to the specified \"country calling code\".\r\nexport default function getCountryByCallingCode(callingCode, {\r\n\tnationalNumber: nationalPhoneNumber,\r\n\tmetadata\r\n}) {\r\n\t/* istanbul ignore if */\r\n\tif (USE_NON_GEOGRAPHIC_COUNTRY_CODE) {\r\n\t\tif (metadata.isNonGeographicCallingCode(callingCode)) {\r\n\t\t\treturn '001'\r\n\t\t}\r\n\t}\r\n\tconst possibleCountries = metadata.getCountryCodesForCallingCode(callingCode)\r\n\tif (!possibleCountries) {\r\n\t\treturn\r\n\t}\r\n\t// If there's just one country corresponding to the country code,\r\n\t// then just return it, without further phone number digits validation.\r\n\tif (possibleCountries.length === 1) {\r\n\t\treturn possibleCountries[0]\r\n\t}\r\n\treturn getCountryByNationalNumber(nationalPhoneNumber, {\r\n\t\tcountries: possibleCountries,\r\n\t\tmetadata: metadata.metadata\r\n\t})\r\n}","import { VALID_PUNCTUATION } from '../constants.js'\r\n\r\n// Removes brackets and replaces dashes with spaces.\r\n//\r\n// E.g. \"(999) 111-22-33\" -> \"999 111 22 33\"\r\n//\r\n// For some reason Google's metadata contains `<intlFormat/>`s with brackets and dashes.\r\n// Meanwhile, there's no single opinion about using punctuation in international phone numbers.\r\n//\r\n// For example, Google's `<intlFormat/>` for USA is `+1 213-373-4253`.\r\n// And here's a quote from WikiPedia's \"North American Numbering Plan\" page:\r\n// https://en.wikipedia.org/wiki/North_American_Numbering_Plan\r\n//\r\n// \"The country calling code for all countries participating in the NANP is 1.\r\n// In international format, an NANP number should be listed as +1 301 555 01 00,\r\n// where 301 is an area code (Maryland).\"\r\n//\r\n// I personally prefer the international format without any punctuation.\r\n// For example, brackets are remnants of the old age, meaning that the\r\n// phone number part in brackets (so called \"area code\") can be omitted\r\n// if dialing within the same \"area\".\r\n// And hyphens were clearly introduced for splitting local numbers into memorizable groups.\r\n// For example, remembering \"5553535\" is difficult but \"555-35-35\" is much simpler.\r\n// Imagine a man taking a bus from home to work and seeing an ad with a phone number.\r\n// He has a couple of seconds to memorize that number until it passes by.\r\n// If it were spaces instead of hyphens the man wouldn't necessarily get it,\r\n// but with hyphens instead of spaces the grouping is more explicit.\r\n// I personally think that hyphens introduce visual clutter,\r\n// so I prefer replacing them with spaces in international numbers.\r\n// In the modern age all output is done on displays where spaces are clearly distinguishable\r\n// so hyphens can be safely replaced with spaces without losing any legibility.\r\n//\r\nexport default function applyInternationalSeparatorStyle(formattedNumber) {\r\n\treturn formattedNumber.replace(new RegExp(`[${VALID_PUNCTUATION}]+`, 'g'), ' ').trim()\r\n}","// The minimum length of the national significant number.\r\nexport const MIN_LENGTH_FOR_NSN = 2\r\n\r\n// The ITU says the maximum length should be 15,\r\n// but one can find longer numbers in Germany.\r\nexport const MAX_LENGTH_FOR_NSN = 17\r\n\r\n// The maximum length of the country calling code.\r\nexport const MAX_LENGTH_COUNTRY_CODE = 3\r\n\r\n// Digits accepted in phone numbers\r\n// (ascii, fullwidth, arabic-indic, and eastern arabic digits).\r\nexport const VALID_DIGITS = '0-9\\uFF10-\\uFF19\\u0660-\\u0669\\u06F0-\\u06F9'\r\n\r\n// `DASHES` will be right after the opening square bracket of the \"character class\"\r\nconst DASHES = '-\\u2010-\\u2015\\u2212\\u30FC\\uFF0D'\r\nconst SLASHES = '\\uFF0F/'\r\nconst DOTS = '\\uFF0E.'\r\nexport const WHITESPACE = ' \\u00A0\\u00AD\\u200B\\u2060\\u3000'\r\nconst BRACKETS = '()\\uFF08\\uFF09\\uFF3B\\uFF3D\\\\[\\\\]'\r\n// export const OPENING_BRACKETS = '(\\uFF08\\uFF3B\\\\\\['\r\nconst TILDES = '~\\u2053\\u223C\\uFF5E'\r\n\r\n// Regular expression of acceptable punctuation found in phone numbers. This\r\n// excludes punctuation found as a leading character only. This consists of dash\r\n// characters, white space characters, full stops, slashes, square brackets,\r\n// parentheses and tildes. Full-width variants are also present.\r\nexport const VALID_PUNCTUATION = `${DASHES}${SLASHES}${DOTS}${WHITESPACE}${BRACKETS}${TILDES}`\r\n\r\nexport const PLUS_CHARS = '+\\uFF0B'\r\n// const LEADING_PLUS_CHARS_PATTERN = new RegExp('^[' + PLUS_CHARS + ']+')","const objectConstructor = {}.constructor;\r\n\r\nexport default function isObject(object) {\r\n return object !== undefined && object !== null && object.constructor === objectConstructor;\r\n}\r\n","import applyInternationalSeparatorStyle from './applyInternationalSeparatorStyle.js'\r\n\r\n// This was originally set to $1 but there are some countries for which the\r\n// first group is not used in the national pattern (e.g. Argentina) so the $1\r\n// group does not match correctly. Therefore, we use `\\d`, so that the first\r\n// group actually used in the pattern will be matched.\r\nexport const FIRST_GROUP_PATTERN = /(\\$\\d)/\r\n\r\nexport default function formatNationalNumberUsingFormat(\r\n\tnumber,\r\n\tformat,\r\n\t{\r\n\t\tuseInternationalFormat,\r\n\t\twithNationalPrefix,\r\n\t\tcarrierCode,\r\n\t\tmetadata\r\n\t}\r\n) {\r\n\tconst formattedNumber = number.replace(\r\n\t\tnew RegExp(format.pattern()),\r\n\t\tuseInternationalFormat\r\n\t\t\t? format.internationalFormat()\r\n\t\t\t: (\r\n\t\t\t\t// This library doesn't use `domestic_carrier_code_formatting_rule`,\r\n\t\t\t\t// because that one is only used when formatting phone numbers\r\n\t\t\t\t// for dialing from a mobile phone, and this is not a dialing library.\r\n\t\t\t\t// carrierCode && format.domesticCarrierCodeFormattingRule()\r\n\t\t\t\t// \t// First, replace the $CC in the formatting rule with the desired carrier code.\r\n\t\t\t\t// \t// Then, replace the $FG in the formatting rule with the first group\r\n\t\t\t\t// \t// and the carrier code combined in the appropriate way.\r\n\t\t\t\t// \t? format.format().replace(FIRST_GROUP_PATTERN, format.domesticCarrierCodeFormattingRule().replace('$CC', carrierCode))\r\n\t\t\t\t// \t: (\r\n\t\t\t\t// \t\twithNationalPrefix && format.nationalPrefixFormattingRule()\r\n\t\t\t\t// \t\t\t? format.format().replace(FIRST_GROUP_PATTERN, format.nationalPrefixFormattingRule())\r\n\t\t\t\t// \t\t\t: format.format()\r\n\t\t\t\t// \t)\r\n\t\t\t\twithNationalPrefix && format.nationalPrefixFormattingRule()\r\n\t\t\t\t\t? format.format().replace(FIRST_GROUP_PATTERN, format.nationalPrefixFormattingRule())\r\n\t\t\t\t\t: format.format()\r\n\t\t\t)\r\n\t)\r\n\tif (useInternationalFormat) {\r\n\t\treturn applyInternationalSeparatorStyle(formattedNumber)\r\n\t}\r\n\treturn formattedNumber\r\n}","import normalizeArguments from './normalizeArguments.js'\r\nimport parsePhoneNumber from './parsePhoneNumber_.js'\r\n\r\nexport default function isValidPhoneNumber() {\r\n\tlet { text, options, metadata } = normalizeArguments(arguments)\r\n\toptions = {\r\n\t\t...options,\r\n\t\textract: false\r\n\t}\r\n\tconst phoneNumber = parsePhoneNumber(text, options, metadata)\r\n\treturn phoneNumber && phoneNumber.isValid() || false\r\n}","import isObject from './helpers/isObject.js'\r\n\r\n// Extracts the following properties from function arguments:\r\n// * input `text`\r\n// * `options` object\r\n// * `metadata` JSON\r\nexport default function normalizeArguments(args) {\r\n\tconst [arg_1, arg_2, arg_3, arg_4] = Array.prototype.slice.call(args)\r\n\r\n\tlet text\r\n\tlet options\r\n\tlet metadata\r\n\r\n\t// If the phone number is passed as a string.\r\n\t// `parsePhoneNumber('88005553535', ...)`.\r\n\tif (typeof arg_1 === 'string') {\r\n\t\ttext = arg_1\r\n\t}\r\n\telse throw new TypeError('A text for parsing must be a string.')\r\n\r\n\t// If \"default country\" argument is being passed then move it to `options`.\r\n\t// `parsePhoneNumber('88005553535', 'RU', [options], metadata)`.\r\n\tif (!arg_2 || typeof arg_2 === 'string')\r\n\t{\r\n\t\tif (arg_4) {\r\n\t\t\toptions = arg_3\r\n\t\t\tmetadata = arg_4\r\n\t\t} else {\r\n\t\t\toptions = undefined\r\n\t\t\tmetadata = arg_3\r\n\t\t}\r\n\r\n\t\tif (arg_2) {\r\n\t\t\toptions = { defaultCountry: arg_2, ...options }\r\n\t\t}\r\n\t}\r\n\t// `defaultCountry` is not passed.\r\n\t// Example: `parsePhoneNumber('+78005553535', [options], metadata)`.\r\n\telse if (isObject(arg_2))\r\n\t{\r\n\t\tif (arg_3) {\r\n\t\t\toptions = arg_2\r\n\t\t\tmetadata = arg_3\r\n\t\t} else {\r\n\t\t\tmetadata = arg_2\r\n\t\t}\r\n\t}\r\n\telse throw new Error(`Invalid second argument: ${arg_2}`)\r\n\r\n\treturn {\r\n\t\ttext,\r\n\t\toptions,\r\n\t\tmetadata\r\n\t}\r\n}","// https://stackoverflow.com/a/46971044/970769\r\n// \"Breaking changes in Typescript 2.1\"\r\n// \"Extending built-ins like Error, Array, and Map may no longer work.\"\r\n// \"As a recommendation, you can manually adjust the prototype immediately after any super(...) calls.\"\r\n// https://github.com/Microsoft/TypeScript-wiki/blob/main/Breaking-Changes.md#extending-built-ins-like-error-array-and-map-may-no-longer-work\r\nexport default class ParseError extends Error {\r\n constructor(code) {\r\n super(code)\r\n // Set the prototype explicitly.\r\n // Any subclass of FooError will have to manually set the prototype as well.\r\n Object.setPrototypeOf(this, ParseError.prototype)\r\n this.name = this.constructor.name\r\n }\r\n}","/**\r\n * Checks whether the entire input sequence can be matched\r\n * against the regular expression.\r\n * @return {boolean}\r\n */\r\nexport default function matchesEntirely(text, regularExpressionText) {\r\n\t// If the assigning of the `''` default value is moved to the arguments above,\r\n\t// the code coverage would decrease for some weird reason.\r\n\ttext = text || ''\r\n\treturn new RegExp('^(?:' + regularExpressionText + ')$').test(text)\r\n}","/**\r\n * Strips any national prefix (such as 0, 1) present in a\r\n * (possibly incomplete) number provided.\r\n * \"Carrier codes\" are only used in Colombia and Brazil,\r\n * and only when dialing within those countries from a mobile phone to a fixed line number.\r\n * Sometimes it won't actually strip national prefix\r\n * and will instead prepend some digits to the `number`:\r\n * for example, when number `2345678` is passed with `VI` country selected,\r\n * it will return `{ number: \"3402345678\" }`, because `340` area code is prepended.\r\n * @param {string} number — National number digits.\r\n * @param {object} metadata — Metadata with country selected.\r\n * @return {object} `{ nationalNumber: string, nationalPrefix: string? carrierCode: string? }`. Even if a national prefix was extracted, it's not necessarily present in the returned object, so don't rely on its presence in the returned object in order to find out whether a national prefix has been extracted or not.\r\n */\r\nexport default function extractNationalNumberFromPossiblyIncompleteNumber(number, metadata) {\r\n\tif (number && metadata.numberingPlan.nationalPrefixForParsing()) {\r\n\t\t// See METADATA.md for the description of\r\n\t\t// `national_prefix_for_parsing` and `national_prefix_transform_rule`.\r\n\t\t// Attempt to parse the first digits as a national prefix.\r\n\t\tconst prefixPattern = new RegExp('^(?:' + metadata.numberingPlan.nationalPrefixForParsing() + ')')\r\n\t\tconst prefixMatch = prefixPattern.exec(number)\r\n\t\tif (prefixMatch) {\r\n\t\t\tlet nationalNumber\r\n\t\t\tlet carrierCode\r\n\t\t\t// https://gitlab.com/catamphetamine/libphonenumber-js/-/blob/master/METADATA.md#national_prefix_for_parsing--national_prefix_transform_rule\r\n\t\t\t// If a `national_prefix_for_parsing` has any \"capturing groups\"\r\n\t\t\t// then it means that the national (significant) number is equal to\r\n\t\t\t// those \"capturing groups\" transformed via `national_prefix_transform_rule`,\r\n\t\t\t// and nothing could be said about the actual national prefix:\r\n\t\t\t// what is it and was it even there.\r\n\t\t\t// If a `national_prefix_for_parsing` doesn't have any \"capturing groups\",\r\n\t\t\t// then everything it matches is a national prefix.\r\n\t\t\t// To determine whether `national_prefix_for_parsing` matched any\r\n\t\t\t// \"capturing groups\", the value of the result of calling `.exec()`\r\n\t\t\t// is looked at, and if it has non-undefined values where there're\r\n\t\t\t// \"capturing groups\" in the regular expression, then it means\r\n\t\t\t// that \"capturing groups\" have been matched.\r\n\t\t\t// It's not possible to tell whether there'll be any \"capturing gropus\"\r\n\t\t\t// before the matching process, because a `national_prefix_for_parsing`\r\n\t\t\t// could exhibit both behaviors.\r\n\t\t\tconst capturedGroupsCount = prefixMatch.length - 1\r\n\t\t\tconst hasCapturedGroups = capturedGroupsCount > 0 && prefixMatch[capturedGroupsCount]\r\n\t\t\tif (metadata.nationalPrefixTransformRule() && hasCapturedGroups) {\r\n\t\t\t\tnationalNumber = number.replace(\r\n\t\t\t\t\tprefixPattern,\r\n\t\t\t\t\tmetadata.nationalPrefixTransformRule()\r\n\t\t\t\t)\r\n\t\t\t\t// If there's more than one captured group,\r\n\t\t\t\t// then carrier code is the second one.\r\n\t\t\t\tif (capturedGroupsCount > 1) {\r\n\t\t\t\t\tcarrierCode = prefixMatch[1]\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\t// If there're no \"capturing groups\",\r\n\t\t\t// or if there're \"capturing groups\" but no\r\n\t\t\t// `national_prefix_transform_rule`,\r\n\t\t\t// then just strip the national prefix from the number,\r\n\t\t\t// and possibly a carrier code.\r\n\t\t\t// Seems like there could be more.\r\n\t\t\telse {\r\n\t\t\t\t// `prefixBeforeNationalNumber` is the whole substring matched by\r\n\t\t\t\t// the `national_prefix_for_parsing` regular expression.\r\n\t\t\t\t// There seem to be no guarantees that it's just a national prefix.\r\n\t\t\t\t// For example, if there's a carrier code, it's gonna be a\r\n\t\t\t\t// part of `prefixBeforeNationalNumber` too.\r\n\t\t\t\tconst prefixBeforeNationalNumber = prefixMatch[0]\r\n\t\t\t\tnationalNumber = number.slice(prefixBeforeNationalNumber.length)\r\n\t\t\t\t// If there's at least one captured group,\r\n\t\t\t\t// then carrier code is the first one.\r\n\t\t\t\tif (hasCapturedGroups) {\r\n\t\t\t\t\tcarrierCode = prefixMatch[1]\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\t// Tries to guess whether a national prefix was present in the input.\r\n\t\t\t// This is not something copy-pasted from Google's library:\r\n\t\t\t// they don't seem to have an equivalent for that.\r\n\t\t\t// So this isn't an \"officially approved\" way of doing something like that.\r\n\t\t\t// But since there seems no other existing method, this library uses it.\r\n\t\t\tlet nationalPrefix\r\n\t\t\tif (hasCapturedGroups) {\r\n\t\t\t\tconst possiblePositionOfTheFirstCapturedGroup = number.indexOf(prefixMatch[1])\r\n\t\t\t\tconst possibleNationalPrefix = number.slice(0, possiblePositionOfTheFirstCapturedGroup)\r\n\t\t\t\t// Example: an Argentinian (AR) phone number `0111523456789`.\r\n\t\t\t\t// `prefixMatch[0]` is `01115`, and `$1` is `11`,\r\n\t\t\t\t// and the rest of the phone number is `23456789`.\r\n\t\t\t\t// The national number is transformed via `9$1` to `91123456789`.\r\n\t\t\t\t// National prefix `0` is detected being present at the start.\r\n\t\t\t\t// if (possibleNationalPrefix.indexOf(metadata.numberingPlan.nationalPrefix()) === 0) {\r\n\t\t\t\tif (possibleNationalPrefix === metadata.numberingPlan.nationalPrefix()) {\r\n\t\t\t\t\tnationalPrefix = metadata.numberingPlan.nationalPrefix()\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\tnationalPrefix = prefixMatch[0]\r\n\t\t\t}\r\n\t\t\treturn {\r\n\t\t\t\tnationalNumber,\r\n\t\t\t\tnationalPrefix,\r\n\t\t\t\tcarrierCode\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n return {\r\n \tnationalNumber: number\r\n }\r\n}","import parse from './parse.js'\r\n\r\nexport default function parsePhoneNumberWithError(text, options, metadata) {\r\n\treturn parse(text, { ...options, v2: true }, metadata)\r\n}","// These mappings map a character (key) to a specific digit that should\r\n// replace it for normalization purposes. Non-European digits that\r\n// may be used in phone numbers are mapped to a European equivalent.\r\n//\r\n// E.g. in Iraq they don't write `+442323234` but rather `+٤٤٢٣٢٣٢٣٤`.\r\n//\r\nexport const DIGITS = {\r\n\t'0': '0',\r\n\t'1': '1',\r\n\t'2': '2',\r\n\t'3': '3',\r\n\t'4': '4',\r\n\t'5': '5',\r\n\t'6': '6',\r\n\t'7': '7',\r\n\t'8': '8',\r\n\t'9': '9',\r\n\t'\\uFF10': '0', // Fullwidth digit 0\r\n\t'\\uFF11': '1', // Fullwidth digit 1\r\n\t'\\uFF12': '2', // Fullwidth digit 2\r\n\t'\\uFF13': '3', // Fullwidth digit 3\r\n\t'\\uFF14': '4', // Fullwidth digit 4\r\n\t'\\uFF15': '5', // Fullwidth digit 5\r\n\t'\\uFF16': '6', // Fullwidth digit 6\r\n\t'\\uFF17': '7', // Fullwidth digit 7\r\n\t'\\uFF18': '8', // Fullwidth digit 8\r\n\t'\\uFF19': '9', // Fullwidth digit 9\r\n\t'\\u0660': '0', // Arabic-indic digit 0\r\n\t'\\u0661': '1', // Arabic-indic digit 1\r\n\t'\\u0662': '2', // Arabic-indic digit 2\r\n\t'\\u0663': '3', // Arabic-indic digit 3\r\n\t'\\u0664': '4', // Arabic-indic digit 4\r\n\t'\\u0665': '5', // Arabic-indic digit 5\r\n\t'\\u0666': '6', // Arabic-indic digit 6\r\n\t'\\u0667': '7', // Arabic-indic digit 7\r\n\t'\\u0668': '8', // Arabic-indic digit 8\r\n\t'\\u0669': '9', // Arabic-indic digit 9\r\n\t'\\u06F0': '0', // Eastern-Arabic digit 0\r\n\t'\\u06F1': '1', // Eastern-Arabic digit 1\r\n\t'\\u06F2': '2', // Eastern-Arabic digit 2\r\n\t'\\u06F3': '3', // Eastern-Arabic digit 3\r\n\t'\\u06F4': '4', // Eastern-Arabic digit 4\r\n\t'\\u06F5': '5', // Eastern-Arabic digit 5\r\n\t'\\u06F6': '6', // Eastern-Arabic digit 6\r\n\t'\\u06F7': '7', // Eastern-Arabic digit 7\r\n\t'\\u06F8': '8', // Eastern-Arabic digit 8\r\n\t'\\u06F9': '9' // Eastern-Arabic digit 9\r\n}\r\n\r\nexport function parseDigit(character) {\r\n\treturn DIGITS[character]\r\n}\r\n\r\n/**\r\n * Parses phone number digits from a string.\r\n * Drops all punctuation leaving only digits.\r\n * Also converts wide-ascii and arabic-indic numerals to conventional numerals.\r\n * E.g. in Iraq they don't write `+442323234` but rather `+٤٤٢٣٢٣٢٣٤`.\r\n * @param {string} string\r\n * @return {string}\r\n * @example\r\n * ```js\r\n * parseDigits('8 (800) 555')\r\n * // Outputs '8800555'.\r\n * ```\r\n */\r\nexport default function parseDigits(string) {\r\n\tlet result = ''\r\n\t// Using `.split('')` here instead of normal `for ... of`\r\n\t// because the importing application doesn't neccessarily include an ES6 polyfill.\r\n\t// The `.split('')` approach discards \"exotic\" UTF-8 characters\r\n\t// (the ones consisting of four bytes) but digits\r\n\t// (including non-European ones) don't fall into that range\r\n\t// so such \"exotic\" characters would be discarded anyway.\r\n\tfor (const character of string.split('')) {\r\n\t\tconst digit = parseDigit(character)\r\n\t\tif (digit) {\r\n\t\t\tresult += digit\r\n\t\t}\r\n\t}\r\n\treturn result\r\n}","import stripIddPrefix from './stripIddPrefix.js'\r\nimport extractCountryCallingCodeFromInternationalNumberWithoutPlusSign from './extractCountryCallingCodeFromInternationalNumberWithoutPlusSign.js'\r\nimport Metadata from '../metadata.js'\r\nimport { MAX_LENGTH_COUNTRY_CODE } from '../constants.js'\r\n\r\n/**\r\n * Converts a phone number digits (possibly with a `+`)\r\n * into a calling code and the rest phone number digits.\r\n * The \"rest phone number digits\" could include\r\n * a national prefix, carrier code, and national\r\n * (significant) number.\r\n * @param {string} number — Phone number digits (possibly with a `+`).\r\n * @param {string} [country] — Country.\r\n * @param {string} [defaultCountry] — Default country.\r\n * @param {string} [defaultCallingCode] — Default calling code (some phone numbering plans are non-geographic).\r\n * @param {object} metadata\r\n * @return {object} `{ countryCallingCodeSource: string?, countryCallingCode: string?, number: string }`\r\n * @example\r\n * // Returns `{ countryCallingCode: \"1\", number: \"2133734253\" }`.\r\n * extractCountryCallingCode('2133734253', null, 'US', null, metadata)\r\n * extractCountryCallingCode('2133734253', null, null, '1', metadata)\r\n * extractCountryCallingCode('+12133734253', null, null, null, metadata)\r\n * extractCountryCallingCode('+12133734253', null, 'RU', null, metadata)\r\n */\r\nexport default function extractCountryCallingCode(\r\n\tnumber,\r\n\tcountry,\r\n\tdefaultCountry,\r\n\tdefaultCallingCode,\r\n\tmetadata\r\n) {\r\n\tif (!number) {\r\n\t\treturn {}\r\n\t}\r\n\r\n\tlet isNumberWithIddPrefix\r\n\r\n\t// If this is not an international phone number,\r\n\t// then either extract an \"IDD\" prefix, or extract a\r\n\t// country calling code from a number by autocorrecting it\r\n\t// by prepending a leading `+` in cases when it starts\r\n\t// with the country calling code.\r\n\t// https://wikitravel.org/en/International_dialling_prefix\r\n\t// https://github.com/catamphetamine/libphonenumber-js/issues/376\r\n\tif (number[0] !== '+') {\r\n\t\t// Convert an \"out-of-country\" dialing phone number\r\n\t\t// to a proper international phone number.\r\n\t\tconst numberWithoutIDD = stripIddPrefix(number, country || defaultCountry, defaultCallingCode, metadata)\r\n\t\t// If an IDD prefix was stripped then\r\n\t\t// convert the number to international one\r\n\t\t// for subsequent parsing.\r\n\t\tif (numberWithoutIDD && numberWithoutIDD !== number) {\r\n\t\t\tisNumberWithIddPrefix = true\r\n\t\t\tnumber = '+' + numberWithoutIDD\r\n\t\t} else {\r\n\t\t\t// Check to see if the number starts with the country calling code\r\n\t\t\t// for the default country. If so, we remove the country calling code,\r\n\t\t\t// and do some checks on the validity of the number before and after.\r\n\t\t\t// https://github.com/catamphetamine/libphonenumber-js/issues/376\r\n\t\t\tif (country || defaultCountry || defaultCallingCode) {\r\n\t\t\t\tconst {\r\n\t\t\t\t\tcountryCallingCode,\r\n\t\t\t\t\tnumber: shorterNumber\r\n\t\t\t\t} = extractCountryCallingCodeFromInternationalNumberWithoutPlusSign(\r\n\t\t\t\t\tnumber,\r\n\t\t\t\t\tcountry,\r\n\t\t\t\t\tdefaultCountry,\r\n\t\t\t\t\tdefaultCallingCode,\r\n\t\t\t\t\tmetadata\r\n\t\t\t\t)\r\n\t\t\t\tif (countryCallingCode) {\r\n\t\t\t\t\treturn {\r\n\t\t\t\t\t\tcountryCallingCodeSource: 'FROM_NUMBER_WITHOUT_PLUS_SIGN',\r\n\t\t\t\t\t\tcountryCallingCode,\r\n\t\t\t\t\t\tnumber: shorterNumber\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\treturn {\r\n\t\t\t\t// No need to set it to `UNSPECIFIED`. It can be just `undefined`.\r\n\t\t\t\t// countryCallingCodeSource: 'UNSPECIFIED',\r\n\t\t\t\tnumber\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t// `number` can only be international at this point.\r\n\r\n\t// Fast abortion: country codes do not begin with a '0'\r\n\tif (number[1] === '0') {\r\n\t\treturn {}\r\n\t}\r\n\r\n\tmetadata = new Metadata(metadata)\r\n\r\n\t// The thing with country phone codes\r\n\t// is that they are orthogonal to each other\r\n\t// i.e. there's no such country phone code A\r\n\t// for which country phone code B exists\r\n\t// where B starts with A.\r\n\t// Therefore, while scanning digits,\r\n\t// if a valid country code is found,\r\n\t// that means that it is the country code.\r\n\t//\r\n\tlet i = 2\r\n\twhile (i - 1 <= MAX_LENGTH_COUNTRY_CODE && i <= number.length) {\r\n\t\tconst countryCallingCode = number.slice(1, i)\r\n\t\tif (metadata.hasCallingCode(countryCallingCode)) {\r\n\t\t\tmetadata.selectNumberingPlan(countryCallingCode)\r\n\t\t\treturn {\r\n\t\t\t\tcountryCallingCodeSource: isNumberWithIddPrefix ? 'FROM_NUMBER_WITH_IDD' : 'FROM_NUMBER_WITH_PLUS_SIGN',\r\n\t\t\t\tcountryCallingCode,\r\n\t\t\t\tnumber: number.slice(i)\r\n\t\t\t}\r\n\t\t}\r\n\t\ti++\r\n\t}\r\n\r\n\treturn {}\r\n}\r\n\r\n// The possible values for the returned `countryCallingCodeSource` are:\r\n//\r\n// Copy-pasted from:\r\n// https://github.com/google/libphonenumber/blob/master/resources/phonenumber.proto\r\n//\r\n// // The source from which the country_code is derived. This is not set in the\r\n// // general parsing method, but in the method that parses and keeps raw_input.\r\n// // New fields could be added upon request.\r\n// enum CountryCodeSource {\r\n// // Default value returned if this is not set, because the phone number was\r\n// // created using parse, not parseAndKeepRawInput. hasCountryCodeSource will\r\n// // return false if this is the case.\r\n// UNSPECIFIED = 0;\r\n//\r\n// // The country_code is derived based on a phone number with a leading \"+\",\r\n// // e.g. the French number \"+33 1 42 68 53 00\".\r\n// FROM_NUMBER_WITH_PLUS_SIGN = 1;\r\n//\r\n// // The country_code is derived based on a phone number with a leading IDD,\r\n// // e.g. the French number \"011 33 1 42 68 53 00\", as it is dialled from US.\r\n// FROM_NUMBER_WITH_IDD = 5;\r\n//\r\n// // The country_code is derived based on a phone number without a leading\r\n// // \"+\", e.g. the French number \"33 1 42 68 53 00\" when defaultCountry is\r\n// // supplied as France.\r\n// FROM_NUMBER_WITHOUT_PLUS_SIGN = 10;\r\n//\r\n// // The country_code is derived NOT based on the phone number itself, but\r\n// // from the defaultCountry parameter provided in the parsing function by the\r\n// // clients. This happens mostly for numbers written in the national format\r\n// // (without country code). For example, this would be set when parsing the\r\n// // French number \"01 42 68 53 00\", when defaultCountry is supplied as\r\n// // France.\r\n// FROM_DEFAULT_COUNTRY = 20;\r\n// }","import Metadata from '../metadata.js'\r\n\r\n/**\r\n * Returns a list of countries that the phone number could potentially belong to.\r\n * @param {string} callingCode — Calling code.\r\n * @param {string} nationalNumber — National (significant) number.\r\n * @param {object} metadata — Metadata.\r\n * @return {string[]} A list of possible countries.\r\n */\r\nexport default function getPossibleCountriesForNumber(callingCode, nationalNumber, metadata) {\r\n\tconst _metadata = new Metadata(metadata)\r\n\tlet possibleCountries = _metadata.getCountryCodesForCallingCode(callingCode)\r\n\tif (!possibleCountries) {\r\n\t\treturn []\r\n\t}\r\n\treturn possibleCountries.filter((country) => {\r\n\t\treturn couldNationalNumberBelongToCountry(nationalNumber, country, metadata)\r\n\t})\r\n}\r\n\r\nfunction couldNationalNumberBelongToCountry(nationalNumber, country, metadata) {\r\n\tconst _metadata = new Metadata(metadata)\r\n\t_metadata.selectNumberingPlan(country)\r\n\tif (_metadata.numberingPlan.possibleLengths().indexOf(nationalNumber.length) >= 0) {\r\n\t\treturn true\r\n\t}\r\n\treturn false\r\n}","import Metadata, { validateMetadata } from './metadata.js'\r\nimport isPossibleNumber from './isPossible.js'\r\nimport isValidNumber from './isValid.js'\r\nimport getNumberType from './helpers/getNumberType.js'\r\nimport getPossibleCountriesForNumber from './helpers/getPossibleCountriesForNumber.js'\r\nimport extractCountryCallingCode from './helpers/extractCountryCallingCode.js'\r\nimport isObject from './helpers/isObject.js'\r\nimport formatNumber from './format.js'\r\n\r\nconst USE_NON_GEOGRAPHIC_COUNTRY_CODE = false\r\n\r\nexport default class PhoneNumber {\r\n\t/**\r\n\t * @param {string} countryOrCountryCallingCode\r\n\t * @param {string} nationalNumber\r\n\t * @param {object} metadata — Metadata JSON\r\n\t * @return {PhoneNumber}\r\n\t */\r\n\tconstructor(countryOrCountryCallingCode, nationalNumber, metadata) {\r\n\t\t// Validate `countryOrCountryCallingCode` argument.\r\n\t\tif (!countryOrCountryCallingCode) {\r\n\t\t\tthrow new TypeError('First argument is required')\r\n\t\t}\r\n\t\tif (typeof countryOrCountryCallingCode !== 'string') {\r\n\t\t\tthrow new TypeError('First argument must be a string')\r\n\t\t}\r\n\r\n\t\t// In case of public API use: `constructor(number, metadata)`.\r\n\t\t// Transform the arguments from `constructor(number, metadata)` to\r\n\t\t// `constructor(countryOrCountryCallingCode, nationalNumber, metadata)`.\r\n\t\tif (countryOrCountryCallingCode[0] === '+' && !nationalNumber) {\r\n\t\t\tthrow new TypeError('`metadata` argument not passed')\r\n\t\t}\r\n\t\tif (isObject(nationalNumber) && isObject(nationalNumber.countries)) {\r\n\t\t\tmetadata = nationalNumber\r\n\t\t\tconst e164Number = countryOrCountryCallingCode\r\n\t\t\tif (!E164_NUMBER_REGEXP.test(e164Number)) {\r\n\t\t\t\tthrow new Error('Invalid `number` argument passed: must consist of a \"+\" followed by digits')\r\n\t\t\t}\r\n\t\t\tconst { countryCallingCode, number } = extractCountryCallingCode(e164Number, undefined, undefined, undefined, metadata)\r\n\t\t\tnationalNumber = number\r\n\t\t\tcountryOrCountryCallingCode = countryCallingCode\r\n\t\t\tif (!nationalNumber) {\r\n\t\t\t\tthrow new Error('Invalid `number` argument passed: too short')\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// Validate `nationalNumber` argument.\r\n\t\tif (!nationalNumber) {\r\n\t\t\tthrow new TypeError('`nationalNumber` argument is required')\r\n\t\t}\r\n\t\tif (typeof nationalNumber !== 'string') {\r\n\t\t\tthrow new TypeError('`nationalNumber` argument must be a string')\r\n\t\t}\r\n\r\n\t\t// Validate `metadata` argument.\r\n\t\tvalidateMetadata(metadata)\r\n\r\n\t\t// Initialize properties.\r\n\t\tconst { country, countryCallingCode } = getCountryAndCountryCallingCode(\r\n\t\t\tcountryOrCountryCallingCode,\r\n\t\t\tmetadata\r\n\t\t)\r\n\t\tthis.country = country\r\n\t\tthis.countryCallingCode = countryCallingCode\r\n\t\tthis.nationalNumber = nationalNumber\r\n\t\tthis.number = '+' + this.countryCallingCode + this.nationalNumber\r\n\t\t// Exclude `metadata` property output from `PhoneNumber.toString()`\r\n\t\t// so that it doesn't clutter the console output of Node.js.\r\n\t\t// Previously, when Node.js did `console.log(new PhoneNumber(...))`,\r\n\t\t// it would output the whole internal structure of the `metadata` object.\r\n\t\tthis.getMetadata = () => metadata\r\n\t}\r\n\r\n\tsetExt(ext) {\r\n\t\tthis.ext = ext\r\n\t}\r\n\r\n\tgetPossibleCountries() {\r\n\t\tif (this.country) {\r\n\t\t\treturn [this.country]\r\n\t\t}\r\n\t\treturn getPossibleCountriesForNumber(\r\n\t\t\tthis.countryCallingCode,\r\n\t\t\tthis.nationalNumber,\r\n\t\t\tthis.getMetadata()\r\n\t\t)\r\n\t}\r\n\r\n\tisPossible() {\r\n\t\treturn isPossibleNumber(this, { v2: true }, this.getMetadata())\r\n\t}\r\n\r\n\tisValid() {\r\n\t\treturn isValidNumber(this, { v2: true }, this.getMetadata())\r\n\t}\r\n\r\n\tisNonGeographic() {\r\n\t\tconst metadata = new Metadata(this.getMetadata())\r\n\t\treturn metadata.isNonGeographicCallingCode(this.countryCallingCode)\r\n\t}\r\n\r\n\tisEqual(phoneNumber) {\r\n\t\treturn this.number === phoneNumber.number && this.ext === phoneNumber.ext\r\n\t}\r\n\r\n\t// This function was originally meant to be an equivalent for `validatePhoneNumberLength()`,\r\n\t// but later it was found out that it doesn't include the possible `TOO_SHORT` result\r\n\t// returned from `parsePhoneNumberWithError()` in the original `validatePhoneNumberLength()`,\r\n\t// so eventually I simply commented out this method from the `PhoneNumber` class\r\n\t// and just left the `validatePhoneNumberLength()` function, even though that one would require\r\n\t// and additional step to also validate the actual country / calling code of the phone number.\r\n\t// validateLength() {\r\n\t// \tconst metadata = new Metadata(this.getMetadata())\r\n\t// \tmetadata.selectNumberingPlan(this.countryCallingCode)\r\n\t// \tconst result = checkNumberLength(this.nationalNumber, metadata)\r\n\t// \tif (result !== 'IS_POSSIBLE') {\r\n\t// \t\treturn result\r\n\t// \t}\r\n\t// }\r\n\r\n\tgetType() {\r\n\t\treturn getNumberType(this, { v2: true }, this.getMetadata())\r\n\t}\r\n\r\n\tformat(format, options) {\r\n\t\treturn formatNumber(\r\n\t\t\tthis,\r\n\t\t\tformat,\r\n\t\t\toptions ? { ...options, v2: true } : { v2: true },\r\n\t\t\tthis.getMetadata()\r\n\t\t)\r\n\t}\r\n\r\n\tformatNational(options) {\r\n\t\treturn this.format('NATIONAL', options)\r\n\t}\r\n\r\n\tformatInternational(options) {\r\n\t\treturn this.format('INTERNATIONAL', options)\r\n\t}\r\n\r\n\tgetURI(options) {\r\n\t\treturn this.format('RFC3966', options)\r\n\t}\r\n}\r\n\r\nconst isCountryCode = (value) => /^[A-Z]{2}$/.test(value)\r\n\r\nfunction getCountryAndCountryCallingCode(countryOrCountryCallingCode, metadataJson) {\r\n\tlet country\r\n\tlet countryCallingCode\r\n\r\n\tconst metadata = new Metadata(metadataJson)\r\n\t// If country code is passed then derive `countryCallingCode` from it.\r\n\t// Also store the country code as `.country`.\r\n\tif (isCountryCode(countryOrCountryCallingCode)) {\r\n\t\tcountry = countryOrCountryCallingCode\r\n\t\tmetadata.selectNumberingPlan(country)\r\n\t\tcountryCallingCode = metadata.countryCallingCode()\r\n\t} else {\r\n\t\tcountryCallingCode = countryOrCountryCallingCode\r\n\t\t/* istanbul ignore if */\r\n\t\tif (USE_NON_GEOGRAPHIC_COUNTRY_CODE) {\r\n\t\t\tif (metadata.isNonGeographicCallingCode(countryCallingCode)) {\r\n\t\t\t\tcountry = '001'\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\treturn {\r\n\t\tcountry,\r\n\t\tcountryCallingCode\r\n\t}\r\n}\r\n\r\nconst E164_NUMBER_REGEXP = /^\\+\\d+$/","import { VALID_DIGITS } from '../../constants.js'\r\n\r\n// The RFC 3966 format for extensions.\r\nconst RFC3966_EXTN_PREFIX = ';ext='\r\n\r\n/**\r\n * Helper method for constructing regular expressions for parsing. Creates\r\n * an expression that captures up to max_length digits.\r\n * @return {string} RegEx pattern to capture extension digits.\r\n */\r\nconst getExtensionDigitsPattern = (maxLength) => `([${VALID_DIGITS}]{1,${maxLength}})`\r\n\r\n/**\r\n * Helper initialiser method to create the regular-expression pattern to match\r\n * extensions.\r\n * Copy-pasted from Google's `libphonenumber`:\r\n * https://github.com/google/libphonenumber/blob/55b2646ec9393f4d3d6661b9c82ef9e258e8b829/javascript/i18n/phonenumbers/phonenumberutil.js#L759-L766\r\n * @return {string} RegEx pattern to capture extensions.\r\n */\r\nexport default function createExtensionPattern(purpose) {\r\n\t// We cap the maximum length of an extension based on the ambiguity of the way\r\n\t// the extension is prefixed. As per ITU, the officially allowed length for\r\n\t// extensions is actually 40, but we don't support this since we haven't seen real\r\n\t// examples and this introduces many false interpretations as the extension labels\r\n\t// are not standardized.\r\n\t/** @type {string} */\r\n\tvar extLimitAfterExplicitLabel = '20';\r\n\t/** @type {string} */\r\n\tvar extLimitAfterLikelyLabel = '15';\r\n\t/** @type {string} */\r\n\tvar extLimitAfterAmbiguousChar = '9';\r\n\t/** @type {string} */\r\n\tvar extLimitWhenNotSure = '6';\r\n\r\n\t/** @type {string} */\r\n\tvar possibleSeparatorsBetweenNumberAndExtLabel = \"[ \\u00A0\\\\t,]*\";\r\n\t// Optional full stop (.) or colon, followed by zero or more spaces/tabs/commas.\r\n\t/** @type {string} */\r\n\tvar possibleCharsAfterExtLabel = \"[:\\\\.\\uFF0E]?[ \\u00A0\\\\t,-]*\";\r\n\t/** @type {string} */\r\n\tvar optionalExtnSuffix = \"#?\";\r\n\r\n\t// Here the extension is called out in more explicit way, i.e mentioning it obvious\r\n\t// patterns like \"ext.\".\r\n\t/** @type {string} */\r\n\tvar explicitExtLabels =\r\n\t \"(?:e?xt(?:ensi(?:o\\u0301?|\\u00F3))?n?|\\uFF45?\\uFF58\\uFF54\\uFF4E?|\\u0434\\u043E\\u0431|anexo)\";\r\n\t// One-character symbols that can be used to indicate an extension, and less\r\n\t// commonly used or more ambiguous extension labels.\r\n\t/** @type {string} */\r\n\tvar ambiguousExtLabels = \"(?:[x\\uFF58#\\uFF03~\\uFF5E]|int|\\uFF49\\uFF4E\\uFF54)\";\r\n\t// When extension is not separated clearly.\r\n\t/** @type {string} */\r\n\tvar ambiguousSeparator = \"[- ]+\";\r\n\t// This is the same as possibleSeparatorsBetweenNumberAndExtLabel, but not matching\r\n\t// comma as extension label may have it.\r\n\t/** @type {string} */\r\n\tvar possibleSeparatorsNumberExtLabelNoComma = \"[ \\u00A0\\\\t]*\";\r\n\t// \",,\" is commonly used for auto dialling the extension when connected. First\r\n\t// comma is matched through possibleSeparatorsBetweenNumberAndExtLabel, so we do\r\n\t// not repeat it here. Semi-colon works in Iphone and Android also to pop up a\r\n\t// button with the extension number following.\r\n\t/** @type {string} */\r\n\tvar autoDiallingAndExtLabelsFound = \"(?:,{2}|;)\";\r\n\r\n\t/** @type {string} */\r\n\tvar rfcExtn = RFC3966_EXTN_PREFIX\r\n\t + getExtensionDigitsPattern(extLimitAfterExplicitLabel);\r\n\t/** @type {string} */\r\n\tvar explicitExtn = possibleSeparatorsBetweenNumberAndExtLabel + explicitExtLabels\r\n\t + possibleCharsAfterExtLabel\r\n\t + getExtensionDigitsPattern(extLimitAfterExplicitLabel)\r\n\t + optionalExtnSuffix;\r\n\t/** @type {string} */\r\n\tvar ambiguousExtn = possibleSeparatorsBetweenNumberAndExtLabel + ambiguousExtLabels\r\n\t + possibleCharsAfterExtLabel\r\n\t+ getExtensionDigitsPattern(extLimitAfterAmbiguousChar)\r\n\t+ optionalExtnSuffix;\r\n\t/** @type {string} */\r\n\tvar americanStyleExtnWithSuffix = ambiguousSeparator\r\n\t+ getExtensionDigitsPattern(extLimitWhenNotSure) + \"#\";\r\n\r\n\t/** @type {string} */\r\n\tvar autoDiallingExtn = possibleSeparatorsNumberExtLabelNoComma\r\n\t + autoDiallingAndExtLabelsFound + possibleCharsAfterExtLabel\r\n\t + getExtensionDigitsPattern(extLimitAfterLikelyLabel)\r\n\t+ optionalExtnSuffix;\r\n\t/** @type {string} */\r\n\tvar onlyCommasExtn = possibleSeparatorsNumberExtLabelNoComma\r\n\t + \"(?:,)+\" + possibleCharsAfterExtLabel\r\n\t + getExtensionDigitsPattern(extLimitAfterAmbiguousChar)\r\n\t + optionalExtnSuffix;\r\n\r\n\t// The first regular expression covers RFC 3966 format, where the extension is added\r\n\t// using \";ext=\". The second more generic where extension is mentioned with explicit\r\n\t// labels like \"ext:\". In both the above cases we allow more numbers in extension than\r\n\t// any other extension labels. The third one captures when single character extension\r\n\t// labels or less commonly used labels are used. In such cases we capture fewer\r\n\t// extension digits in order to reduce the chance of falsely interpreting two\r\n\t// numbers beside each other as a number + extension. The fourth one covers the\r\n\t// special case of American numbers where the extension is written with a hash\r\n\t// at the end, such as \"- 503#\". The fifth one is exclusively for extension\r\n\t// autodialling formats which are used when dialling and in this case we accept longer\r\n\t// extensions. The last one is more liberal on the number of commas that acts as\r\n\t// extension labels, so we have a strict cap on the number of digits in such extensions.\r\n\treturn rfcExtn + \"|\"\r\n\t + explicitExtn + \"|\"\r\n\t + ambiguousExtn + \"|\"\r\n\t + americanStyleExtnWithSuffix + \"|\"\r\n\t + autoDiallingExtn + \"|\"\r\n\t + onlyCommasExtn;\r\n}","import Metadata from '../metadata.js'\r\nimport { VALID_DIGITS } from '../constants.js'\r\n\r\nconst CAPTURING_DIGIT_PATTERN = new RegExp('([' + VALID_DIGITS + '])')\r\n\r\nexport default function stripIddPrefix(number, country, callingCode, metadata) {\r\n\tif (!country) {\r\n\t\treturn\r\n\t}\r\n\t// Check if the number is IDD-prefixed.\r\n\tconst countryMetadata = new Metadata(metadata)\r\n\tcountryMetadata.selectNumberingPlan(country, callingCode)\r\n\tconst IDDPrefixPattern = new RegExp(countryMetadata.IDDPrefix())\r\n\tif (number.search(IDDPrefixPattern) !== 0) {\r\n\t\treturn\r\n\t}\r\n\t// Strip IDD prefix.\r\n\tnumber = number.slice(number.match(IDDPrefixPattern)[0].length)\r\n\t// If there're any digits after an IDD prefix,\r\n\t// then those digits are a country calling code.\r\n\t// Since no country code starts with a `0`,\r\n\t// the code below validates that the next digit (if present) is not `0`.\r\n\tconst matchedGroups = number.match(CAPTURING_DIGIT_PATTERN)\r\n\tif (matchedGroups && matchedGroups[1] != null && matchedGroups[1].length > 0) {\r\n\t\tif (matchedGroups[1] === '0') {\r\n\t\t\treturn\r\n\t\t}\r\n\t}\r\n\treturn number\r\n}","import createExtensionPattern from './createExtensionPattern.js'\r\n\r\n// Regexp of all known extension prefixes used by different regions followed by\r\n// 1 or more valid digits, for use when parsing.\r\nconst EXTN_PATTERN = new RegExp('(?:' + createExtensionPattern() + ')$', 'i')\r\n\r\n// Strips any extension (as in, the part of the number dialled after the call is\r\n// connected, usually indicated with extn, ext, x or similar) from the end of\r\n// the number, and returns it.\r\nexport default function extractExtension(number) {\r\n\tconst start = number.search(EXTN_PATTERN)\r\n\tif (start < 0) {\r\n\t\treturn {}\r\n\t}\r\n\t// If we find a potential extension, and the number preceding this is a viable\r\n\t// number, we assume it is an extension.\r\n\tconst numberWithoutExtension = number.slice(0, start)\r\n\tconst matches = number.match(EXTN_PATTERN)\r\n\tlet i = 1\r\n\twhile (i < matches.length) {\r\n\t\tif (matches[i]) {\r\n\t\t\treturn {\r\n\t\t\t\tnumber: numberWithoutExtension,\r\n\t\t\t\text: matches[i]\r\n\t\t\t}\r\n\t\t}\r\n\t\ti++\r\n\t}\r\n}","// When phone numbers are written in `RFC3966` format — `\"tel:+12133734253\"` —\r\n// they can have their \"calling code\" part written separately in a `phone-context` parameter.\r\n// Example: `\"tel:12133734253;phone-context=+1\"`.\r\n// This function parses the full phone number from the local number and the `phone-context`\r\n// when the `phone-context` contains a `+` sign.\r\n\r\nimport {\r\n VALID_DIGITS,\r\n // PLUS_CHARS\r\n} from '../constants.js'\r\n\r\nexport const PLUS_SIGN = '+'\r\n\r\nconst RFC3966_VISUAL_SEPARATOR_ = '[\\\\-\\\\.\\\\(\\\\)]?'\r\n\r\nconst RFC3966_PHONE_DIGIT_ = '(' + '[' + VALID_DIGITS + ']' + '|' + RFC3966_VISUAL_SEPARATOR_ + ')'\r\n\r\nconst RFC3966_GLOBAL_NUMBER_DIGITS_ =\r\n\t'^' +\r\n\t'\\\\' +\r\n\tPLUS_SIGN +\r\n\tRFC3966_PHONE_DIGIT_ +\r\n\t'*' +\r\n\t'[' + VALID_DIGITS + ']' +\r\n\tRFC3966_PHONE_DIGIT_ +\r\n\t'*' +\r\n\t'$'\r\n\r\n/**\r\n * Regular expression of valid global-number-digits for the phone-context\r\n * parameter, following the syntax defined in RFC3966.\r\n */\r\nconst RFC3966_GLOBAL_NUMBER_DIGITS_PATTERN_ = new RegExp(RFC3966_GLOBAL_NUMBER_DIGITS_, 'g')\r\n\r\n// In this port of Google's library, we don't accept alpha characters in phone numbers.\r\n// const ALPHANUM_ = VALID_ALPHA_ + VALID_DIGITS\r\nconst ALPHANUM_ = VALID_DIGITS\r\n\r\nconst RFC3966_DOMAINLABEL_ = '[' + ALPHANUM_ + ']+((\\\\-)*[' + ALPHANUM_ + '])*'\r\n\r\nconst VALID_ALPHA_ = 'a-zA-Z'\r\nconst RFC3966_TOPLABEL_ = '[' + VALID_ALPHA_ + ']+((\\\\-)*[' + ALPHANUM_ + '])*'\r\n\r\nconst RFC3966_DOMAINNAME_ = '^(' + RFC3966_DOMAINLABEL_ + '\\\\.)*' + RFC3966_TOPLABEL_ + '\\\\.?$'\r\n\r\n/**\r\n * Regular expression of valid domainname for the phone-context parameter,\r\n * following the syntax defined in RFC3966.\r\n */\r\nconst RFC3966_DOMAINNAME_PATTERN_ = new RegExp(RFC3966_DOMAINNAME_, 'g')\r\n\r\nexport const RFC3966_PREFIX_ = 'tel:'\r\nexport const RFC3966_PHONE_CONTEXT_ = ';phone-context='\r\nexport const RFC3966_ISDN_SUBADDRESS_ = ';isub='\r\n\r\n/**\r\n * Extracts the value of the phone-context parameter of `numberToExtractFrom`,\r\n * following the syntax defined in RFC3966.\r\n *\r\n * @param {string} numberToExtractFrom\r\n * @return {string|null} the extracted string (possibly empty), or `null` if no phone-context parameter is found.\r\n */\r\nexport default function extractPhoneContext(numberToExtractFrom) {\r\n\tconst indexOfPhoneContext = numberToExtractFrom.indexOf(RFC3966_PHONE_CONTEXT_)\r\n\t// If no phone-context parameter is present\r\n\tif (indexOfPhoneContext < 0) {\r\n\t\treturn null\r\n\t}\r\n\r\n\tconst phoneContextStart = indexOfPhoneContext + RFC3966_PHONE_CONTEXT_.length\r\n\t// If phone-context parameter is empty\r\n\tif (phoneContextStart >= numberToExtractFrom.length) {\r\n\t\treturn ''\r\n\t}\r\n\r\n\tconst phoneContextEnd = numberToExtractFrom.indexOf(';', phoneContextStart)\r\n\t// If phone-context is not the last parameter\r\n\tif (phoneContextEnd >= 0) {\r\n\t\treturn numberToExtractFrom.substring(phoneContextStart, phoneContextEnd)\r\n\t} else {\r\n\t\treturn numberToExtractFrom.substring(phoneContextStart)\r\n\t}\r\n}\r\n\r\n/**\r\n * Returns whether the value of phoneContext follows the syntax defined in RFC3966.\r\n *\r\n * @param {string|null} phoneContext\r\n * @return {boolean}\r\n */\r\nexport function isPhoneContextValid(phoneContext) {\r\n\tif (phoneContext === null) {\r\n\t\treturn true\r\n\t}\r\n\r\n\tif (phoneContext.length === 0) {\r\n\t\treturn false\r\n\t}\r\n\r\n\t// Does phone-context value match pattern of global-number-digits or domainname.\r\n\treturn RFC3966_GLOBAL_NUMBER_DIGITS_PATTERN_.test(phoneContext) ||\r\n\t\tRFC3966_DOMAINNAME_PATTERN_.test(phoneContext)\r\n}","import extractPhoneContext, {\r\n\tisPhoneContextValid,\r\n\tPLUS_SIGN,\r\n\tRFC3966_PREFIX_,\r\n\tRFC3966_PHONE_CONTEXT_,\r\n\tRFC3966_ISDN_SUBADDRESS_\r\n} from './extractPhoneContext.js'\r\n\r\nimport ParseError from '../ParseError.js'\r\n\r\n/**\r\n * @param {string} numberToParse\r\n * @param {string} nationalNumber\r\n * @return {}\r\n */\r\nexport default function extractFormattedPhoneNumberFromPossibleRfc3966NumberUri(numberToParse, {\r\n\textractFormattedPhoneNumber\r\n}) {\r\n\tconst phoneContext = extractPhoneContext(numberToParse)\r\n\tif (!isPhoneContextValid(phoneContext)) {\r\n\t\tthrow new ParseError('NOT_A_NUMBER')\r\n\t}\r\n\r\n\tlet phoneNumberString\r\n\r\n\tif (phoneContext === null) {\r\n\t\t// Extract a possible number from the string passed in.\r\n\t\t// (this strips leading characters that could not be the start of a phone number)\r\n\t\tphoneNumberString = extractFormattedPhoneNumber(numberToParse) || ''\r\n\t} else {\r\n\t\tphoneNumberString = ''\r\n\r\n\t\t// If the phone context contains a phone number prefix, we need to capture\r\n\t\t// it, whereas domains will be ignored.\r\n\t\tif (phoneContext.charAt(0) === PLUS_SIGN) {\r\n\t\t\tphoneNumberString += phoneContext\r\n\t\t}\r\n\r\n\t\t// Now append everything between the \"tel:\" prefix and the phone-context.\r\n\t\t// This should include the national number, an optional extension or\r\n\t\t// isdn-subaddress component. Note we also handle the case when \"tel:\" is\r\n\t\t// missing, as we have seen in some of the phone number inputs.\r\n\t\t// In that case, we append everything from the beginning.\r\n\t\tconst indexOfRfc3966Prefix = numberToParse.indexOf(RFC3966_PREFIX_)\r\n\t\tlet indexOfNationalNumber\r\n\t\t// RFC 3966 \"tel:\" prefix is preset at this stage because\r\n\t\t// `isPhoneContextValid()` requires it to be present.\r\n\t\t/* istanbul ignore else */\r\n\t\tif (indexOfRfc3966Prefix >= 0) {\r\n\t\t\tindexOfNationalNumber = indexOfRfc3966Prefix + RFC3966_PREFIX_.length\r\n\t\t} else {\r\n\t\t\tindexOfNationalNumber = 0\r\n\t\t}\r\n\t\tconst indexOfPhoneContext = numberToParse.indexOf(RFC3966_PHONE_CONTEXT_)\r\n\t\tphoneNumberString += numberToParse.substring(indexOfNationalNumber, indexOfPhoneContext)\r\n\t}\r\n\r\n\t// Delete the isdn-subaddress and everything after it if it is present.\r\n\t// Note extension won't appear at the same time with isdn-subaddress\r\n\t// according to paragraph 5.3 of the RFC3966 spec.\r\n\tconst indexOfIsdn = phoneNumberString.indexOf(RFC3966_ISDN_SUBADDRESS_)\r\n\tif (indexOfIsdn > 0) {\r\n\t\tphoneNumberString = phoneNumberString.substring(0, indexOfIsdn)\r\n\t}\r\n\t// If both phone context and isdn-subaddress are absent but other\r\n\t// parameters are present, the parameters are left in nationalNumber.\r\n\t// This is because we are concerned about deleting content from a potential\r\n\t// number string when there is no strong evidence that the number is\r\n\t// actually written in RFC3966.\r\n\r\n\tif (phoneNumberString !== '') {\r\n\t\treturn phoneNumberString\r\n\t}\r\n}","// This is a port of Google Android `libphonenumber`'s\r\n// `phonenumberutil.js` of December 31th, 2018.\r\n//\r\n// https://github.com/googlei18n/libphonenumber/commits/master/javascript/i18n/phonenumbers/phonenumberutil.js\r\n\r\nimport {\r\n\tVALID_DIGITS,\r\n\tPLUS_CHARS,\r\n\tMIN_LENGTH_FOR_NSN,\r\n\tMAX_LENGTH_FOR_NSN\r\n} from './constants.js'\r\n\r\nimport ParseError from './ParseError.js'\r\nimport Metadata from './metadata.js'\r\nimport isViablePhoneNumber, { isViablePhoneNumberStart } from './helpers/isViablePhoneNumber.js'\r\nimport extractExtension from './helpers/extension/extractExtension.js'\r\nimport parseIncompletePhoneNumber from './parseIncompletePhoneNumber.js'\r\nimport getCountryCallingCode from './getCountryCallingCode.js'\r\nimport { isPossibleNumber } from './isPossible.js'\r\n// import { parseRFC3966 } from './helpers/RFC3966.js'\r\nimport PhoneNumber from './PhoneNumber.js'\r\nimport matchesEntirely from './helpers/matchesEntirely.js'\r\nimport extractCountryCallingCode from './helpers/extractCountryCallingCode.js'\r\nimport extractNationalNumber from './helpers/extractNationalNumber.js'\r\nimport stripIddPrefix from './helpers/stripIddPrefix.js'\r\nimport getCountryByCallingCode from './helpers/getCountryByCallingCode.js'\r\nimport extractFormattedPhoneNumberFromPossibleRfc3966NumberUri from './helpers/extractFormattedPhoneNumberFromPossibleRfc3966NumberUri.js'\r\n\r\n// We don't allow input strings for parsing to be longer than 250 chars.\r\n// This prevents malicious input from consuming CPU.\r\nconst MAX_INPUT_STRING_LENGTH = 250\r\n\r\n// This consists of the plus symbol, digits, and arabic-indic digits.\r\nconst PHONE_NUMBER_START_PATTERN = new RegExp('[' + PLUS_CHARS + VALID_DIGITS + ']')\r\n\r\n// Regular expression of trailing characters that we want to remove.\r\n// A trailing `#` is sometimes used when writing phone numbers with extensions in US.\r\n// Example: \"+1 (645) 123 1234-910#\" number has extension \"910\".\r\nconst AFTER_PHONE_NUMBER_END_PATTERN = new RegExp('[^' + VALID_DIGITS + '#' + ']+$')\r\n\r\nconst USE_NON_GEOGRAPHIC_COUNTRY_CODE = false\r\n\r\n// Examples:\r\n//\r\n// ```js\r\n// parse('8 (800) 555-35-35', 'RU')\r\n// parse('8 (800) 555-35-35', 'RU', metadata)\r\n// parse('8 (800) 555-35-35', { country: { default: 'RU' } })\r\n// parse('8 (800) 555-35-35', { country: { default: 'RU' } }, metadata)\r\n// parse('+7 800 555 35 35')\r\n// parse('+7 800 555 35 35', metadata)\r\n// ```\r\n//\r\n\r\n/**\r\n * Parses a phone number.\r\n *\r\n * parse('123456789', { defaultCountry: 'RU', v2: true }, metadata)\r\n * parse('123456789', { defaultCountry: 'RU' }, metadata)\r\n * parse('123456789', undefined, metadata)\r\n *\r\n * @param {string} input\r\n * @param {object} [options]\r\n * @param {object} metadata\r\n * @return {object|PhoneNumber?} If `options.v2: true` flag is passed, it returns a `PhoneNumber?` instance. Otherwise, returns an object of shape `{ phone: '...', country: '...' }` (or just `{}` if no phone number was parsed).\r\n */\r\nexport default function parse(text, options, metadata) {\r\n\t// If assigning the `{}` default value is moved to the arguments above,\r\n\t// code coverage would decrease for some weird reason.\r\n\toptions = options || {}\r\n\r\n\tmetadata = new Metadata(metadata)\r\n\r\n\t// Validate `defaultCountry`.\r\n\tif (options.defaultCountry && !metadata.hasCountry(options.defaultCountry)) {\r\n\t\tif (options.v2) {\r\n\t\t\tthrow new ParseError('INVALID_COUNTRY')\r\n\t\t}\r\n\t\tthrow new Error(`Unknown country: ${options.defaultCountry}`)\r\n\t}\r\n\r\n\t// Parse the phone number.\r\n\tconst { number: formattedPhoneNumber, ext, error } = parseInput(text, options.v2, options.extract)\r\n\r\n\t// If the phone number is not viable then return nothing.\r\n\tif (!formattedPhoneNumber) {\r\n\t\tif (options.v2) {\r\n\t\t\tif (error === 'TOO_SHORT') {\r\n\t\t\t\tthrow new ParseError('TOO_SHORT')\r\n\t\t\t}\r\n\t\t\tthrow new ParseError('NOT_A_NUMBER')\r\n\t\t}\r\n\t\treturn {}\r\n\t}\r\n\r\n\tconst {\r\n\t\tcountry,\r\n\t\tnationalNumber,\r\n\t\tcountryCallingCode,\r\n\t\tcountryCallingCodeSource,\r\n\t\tcarrierCode\r\n\t} = parsePhoneNumber(\r\n\t\tformattedPhoneNumber,\r\n\t\toptions.defaultCountry,\r\n\t\toptions.defaultCallingCode,\r\n\t\tmetadata\r\n\t)\r\n\r\n\tif (!metadata.hasSelectedNumberingPlan()) {\r\n\t\tif (options.v2) {\r\n\t\t\tthrow new ParseError('INVALID_COUNTRY')\r\n\t\t}\r\n\t\treturn {}\r\n\t}\r\n\r\n\t// Validate national (significant) number length.\r\n\tif (!nationalNumber || nationalNumber.length < MIN_LENGTH_FOR_NSN) {\r\n\t\t// Won't throw here because the regexp already demands length > 1.\r\n\t\t/* istanbul ignore if */\r\n\t\tif (options.v2) {\r\n\t\t\tthrow new ParseError('TOO_SHORT')\r\n\t\t}\r\n\t\t// Google's demo just throws an error in this case.\r\n\t\treturn {}\r\n\t}\r\n\r\n\t// Validate national (significant) number length.\r\n\t//\r\n\t// A sidenote:\r\n\t//\r\n\t// They say that sometimes national (significant) numbers\r\n\t// can be longer than `MAX_LENGTH_FOR_NSN` (e.g. in Germany).\r\n\t// https://github.com/googlei18n/libphonenumber/blob/7e1748645552da39c4e1ba731e47969d97bdb539/resources/phonenumber.proto#L36\r\n\t// Such numbers will just be discarded.\r\n\t//\r\n\tif (nationalNumber.length > MAX_LENGTH_FOR_NSN) {\r\n\t\tif (options.v2) {\r\n\t\t\tthrow new ParseError('TOO_LONG')\r\n\t\t}\r\n\t\t// Google's demo just throws an error in this case.\r\n\t\treturn {}\r\n\t}\r\n\r\n\tif (options.v2) {\r\n\t\tconst phoneNumber = new PhoneNumber(\r\n\t\t\tcountryCallingCode,\r\n\t\t\tnationalNumber,\r\n\t\t\tmetadata.metadata\r\n\t\t)\r\n\t\tif (country) {\r\n\t\t\tphoneNumber.country = country\r\n\t\t}\r\n\t\tif (carrierCode) {\r\n\t\t\tphoneNumber.carrierCode = carrierCode\r\n\t\t}\r\n\t\tif (ext) {\r\n\t\t\tphoneNumber.ext = ext\r\n\t\t}\r\n\t\tphoneNumber.__countryCallingCodeSource = countryCallingCodeSource\r\n\t\treturn phoneNumber\r\n\t}\r\n\r\n\t// Check if national phone number pattern matches the number.\r\n\t// National number pattern is different for each country,\r\n\t// even for those ones which are part of the \"NANPA\" group.\r\n\tconst valid = (options.extended ? metadata.hasSelectedNumberingPlan() : country) ?\r\n\t\tmatchesEntirely(nationalNumber, metadata.nationalNumberPattern()) :\r\n\t\tfalse\r\n\r\n\tif (!options.extended) {\r\n\t\treturn valid ? result(country, nationalNumber, ext) : {}\r\n\t}\r\n\r\n\t// isInternational: countryCallingCode !== undefined\r\n\r\n\treturn {\r\n\t\tcountry,\r\n\t\tcountryCallingCode,\r\n\t\tcarrierCode,\r\n\t\tvalid,\r\n\t\tpossible: valid ? true : (\r\n\t\t\toptions.extended === true &&\r\n\t\t\tmetadata.possibleLengths() &&\r\n\t\t\tisPossibleNumber(nationalNumber, country, metadata) ? true : false\r\n\t\t),\r\n\t\tphone: nationalNumber,\r\n\t\text\r\n\t}\r\n}\r\n\r\n/**\r\n * Extracts a formatted phone number from text.\r\n * Doesn't guarantee that the extracted phone number\r\n * is a valid phone number (for example, doesn't validate its length).\r\n * @param {string} text\r\n * @param {boolean} [extract] — If `false`, then will parse the entire `text` as a phone number.\r\n * @param {boolean} [throwOnError] — By default, it won't throw if the text is too long.\r\n * @return {string}\r\n * @example\r\n * // Returns \"(213) 373-4253\".\r\n * extractFormattedPhoneNumber(\"Call (213) 373-4253 for assistance.\")\r\n */\r\nfunction extractFormattedPhoneNumber(text, extract, throwOnError) {\r\n\tif (!text) {\r\n\t\treturn\r\n\t}\r\n\tif (text.length > MAX_INPUT_STRING_LENGTH) {\r\n\t\tif (throwOnError) {\r\n\t\t\tthrow new ParseError('TOO_LONG')\r\n\t\t}\r\n\t\treturn\r\n\t}\r\n\tif (extract === false) {\r\n\t\treturn text\r\n\t}\r\n\t// Attempt to extract a possible number from the string passed in\r\n\tconst startsAt = text.search(PHONE_NUMBER_START_PATTERN)\r\n\tif (startsAt < 0) {\r\n\t\treturn\r\n\t}\r\n\treturn text\r\n\t\t// Trim everything to the left of the phone number\r\n\t\t.slice(startsAt)\r\n\t\t// Remove trailing non-numerical characters\r\n\t\t.replace(AFTER_PHONE_NUMBER_END_PATTERN, '')\r\n}\r\n\r\n/**\r\n * @param {string} text - Input.\r\n * @param {boolean} v2 - Legacy API functions don't pass `v2: true` flag.\r\n * @param {boolean} [extract] - Whether to extract a phone number from `text`, or attempt to parse the entire text as a phone number.\r\n * @return {object} `{ ?number, ?ext }`.\r\n */\r\nfunction parseInput(text, v2, extract) {\r\n\t// // Parse RFC 3966 phone number URI.\r\n\t// if (text && text.indexOf('tel:') === 0) {\r\n\t// \treturn parseRFC3966(text)\r\n\t// }\r\n\t// let number = extractFormattedPhoneNumber(text, extract, v2)\r\n\tlet number = extractFormattedPhoneNumberFromPossibleRfc3966NumberUri(text, {\r\n\t\textractFormattedPhoneNumber: (text) => extractFormattedPhoneNumber(text, extract, v2)\r\n\t})\r\n\t// If the phone number is not viable, then abort.\r\n\tif (!number) {\r\n\t\treturn {}\r\n\t}\r\n\tif (!isViablePhoneNumber(number)) {\r\n\t\tif (isViablePhoneNumberStart(number)) {\r\n\t\t\treturn { error: 'TOO_SHORT' }\r\n\t\t}\r\n\t\treturn {}\r\n\t}\r\n\t// Attempt to parse extension first, since it doesn't require region-specific\r\n\t// data and we want to have the non-normalised number here.\r\n\tconst withExtensionStripped = extractExtension(number)\r\n\tif (withExtensionStripped.ext) {\r\n\t\treturn withExtensionStripped\r\n\t}\r\n\treturn { number }\r\n}\r\n\r\n/**\r\n * Creates `parse()` result object.\r\n */\r\nfunction result(country, nationalNumber, ext) {\r\n\tconst result = {\r\n\t\tcountry,\r\n\t\tphone: nationalNumber\r\n\t}\r\n\tif (ext) {\r\n\t\tresult.ext = ext\r\n\t}\r\n\treturn result\r\n}\r\n\r\n/**\r\n * Parses a viable phone number.\r\n * @param {string} formattedPhoneNumber — Example: \"(213) 373-4253\".\r\n * @param {string} [defaultCountry]\r\n * @param {string} [defaultCallingCode]\r\n * @param {Metadata} metadata\r\n * @return {object} Returns `{ country: string?, countryCallingCode: string?, nationalNumber: string? }`.\r\n */\r\nfunction parsePhoneNumber(\r\n\tformattedPhoneNumber,\r\n\tdefaultCountry,\r\n\tdefaultCallingCode,\r\n\tmetadata\r\n) {\r\n\t// Extract calling code from phone number.\r\n\tlet { countryCallingCodeSource, countryCallingCode, number } = extractCountryCallingCode(\r\n\t\tparseIncompletePhoneNumber(formattedPhoneNumber),\r\n\t\tundefined,\r\n\t\tdefaultCountry,\r\n\t\tdefaultCallingCode,\r\n\t\tmetadata.metadata\r\n\t)\r\n\r\n\t// The exact country of the phone number\r\n\tlet country\r\n\r\n\t// If `formattedPhoneNumber` is passed in \"international\" format,\r\n\t// choose a country by `countryCallingCode`.\r\n\tif (countryCallingCode) {\r\n\t\tmetadata.selectNumberingPlan(countryCallingCode)\r\n\t}\r\n\t// Else, if `formattedPhoneNumber` is passed in \"national\" format,\r\n\t// then `number` is defined and `countryCallingCode` is `undefined`.\r\n\telse if (number && (defaultCountry || defaultCallingCode)) {\r\n\t\tmetadata.selectNumberingPlan(defaultCountry, defaultCallingCode)\r\n\t\tif (defaultCountry) {\r\n\t\t\tcountry = defaultCountry\r\n\t\t} else {\r\n\t\t\t/* istanbul ignore if */\r\n\t\t\tif (USE_NON_GEOGRAPHIC_COUNTRY_CODE) {\r\n\t\t\t\tif (metadata.isNonGeographicCallingCode(defaultCallingCode)) {\r\n\t\t\t\t\tcountry = '001'\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t\tcountryCallingCode = defaultCallingCode || getCountryCallingCode(defaultCountry, metadata.metadata)\r\n\t}\r\n\telse return {}\r\n\r\n\tif (!number) {\r\n\t\treturn {\r\n\t\t\tcountryCallingCodeSource,\r\n\t\t\tcountryCallingCode\r\n\t\t}\r\n\t}\r\n\r\n\tconst {\r\n\t\tnationalNumber,\r\n\t\tcarrierCode\r\n\t} = extractNationalNumber(\r\n\t\tparseIncompletePhoneNumber(number),\r\n\t\tcountry,\r\n\t\tmetadata\r\n\t)\r\n\r\n\t// Sometimes there are several countries\r\n\t// corresponding to the same country phone code\r\n\t// (e.g. NANPA countries all having `1` country phone code).\r\n\t// Therefore, to reliably determine the exact country,\r\n\t// national (significant) number should have been parsed first.\r\n\t//\r\n\t// When `metadata.json` is generated, all \"ambiguous\" country phone codes\r\n\t// get their countries populated with the full set of\r\n\t// \"phone number type\" regular expressions.\r\n\t//\r\n\tconst exactCountry = getCountryByCallingCode(countryCallingCode, {\r\n\t\tnationalNumber,\r\n\t\tmetadata\r\n\t})\r\n\tif (exactCountry) {\r\n\t\tcountry = exactCountry\r\n\t\t/* istanbul ignore if */\r\n\t\tif (exactCountry === '001') {\r\n\t\t\t// Can't happen with `USE_NON_GEOGRAPHIC_COUNTRY_CODE` being `false`.\r\n\t\t\t// If `USE_NON_GEOGRAPHIC_COUNTRY_CODE` is set to `true` for some reason,\r\n\t\t\t// then remove the \"istanbul ignore if\".\r\n\t\t} else {\r\n\t\t\tmetadata.selectNumberingPlan(country)\r\n\t\t}\r\n\t}\r\n\r\n\treturn {\r\n\t\tcountry,\r\n\t\tcountryCallingCode,\r\n\t\tcountryCallingCodeSource,\r\n\t\tnationalNumber,\r\n\t\tcarrierCode\r\n\t}\r\n}","import Metadata from '../metadata.js'\r\nimport mergeArrays from './mergeArrays.js'\r\n\r\nexport default function checkNumberLength(nationalNumber, country, metadata) {\r\n\treturn checkNumberLengthForType(nationalNumber, country, undefined, metadata)\r\n}\r\n\r\n// Checks whether a number is possible for a certain `country` based on the number length.\r\n//\r\n// This function is not supported by metadata generated with ancient versions of\r\n// `libphonenumber-js` (before version `1.0.18`) which didn't include \"possible lengths\".\r\n//\r\n// There was also a known issue with `checkNumberLength()` function:\r\n// if a number is possible only in a certain `country` among several `countries`\r\n// that share the same \"country calling code\", that function would check\r\n// the possibility of the phone number only in the \"main\" `country` for the \"country calling code\"\r\n// and would not check if it's actually be possible in the speciifc `country`.\r\n//\r\n// For example, \"+1310xxxx\" numbers are valid in Canada.\r\n// However, they are not possible in the US due to being too short.\r\n// Since Canada and the US share the same country calling code — \"+1\" —\r\n// `checkNumberLength()` function used to return not \"IS_POSSIBLE\" for \"+1310xxxx\" numbers.\r\n//\r\n// In such cases, when using \"/max\" metadata, `isValid()` could output `true`\r\n// but at the same time `isPossible()` could output `false`, which was contradictory.\r\n//\r\n// See https://issuetracker.google.com/issues/335892662 for the discusson in Google's issues.\r\n//\r\n// The solution suggested by Google was implemented: an optional `country` argument\r\n// was added to `checkNumberLength()` function. If present, that `country` will be used\r\n// to check phone number length for that specific `country` rather than the \"main\" country\r\n// for the shared \"country calling code\".\r\n//\r\nexport function checkNumberLengthForType(nationalNumber, country, type, metadata) {\r\n\t// If the exact `country` is specified, it's no necessarily already selected in `metadata`.\r\n\t// Most likely, in cases when there're multiple countries corresponding to the same\r\n\t// \"country calling code\", the \"main\" country for that \"country calling code\" will be selected.\r\n\tif (country) {\r\n\t\tmetadata = new Metadata(metadata.metadata)\r\n\t\tmetadata.selectNumberingPlan(country)\r\n\t}\r\n\r\n\tconst type_info = metadata.type(type)\r\n\r\n\t// There should always be \"<possiblePengths/>\" set for every type element.\r\n\t// This is declared in the XML schema.\r\n\t// For size efficiency, where a sub-description (e.g. fixed-line)\r\n\t// has the same \"<possiblePengths/>\" as the \"general description\", this is missing,\r\n\t// so we fall back to the \"general description\". Where no numbers of the type\r\n\t// exist at all, there is one possible length (-1) which is guaranteed\r\n\t// not to match the length of any real phone number.\r\n\tlet possible_lengths = type_info && type_info.possibleLengths() || metadata.possibleLengths()\r\n\t// let local_lengths = type_info && type.possibleLengthsLocal() || metadata.possibleLengthsLocal()\r\n\r\n\t// Metadata before version `1.0.18` didn't contain `possible_lengths`.\r\n\tif (!possible_lengths) {\r\n\t\treturn 'IS_POSSIBLE'\r\n\t}\r\n\r\n\tif (type === 'FIXED_LINE_OR_MOBILE') {\r\n\t\t// No such country in metadata.\r\n\t\t/* istanbul ignore next */\r\n\t\tif (!metadata.type('FIXED_LINE')) {\r\n\t\t\t// The rare case has been encountered where no fixedLine data is available\r\n\t\t\t// (true for some non-geographic entities), so we just check mobile.\r\n\t\t\treturn checkNumberLengthForType(nationalNumber, country, 'MOBILE', metadata)\r\n\t\t}\r\n\r\n\t\tconst mobile_type = metadata.type('MOBILE')\r\n\t\tif (mobile_type) {\r\n\t\t\t// Merge the mobile data in if there was any. \"Concat\" creates a new\r\n\t\t\t// array, it doesn't edit possible_lengths in place, so we don't need a copy.\r\n\t\t\t// Note that when adding the possible lengths from mobile, we have\r\n\t\t\t// to again check they aren't empty since if they are this indicates\r\n\t\t\t// they are the same as the general desc and should be obtained from there.\r\n\t\t\tpossible_lengths = mergeArrays(possible_lengths, mobile_type.possibleLengths())\r\n\t\t\t// The current list is sorted; we need to merge in the new list and\r\n\t\t\t// re-sort (duplicates are okay). Sorting isn't so expensive because\r\n\t\t\t// the lists are very small.\r\n\r\n\t\t\t// if (local_lengths) {\r\n\t\t\t// \tlocal_lengths = mergeArrays(local_lengths, mobile_type.possibleLengthsLocal())\r\n\t\t\t// } else {\r\n\t\t\t// \tlocal_lengths = mobile_type.possibleLengthsLocal()\r\n\t\t\t// }\r\n\t\t}\r\n\t}\r\n\t// If the type doesn't exist then return 'INVALID_LENGTH'.\r\n\telse if (type && !type_info) {\r\n\t\treturn 'INVALID_LENGTH'\r\n\t}\r\n\r\n\tconst actual_length = nationalNumber.length\r\n\r\n\t// In `libphonenumber-js` all \"local-only\" formats are dropped for simplicity.\r\n\t// // This is safe because there is never an overlap beween the possible lengths\r\n\t// // and the local-only lengths; this is checked at build time.\r\n\t// if (local_lengths && local_lengths.indexOf(nationalNumber.length) >= 0)\r\n\t// {\r\n\t// \treturn 'IS_POSSIBLE_LOCAL_ONLY'\r\n\t// }\r\n\r\n\tconst minimum_length = possible_lengths[0]\r\n\r\n\tif (minimum_length === actual_length) {\r\n\t\treturn 'IS_POSSIBLE'\r\n\t}\r\n\r\n\tif (minimum_length > actual_length) {\r\n\t\treturn 'TOO_SHORT'\r\n\t}\r\n\r\n\tif (possible_lengths[possible_lengths.length - 1] < actual_length) {\r\n\t\treturn 'TOO_LONG'\r\n\t}\r\n\r\n\t// We skip the first element since we've already checked it.\r\n\treturn possible_lengths.indexOf(actual_length, 1) >= 0 ? 'IS_POSSIBLE' : 'INVALID_LENGTH'\r\n}","/**\r\n * Merges two arrays.\r\n * @param {*} a\r\n * @param {*} b\r\n * @return {*}\r\n */\r\nexport default function mergeArrays(a, b) {\r\n\tconst merged = a.slice()\r\n\r\n\tfor (const element of b) {\r\n\t\tif (a.indexOf(element) < 0) {\r\n\t\t\tmerged.push(element)\r\n\t\t}\r\n\t}\r\n\r\n\treturn merged.sort((a, b) => a - b)\r\n\r\n\t// ES6 version, requires Set polyfill.\r\n\t// let merged = new Set(a)\r\n\t// for (const element of b) {\r\n\t// \tmerged.add(i)\r\n\t// }\r\n\t// return Array.from(merged).sort((a, b) => a - b)\r\n}","import Metadata from '../metadata.js'\r\nimport matchesEntirely from './matchesEntirely.js'\r\nimport extractNationalNumber from './extractNationalNumber.js'\r\nimport checkNumberLength from './checkNumberLength.js'\r\nimport getCountryCallingCode from '../getCountryCallingCode.js'\r\n\r\n/**\r\n * Sometimes some people incorrectly input international phone numbers\r\n * without the leading `+`. This function corrects such input.\r\n * @param {string} number — Phone number digits.\r\n * @param {string} [country] — Exact country of the phone number.\r\n * @param {string} [defaultCountry]\r\n * @param {string} [defaultCallingCode]\r\n * @param {object} metadata\r\n * @return {object} `{ countryCallingCode: string?, number: string }`.\r\n */\r\nexport default function extractCountryCallingCodeFromInternationalNumberWithoutPlusSign(\r\n\tnumber,\r\n\tcountry,\r\n\tdefaultCountry,\r\n\tdefaultCallingCode,\r\n\tmetadata\r\n) {\r\n\tconst countryCallingCode = country || defaultCountry\r\n\t\t? getCountryCallingCode(country || defaultCountry, metadata)\r\n\t\t: defaultCallingCode\r\n\r\n\tif (number.indexOf(countryCallingCode) === 0) {\r\n\t\tmetadata = new Metadata(metadata)\r\n\t\tmetadata.selectNumberingPlan(country || defaultCountry, countryCallingCode)\r\n\r\n\t\tconst possibleShorterNumber = number.slice(countryCallingCode.length)\r\n\r\n\t\tconst {\r\n\t\t\tnationalNumber: possibleShorterNationalNumber,\r\n\t\t} = extractNationalNumber(\r\n\t\t\tpossibleShorterNumber,\r\n\t\t\tcountry,\r\n\t\t\tmetadata\r\n\t\t)\r\n\r\n\t\tconst {\r\n\t\t\tnationalNumber\r\n\t\t} = extractNationalNumber(\r\n\t\t\tnumber,\r\n\t\t\tcountry,\r\n\t\t\tmetadata\r\n\t\t)\r\n\r\n\t\t// If the number was not valid before but is valid now,\r\n\t\t// or if it was too long before, we consider the number\r\n\t\t// with the country calling code stripped to be a better result\r\n\t\t// and keep that instead.\r\n\t\t// For example, in Germany (+49), `49` is a valid area code,\r\n\t\t// so if a number starts with `49`, it could be both a valid\r\n\t\t// national German number or an international number without\r\n\t\t// a leading `+`.\r\n\t\tif (\r\n\t\t\t(\r\n\t\t\t\t!matchesEntirely(nationalNumber, metadata.nationalNumberPattern()) &&\r\n\t\t\t\tmatchesEntirely(possibleShorterNationalNumber, metadata.nationalNumberPattern())\r\n\t\t\t)\r\n\t\t\t||\r\n\t\t\tcheckNumberLength(nationalNumber, country, metadata) === 'TOO_LONG'\r\n\t\t) {\r\n\t\t\treturn {\r\n\t\t\t\tcountryCallingCode,\r\n\t\t\t\tnumber: possibleShorterNumber\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\treturn { number }\r\n}","import Metadata from '../metadata.js'\r\n\r\n/**\r\n * Pattern that makes it easy to distinguish whether a region has a single\r\n * international dialing prefix or not. If a region has a single international\r\n * prefix (e.g. 011 in USA), it will be represented as a string that contains\r\n * a sequence of ASCII digits, and possibly a tilde, which signals waiting for\r\n * the tone. If there are multiple available international prefixes in a\r\n * region, they will be represented as a regex string that always contains one\r\n * or more characters that are not ASCII digits or a tilde.\r\n */\r\nconst SINGLE_IDD_PREFIX_REG_EXP = /^[\\d]+(?:[~\\u2053\\u223C\\uFF5E][\\d]+)?$/\r\n\r\n// For regions that have multiple IDD prefixes\r\n// a preferred IDD prefix is returned.\r\nexport default function getIddPrefix(country, callingCode, metadata) {\r\n\tconst countryMetadata = new Metadata(metadata)\r\n\tcountryMetadata.selectNumberingPlan(country, callingCode)\r\n\tif (countryMetadata.defaultIDDPrefix()) {\r\n\t\treturn countryMetadata.defaultIDDPrefix()\r\n\t}\r\n\tif (SINGLE_IDD_PREFIX_REG_EXP.test(countryMetadata.IDDPrefix())) {\r\n\t\treturn countryMetadata.IDDPrefix()\r\n\t}\r\n}\r\n","// This is a port of Google Android `libphonenumber`'s\r\n// `phonenumberutil.js` of December 31th, 2018.\r\n//\r\n// https://github.com/googlei18n/libphonenumber/commits/master/javascript/i18n/phonenumbers/phonenumberutil.js\r\n\r\nimport matchesEntirely from './helpers/matchesEntirely.js'\r\nimport formatNationalNumberUsingFormat from './helpers/formatNationalNumberUsingFormat.js'\r\nimport Metadata, { getCountryCallingCode } from './metadata.js'\r\nimport getIddPrefix from './helpers/getIddPrefix.js'\r\nimport { formatRFC3966 } from './helpers/RFC3966.js'\r\n\r\nconst DEFAULT_OPTIONS = {\r\n\tformatExtension: (formattedNumber, extension, metadata) => `${formattedNumber}${metadata.ext()}${extension}`\r\n}\r\n\r\n/**\r\n * Formats a phone number.\r\n *\r\n * format(phoneNumberInstance, 'INTERNATIONAL', { ..., v2: true }, metadata)\r\n * format(phoneNumberInstance, 'NATIONAL', { ..., v2: true }, metadata)\r\n *\r\n * format({ phone: '8005553535', country: 'RU' }, 'INTERNATIONAL', { ... }, metadata)\r\n * format({ phone: '8005553535', country: 'RU' }, 'NATIONAL', undefined, metadata)\r\n *\r\n * @param {object|PhoneNumber} input — If `options.v2: true` flag is passed, the `input` should be a `PhoneNumber` instance. Otherwise, it should be an object of shape `{ phone: '...', country: '...' }`.\r\n * @param {string} format\r\n * @param {object} [options]\r\n * @param {object} metadata\r\n * @return {string}\r\n */\r\nexport default function formatNumber(input, format, options, metadata) {\r\n\t// Apply default options.\r\n\tif (options) {\r\n\t\t// Using ES6 \"rest spread\" syntax here didn't work with `babel`/`istanbul`\r\n\t\t// for some weird reason: this line of code would cause the code coverage\r\n\t\t// to show as not 100%. That's because `babel`/`istanbul`, for some weird reason,\r\n\t\t// apparently doesn't know how to properly exclude Babel polyfills from code coverage.\r\n\t\t//\r\n\t\t// options = { ...DEFAULT_OPTIONS, ...options }\r\n\t\t//\r\n\t\toptions = merge({}, DEFAULT_OPTIONS, options)\r\n\t} else {\r\n\t\toptions = DEFAULT_OPTIONS\r\n\t}\r\n\r\n\tmetadata = new Metadata(metadata)\r\n\r\n\tif (input.country && input.country !== '001') {\r\n\t\t// Validate `input.country`.\r\n\t\tif (!metadata.hasCountry(input.country)) {\r\n\t\t\tthrow new Error(`Unknown country: ${input.country}`)\r\n\t\t}\r\n\t\tmetadata.selectNumberingPlan(input.country)\r\n\t}\r\n\telse if (input.countryCallingCode) {\r\n\t\tmetadata.selectNumberingPlan(input.countryCallingCode)\r\n\t}\r\n\telse return input.phone || ''\r\n\r\n\tconst countryCallingCode = metadata.countryCallingCode()\r\n\r\n\tconst nationalNumber = options.v2 ? input.nationalNumber : input.phone\r\n\r\n\t// This variable should have been declared inside `case`s\r\n\t// but Babel has a bug and it says \"duplicate variable declaration\".\r\n\tlet number\r\n\r\n\tswitch (format) {\r\n\t\tcase 'NATIONAL':\r\n\t\t\t// Legacy argument support.\r\n\t\t\t// (`{ country: ..., phone: '' }`)\r\n\t\t\tif (!nationalNumber) {\r\n\t\t\t\treturn ''\r\n\t\t\t}\r\n\t\t\tnumber = formatNationalNumber(nationalNumber, input.carrierCode, 'NATIONAL', metadata, options)\r\n\t\t\treturn addExtension(number, input.ext, metadata, options.formatExtension)\r\n\r\n\t\tcase 'INTERNATIONAL':\r\n\t\t\t// Legacy argument support.\r\n\t\t\t// (`{ country: ..., phone: '' }`)\r\n\t\t\tif (!nationalNumber) {\r\n\t\t\t\treturn `+${countryCallingCode}`\r\n\t\t\t}\r\n\t\t\tnumber = formatNationalNumber(nationalNumber, null, 'INTERNATIONAL', metadata, options)\r\n\t\t\tnumber = `+${countryCallingCode} ${number}`\r\n\t\t\treturn addExtension(number, input.ext, metadata, options.formatExtension)\r\n\r\n\t\tcase 'E.164':\r\n\t\t\t// `E.164` doesn't define \"phone number extensions\".\r\n\t\t\treturn `+${countryCallingCode}${nationalNumber}`\r\n\r\n\t\tcase 'RFC3966':\r\n\t\t\treturn formatRFC3966({\r\n\t\t\t\tnumber: `+${countryCallingCode}${nationalNumber}`,\r\n\t\t\t\text: input.ext\r\n\t\t\t})\r\n\r\n\t\t// For reference, here's Google's IDD formatter:\r\n\t\t// https://github.com/google/libphonenumber/blob/32719cf74e68796788d1ca45abc85dcdc63ba5b9/java/libphonenumber/src/com/google/i18n/phonenumbers/PhoneNumberUtil.java#L1546\r\n\t\t// Not saying that this IDD formatter replicates it 1:1, but it seems to work.\r\n\t\t// Who would even need to format phone numbers in IDD format anyway?\r\n\t\tcase 'IDD':\r\n\t\t\tif (!options.fromCountry) {\r\n\t\t\t\treturn\r\n\t\t\t\t// throw new Error('`fromCountry` option not passed for IDD-prefixed formatting.')\r\n\t\t\t}\r\n\t\t\tconst formattedNumber = formatIDD(\r\n\t\t\t\tnationalNumber,\r\n\t\t\t\tinput.carrierCode,\r\n\t\t\t\tcountryCallingCode,\r\n\t\t\t\toptions.fromCountry,\r\n\t\t\t\tmetadata\r\n\t\t\t)\r\n\t\t\treturn addExtension(formattedNumber, input.ext, metadata, options.formatExtension)\r\n\r\n\t\tdefault:\r\n\t\t\tthrow new Error(`Unknown \"format\" argument passed to \"formatNumber()\": \"${format}\"`)\r\n\t}\r\n}\r\n\r\nfunction formatNationalNumber(number, carrierCode, formatAs, metadata, options) {\r\n\tconst format = chooseFormatForNumber(metadata.formats(), number)\r\n\tif (!format) {\r\n\t\treturn number\r\n\t}\r\n\treturn formatNationalNumberUsingFormat(\r\n\t\tnumber,\r\n\t\tformat,\r\n\t\t{\r\n\t\t\tuseInternationalFormat: formatAs === 'INTERNATIONAL',\r\n\t\t\twithNationalPrefix: format.nationalPrefixIsOptionalWhenFormattingInNationalFormat() && (options && options.nationalPrefix === false) ? false : true,\r\n\t\t\tcarrierCode,\r\n\t\t\tmetadata\r\n\t\t}\r\n\t)\r\n}\r\n\r\nexport function chooseFormatForNumber(availableFormats, nationalNumber) {\r\n\t// Using a `for ... of` loop here didn't work with `babel`/`istanbul`:\r\n\t// for some weird reason, it showed code coverage less than 100%.\r\n\t// That's because `babel`/`istanbul`, for some weird reason,\r\n\t// apparently doesn't know how to properly exclude Babel polyfills from code coverage.\r\n\t//\r\n\t// for (const format of availableFormats) { ... }\r\n\t//\r\n\treturn pickFirstMatchingElement(availableFormats, (format) => {\r\n\t\t// Validate leading digits.\r\n\t\t// The test case for \"else path\" could be found by searching for\r\n\t\t// \"format.leadingDigitsPatterns().length === 0\".\r\n\t\tif (format.leadingDigitsPatterns().length > 0) {\r\n\t\t\t// The last leading_digits_pattern is used here, as it is the most detailed\r\n\t\t\tconst lastLeadingDigitsPattern = format.leadingDigitsPatterns()[format.leadingDigitsPatterns().length - 1]\r\n\t\t\t// If leading digits don't match then move on to the next phone number format\r\n\t\t\tif (nationalNumber.search(lastLeadingDigitsPattern) !== 0) {\r\n\t\t\t\treturn false\r\n\t\t\t}\r\n\t\t}\r\n\t\t// Check that the national number matches the phone number format regular expression\r\n\t\treturn matchesEntirely(nationalNumber, format.pattern())\r\n\t})\r\n}\r\n\r\nfunction addExtension(formattedNumber, ext, metadata, formatExtension) {\r\n\treturn ext ? formatExtension(formattedNumber, ext, metadata) : formattedNumber\r\n}\r\n\r\nfunction formatIDD(\r\n\tnationalNumber,\r\n\tcarrierCode,\r\n\tcountryCallingCode,\r\n\tfromCountry,\r\n\tmetadata\r\n) {\r\n\tconst fromCountryCallingCode = getCountryCallingCode(fromCountry, metadata.metadata)\r\n\t// When calling within the same country calling code.\r\n\tif (fromCountryCallingCode === countryCallingCode) {\r\n\t\tconst formattedNumber = formatNationalNumber(nationalNumber, carrierCode, 'NATIONAL', metadata)\r\n\t\t// For NANPA regions, return the national format for these regions\r\n\t\t// but prefix it with the country calling code.\r\n\t\tif (countryCallingCode === '1') {\r\n\t\t\treturn countryCallingCode + ' ' + formattedNumber\r\n\t\t}\r\n\t\t// If regions share a country calling code, the country calling code need\r\n\t\t// not be dialled. This also applies when dialling within a region, so this\r\n\t\t// if clause covers both these cases. Technically this is the case for\r\n\t\t// dialling from La Reunion to other overseas departments of France (French\r\n\t\t// Guiana, Martinique, Guadeloupe), but not vice versa - so we don't cover\r\n\t\t// this edge case for now and for those cases return the version including\r\n\t\t// country calling code. Details here:\r\n\t\t// http://www.petitfute.com/voyage/225-info-pratiques-reunion\r\n\t\t//\r\n\t\treturn formattedNumber\r\n\t}\r\n\tconst iddPrefix = getIddPrefix(fromCountry, undefined, metadata.metadata)\r\n\tif (iddPrefix) {\r\n\t\treturn `${iddPrefix} ${countryCallingCode} ${formatNationalNumber(nationalNumber, null, 'INTERNATIONAL', metadata)}`\r\n\t}\r\n}\r\n\r\nfunction merge(...objects) {\r\n\tlet i = 1\r\n\twhile (i < objects.length) {\r\n\t\tif (objects[i]) {\r\n\t\t\tfor (const key in objects[i]) {\r\n\t\t\t\tobjects[0][key] = objects[i][key]\r\n\t\t\t}\r\n\t\t}\r\n\t\ti++\r\n\t}\r\n\treturn objects[0]\r\n}\r\n\r\nfunction pickFirstMatchingElement(elements, testFunction) {\r\n\tlet i = 0\r\n\twhile (i < elements.length) {\r\n\t\tif (testFunction(elements[i])) {\r\n\t\t\treturn elements[i]\r\n\t\t}\r\n\t\ti++\r\n\t}\r\n}","import Metadata from './metadata.js'\r\nimport checkNumberLength from './helpers/checkNumberLength.js'\r\n\r\n/**\r\n * Checks if a phone number is \"possible\" (basically just checks its length).\r\n *\r\n * isPossible(phoneNumberInstance, { ..., v2: true }, metadata)\r\n *\r\n * isPossible({ phone: '8005553535', country: 'RU' }, { ... }, metadata)\r\n * isPossible({ phone: '8005553535', country: 'RU' }, undefined, metadata)\r\n *\r\n * @param {object|PhoneNumber} input — If `options.v2: true` flag is passed, the `input` should be a `PhoneNumber` instance. Otherwise, it should be an object of shape `{ phone: '...', country: '...' }`.\r\n * @param {object} [options]\r\n * @param {object} metadata\r\n * @return {string}\r\n */\r\nexport default function isPossiblePhoneNumber(input, options, metadata) {\r\n\t/* istanbul ignore if */\r\n\tif (options === undefined) {\r\n\t\toptions = {}\r\n\t}\r\n\r\n\tmetadata = new Metadata(metadata)\r\n\r\n\tif (options.v2) {\r\n\t\tif (!input.countryCallingCode) {\r\n\t\t\tthrow new Error('Invalid phone number object passed')\r\n\t\t}\r\n\t\tmetadata.selectNumberingPlan(input.countryCallingCode)\r\n\t} else {\r\n\t\tif (!input.phone) {\r\n\t\t\treturn false\r\n\t\t}\r\n\t\tif (input.country) {\r\n\t\t\tif (!metadata.hasCountry(input.country)) {\r\n\t\t\t\tthrow new Error(`Unknown country: ${input.country}`)\r\n\t\t\t}\r\n\t\t\tmetadata.selectNumberingPlan(input.country)\r\n\t\t} else {\r\n\t\t\tif (!input.countryCallingCode) {\r\n\t\t\t\tthrow new Error('Invalid phone number object passed')\r\n\t\t\t}\r\n\t\t\tmetadata.selectNumberingPlan(input.countryCallingCode)\r\n\t\t}\r\n\t}\r\n\r\n\t// Old metadata (< 1.0.18) had no \"possible length\" data.\r\n\tif (metadata.possibleLengths()) {\r\n\t\treturn isPossibleNumber(input.phone || input.nationalNumber, input.country, metadata)\r\n\t} else {\r\n\t\t// There was a bug between `1.7.35` and `1.7.37` where \"possible_lengths\"\r\n\t\t// were missing for \"non-geographical\" numbering plans.\r\n\t\t// Just assume the number is possible in such cases:\r\n\t\t// it's unlikely that anyone generated their custom metadata\r\n\t\t// in that short period of time (one day).\r\n\t\t// This code can be removed in some future major version update.\r\n\t\tif (input.countryCallingCode && metadata.isNonGeographicCallingCode(input.countryCallingCode)) {\r\n\t\t\t// \"Non-geographic entities\" did't have `possibleLengths`\r\n\t\t\t// due to a bug in metadata generation process.\r\n\t\t\treturn true\r\n\t\t} else {\r\n\t\t\tthrow new Error('Missing \"possibleLengths\" in metadata. Perhaps the metadata has been generated before v1.0.18.');\r\n\t\t}\r\n\t}\r\n}\r\n\r\nexport function isPossibleNumber(nationalNumber, country, metadata) { //, isInternational) {\r\n\tswitch (checkNumberLength(nationalNumber, country, metadata)) {\r\n\t\tcase 'IS_POSSIBLE':\r\n\t\t\treturn true\r\n\t\t// This library ignores \"local-only\" phone numbers (for simplicity).\r\n\t\t// See the readme for more info on what are \"local-only\" phone numbers.\r\n\t\t// case 'IS_POSSIBLE_LOCAL_ONLY':\r\n\t\t// \treturn !isInternational\r\n\t\tdefault:\r\n\t\t\treturn false\r\n\t}\r\n}","import extractNationalNumberFromPossiblyIncompleteNumber from './extractNationalNumberFromPossiblyIncompleteNumber.js'\r\nimport matchesEntirely from './matchesEntirely.js'\r\nimport checkNumberLength from './checkNumberLength.js'\r\nimport getCountryByCallingCode from './getCountryByCallingCode.js'\r\n\r\n/**\r\n * Strips national prefix and carrier code from a complete phone number.\r\n * The difference from the non-\"FromCompleteNumber\" function is that\r\n * it won't extract national prefix if the resultant number is too short\r\n * to be a complete number for the selected phone numbering plan.\r\n * @param {string} number — Complete phone number digits.\r\n * @param {string?} country — Country, if known.\r\n * @param {Metadata} metadata — Metadata with a phone numbering plan selected.\r\n * @return {object} `{ nationalNumber: string, carrierCode: string? }`.\r\n */\r\nexport default function extractNationalNumber(number, country, metadata) {\r\n\t// Parsing national prefixes and carrier codes\r\n\t// is only required for local phone numbers\r\n\t// but some people don't understand that\r\n\t// and sometimes write international phone numbers\r\n\t// with national prefixes (or maybe even carrier codes).\r\n\t// http://ucken.blogspot.ru/2016/03/trunk-prefixes-in-skype4b.html\r\n\t// Google's original library forgives such mistakes\r\n\t// and so does this library, because it has been requested:\r\n\t// https://github.com/catamphetamine/libphonenumber-js/issues/127\r\n\tconst {\r\n\t\tcarrierCode,\r\n\t\tnationalNumber\r\n\t} = extractNationalNumberFromPossiblyIncompleteNumber(\r\n\t\tnumber,\r\n\t\tmetadata\r\n\t)\r\n\r\n\tif (nationalNumber !== number) {\r\n\t\tif (!shouldHaveExtractedNationalPrefix(number, nationalNumber, metadata)) {\r\n\t\t\t// Don't strip the national prefix.\r\n\t\t\treturn { nationalNumber: number }\r\n\t\t}\r\n\t\t// Check the national (significant) number length after extracting national prefix and carrier code.\r\n\t\t// Legacy generated metadata (before `1.0.18`) didn't support the \"possible lengths\" feature.\r\n\t\tif (metadata.numberingPlan.possibleLengths()) {\r\n\t\t\t// If an exact `country` is not specified, attempt to detect it from the assumed national number.\r\n\t\t\tif (!country) {\r\n\t\t\t\tcountry = getCountryByCallingCode(metadata.numberingPlan.callingCode(), {\r\n\t\t\t\t\tnationalNumber,\r\n\t\t\t\t\tmetadata\r\n\t\t\t\t})\r\n\t\t\t}\r\n\r\n\t\t\t// The number remaining after stripping the national prefix and carrier code\r\n\t\t\t// should be long enough to have a possible length for the country.\r\n\t\t\t// Otherwise, don't strip the national prefix and carrier code,\r\n\t\t\t// since the original number could be a valid number.\r\n\t\t\t// This check has been copy-pasted \"as is\" from Google's original library:\r\n\t\t\t// https://github.com/google/libphonenumber/blob/876268eb1ad6cdc1b7b5bef17fc5e43052702d57/java/libphonenumber/src/com/google/i18n/phonenumbers/PhoneNumberUtil.java#L3236-L3250\r\n\t\t\t// It doesn't check for the \"possibility\" of the original `number`.\r\n\t\t\t// I guess it's fine not checking that one. It works as is anyway.\r\n\t\t\tif (!isPossibleIncompleteNationalNumber(nationalNumber, country, metadata)) {\r\n\t\t\t\t// Don't strip the national prefix.\r\n\t\t\t\treturn { nationalNumber: number }\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\treturn { nationalNumber, carrierCode }\r\n}\r\n\r\n// In some countries, the same digit could be a national prefix\r\n// or a leading digit of a valid phone number.\r\n// For example, in Russia, national prefix is `8`,\r\n// and also `800 555 35 35` is a valid number\r\n// in which `8` is not a national prefix, but the first digit\r\n// of a national (significant) number.\r\n// Same's with Belarus:\r\n// `82004910060` is a valid national (significant) number,\r\n// but `2004910060` is not.\r\n// To support such cases (to prevent the code from always stripping\r\n// national prefix), a condition is imposed: a national prefix\r\n// is not extracted when the original number is \"viable\" and the\r\n// resultant number is not, a \"viable\" national number being the one\r\n// that matches `national_number_pattern`.\r\nfunction shouldHaveExtractedNationalPrefix(nationalNumberBefore, nationalNumberAfter, metadata) {\r\n\t// The equivalent in Google's code is:\r\n\t// https://github.com/google/libphonenumber/blob/e326fa1fc4283bb05eb35cb3c15c18f98a31af33/java/libphonenumber/src/com/google/i18n/phonenumbers/PhoneNumberUtil.java#L2969-L3004\r\n\tif (matchesEntirely(nationalNumberBefore, metadata.nationalNumberPattern()) &&\r\n\t\t!matchesEntirely(nationalNumberAfter, metadata.nationalNumberPattern())) {\r\n\t\treturn false\r\n\t}\r\n\t// This \"is possible\" national number (length) check has been commented out\r\n\t// because it's superceded by the (effectively) same check done in the\r\n\t// `extractNationalNumber()` function after it calls `shouldHaveExtractedNationalPrefix()`.\r\n\t// In other words, why run the same check twice if it could only be run once.\r\n\t// // Check the national (significant) number length after extracting national prefix and carrier code.\r\n\t// // Fixes a minor \"weird behavior\" bug: https://gitlab.com/catamphetamine/libphonenumber-js/-/issues/57\r\n\t// // (Legacy generated metadata (before `1.0.18`) didn't support the \"possible lengths\" feature).\r\n\t// if (metadata.possibleLengths()) {\r\n\t// \tif (isPossibleIncompleteNationalNumber(nationalNumberBefore, metadata) &&\r\n\t// \t\t!isPossibleIncompleteNationalNumber(nationalNumberAfter, metadata)) {\r\n\t// \t\treturn false\r\n\t// \t}\r\n\t// }\r\n\treturn true\r\n}\r\n\r\nfunction isPossibleIncompleteNationalNumber(nationalNumber, country, metadata) {\r\n\tswitch (checkNumberLength(nationalNumber, country, metadata)) {\r\n\t\tcase 'TOO_SHORT':\r\n\t\tcase 'INVALID_LENGTH':\r\n\t\t// This library ignores \"local-only\" phone numbers (for simplicity).\r\n\t\t// See the readme for more info on what are \"local-only\" phone numbers.\r\n\t\t// case 'IS_POSSIBLE_LOCAL_ONLY':\r\n\t\t\treturn false\r\n\t\tdefault:\r\n\t\t\treturn true\r\n\t}\r\n}","import {\r\n\tMIN_LENGTH_FOR_NSN,\r\n\tVALID_DIGITS,\r\n\tVALID_PUNCTUATION,\r\n\tPLUS_CHARS\r\n} from '../constants.js'\r\n\r\nimport createExtensionPattern from './extension/createExtensionPattern.js'\r\n\r\n// Regular expression of viable phone numbers. This is location independent.\r\n// Checks we have at least three leading digits, and only valid punctuation,\r\n// alpha characters and digits in the phone number. Does not include extension\r\n// data. The symbol 'x' is allowed here as valid punctuation since it is often\r\n// used as a placeholder for carrier codes, for example in Brazilian phone\r\n// numbers. We also allow multiple '+' characters at the start.\r\n//\r\n// Corresponds to the following:\r\n// [digits]{minLengthNsn}|\r\n// plus_sign*\r\n// (([punctuation]|[star])*[digits]){3,}([punctuation]|[star]|[digits]|[alpha])*\r\n//\r\n// The first reg-ex is to allow short numbers (two digits long) to be parsed if\r\n// they are entered as \"15\" etc, but only if there is no punctuation in them.\r\n// The second expression restricts the number of digits to three or more, but\r\n// then allows them to be in international form, and to have alpha-characters\r\n// and punctuation. We split up the two reg-exes here and combine them when\r\n// creating the reg-ex VALID_PHONE_NUMBER_PATTERN itself so we can prefix it\r\n// with ^ and append $ to each branch.\r\n//\r\n// \"Note VALID_PUNCTUATION starts with a -,\r\n// so must be the first in the range\" (c) Google devs.\r\n// (wtf did they mean by saying that; probably nothing)\r\n//\r\nconst MIN_LENGTH_PHONE_NUMBER_PATTERN = '[' + VALID_DIGITS + ']{' + MIN_LENGTH_FOR_NSN + '}'\r\n//\r\n// And this is the second reg-exp:\r\n// (see MIN_LENGTH_PHONE_NUMBER_PATTERN for a full description of this reg-exp)\r\n//\r\nexport const VALID_PHONE_NUMBER =\r\n\t'[' + PLUS_CHARS + ']{0,1}' +\r\n\t'(?:' +\r\n\t\t'[' + VALID_PUNCTUATION + ']*' +\r\n\t\t'[' + VALID_DIGITS + ']' +\r\n\t'){3,}' +\r\n\t'[' +\r\n\t\tVALID_PUNCTUATION +\r\n\t\tVALID_DIGITS +\r\n\t']*'\r\n\r\n// This regular expression isn't present in Google's `libphonenumber`\r\n// and is only used to determine whether the phone number being input\r\n// is too short for it to even consider it a \"valid\" number.\r\n// This is just a way to differentiate between a really invalid phone\r\n// number like \"abcde\" and a valid phone number that a user has just\r\n// started inputting, like \"+1\" or \"1\": both these cases would be\r\n// considered `NOT_A_NUMBER` by Google's `libphonenumber`, but this\r\n// library can provide a more detailed error message — whether it's\r\n// really \"not a number\", or is it just a start of a valid phone number.\r\nconst VALID_PHONE_NUMBER_START_REG_EXP = new RegExp(\r\n\t'^' +\r\n\t'[' + PLUS_CHARS + ']{0,1}' +\r\n\t'(?:' +\r\n\t\t'[' + VALID_PUNCTUATION + ']*' +\r\n\t\t'[' + VALID_DIGITS + ']' +\r\n\t'){1,2}' +\r\n\t'$'\r\n, 'i')\r\n\r\nexport const VALID_PHONE_NUMBER_WITH_EXTENSION =\r\n\tVALID_PHONE_NUMBER +\r\n\t// Phone number extensions\r\n\t'(?:' + createExtensionPattern() + ')?'\r\n\r\n// The combined regular expression for valid phone numbers:\r\n//\r\nconst VALID_PHONE_NUMBER_PATTERN = new RegExp(\r\n\t// Either a short two-digit-only phone number\r\n\t'^' +\r\n\t\tMIN_LENGTH_PHONE_NUMBER_PATTERN +\r\n\t'$' +\r\n\t'|' +\r\n\t// Or a longer fully parsed phone number (min 3 characters)\r\n\t'^' +\r\n\t\tVALID_PHONE_NUMBER_WITH_EXTENSION +\r\n\t'$'\r\n, 'i')\r\n\r\n// Checks to see if the string of characters could possibly be a phone number at\r\n// all. At the moment, checks to see that the string begins with at least 2\r\n// digits, ignoring any punctuation commonly found in phone numbers. This method\r\n// does not require the number to be normalized in advance - but does assume\r\n// that leading non-number symbols have been removed, such as by the method\r\n// `extract_possible_number`.\r\n//\r\nexport default function isViablePhoneNumber(number) {\r\n\treturn number.length >= MIN_LENGTH_FOR_NSN &&\r\n\t\tVALID_PHONE_NUMBER_PATTERN.test(number)\r\n}\r\n\r\n// This is just a way to differentiate between a really invalid phone\r\n// number like \"abcde\" and a valid phone number that a user has just\r\n// started inputting, like \"+1\" or \"1\": both these cases would be\r\n// considered `NOT_A_NUMBER` by Google's `libphonenumber`, but this\r\n// library can provide a more detailed error message — whether it's\r\n// really \"not a number\", or is it just a start of a valid phone number.\r\nexport function isViablePhoneNumberStart(number) {\r\n\treturn VALID_PHONE_NUMBER_START_REG_EXP.test(number)\r\n}","import { parseDigit } from './helpers/parseDigits.js'\r\n\r\n/**\r\n * Parses phone number characters from a string.\r\n * Drops all punctuation leaving only digits and the leading `+` sign (if any).\r\n * Also converts wide-ascii and arabic-indic numerals to conventional numerals.\r\n * E.g. in Iraq they don't write `+442323234` but rather `+٤٤٢٣٢٣٢٣٤`.\r\n * @param {string} string\r\n * @return {string}\r\n * @example\r\n * ```js\r\n * // Outputs '8800555'.\r\n * parseIncompletePhoneNumber('8 (800) 555')\r\n * // Outputs '+7800555'.\r\n * parseIncompletePhoneNumber('+7 800 555')\r\n * ```\r\n */\r\nexport default function parseIncompletePhoneNumber(string) {\r\n\tlet result = ''\r\n\t// Using `.split('')` here instead of normal `for ... of`\r\n\t// because the importing application doesn't neccessarily include an ES6 polyfill.\r\n\t// The `.split('')` approach discards \"exotic\" UTF-8 characters\r\n\t// (the ones consisting of four bytes) but digits\r\n\t// (including non-European ones) don't fall into that range\r\n\t// so such \"exotic\" characters would be discarded anyway.\r\n\tfor (const character of string.split('')) {\r\n\t\tresult += parsePhoneNumberCharacter(character, result) || ''\r\n\t}\r\n\treturn result\r\n}\r\n\r\n/**\r\n * Parses next character while parsing phone number digits (including a `+`)\r\n * from text: discards everything except `+` and digits, and `+` is only allowed\r\n * at the start of a phone number.\r\n * For example, is used in `react-phone-number-input` where it uses\r\n * [`input-format`](https://gitlab.com/catamphetamine/input-format).\r\n * @param {string} character - Yet another character from raw input string.\r\n * @param {string?} prevParsedCharacters - Previous parsed characters.\r\n * @param {function?} eventListener - An optional \"on event\" function.\r\n * @return {string?} The parsed character.\r\n */\r\nexport function parsePhoneNumberCharacter(character, prevParsedCharacters, eventListener) {\r\n\t// Only allow a leading `+`.\r\n\tif (character === '+') {\r\n\t\t// If this `+` is not the first parsed character\r\n\t\t// then discard it.\r\n\t\tif (prevParsedCharacters) {\r\n\t\t\t// `eventListener` argument was added to this `export`ed function on Dec 26th, 2023.\r\n\t\t\t// Any 3rd-party code that used to `import` and call this function before that\r\n\t\t\t// won't be passing any `eventListener` argument.\r\n\t\t\t//\r\n\t\t\t// The addition of the `eventListener` argument was to fix the slightly-weird behavior\r\n\t\t\t// of parsing an input string when the user inputs something like `\"2+7\"\r\n\t\t\t// https://github.com/catamphetamine/react-phone-number-input/issues/437\r\n\t\t\t//\r\n\t\t\t// If the parser encounters an unexpected `+` in a string being parsed\r\n\t\t\t// then it simply discards that out-of-place `+` and any following characters.\r\n\t\t\t//\r\n\t\t\tif (typeof eventListener === 'function') {\r\n\t\t\t\teventListener('end')\r\n\t\t\t}\r\n\t\t\treturn\r\n\t\t}\r\n\t\treturn '+'\r\n\t}\r\n\t// Allow digits.\r\n\treturn parseDigit(character)\r\n}","import isViablePhoneNumber from './isViablePhoneNumber.js'\r\n\r\n// https://www.ietf.org/rfc/rfc3966.txt\r\n\r\n/**\r\n * @param {string} text - Phone URI (RFC 3966).\r\n * @return {object} `{ ?number, ?ext }`.\r\n */\r\nexport function parseRFC3966(text) {\r\n\tlet number\r\n\tlet ext\r\n\r\n\t// Replace \"tel:\" with \"tel=\" for parsing convenience.\r\n\ttext = text.replace(/^tel:/, 'tel=')\r\n\r\n\tfor (const part of text.split(';')) {\r\n\t\tconst [name, value] = part.split('=')\r\n\t\tswitch (name) {\r\n\t\t\tcase 'tel':\r\n\t\t\t\tnumber = value\r\n\t\t\t\tbreak\r\n\t\t\tcase 'ext':\r\n\t\t\t\text = value\r\n\t\t\t\tbreak\r\n\t\t\tcase 'phone-context':\r\n\t\t\t\t// Only \"country contexts\" are supported.\r\n\t\t\t\t// \"Domain contexts\" are ignored.\r\n\t\t\t\tif (value[0] === '+') {\r\n\t\t\t\t\tnumber = value + number\r\n\t\t\t\t}\r\n\t\t\t\tbreak\r\n\t\t}\r\n\t}\r\n\r\n\t// If the phone number is not viable, then abort.\r\n\tif (!isViablePhoneNumber(number)) {\r\n\t\treturn {}\r\n\t}\r\n\r\n\tconst result = { number }\r\n\tif (ext) {\r\n\t\tresult.ext = ext\r\n\t}\r\n\treturn result\r\n}\r\n\r\n/**\r\n * @param {object} - `{ ?number, ?extension }`.\r\n * @return {string} Phone URI (RFC 3966).\r\n */\r\nexport function formatRFC3966({ number, ext }) {\r\n\tif (!number) {\r\n\t\treturn ''\r\n\t}\r\n\tif (number[0] !== '+') {\r\n\t\tthrow new Error(`\"formatRFC3966()\" expects \"number\" to be in E.164 format.`)\r\n\t}\r\n\treturn `tel:${number}${ext ? ';ext=' + ext : ''}`\r\n}","import parsePhoneNumberWithError from './parsePhoneNumberWithError_.js'\r\nimport ParseError from './ParseError.js'\r\nimport { isSupportedCountry } from './metadata.js'\r\n\r\nexport default function parsePhoneNumber(text, options, metadata) {\r\n\t// Validate `defaultCountry`.\r\n\tif (options && options.defaultCountry && !isSupportedCountry(options.defaultCountry, metadata)) {\r\n\t\toptions = {\r\n\t\t\t...options,\r\n\t\t\tdefaultCountry: undefined\r\n\t\t}\r\n\t}\r\n\t// Parse phone number.\r\n\ttry {\r\n\t\treturn parsePhoneNumberWithError(text, options, metadata)\r\n\t} catch (error) {\r\n\t\t/* istanbul ignore else */\r\n\t\tif (error instanceof ParseError) {\r\n\t\t\t//\r\n\t\t} else {\r\n\t\t\tthrow error\r\n\t\t}\r\n\t}\r\n}\r\n","import Metadata from './metadata.js'\r\nimport matchesEntirely from './helpers/matchesEntirely.js'\r\nimport getNumberType from './helpers/getNumberType.js'\r\n\r\n/**\r\n * Checks if a given phone number is valid.\r\n *\r\n * isValid(phoneNumberInstance, { ..., v2: true }, metadata)\r\n *\r\n * isPossible({ phone: '8005553535', country: 'RU' }, { ... }, metadata)\r\n * isPossible({ phone: '8005553535', country: 'RU' }, undefined, metadata)\r\n *\r\n * If the `number` is a string, it will be parsed to an object,\r\n * but only if it contains only valid phone number characters (including punctuation).\r\n * If the `number` is an object, it is used as is.\r\n *\r\n * The optional `defaultCountry` argument is the default country.\r\n * I.e. it does not restrict to just that country,\r\n * e.g. in those cases where several countries share\r\n * the same phone numbering rules (NANPA, Britain, etc).\r\n * For example, even though the number `07624 369230`\r\n * belongs to the Isle of Man (\"IM\" country code)\r\n * calling `isValidNumber('07624369230', 'GB', metadata)`\r\n * still returns `true` because the country is not restricted to `GB`,\r\n * it's just that `GB` is the default one for the phone numbering rules.\r\n * For restricting the country see `isValidNumberForRegion()`\r\n * though restricting a country might not be a good idea.\r\n * https://github.com/googlei18n/libphonenumber/blob/master/FAQ.md#when-should-i-use-isvalidnumberforregion\r\n *\r\n * Examples:\r\n *\r\n * ```js\r\n * isValidNumber('+78005553535', metadata)\r\n * isValidNumber('8005553535', 'RU', metadata)\r\n * isValidNumber('88005553535', 'RU', metadata)\r\n * isValidNumber({ phone: '8005553535', country: 'RU' }, metadata)\r\n * ```\r\n */\r\nexport default function isValidNumber(input, options, metadata)\r\n{\r\n\t// If assigning the `{}` default value is moved to the arguments above,\r\n\t// code coverage would decrease for some weird reason.\r\n\toptions = options || {}\r\n\r\n\tmetadata = new Metadata(metadata)\r\n\r\n\tmetadata.selectNumberingPlan(input.country, input.countryCallingCode)\r\n\r\n\t// By default, countries only have type regexps when it's required for\r\n\t// distinguishing different countries having the same `countryCallingCode`.\r\n\tif (metadata.hasTypes()) {\r\n\t\treturn getNumberType(input, options, metadata.metadata) !== undefined\r\n\t}\r\n\r\n\t// If there are no type regexps for this country in metadata then use\r\n\t// `nationalNumberPattern` as a \"better than nothing\" replacement.\r\n\tconst nationalNumber = options.v2 ? input.nationalNumber : input.phone\r\n\treturn matchesEntirely(nationalNumber, metadata.nationalNumberPattern())\r\n}","// Copy-pasted from:\r\n// https://github.com/substack/semver-compare/blob/master/index.js\r\n//\r\n// Inlining this function because some users reported issues with\r\n// importing from `semver-compare` in a browser with ES6 \"native\" modules.\r\n//\r\n// Fixes `semver-compare` not being able to compare versions with alpha/beta/etc \"tags\".\r\n// https://github.com/catamphetamine/libphonenumber-js/issues/381\r\nexport default function(a, b) {\r\n a = a.split('-')\r\n b = b.split('-')\r\n var pa = a[0].split('.')\r\n var pb = b[0].split('.')\r\n for (var i = 0; i < 3; i++) {\r\n var na = Number(pa[i])\r\n var nb = Number(pb[i])\r\n if (na > nb) return 1\r\n if (nb > na) return -1\r\n if (!isNaN(na) && isNaN(nb)) return 1\r\n if (isNaN(na) && !isNaN(nb)) return -1\r\n }\r\n if (a[1] && b[1]) {\r\n return a[1] > b[1] ? 1 : (a[1] < b[1] ? -1 : 0)\r\n }\r\n return !a[1] && b[1] ? 1 : (a[1] && !b[1] ? -1 : 0)\r\n}","import compare from './tools/semver-compare.js'\r\nimport isObject from './helpers/isObject.js'\r\n\r\n// Added \"possibleLengths\" and renamed\r\n// \"country_phone_code_to_countries\" to \"country_calling_codes\".\r\nconst V2 = '1.0.18'\r\n\r\n// Added \"idd_prefix\" and \"default_idd_prefix\".\r\nconst V3 = '1.2.0'\r\n\r\n// Moved `001` country code to \"nonGeographic\" section of metadata.\r\nconst V4 = '1.7.35'\r\n\r\nconst DEFAULT_EXT_PREFIX = ' ext. '\r\n\r\nconst CALLING_CODE_REG_EXP = /^\\d+$/\r\n\r\n/**\r\n * See: https://gitlab.com/catamphetamine/libphonenumber-js/blob/master/METADATA.md\r\n */\r\nexport default class Metadata {\r\n\tconstructor(metadata) {\r\n\t\tvalidateMetadata(metadata)\r\n\t\tthis.metadata = metadata\r\n\t\tsetVersion.call(this, metadata)\r\n\t}\r\n\r\n\tgetCountries() {\r\n\t\treturn Object.keys(this.metadata.countries).filter(_ => _ !== '001')\r\n\t}\r\n\r\n\tgetCountryMetadata(countryCode) {\r\n\t\treturn this.metadata.countries[countryCode]\r\n\t}\r\n\r\n\tnonGeographic() {\r\n\t\tif (this.v1 || this.v2 || this.v3) return\r\n\t\t// `nonGeographical` was a typo.\r\n\t\t// It's present in metadata generated from `1.7.35` to `1.7.37`.\r\n\t\t// The test case could be found by searching for \"nonGeographical\".\r\n\t\treturn this.metadata.nonGeographic || this.metadata.nonGeographical\r\n\t}\r\n\r\n\thasCountry(country) {\r\n\t\treturn this.getCountryMetadata(country) !== undefined\r\n\t}\r\n\r\n\thasCallingCode(callingCode) {\r\n\t\tif (this.getCountryCodesForCallingCode(callingCode)) {\r\n\t\t\treturn true\r\n\t\t}\r\n\t\tif (this.nonGeographic()) {\r\n\t\t\tif (this.nonGeographic()[callingCode]) {\r\n\t\t\t\treturn true\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\t// A hacky workaround for old custom metadata (generated before V4).\r\n\t\t\tconst countryCodes = this.countryCallingCodes()[callingCode]\r\n\t\t\tif (countryCodes && countryCodes.length === 1 && countryCodes[0] === '001') {\r\n\t\t\t\treturn true\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tisNonGeographicCallingCode(callingCode) {\r\n\t\tif (this.nonGeographic()) {\r\n\t\t\treturn this.nonGeographic()[callingCode] ? true : false\r\n\t\t} else {\r\n\t\t\treturn this.getCountryCodesForCallingCode(callingCode) ? false : true\r\n\t\t}\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tcountry(countryCode) {\r\n\t\treturn this.selectNumberingPlan(countryCode)\r\n\t}\r\n\r\n\tselectNumberingPlan(countryCode, callingCode) {\r\n\t\t// Supports just passing `callingCode` as the first argument.\r\n\t\tif (countryCode && CALLING_CODE_REG_EXP.test(countryCode)) {\r\n\t\t\tcallingCode = countryCode\r\n\t\t\tcountryCode = null\r\n\t\t}\r\n\t\tif (countryCode && countryCode !== '001') {\r\n\t\t\tif (!this.hasCountry(countryCode)) {\r\n\t\t\t\tthrow new Error(`Unknown country: ${countryCode}`)\r\n\t\t\t}\r\n\t\t\tthis.numberingPlan = new NumberingPlan(this.getCountryMetadata(countryCode), this)\r\n\t\t} else if (callingCode) {\r\n\t\t\tif (!this.hasCallingCode(callingCode)) {\r\n\t\t\t\tthrow new Error(`Unknown calling code: ${callingCode}`)\r\n\t\t\t}\r\n\t\t\tthis.numberingPlan = new NumberingPlan(this.getNumberingPlanMetadata(callingCode), this)\r\n\t\t} else {\r\n\t\t\tthis.numberingPlan = undefined\r\n\t\t}\r\n\t\treturn this\r\n\t}\r\n\r\n\tgetCountryCodesForCallingCode(callingCode) {\r\n\t\tconst countryCodes = this.countryCallingCodes()[callingCode]\r\n\t\tif (countryCodes) {\r\n\t\t\t// Metadata before V4 included \"non-geographic entity\" calling codes\r\n\t\t\t// inside `country_calling_codes` (for example, `\"881\":[\"001\"]`).\r\n\t\t\t// Now the semantics of `country_calling_codes` has changed:\r\n\t\t\t// it's specifically for \"countries\" now.\r\n\t\t\t// Older versions of custom metadata will simply skip parsing\r\n\t\t\t// \"non-geographic entity\" phone numbers with new versions\r\n\t\t\t// of this library: it's not considered a bug,\r\n\t\t\t// because such numbers are extremely rare,\r\n\t\t\t// and developers extremely rarely use custom metadata.\r\n\t\t\tif (countryCodes.length === 1 && countryCodes[0].length === 3) {\r\n\t\t\t\treturn\r\n\t\t\t}\r\n\t\t\treturn countryCodes\r\n\t\t}\r\n\t}\r\n\r\n\tgetCountryCodeForCallingCode(callingCode) {\r\n\t\tconst countryCodes = this.getCountryCodesForCallingCode(callingCode)\r\n\t\tif (countryCodes) {\r\n\t\t\treturn countryCodes[0]\r\n\t\t}\r\n\t}\r\n\r\n\tgetNumberingPlanMetadata(callingCode) {\r\n\t\tconst countryCode = this.getCountryCodeForCallingCode(callingCode)\r\n\t\tif (countryCode) {\r\n\t\t\treturn this.getCountryMetadata(countryCode)\r\n\t\t}\r\n\t\tif (this.nonGeographic()) {\r\n\t\t\tconst metadata = this.nonGeographic()[callingCode]\r\n\t\t\tif (metadata) {\r\n\t\t\t\treturn metadata\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\t// A hacky workaround for old custom metadata (generated before V4).\r\n\t\t\t// In that metadata, there was no concept of \"non-geographic\" metadata\r\n\t\t\t// so metadata for `001` country code was stored along with other countries.\r\n\t\t\t// The test case can be found by searching for:\r\n\t\t\t// \"should work around `nonGeographic` metadata not existing\".\r\n\t\t\tconst countryCodes = this.countryCallingCodes()[callingCode]\r\n\t\t\tif (countryCodes && countryCodes.length === 1 && countryCodes[0] === '001') {\r\n\t\t\t\treturn this.metadata.countries['001']\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tcountryCallingCode() {\r\n\t\treturn this.numberingPlan.callingCode()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tIDDPrefix() {\r\n\t\treturn this.numberingPlan.IDDPrefix()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tdefaultIDDPrefix() {\r\n\t\treturn this.numberingPlan.defaultIDDPrefix()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tnationalNumberPattern() {\r\n\t\treturn this.numberingPlan.nationalNumberPattern()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tpossibleLengths() {\r\n\t\treturn this.numberingPlan.possibleLengths()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tformats() {\r\n\t\treturn this.numberingPlan.formats()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tnationalPrefixForParsing() {\r\n\t\treturn this.numberingPlan.nationalPrefixForParsing()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tnationalPrefixTransformRule() {\r\n\t\treturn this.numberingPlan.nationalPrefixTransformRule()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tleadingDigits() {\r\n\t\treturn this.numberingPlan.leadingDigits()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\thasTypes() {\r\n\t\treturn this.numberingPlan.hasTypes()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\ttype(type) {\r\n\t\treturn this.numberingPlan.type(type)\r\n\t}\r\n\r\n\t// Deprecated.\r\n\text() {\r\n\t\treturn this.numberingPlan.ext()\r\n\t}\r\n\r\n\tcountryCallingCodes() {\r\n\t\tif (this.v1) return this.metadata.country_phone_code_to_countries\r\n\t\treturn this.metadata.country_calling_codes\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tchooseCountryByCountryCallingCode(callingCode) {\r\n\t\treturn this.selectNumberingPlan(callingCode)\r\n\t}\r\n\r\n\thasSelectedNumberingPlan() {\r\n\t\treturn this.numberingPlan !== undefined\r\n\t}\r\n}\r\n\r\nclass NumberingPlan {\r\n\tconstructor(metadata, globalMetadataObject) {\r\n\t\tthis.globalMetadataObject = globalMetadataObject\r\n\t\tthis.metadata = metadata\r\n\t\tsetVersion.call(this, globalMetadataObject.metadata)\r\n\t}\r\n\r\n\tcallingCode() {\r\n\t\treturn this.metadata[0]\r\n\t}\r\n\r\n\t// Formatting information for regions which share\r\n\t// a country calling code is contained by only one region\r\n\t// for performance reasons. For example, for NANPA region\r\n\t// (\"North American Numbering Plan Administration\",\r\n\t// which includes USA, Canada, Cayman Islands, Bahamas, etc)\r\n\t// it will be contained in the metadata for `US`.\r\n\tgetDefaultCountryMetadataForRegion() {\r\n\t\treturn this.globalMetadataObject.getNumberingPlanMetadata(this.callingCode())\r\n\t}\r\n\r\n\t// Is always present.\r\n\tIDDPrefix() {\r\n\t\tif (this.v1 || this.v2) return\r\n\t\treturn this.metadata[1]\r\n\t}\r\n\r\n\t// Is only present when a country supports multiple IDD prefixes.\r\n\tdefaultIDDPrefix() {\r\n\t\tif (this.v1 || this.v2) return\r\n\t\treturn this.metadata[12]\r\n\t}\r\n\r\n\tnationalNumberPattern() {\r\n\t\tif (this.v1 || this.v2) return this.metadata[1]\r\n\t\treturn this.metadata[2]\r\n\t}\r\n\r\n\t// \"possible length\" data is always present in Google's metadata.\r\n\tpossibleLengths() {\r\n\t\tif (this.v1) return\r\n\t\treturn this.metadata[this.v2 ? 2 : 3]\r\n\t}\r\n\r\n\t_getFormats(metadata) {\r\n\t\treturn metadata[this.v1 ? 2 : this.v2 ? 3 : 4]\r\n\t}\r\n\r\n\t// For countries of the same region (e.g. NANPA)\r\n\t// formats are all stored in the \"main\" country for that region.\r\n\t// E.g. \"RU\" and \"KZ\", \"US\" and \"CA\".\r\n\tformats() {\r\n\t\tconst formats = this._getFormats(this.metadata) || this._getFormats(this.getDefaultCountryMetadataForRegion()) || []\r\n\t\treturn formats.map(_ => new Format(_, this))\r\n\t}\r\n\r\n\tnationalPrefix() {\r\n\t\treturn this.metadata[this.v1 ? 3 : this.v2 ? 4 : 5]\r\n\t}\r\n\r\n\t_getNationalPrefixFormattingRule(metadata) {\r\n\t\treturn metadata[this.v1 ? 4 : this.v2 ? 5 : 6]\r\n\t}\r\n\r\n\t// For countries of the same region (e.g. NANPA)\r\n\t// national prefix formatting rule is stored in the \"main\" country for that region.\r\n\t// E.g. \"RU\" and \"KZ\", \"US\" and \"CA\".\r\n\tnationalPrefixFormattingRule() {\r\n\t\treturn this._getNationalPrefixFormattingRule(this.metadata) || this._getNationalPrefixFormattingRule(this.getDefaultCountryMetadataForRegion())\r\n\t}\r\n\r\n\t_nationalPrefixForParsing() {\r\n\t\treturn this.metadata[this.v1 ? 5 : this.v2 ? 6 : 7]\r\n\t}\r\n\r\n\tnationalPrefixForParsing() {\r\n\t\t// If `national_prefix_for_parsing` is not set explicitly,\r\n\t\t// then infer it from `national_prefix` (if any)\r\n\t\treturn this._nationalPrefixForParsing() || this.nationalPrefix()\r\n\t}\r\n\r\n\tnationalPrefixTransformRule() {\r\n\t\treturn this.metadata[this.v1 ? 6 : this.v2 ? 7 : 8]\r\n\t}\r\n\r\n\t_getNationalPrefixIsOptionalWhenFormatting() {\r\n\t\treturn !!this.metadata[this.v1 ? 7 : this.v2 ? 8 : 9]\r\n\t}\r\n\r\n\t// For countries of the same region (e.g. NANPA)\r\n\t// \"national prefix is optional when formatting\" flag is\r\n\t// stored in the \"main\" country for that region.\r\n\t// E.g. \"RU\" and \"KZ\", \"US\" and \"CA\".\r\n\tnationalPrefixIsOptionalWhenFormattingInNationalFormat() {\r\n\t\treturn this._getNationalPrefixIsOptionalWhenFormatting(this.metadata) ||\r\n\t\t\tthis._getNationalPrefixIsOptionalWhenFormatting(this.getDefaultCountryMetadataForRegion())\r\n\t}\r\n\r\n\tleadingDigits() {\r\n\t\treturn this.metadata[this.v1 ? 8 : this.v2 ? 9 : 10]\r\n\t}\r\n\r\n\ttypes() {\r\n\t\treturn this.metadata[this.v1 ? 9 : this.v2 ? 10 : 11]\r\n\t}\r\n\r\n\thasTypes() {\r\n\t\t// Versions 1.2.0 - 1.2.4: can be `[]`.\r\n\t\t/* istanbul ignore next */\r\n\t\tif (this.types() && this.types().length === 0) {\r\n\t\t\treturn false\r\n\t\t}\r\n\t\t// Versions <= 1.2.4: can be `undefined`.\r\n\t\t// Version >= 1.2.5: can be `0`.\r\n\t\treturn !!this.types()\r\n\t}\r\n\r\n\ttype(type) {\r\n\t\tif (this.hasTypes() && getType(this.types(), type)) {\r\n\t\t\treturn new Type(getType(this.types(), type), this)\r\n\t\t}\r\n\t}\r\n\r\n\text() {\r\n\t\tif (this.v1 || this.v2) return DEFAULT_EXT_PREFIX\r\n\t\treturn this.metadata[13] || DEFAULT_EXT_PREFIX\r\n\t}\r\n}\r\n\r\nclass Format {\r\n\tconstructor(format, metadata) {\r\n\t\tthis._format = format\r\n\t\tthis.metadata = metadata\r\n\t}\r\n\r\n\tpattern() {\r\n\t\treturn this._format[0]\r\n\t}\r\n\r\n\tformat() {\r\n\t\treturn this._format[1]\r\n\t}\r\n\r\n\tleadingDigitsPatterns() {\r\n\t\treturn this._format[2] || []\r\n\t}\r\n\r\n\tnationalPrefixFormattingRule() {\r\n\t\treturn this._format[3] || this.metadata.nationalPrefixFormattingRule()\r\n\t}\r\n\r\n\tnationalPrefixIsOptionalWhenFormattingInNationalFormat() {\r\n\t\treturn !!this._format[4] || this.metadata.nationalPrefixIsOptionalWhenFormattingInNationalFormat()\r\n\t}\r\n\r\n\tnationalPrefixIsMandatoryWhenFormattingInNationalFormat() {\r\n\t\t// National prefix is omitted if there's no national prefix formatting rule\r\n\t\t// set for this country, or when the national prefix formatting rule\r\n\t\t// contains no national prefix itself, or when this rule is set but\r\n\t\t// national prefix is optional for this phone number format\r\n\t\t// (and it is not enforced explicitly)\r\n\t\treturn this.usesNationalPrefix() && !this.nationalPrefixIsOptionalWhenFormattingInNationalFormat()\r\n\t}\r\n\r\n\t// Checks whether national prefix formatting rule contains national prefix.\r\n\tusesNationalPrefix() {\r\n\t\treturn this.nationalPrefixFormattingRule() &&\r\n\t\t\t// Check that national prefix formatting rule is not a \"dummy\" one.\r\n\t\t\t!FIRST_GROUP_ONLY_PREFIX_PATTERN.test(this.nationalPrefixFormattingRule())\r\n\t\t\t// In compressed metadata, `this.nationalPrefixFormattingRule()` is `0`\r\n\t\t\t// when `national_prefix_formatting_rule` is not present.\r\n\t\t\t// So, `true` or `false` are returned explicitly here, so that\r\n\t\t\t// `0` number isn't returned.\r\n\t\t\t? true\r\n\t\t\t: false\r\n\t}\r\n\r\n\tinternationalFormat() {\r\n\t\treturn this._format[5] || this.format()\r\n\t}\r\n}\r\n\r\n/**\r\n * A pattern that is used to determine if the national prefix formatting rule\r\n * has the first group only, i.e., does not start with the national prefix.\r\n * Note that the pattern explicitly allows for unbalanced parentheses.\r\n */\r\nconst FIRST_GROUP_ONLY_PREFIX_PATTERN = /^\\(?\\$1\\)?$/\r\n\r\nclass Type {\r\n\tconstructor(type, metadata) {\r\n\t\tthis.type = type\r\n\t\tthis.metadata = metadata\r\n\t}\r\n\r\n\tpattern() {\r\n\t\tif (this.metadata.v1) return this.type\r\n\t\treturn this.type[0]\r\n\t}\r\n\r\n\tpossibleLengths() {\r\n\t\tif (this.metadata.v1) return\r\n\t\treturn this.type[1] || this.metadata.possibleLengths()\r\n\t}\r\n}\r\n\r\nfunction getType(types, type) {\r\n\tswitch (type) {\r\n\t\tcase 'FIXED_LINE':\r\n\t\t\treturn types[0]\r\n\t\tcase 'MOBILE':\r\n\t\t\treturn types[1]\r\n\t\tcase 'TOLL_FREE':\r\n\t\t\treturn types[2]\r\n\t\tcase 'PREMIUM_RATE':\r\n\t\t\treturn types[3]\r\n\t\tcase 'PERSONAL_NUMBER':\r\n\t\t\treturn types[4]\r\n\t\tcase 'VOICEMAIL':\r\n\t\t\treturn types[5]\r\n\t\tcase 'UAN':\r\n\t\t\treturn types[6]\r\n\t\tcase 'PAGER':\r\n\t\t\treturn types[7]\r\n\t\tcase 'VOIP':\r\n\t\t\treturn types[8]\r\n\t\tcase 'SHARED_COST':\r\n\t\t\treturn types[9]\r\n\t}\r\n}\r\n\r\nexport function validateMetadata(metadata) {\r\n\tif (!metadata) {\r\n\t\tthrow new Error('[libphonenumber-js] `metadata` argument not passed. Check your arguments.')\r\n\t}\r\n\r\n\t// `country_phone_code_to_countries` was renamed to `country_calling_codes` in `1.0.18`.\r\n\t// For that reason, it's not used in this detection algorithm.\r\n\t// Instead, it detects by `countries: {}` property existence.\r\n\tif (!isObject(metadata) || !isObject(metadata.countries)) {\r\n\t\tthrow new Error(`[libphonenumber-js] \\`metadata\\` argument was passed but it's not a valid metadata. Must be an object having \\`.countries\\` child object property. Got ${isObject(metadata) ? 'an object of shape: { ' + Object.keys(metadata).join(', ') + ' }' : 'a ' + typeOf(metadata) + ': ' + metadata}.`)\r\n\t}\r\n}\r\n\r\n// Babel transforms `typeof` into some \"branches\"\r\n// so istanbul will show this as \"branch not covered\".\r\n/* istanbul ignore next */\r\nconst typeOf = _ => typeof _\r\n\r\n/**\r\n * Returns extension prefix for a country.\r\n * @param {string} country\r\n * @param {object} metadata\r\n * @return {string?}\r\n * @example\r\n * // Returns \" ext. \"\r\n * getExtPrefix(\"US\")\r\n */\r\nexport function getExtPrefix(country, metadata) {\r\n\tmetadata = new Metadata(metadata)\r\n\tif (metadata.hasCountry(country)) {\r\n\t\treturn metadata.selectNumberingPlan(country).ext()\r\n\t}\r\n\treturn DEFAULT_EXT_PREFIX\r\n}\r\n\r\n/**\r\n * Returns \"country calling code\" for a country.\r\n * Throws an error if the country doesn't exist or isn't supported by this library.\r\n * @param {string} country\r\n * @param {object} metadata\r\n * @return {string}\r\n * @example\r\n * // Returns \"44\"\r\n * getCountryCallingCode(\"GB\")\r\n */\r\nexport function getCountryCallingCode(country, metadata) {\r\n\tmetadata = new Metadata(metadata)\r\n\tif (metadata.hasCountry(country)) {\r\n\t\treturn metadata.selectNumberingPlan(country).countryCallingCode()\r\n\t}\r\n\tthrow new Error(`Unknown country: ${country}`)\r\n}\r\n\r\nexport function isSupportedCountry(country, metadata) {\r\n\t// metadata = new Metadata(metadata)\r\n\t// return metadata.hasCountry(country)\r\n\treturn metadata.countries.hasOwnProperty(country)\r\n}\r\n\r\nfunction setVersion(metadata) {\r\n\tconst { version } = metadata\r\n\tif (typeof version === 'number') {\r\n\t\tthis.v1 = version === 1\r\n\t\tthis.v2 = version === 2\r\n\t\tthis.v3 = version === 3\r\n\t\tthis.v4 = version === 4\r\n\t} else {\r\n\t\tif (!version) {\r\n\t\t\tthis.v1 = true\r\n\t\t} else if (compare(version, V3) === -1) {\r\n\t\t\tthis.v2 = true\r\n\t\t} else if (compare(version, V4) === -1) {\r\n\t\t\tthis.v3 = true\r\n\t\t} else {\r\n\t\t\tthis.v4 = true\r\n\t\t}\r\n\t}\r\n}\r\n\r\n// const ISO_COUNTRY_CODE = /^[A-Z]{2}$/\r\n// function isCountryCode(countryCode) {\r\n// \treturn ISO_COUNTRY_CODE.test(countryCodeOrCountryCallingCode)\r\n// }","import Metadata from '../metadata.js'\r\nimport getNumberType from './getNumberType.js'\r\n\r\n// Returns the exact country that the `nationalPhoneNumber` belongs to\r\n// in cases of ambiguity, i.e. when multiple countries share the same \"country calling code\".\r\nexport default function getCountryByNationalNumber(nationalPhoneNumber, {\r\n\tcountries,\r\n\tmetadata\r\n}) {\r\n\t// Re-create `metadata` because it will be selecting a `country`.\r\n\tmetadata = new Metadata(metadata)\r\n\r\n\t// const matchingCountries = []\r\n\r\n\tfor (const country of countries) {\r\n\t\tmetadata.selectNumberingPlan(country)\r\n\t\t// \"Leading digits\" patterns are only defined for about 20% of all countries.\r\n\t\t// By definition, matching \"leading digits\" is a sufficient but not a necessary\r\n\t\t// condition for a phone number to belong to a country.\r\n\t\t// The point of \"leading digits\" check is that it's the fastest one to get a match.\r\n\t\t// https://gitlab.com/catamphetamine/libphonenumber-js/blob/master/METADATA.md#leading_digits\r\n\t\t// I'd suppose that \"leading digits\" patterns are mutually exclusive for different countries\r\n\t\t// because of the intended use of that feature.\r\n\t\tif (metadata.leadingDigits()) {\r\n\t\t\tif (nationalPhoneNumber &&\r\n\t\t\t\tnationalPhoneNumber.search(metadata.leadingDigits()) === 0) {\r\n\t\t\t\treturn country\r\n\t\t\t}\r\n\t\t}\r\n\t\t// Else perform full validation with all of those\r\n\t\t// fixed-line/mobile/etc regular expressions.\r\n\t\telse if (getNumberType({ phone: nationalPhoneNumber, country }, undefined, metadata.metadata)) {\r\n\t\t\t// When multiple countries share the same \"country calling code\",\r\n\t\t\t// type patterns aren't guaranteed to be unique among them.\r\n\t\t\t// For example, both `US` and `CA` have the same pattern for `toll_free` numbers.\r\n\t\t\t// https://gitlab.com/catamphetamine/libphonenumber-js/-/issues/103#note_1417147572\r\n\t\t\t//\r\n\t\t\t// That means that this `if` condition could be `true` for multiple countries from the list.\r\n\t\t\t// Currently, it just returns the first one, which is also the \"main\" country for the \"country calling code\".\r\n\t\t\t// In an example with `toll_free` numbers above, `\"US\"` would be returned even though\r\n\t\t\t// it could as well be `\"CA\"`.\r\n\t\t\t//\r\n\t\t\t// There was also a time when this attempted to be overly smart\r\n\t\t\t// and kept track of all such multiple matching countries\r\n\t\t\t// and then picked the one that matched the `defaultCountry`, if provided.\r\n\t\t\t// For example, with `toll_free` numbers above, and with `defaultCountry: \"CA\"`,\r\n\t\t\t// it would've returned `\"CA\"` instead of `\"US\"`.\r\n\t\t\t// Later it turned out that such \"overly smart\" behavior turned out to be just confusing,\r\n\t\t\t// so this \"overly smart\" country detection was reverted to returning the \"main\" country\r\n\t\t\t// for the \"country calling code\".\r\n\t\t\t// https://gitlab.com/catamphetamine/libphonenumber-js/-/issues/154\r\n\t\t\t//\r\n\t\t\treturn country\r\n\t\t\t//\r\n\t\t\t// The \"overly smart\" behavior code:\r\n\t\t\t//\r\n\t\t\t// if (defaultCountry) {\r\n\t\t\t// \tif (country === defaultCountry) {\r\n\t\t\t// \t\treturn country\r\n\t\t\t// \t} else {\r\n\t\t\t// \t\tmatchingCountries.push(country)\r\n\t\t\t// \t}\r\n\t\t\t// } else {\r\n\t\t\t// \treturn country\r\n\t\t\t// }\r\n\t\t}\r\n\t}\r\n\r\n\t// // Return the first (\"main\") one of the `matchingCountries`.\r\n\t// if (matchingCountries.length > 0) {\r\n\t// \treturn matchingCountries[0]\r\n\t// }\r\n}","import Metadata from '../metadata.js'\r\nimport matchesEntirely from './matchesEntirely.js'\r\n\r\nconst NON_FIXED_LINE_PHONE_TYPES = [\r\n\t'MOBILE',\r\n\t'PREMIUM_RATE',\r\n\t'TOLL_FREE',\r\n\t'SHARED_COST',\r\n\t'VOIP',\r\n\t'PERSONAL_NUMBER',\r\n\t'PAGER',\r\n\t'UAN',\r\n\t'VOICEMAIL'\r\n]\r\n\r\n// Finds out national phone number type (fixed line, mobile, etc)\r\nexport default function getNumberType(input, options, metadata)\r\n{\r\n\t// If assigning the `{}` default value is moved to the arguments above,\r\n\t// code coverage would decrease for some weird reason.\r\n\toptions = options || {}\r\n\r\n\t// When `parse()` returns an empty object — `{}` —\r\n\t// that means that the phone number is malformed,\r\n\t// so it can't possibly be valid.\r\n\tif (!input.country && !input.countryCallingCode) {\r\n\t\treturn\r\n\t}\r\n\r\n\tmetadata = new Metadata(metadata)\r\n\r\n\tmetadata.selectNumberingPlan(input.country, input.countryCallingCode)\r\n\r\n\tconst nationalNumber = options.v2 ? input.nationalNumber : input.phone\r\n\r\n\t// The following is copy-pasted from the original function:\r\n\t// https://github.com/googlei18n/libphonenumber/blob/3ea547d4fbaa2d0b67588904dfa5d3f2557c27ff/javascript/i18n/phonenumbers/phonenumberutil.js#L2835\r\n\r\n\t// Is this national number even valid for this country\r\n\tif (!matchesEntirely(nationalNumber, metadata.nationalNumberPattern())) {\r\n\t\treturn\r\n\t}\r\n\r\n\t// Is it fixed line number\r\n\tif (isNumberTypeEqualTo(nationalNumber, 'FIXED_LINE', metadata)) {\r\n\t\t// Because duplicate regular expressions are removed\r\n\t\t// to reduce metadata size, if \"mobile\" pattern is \"\"\r\n\t\t// then it means it was removed due to being a duplicate of the fixed-line pattern.\r\n\t\t//\r\n\t\tif (metadata.type('MOBILE') && metadata.type('MOBILE').pattern() === '') {\r\n\t\t\treturn 'FIXED_LINE_OR_MOBILE'\r\n\t\t}\r\n\r\n\t\t// `MOBILE` type pattern isn't included if it matched `FIXED_LINE` one.\r\n\t\t// For example, for \"US\" country.\r\n\t\t// Old metadata (< `1.0.18`) had a specific \"types\" data structure\r\n\t\t// that happened to be `undefined` for `MOBILE` in that case.\r\n\t\t// Newer metadata (>= `1.0.18`) has another data structure that is\r\n\t\t// not `undefined` for `MOBILE` in that case (it's just an empty array).\r\n\t\t// So this `if` is just for backwards compatibility with old metadata.\r\n\t\tif (!metadata.type('MOBILE')) {\r\n\t\t\treturn 'FIXED_LINE_OR_MOBILE'\r\n\t\t}\r\n\r\n\t\t// Check if the number happens to qualify as both fixed line and mobile.\r\n\t\t// (no such country in the minimal metadata set)\r\n\t\t/* istanbul ignore if */\r\n\t\tif (isNumberTypeEqualTo(nationalNumber, 'MOBILE', metadata)) {\r\n\t\t\treturn 'FIXED_LINE_OR_MOBILE'\r\n\t\t}\r\n\r\n\t\treturn 'FIXED_LINE'\r\n\t}\r\n\r\n\tfor (const type of NON_FIXED_LINE_PHONE_TYPES) {\r\n\t\tif (isNumberTypeEqualTo(nationalNumber, type, metadata)) {\r\n\t\t\treturn type\r\n\t\t}\r\n\t}\r\n}\r\n\r\nexport function isNumberTypeEqualTo(nationalNumber, type, metadata) {\r\n\ttype = metadata.type(type)\r\n\tif (!type || !type.pattern()) {\r\n\t\treturn false\r\n\t}\r\n\t// Check if any possible number lengths are present;\r\n\t// if so, we use them to avoid checking\r\n\t// the validation pattern if they don't match.\r\n\t// If they are absent, this means they match\r\n\t// the general description, which we have\r\n\t// already checked before a specific number type.\r\n\tif (type.possibleLengths() &&\r\n\t\ttype.possibleLengths().indexOf(nationalNumber.length) < 0) {\r\n\t\treturn false\r\n\t}\r\n\treturn matchesEntirely(nationalNumber, type.pattern())\r\n}"],"names":["USE_NON_GEOGRAPHIC_COUNTRY_CODE","getCountryByCallingCode","callingCode","_ref","nationalPhoneNumber","nationalNumber","metadata","isNonGeographicCallingCode","possibleCountries","getCountryCodesForCallingCode","length","getCountryByNationalNumber","countries","applyInternationalSeparatorStyle","formattedNumber","replace","RegExp","concat","VALID_PUNCTUATION","trim","MIN_LENGTH_FOR_NSN","MAX_LENGTH_FOR_NSN","MAX_LENGTH_COUNTRY_CODE","VALID_DIGITS","WHITESPACE","PLUS_CHARS","objectConstructor","constructor","isObject","object","undefined","FIRST_GROUP_PATTERN","formatNationalNumberUsingFormat","number","format","useInternationalFormat","withNationalPrefix","carrierCode","pattern","internationalFormat","nationalPrefixFormattingRule","isValidPhoneNumber","_normalizeArguments","normalizeArguments","arguments","text","options","_objectSpread","extract","phoneNumber","parsePhoneNumber","isValid","args","_Array$prototype$slic2","_slicedToArray","Array","prototype","slice","call","arg_1","arg_2","arg_3","arg_4","TypeError","Error","defaultCountry","ParseError","_Error","code","_this","_classCallCheck","_callSuper","Object","setPrototypeOf","name","_inherits","_wrapNativeSuper","matchesEntirely","regularExpressionText","test","extractNationalNumberFromPossiblyIncompleteNumber","numberingPlan","nationalPrefixForParsing","prefixPattern","prefixMatch","exec","nationalPrefix","capturedGroupsCount","hasCapturedGroups","nationalPrefixTransformRule","prefixBeforeNationalNumber","possiblePositionOfTheFirstCapturedGroup","indexOf","parsePhoneNumberWithError","parse","v2","DIGITS","parseDigit","character","parseDigits","string","_step","result","_iterator","_createForOfIteratorHelperLoose","split","done","digit","value","extractCountryCallingCode","country","defaultCallingCode","isNumberWithIddPrefix","numberWithoutIDD","stripIddPrefix","_extractCountryCallin","extractCountryCallingCodeFromInternationalNumberWithoutPlusSign","countryCallingCode","shorterNumber","countryCallingCodeSource","Metadata","i","_countryCallingCode","hasCallingCode","selectNumberingPlan","getPossibleCountriesForNumber","filter","_metadata","possibleLengths","couldNationalNumberBelongToCountry","PhoneNumber","countryOrCountryCallingCode","e164Number","E164_NUMBER_REGEXP","validateMetadata","_getCountryAndCountry","metadataJson","isCountryCode","getCountryAndCountryCallingCode","this","getMetadata","key","ext","isPossibleNumber","isValidNumber","getNumberType","_format","formatNumber","RFC3966_EXTN_PREFIX","getExtensionDigitsPattern","maxLength","createExtensionPattern","purpose","possibleSeparatorsBetweenNumberAndExtLabel","possibleCharsAfterExtLabel","optionalExtnSuffix","possibleSeparatorsNumberExtLabelNoComma","CAPTURING_DIGIT_PATTERN","countryMetadata","IDDPrefixPattern","IDDPrefix","search","matchedGroups","match","EXTN_PATTERN","PLUS_SIGN","RFC3966_PHONE_DIGIT_","RFC3966_GLOBAL_NUMBER_DIGITS_","RFC3966_GLOBAL_NUMBER_DIGITS_PATTERN_","ALPHANUM_","RFC3966_DOMAINNAME_PATTERN_","RFC3966_PREFIX_","RFC3966_PHONE_CONTEXT_","RFC3966_ISDN_SUBADDRESS_","extractFormattedPhoneNumberFromPossibleRfc3966NumberUri","numberToParse","phoneNumberString","extractFormattedPhoneNumber","phoneContext","numberToExtractFrom","indexOfPhoneContext","phoneContextStart","phoneContextEnd","substring","extractPhoneContext","isPhoneContextValid","charAt","indexOfNationalNumber","indexOfRfc3966Prefix","indexOfIsdn","MAX_INPUT_STRING_LENGTH","PHONE_NUMBER_START_PATTERN","AFTER_PHONE_NUMBER_END_PATTERN","hasCountry","_parseInput","throwOnError","startsAt","_extractFormattedPhoneNumber","isViablePhoneNumber","isViablePhoneNumberStart","error","withExtensionStripped","start","numberWithoutExtension","matches","extractExtension","parseInput","formattedPhoneNumber","_parsePhoneNumber","parseIncompletePhoneNumber","getCountryCallingCode","_extractNationalNumbe","extractNationalNumber","exactCountry","hasSelectedNumberingPlan","__countryCallingCodeSource","valid","extended","nationalNumberPattern","possible","phone","checkNumberLength","checkNumberLengthForType","type","type_info","possible_lengths","mobile_type","a","b","merged","element","push","sort","mergeArrays","actual_length","minimum_length","possibleShorterNumber","possibleShorterNationalNumber","SINGLE_IDD_PREFIX_REG_EXP","DEFAULT_OPTIONS","formatExtension","extension","input","_len","objects","_key","merge","addExtension","formatNationalNumber","formatRFC3966","fromCountry","fromCountryCallingCode","iddPrefix","defaultIDDPrefix","getIddPrefix","formatIDD","formatAs","chooseFormatForNumber","formats","nationalPrefixIsOptionalWhenFormattingInNationalFormat","availableFormats","elements","testFunction","pickFirstMatchingElement","leadingDigitsPatterns","lastLeadingDigitsPattern","isPossiblePhoneNumber","nationalNumberBefore","nationalNumberAfter","shouldHaveExtractedNationalPrefix","isPossibleIncompleteNationalNumber","MIN_LENGTH_PHONE_NUMBER_PATTERN","VALID_PHONE_NUMBER","VALID_PHONE_NUMBER_START_REG_EXP","VALID_PHONE_NUMBER_WITH_EXTENSION","VALID_PHONE_NUMBER_PATTERN","parsePhoneNumberCharacter","prevParsedCharacters","eventListener","parseRFC3966","_part$split2","isSupportedCountry","hasTypes","pa","pb","na","Number","nb","isNaN","DEFAULT_EXT_PREFIX","CALLING_CODE_REG_EXP","_createClass","setVersion","keys","_","countryCode","v1","v3","nonGeographic","nonGeographical","getCountryMetadata","countryCodes","countryCallingCodes","NumberingPlan","getNumberingPlanMetadata","getCountryCodeForCallingCode","leadingDigits","_type","country_phone_code_to_countries","country_calling_codes","globalMetadataObject","_getFormats","getDefaultCountryMetadataForRegion","map","Format","_getNationalPrefixFormattingRule","_nationalPrefixForParsing","_getNationalPrefixIsOptionalWhenFormatting","types","_type2","getType","Type","usesNationalPrefix","FIRST_GROUP_ONLY_PREFIX_PATTERN","join","typeOf","_typeof","getExtPrefix","hasOwnProperty","version","v4","compare","NON_FIXED_LINE_PHONE_TYPES","isNumberTypeEqualTo"],"ignoreList":[],"sourceRoot":""}
1
+ {"version":3,"file":"static/js/2931.2ad9df38.chunk.js","mappings":"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","sources":["../node_modules/libphonenumber-js/source/helpers/getCountryByCallingCode.js","../node_modules/libphonenumber-js/source/helpers/applyInternationalSeparatorStyle.js","../node_modules/libphonenumber-js/source/constants.js","../node_modules/libphonenumber-js/source/helpers/isObject.js","../node_modules/libphonenumber-js/source/helpers/formatNationalNumberUsingFormat.js","../node_modules/libphonenumber-js/source/isValidPhoneNumber.js","../node_modules/libphonenumber-js/source/normalizeArguments.js","../node_modules/libphonenumber-js/source/ParseError.js","../node_modules/libphonenumber-js/source/helpers/matchesEntirely.js","../node_modules/libphonenumber-js/source/helpers/extractNationalNumberFromPossiblyIncompleteNumber.js","../node_modules/libphonenumber-js/source/parsePhoneNumberWithError_.js","../node_modules/libphonenumber-js/source/helpers/parseDigits.js","../node_modules/libphonenumber-js/source/helpers/extractCountryCallingCode.js","../node_modules/libphonenumber-js/source/helpers/getPossibleCountriesForNumber.js","../node_modules/libphonenumber-js/source/PhoneNumber.js","../node_modules/libphonenumber-js/source/helpers/extension/createExtensionPattern.js","../node_modules/libphonenumber-js/source/helpers/stripIddPrefix.js","../node_modules/libphonenumber-js/source/helpers/extension/extractExtension.js","../node_modules/libphonenumber-js/source/helpers/extractPhoneContext.js","../node_modules/libphonenumber-js/source/helpers/extractFormattedPhoneNumberFromPossibleRfc3966NumberUri.js","../node_modules/libphonenumber-js/source/parse.js","../node_modules/libphonenumber-js/source/helpers/checkNumberLength.js","../node_modules/libphonenumber-js/source/helpers/mergeArrays.js","../node_modules/libphonenumber-js/source/helpers/extractCountryCallingCodeFromInternationalNumberWithoutPlusSign.js","../node_modules/libphonenumber-js/source/helpers/getIddPrefix.js","../node_modules/libphonenumber-js/source/format.js","../node_modules/libphonenumber-js/source/isPossible.js","../node_modules/libphonenumber-js/source/helpers/extractNationalNumber.js","../node_modules/libphonenumber-js/source/helpers/isViablePhoneNumber.js","../node_modules/libphonenumber-js/source/parseIncompletePhoneNumber.js","../node_modules/libphonenumber-js/source/helpers/RFC3966.js","../node_modules/libphonenumber-js/source/parsePhoneNumber_.js","../node_modules/libphonenumber-js/source/isValid.js","../node_modules/libphonenumber-js/source/tools/semver-compare.js","../node_modules/libphonenumber-js/source/metadata.js","../node_modules/libphonenumber-js/source/helpers/getCountryByNationalNumber.js","../node_modules/libphonenumber-js/source/helpers/getNumberType.js"],"sourcesContent":["import getCountryByNationalNumber from './getCountryByNationalNumber.js'\r\n\r\nconst USE_NON_GEOGRAPHIC_COUNTRY_CODE = false\r\n\r\n// Returns the exact country for the `nationalNumber`\r\n// that belongs to the specified \"country calling code\".\r\nexport default function getCountryByCallingCode(callingCode, {\r\n\tnationalNumber: nationalPhoneNumber,\r\n\tmetadata\r\n}) {\r\n\t/* istanbul ignore if */\r\n\tif (USE_NON_GEOGRAPHIC_COUNTRY_CODE) {\r\n\t\tif (metadata.isNonGeographicCallingCode(callingCode)) {\r\n\t\t\treturn '001'\r\n\t\t}\r\n\t}\r\n\tconst possibleCountries = metadata.getCountryCodesForCallingCode(callingCode)\r\n\tif (!possibleCountries) {\r\n\t\treturn\r\n\t}\r\n\t// If there's just one country corresponding to the country code,\r\n\t// then just return it, without further phone number digits validation.\r\n\tif (possibleCountries.length === 1) {\r\n\t\treturn possibleCountries[0]\r\n\t}\r\n\treturn getCountryByNationalNumber(nationalPhoneNumber, {\r\n\t\tcountries: possibleCountries,\r\n\t\tmetadata: metadata.metadata\r\n\t})\r\n}","import { VALID_PUNCTUATION } from '../constants.js'\r\n\r\n// Removes brackets and replaces dashes with spaces.\r\n//\r\n// E.g. \"(999) 111-22-33\" -> \"999 111 22 33\"\r\n//\r\n// For some reason Google's metadata contains `<intlFormat/>`s with brackets and dashes.\r\n// Meanwhile, there's no single opinion about using punctuation in international phone numbers.\r\n//\r\n// For example, Google's `<intlFormat/>` for USA is `+1 213-373-4253`.\r\n// And here's a quote from WikiPedia's \"North American Numbering Plan\" page:\r\n// https://en.wikipedia.org/wiki/North_American_Numbering_Plan\r\n//\r\n// \"The country calling code for all countries participating in the NANP is 1.\r\n// In international format, an NANP number should be listed as +1 301 555 01 00,\r\n// where 301 is an area code (Maryland).\"\r\n//\r\n// I personally prefer the international format without any punctuation.\r\n// For example, brackets are remnants of the old age, meaning that the\r\n// phone number part in brackets (so called \"area code\") can be omitted\r\n// if dialing within the same \"area\".\r\n// And hyphens were clearly introduced for splitting local numbers into memorizable groups.\r\n// For example, remembering \"5553535\" is difficult but \"555-35-35\" is much simpler.\r\n// Imagine a man taking a bus from home to work and seeing an ad with a phone number.\r\n// He has a couple of seconds to memorize that number until it passes by.\r\n// If it were spaces instead of hyphens the man wouldn't necessarily get it,\r\n// but with hyphens instead of spaces the grouping is more explicit.\r\n// I personally think that hyphens introduce visual clutter,\r\n// so I prefer replacing them with spaces in international numbers.\r\n// In the modern age all output is done on displays where spaces are clearly distinguishable\r\n// so hyphens can be safely replaced with spaces without losing any legibility.\r\n//\r\nexport default function applyInternationalSeparatorStyle(formattedNumber) {\r\n\treturn formattedNumber.replace(new RegExp(`[${VALID_PUNCTUATION}]+`, 'g'), ' ').trim()\r\n}","// The minimum length of the national significant number.\r\nexport const MIN_LENGTH_FOR_NSN = 2\r\n\r\n// The ITU says the maximum length should be 15,\r\n// but one can find longer numbers in Germany.\r\nexport const MAX_LENGTH_FOR_NSN = 17\r\n\r\n// The maximum length of the country calling code.\r\nexport const MAX_LENGTH_COUNTRY_CODE = 3\r\n\r\n// Digits accepted in phone numbers\r\n// (ascii, fullwidth, arabic-indic, and eastern arabic digits).\r\nexport const VALID_DIGITS = '0-9\\uFF10-\\uFF19\\u0660-\\u0669\\u06F0-\\u06F9'\r\n\r\n// `DASHES` will be right after the opening square bracket of the \"character class\"\r\nconst DASHES = '-\\u2010-\\u2015\\u2212\\u30FC\\uFF0D'\r\nconst SLASHES = '\\uFF0F/'\r\nconst DOTS = '\\uFF0E.'\r\nexport const WHITESPACE = ' \\u00A0\\u00AD\\u200B\\u2060\\u3000'\r\nconst BRACKETS = '()\\uFF08\\uFF09\\uFF3B\\uFF3D\\\\[\\\\]'\r\n// export const OPENING_BRACKETS = '(\\uFF08\\uFF3B\\\\\\['\r\nconst TILDES = '~\\u2053\\u223C\\uFF5E'\r\n\r\n// Regular expression of acceptable punctuation found in phone numbers. This\r\n// excludes punctuation found as a leading character only. This consists of dash\r\n// characters, white space characters, full stops, slashes, square brackets,\r\n// parentheses and tildes. Full-width variants are also present.\r\nexport const VALID_PUNCTUATION = `${DASHES}${SLASHES}${DOTS}${WHITESPACE}${BRACKETS}${TILDES}`\r\n\r\nexport const PLUS_CHARS = '+\\uFF0B'\r\n// const LEADING_PLUS_CHARS_PATTERN = new RegExp('^[' + PLUS_CHARS + ']+')","const objectConstructor = {}.constructor;\r\n\r\nexport default function isObject(object) {\r\n return object !== undefined && object !== null && object.constructor === objectConstructor;\r\n}\r\n","import applyInternationalSeparatorStyle from './applyInternationalSeparatorStyle.js'\r\n\r\n// This was originally set to $1 but there are some countries for which the\r\n// first group is not used in the national pattern (e.g. Argentina) so the $1\r\n// group does not match correctly. Therefore, we use `\\d`, so that the first\r\n// group actually used in the pattern will be matched.\r\nexport const FIRST_GROUP_PATTERN = /(\\$\\d)/\r\n\r\nexport default function formatNationalNumberUsingFormat(\r\n\tnumber,\r\n\tformat,\r\n\t{\r\n\t\tuseInternationalFormat,\r\n\t\twithNationalPrefix,\r\n\t\tcarrierCode,\r\n\t\tmetadata\r\n\t}\r\n) {\r\n\tconst formattedNumber = number.replace(\r\n\t\tnew RegExp(format.pattern()),\r\n\t\tuseInternationalFormat\r\n\t\t\t? format.internationalFormat()\r\n\t\t\t: (\r\n\t\t\t\t// This library doesn't use `domestic_carrier_code_formatting_rule`,\r\n\t\t\t\t// because that one is only used when formatting phone numbers\r\n\t\t\t\t// for dialing from a mobile phone, and this is not a dialing library.\r\n\t\t\t\t// carrierCode && format.domesticCarrierCodeFormattingRule()\r\n\t\t\t\t// \t// First, replace the $CC in the formatting rule with the desired carrier code.\r\n\t\t\t\t// \t// Then, replace the $FG in the formatting rule with the first group\r\n\t\t\t\t// \t// and the carrier code combined in the appropriate way.\r\n\t\t\t\t// \t? format.format().replace(FIRST_GROUP_PATTERN, format.domesticCarrierCodeFormattingRule().replace('$CC', carrierCode))\r\n\t\t\t\t// \t: (\r\n\t\t\t\t// \t\twithNationalPrefix && format.nationalPrefixFormattingRule()\r\n\t\t\t\t// \t\t\t? format.format().replace(FIRST_GROUP_PATTERN, format.nationalPrefixFormattingRule())\r\n\t\t\t\t// \t\t\t: format.format()\r\n\t\t\t\t// \t)\r\n\t\t\t\twithNationalPrefix && format.nationalPrefixFormattingRule()\r\n\t\t\t\t\t? format.format().replace(FIRST_GROUP_PATTERN, format.nationalPrefixFormattingRule())\r\n\t\t\t\t\t: format.format()\r\n\t\t\t)\r\n\t)\r\n\tif (useInternationalFormat) {\r\n\t\treturn applyInternationalSeparatorStyle(formattedNumber)\r\n\t}\r\n\treturn formattedNumber\r\n}","import normalizeArguments from './normalizeArguments.js'\r\nimport parsePhoneNumber from './parsePhoneNumber_.js'\r\n\r\nexport default function isValidPhoneNumber() {\r\n\tlet { text, options, metadata } = normalizeArguments(arguments)\r\n\toptions = {\r\n\t\t...options,\r\n\t\textract: false\r\n\t}\r\n\tconst phoneNumber = parsePhoneNumber(text, options, metadata)\r\n\treturn phoneNumber && phoneNumber.isValid() || false\r\n}","import isObject from './helpers/isObject.js'\r\n\r\n// Extracts the following properties from function arguments:\r\n// * input `text`\r\n// * `options` object\r\n// * `metadata` JSON\r\nexport default function normalizeArguments(args) {\r\n\tconst [arg_1, arg_2, arg_3, arg_4] = Array.prototype.slice.call(args)\r\n\r\n\tlet text\r\n\tlet options\r\n\tlet metadata\r\n\r\n\t// If the phone number is passed as a string.\r\n\t// `parsePhoneNumber('88005553535', ...)`.\r\n\tif (typeof arg_1 === 'string') {\r\n\t\ttext = arg_1\r\n\t}\r\n\telse throw new TypeError('A text for parsing must be a string.')\r\n\r\n\t// If \"default country\" argument is being passed then move it to `options`.\r\n\t// `parsePhoneNumber('88005553535', 'RU', [options], metadata)`.\r\n\tif (!arg_2 || typeof arg_2 === 'string')\r\n\t{\r\n\t\tif (arg_4) {\r\n\t\t\toptions = arg_3\r\n\t\t\tmetadata = arg_4\r\n\t\t} else {\r\n\t\t\toptions = undefined\r\n\t\t\tmetadata = arg_3\r\n\t\t}\r\n\r\n\t\tif (arg_2) {\r\n\t\t\toptions = { defaultCountry: arg_2, ...options }\r\n\t\t}\r\n\t}\r\n\t// `defaultCountry` is not passed.\r\n\t// Example: `parsePhoneNumber('+78005553535', [options], metadata)`.\r\n\telse if (isObject(arg_2))\r\n\t{\r\n\t\tif (arg_3) {\r\n\t\t\toptions = arg_2\r\n\t\t\tmetadata = arg_3\r\n\t\t} else {\r\n\t\t\tmetadata = arg_2\r\n\t\t}\r\n\t}\r\n\telse throw new Error(`Invalid second argument: ${arg_2}`)\r\n\r\n\treturn {\r\n\t\ttext,\r\n\t\toptions,\r\n\t\tmetadata\r\n\t}\r\n}","// https://stackoverflow.com/a/46971044/970769\r\n// \"Breaking changes in Typescript 2.1\"\r\n// \"Extending built-ins like Error, Array, and Map may no longer work.\"\r\n// \"As a recommendation, you can manually adjust the prototype immediately after any super(...) calls.\"\r\n// https://github.com/Microsoft/TypeScript-wiki/blob/main/Breaking-Changes.md#extending-built-ins-like-error-array-and-map-may-no-longer-work\r\nexport default class ParseError extends Error {\r\n constructor(code) {\r\n super(code)\r\n // Set the prototype explicitly.\r\n // Any subclass of FooError will have to manually set the prototype as well.\r\n Object.setPrototypeOf(this, ParseError.prototype)\r\n this.name = this.constructor.name\r\n }\r\n}","/**\r\n * Checks whether the entire input sequence can be matched\r\n * against the regular expression.\r\n * @return {boolean}\r\n */\r\nexport default function matchesEntirely(text, regularExpressionText) {\r\n\t// If the assigning of the `''` default value is moved to the arguments above,\r\n\t// the code coverage would decrease for some weird reason.\r\n\ttext = text || ''\r\n\treturn new RegExp('^(?:' + regularExpressionText + ')$').test(text)\r\n}","/**\r\n * Strips any national prefix (such as 0, 1) present in a\r\n * (possibly incomplete) number provided.\r\n * \"Carrier codes\" are only used in Colombia and Brazil,\r\n * and only when dialing within those countries from a mobile phone to a fixed line number.\r\n * Sometimes it won't actually strip national prefix\r\n * and will instead prepend some digits to the `number`:\r\n * for example, when number `2345678` is passed with `VI` country selected,\r\n * it will return `{ number: \"3402345678\" }`, because `340` area code is prepended.\r\n * @param {string} number — National number digits.\r\n * @param {object} metadata — Metadata with country selected.\r\n * @return {object} `{ nationalNumber: string, nationalPrefix: string? carrierCode: string? }`. Even if a national prefix was extracted, it's not necessarily present in the returned object, so don't rely on its presence in the returned object in order to find out whether a national prefix has been extracted or not.\r\n */\r\nexport default function extractNationalNumberFromPossiblyIncompleteNumber(number, metadata) {\r\n\tif (number && metadata.numberingPlan.nationalPrefixForParsing()) {\r\n\t\t// See METADATA.md for the description of\r\n\t\t// `national_prefix_for_parsing` and `national_prefix_transform_rule`.\r\n\t\t// Attempt to parse the first digits as a national prefix.\r\n\t\tconst prefixPattern = new RegExp('^(?:' + metadata.numberingPlan.nationalPrefixForParsing() + ')')\r\n\t\tconst prefixMatch = prefixPattern.exec(number)\r\n\t\tif (prefixMatch) {\r\n\t\t\tlet nationalNumber\r\n\t\t\tlet carrierCode\r\n\t\t\t// https://gitlab.com/catamphetamine/libphonenumber-js/-/blob/master/METADATA.md#national_prefix_for_parsing--national_prefix_transform_rule\r\n\t\t\t// If a `national_prefix_for_parsing` has any \"capturing groups\"\r\n\t\t\t// then it means that the national (significant) number is equal to\r\n\t\t\t// those \"capturing groups\" transformed via `national_prefix_transform_rule`,\r\n\t\t\t// and nothing could be said about the actual national prefix:\r\n\t\t\t// what is it and was it even there.\r\n\t\t\t// If a `national_prefix_for_parsing` doesn't have any \"capturing groups\",\r\n\t\t\t// then everything it matches is a national prefix.\r\n\t\t\t// To determine whether `national_prefix_for_parsing` matched any\r\n\t\t\t// \"capturing groups\", the value of the result of calling `.exec()`\r\n\t\t\t// is looked at, and if it has non-undefined values where there're\r\n\t\t\t// \"capturing groups\" in the regular expression, then it means\r\n\t\t\t// that \"capturing groups\" have been matched.\r\n\t\t\t// It's not possible to tell whether there'll be any \"capturing gropus\"\r\n\t\t\t// before the matching process, because a `national_prefix_for_parsing`\r\n\t\t\t// could exhibit both behaviors.\r\n\t\t\tconst capturedGroupsCount = prefixMatch.length - 1\r\n\t\t\tconst hasCapturedGroups = capturedGroupsCount > 0 && prefixMatch[capturedGroupsCount]\r\n\t\t\tif (metadata.nationalPrefixTransformRule() && hasCapturedGroups) {\r\n\t\t\t\tnationalNumber = number.replace(\r\n\t\t\t\t\tprefixPattern,\r\n\t\t\t\t\tmetadata.nationalPrefixTransformRule()\r\n\t\t\t\t)\r\n\t\t\t\t// If there's more than one captured group,\r\n\t\t\t\t// then carrier code is the second one.\r\n\t\t\t\tif (capturedGroupsCount > 1) {\r\n\t\t\t\t\tcarrierCode = prefixMatch[1]\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\t// If there're no \"capturing groups\",\r\n\t\t\t// or if there're \"capturing groups\" but no\r\n\t\t\t// `national_prefix_transform_rule`,\r\n\t\t\t// then just strip the national prefix from the number,\r\n\t\t\t// and possibly a carrier code.\r\n\t\t\t// Seems like there could be more.\r\n\t\t\telse {\r\n\t\t\t\t// `prefixBeforeNationalNumber` is the whole substring matched by\r\n\t\t\t\t// the `national_prefix_for_parsing` regular expression.\r\n\t\t\t\t// There seem to be no guarantees that it's just a national prefix.\r\n\t\t\t\t// For example, if there's a carrier code, it's gonna be a\r\n\t\t\t\t// part of `prefixBeforeNationalNumber` too.\r\n\t\t\t\tconst prefixBeforeNationalNumber = prefixMatch[0]\r\n\t\t\t\tnationalNumber = number.slice(prefixBeforeNationalNumber.length)\r\n\t\t\t\t// If there's at least one captured group,\r\n\t\t\t\t// then carrier code is the first one.\r\n\t\t\t\tif (hasCapturedGroups) {\r\n\t\t\t\t\tcarrierCode = prefixMatch[1]\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\t// Tries to guess whether a national prefix was present in the input.\r\n\t\t\t// This is not something copy-pasted from Google's library:\r\n\t\t\t// they don't seem to have an equivalent for that.\r\n\t\t\t// So this isn't an \"officially approved\" way of doing something like that.\r\n\t\t\t// But since there seems no other existing method, this library uses it.\r\n\t\t\tlet nationalPrefix\r\n\t\t\tif (hasCapturedGroups) {\r\n\t\t\t\tconst possiblePositionOfTheFirstCapturedGroup = number.indexOf(prefixMatch[1])\r\n\t\t\t\tconst possibleNationalPrefix = number.slice(0, possiblePositionOfTheFirstCapturedGroup)\r\n\t\t\t\t// Example: an Argentinian (AR) phone number `0111523456789`.\r\n\t\t\t\t// `prefixMatch[0]` is `01115`, and `$1` is `11`,\r\n\t\t\t\t// and the rest of the phone number is `23456789`.\r\n\t\t\t\t// The national number is transformed via `9$1` to `91123456789`.\r\n\t\t\t\t// National prefix `0` is detected being present at the start.\r\n\t\t\t\t// if (possibleNationalPrefix.indexOf(metadata.numberingPlan.nationalPrefix()) === 0) {\r\n\t\t\t\tif (possibleNationalPrefix === metadata.numberingPlan.nationalPrefix()) {\r\n\t\t\t\t\tnationalPrefix = metadata.numberingPlan.nationalPrefix()\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\tnationalPrefix = prefixMatch[0]\r\n\t\t\t}\r\n\t\t\treturn {\r\n\t\t\t\tnationalNumber,\r\n\t\t\t\tnationalPrefix,\r\n\t\t\t\tcarrierCode\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n return {\r\n \tnationalNumber: number\r\n }\r\n}","import parse from './parse.js'\r\n\r\nexport default function parsePhoneNumberWithError(text, options, metadata) {\r\n\treturn parse(text, { ...options, v2: true }, metadata)\r\n}","// These mappings map a character (key) to a specific digit that should\r\n// replace it for normalization purposes. Non-European digits that\r\n// may be used in phone numbers are mapped to a European equivalent.\r\n//\r\n// E.g. in Iraq they don't write `+442323234` but rather `+٤٤٢٣٢٣٢٣٤`.\r\n//\r\nexport const DIGITS = {\r\n\t'0': '0',\r\n\t'1': '1',\r\n\t'2': '2',\r\n\t'3': '3',\r\n\t'4': '4',\r\n\t'5': '5',\r\n\t'6': '6',\r\n\t'7': '7',\r\n\t'8': '8',\r\n\t'9': '9',\r\n\t'\\uFF10': '0', // Fullwidth digit 0\r\n\t'\\uFF11': '1', // Fullwidth digit 1\r\n\t'\\uFF12': '2', // Fullwidth digit 2\r\n\t'\\uFF13': '3', // Fullwidth digit 3\r\n\t'\\uFF14': '4', // Fullwidth digit 4\r\n\t'\\uFF15': '5', // Fullwidth digit 5\r\n\t'\\uFF16': '6', // Fullwidth digit 6\r\n\t'\\uFF17': '7', // Fullwidth digit 7\r\n\t'\\uFF18': '8', // Fullwidth digit 8\r\n\t'\\uFF19': '9', // Fullwidth digit 9\r\n\t'\\u0660': '0', // Arabic-indic digit 0\r\n\t'\\u0661': '1', // Arabic-indic digit 1\r\n\t'\\u0662': '2', // Arabic-indic digit 2\r\n\t'\\u0663': '3', // Arabic-indic digit 3\r\n\t'\\u0664': '4', // Arabic-indic digit 4\r\n\t'\\u0665': '5', // Arabic-indic digit 5\r\n\t'\\u0666': '6', // Arabic-indic digit 6\r\n\t'\\u0667': '7', // Arabic-indic digit 7\r\n\t'\\u0668': '8', // Arabic-indic digit 8\r\n\t'\\u0669': '9', // Arabic-indic digit 9\r\n\t'\\u06F0': '0', // Eastern-Arabic digit 0\r\n\t'\\u06F1': '1', // Eastern-Arabic digit 1\r\n\t'\\u06F2': '2', // Eastern-Arabic digit 2\r\n\t'\\u06F3': '3', // Eastern-Arabic digit 3\r\n\t'\\u06F4': '4', // Eastern-Arabic digit 4\r\n\t'\\u06F5': '5', // Eastern-Arabic digit 5\r\n\t'\\u06F6': '6', // Eastern-Arabic digit 6\r\n\t'\\u06F7': '7', // Eastern-Arabic digit 7\r\n\t'\\u06F8': '8', // Eastern-Arabic digit 8\r\n\t'\\u06F9': '9' // Eastern-Arabic digit 9\r\n}\r\n\r\nexport function parseDigit(character) {\r\n\treturn DIGITS[character]\r\n}\r\n\r\n/**\r\n * Parses phone number digits from a string.\r\n * Drops all punctuation leaving only digits.\r\n * Also converts wide-ascii and arabic-indic numerals to conventional numerals.\r\n * E.g. in Iraq they don't write `+442323234` but rather `+٤٤٢٣٢٣٢٣٤`.\r\n * @param {string} string\r\n * @return {string}\r\n * @example\r\n * ```js\r\n * parseDigits('8 (800) 555')\r\n * // Outputs '8800555'.\r\n * ```\r\n */\r\nexport default function parseDigits(string) {\r\n\tlet result = ''\r\n\t// Using `.split('')` here instead of normal `for ... of`\r\n\t// because the importing application doesn't neccessarily include an ES6 polyfill.\r\n\t// The `.split('')` approach discards \"exotic\" UTF-8 characters\r\n\t// (the ones consisting of four bytes) but digits\r\n\t// (including non-European ones) don't fall into that range\r\n\t// so such \"exotic\" characters would be discarded anyway.\r\n\tfor (const character of string.split('')) {\r\n\t\tconst digit = parseDigit(character)\r\n\t\tif (digit) {\r\n\t\t\tresult += digit\r\n\t\t}\r\n\t}\r\n\treturn result\r\n}","import stripIddPrefix from './stripIddPrefix.js'\r\nimport extractCountryCallingCodeFromInternationalNumberWithoutPlusSign from './extractCountryCallingCodeFromInternationalNumberWithoutPlusSign.js'\r\nimport Metadata from '../metadata.js'\r\nimport { MAX_LENGTH_COUNTRY_CODE } from '../constants.js'\r\n\r\n/**\r\n * Converts a phone number digits (possibly with a `+`)\r\n * into a calling code and the rest phone number digits.\r\n * The \"rest phone number digits\" could include\r\n * a national prefix, carrier code, and national\r\n * (significant) number.\r\n * @param {string} number — Phone number digits (possibly with a `+`).\r\n * @param {string} [country] — Country.\r\n * @param {string} [defaultCountry] — Default country.\r\n * @param {string} [defaultCallingCode] — Default calling code (some phone numbering plans are non-geographic).\r\n * @param {object} metadata\r\n * @return {object} `{ countryCallingCodeSource: string?, countryCallingCode: string?, number: string }`\r\n * @example\r\n * // Returns `{ countryCallingCode: \"1\", number: \"2133734253\" }`.\r\n * extractCountryCallingCode('2133734253', null, 'US', null, metadata)\r\n * extractCountryCallingCode('2133734253', null, null, '1', metadata)\r\n * extractCountryCallingCode('+12133734253', null, null, null, metadata)\r\n * extractCountryCallingCode('+12133734253', null, 'RU', null, metadata)\r\n */\r\nexport default function extractCountryCallingCode(\r\n\tnumber,\r\n\tcountry,\r\n\tdefaultCountry,\r\n\tdefaultCallingCode,\r\n\tmetadata\r\n) {\r\n\tif (!number) {\r\n\t\treturn {}\r\n\t}\r\n\r\n\tlet isNumberWithIddPrefix\r\n\r\n\t// If this is not an international phone number,\r\n\t// then either extract an \"IDD\" prefix, or extract a\r\n\t// country calling code from a number by autocorrecting it\r\n\t// by prepending a leading `+` in cases when it starts\r\n\t// with the country calling code.\r\n\t// https://wikitravel.org/en/International_dialling_prefix\r\n\t// https://github.com/catamphetamine/libphonenumber-js/issues/376\r\n\tif (number[0] !== '+') {\r\n\t\t// Convert an \"out-of-country\" dialing phone number\r\n\t\t// to a proper international phone number.\r\n\t\tconst numberWithoutIDD = stripIddPrefix(number, country || defaultCountry, defaultCallingCode, metadata)\r\n\t\t// If an IDD prefix was stripped then\r\n\t\t// convert the number to international one\r\n\t\t// for subsequent parsing.\r\n\t\tif (numberWithoutIDD && numberWithoutIDD !== number) {\r\n\t\t\tisNumberWithIddPrefix = true\r\n\t\t\tnumber = '+' + numberWithoutIDD\r\n\t\t} else {\r\n\t\t\t// Check to see if the number starts with the country calling code\r\n\t\t\t// for the default country. If so, we remove the country calling code,\r\n\t\t\t// and do some checks on the validity of the number before and after.\r\n\t\t\t// https://github.com/catamphetamine/libphonenumber-js/issues/376\r\n\t\t\tif (country || defaultCountry || defaultCallingCode) {\r\n\t\t\t\tconst {\r\n\t\t\t\t\tcountryCallingCode,\r\n\t\t\t\t\tnumber: shorterNumber\r\n\t\t\t\t} = extractCountryCallingCodeFromInternationalNumberWithoutPlusSign(\r\n\t\t\t\t\tnumber,\r\n\t\t\t\t\tcountry,\r\n\t\t\t\t\tdefaultCountry,\r\n\t\t\t\t\tdefaultCallingCode,\r\n\t\t\t\t\tmetadata\r\n\t\t\t\t)\r\n\t\t\t\tif (countryCallingCode) {\r\n\t\t\t\t\treturn {\r\n\t\t\t\t\t\tcountryCallingCodeSource: 'FROM_NUMBER_WITHOUT_PLUS_SIGN',\r\n\t\t\t\t\t\tcountryCallingCode,\r\n\t\t\t\t\t\tnumber: shorterNumber\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\treturn {\r\n\t\t\t\t// No need to set it to `UNSPECIFIED`. It can be just `undefined`.\r\n\t\t\t\t// countryCallingCodeSource: 'UNSPECIFIED',\r\n\t\t\t\tnumber\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t// `number` can only be international at this point.\r\n\r\n\t// Fast abortion: country codes do not begin with a '0'\r\n\tif (number[1] === '0') {\r\n\t\treturn {}\r\n\t}\r\n\r\n\tmetadata = new Metadata(metadata)\r\n\r\n\t// The thing with country phone codes\r\n\t// is that they are orthogonal to each other\r\n\t// i.e. there's no such country phone code A\r\n\t// for which country phone code B exists\r\n\t// where B starts with A.\r\n\t// Therefore, while scanning digits,\r\n\t// if a valid country code is found,\r\n\t// that means that it is the country code.\r\n\t//\r\n\tlet i = 2\r\n\twhile (i - 1 <= MAX_LENGTH_COUNTRY_CODE && i <= number.length) {\r\n\t\tconst countryCallingCode = number.slice(1, i)\r\n\t\tif (metadata.hasCallingCode(countryCallingCode)) {\r\n\t\t\tmetadata.selectNumberingPlan(countryCallingCode)\r\n\t\t\treturn {\r\n\t\t\t\tcountryCallingCodeSource: isNumberWithIddPrefix ? 'FROM_NUMBER_WITH_IDD' : 'FROM_NUMBER_WITH_PLUS_SIGN',\r\n\t\t\t\tcountryCallingCode,\r\n\t\t\t\tnumber: number.slice(i)\r\n\t\t\t}\r\n\t\t}\r\n\t\ti++\r\n\t}\r\n\r\n\treturn {}\r\n}\r\n\r\n// The possible values for the returned `countryCallingCodeSource` are:\r\n//\r\n// Copy-pasted from:\r\n// https://github.com/google/libphonenumber/blob/master/resources/phonenumber.proto\r\n//\r\n// // The source from which the country_code is derived. This is not set in the\r\n// // general parsing method, but in the method that parses and keeps raw_input.\r\n// // New fields could be added upon request.\r\n// enum CountryCodeSource {\r\n// // Default value returned if this is not set, because the phone number was\r\n// // created using parse, not parseAndKeepRawInput. hasCountryCodeSource will\r\n// // return false if this is the case.\r\n// UNSPECIFIED = 0;\r\n//\r\n// // The country_code is derived based on a phone number with a leading \"+\",\r\n// // e.g. the French number \"+33 1 42 68 53 00\".\r\n// FROM_NUMBER_WITH_PLUS_SIGN = 1;\r\n//\r\n// // The country_code is derived based on a phone number with a leading IDD,\r\n// // e.g. the French number \"011 33 1 42 68 53 00\", as it is dialled from US.\r\n// FROM_NUMBER_WITH_IDD = 5;\r\n//\r\n// // The country_code is derived based on a phone number without a leading\r\n// // \"+\", e.g. the French number \"33 1 42 68 53 00\" when defaultCountry is\r\n// // supplied as France.\r\n// FROM_NUMBER_WITHOUT_PLUS_SIGN = 10;\r\n//\r\n// // The country_code is derived NOT based on the phone number itself, but\r\n// // from the defaultCountry parameter provided in the parsing function by the\r\n// // clients. This happens mostly for numbers written in the national format\r\n// // (without country code). For example, this would be set when parsing the\r\n// // French number \"01 42 68 53 00\", when defaultCountry is supplied as\r\n// // France.\r\n// FROM_DEFAULT_COUNTRY = 20;\r\n// }","import Metadata from '../metadata.js'\r\n\r\n/**\r\n * Returns a list of countries that the phone number could potentially belong to.\r\n * @param {string} callingCode — Calling code.\r\n * @param {string} nationalNumber — National (significant) number.\r\n * @param {object} metadata — Metadata.\r\n * @return {string[]} A list of possible countries.\r\n */\r\nexport default function getPossibleCountriesForNumber(callingCode, nationalNumber, metadata) {\r\n\tconst _metadata = new Metadata(metadata)\r\n\tlet possibleCountries = _metadata.getCountryCodesForCallingCode(callingCode)\r\n\tif (!possibleCountries) {\r\n\t\treturn []\r\n\t}\r\n\treturn possibleCountries.filter((country) => {\r\n\t\treturn couldNationalNumberBelongToCountry(nationalNumber, country, metadata)\r\n\t})\r\n}\r\n\r\nfunction couldNationalNumberBelongToCountry(nationalNumber, country, metadata) {\r\n\tconst _metadata = new Metadata(metadata)\r\n\t_metadata.selectNumberingPlan(country)\r\n\tif (_metadata.numberingPlan.possibleLengths().indexOf(nationalNumber.length) >= 0) {\r\n\t\treturn true\r\n\t}\r\n\treturn false\r\n}","import Metadata, { validateMetadata } from './metadata.js'\r\nimport isPossibleNumber from './isPossible.js'\r\nimport isValidNumber from './isValid.js'\r\nimport getNumberType from './helpers/getNumberType.js'\r\nimport getPossibleCountriesForNumber from './helpers/getPossibleCountriesForNumber.js'\r\nimport extractCountryCallingCode from './helpers/extractCountryCallingCode.js'\r\nimport isObject from './helpers/isObject.js'\r\nimport formatNumber from './format.js'\r\n\r\nconst USE_NON_GEOGRAPHIC_COUNTRY_CODE = false\r\n\r\nexport default class PhoneNumber {\r\n\t/**\r\n\t * @param {string} countryOrCountryCallingCode\r\n\t * @param {string} nationalNumber\r\n\t * @param {object} metadata — Metadata JSON\r\n\t * @return {PhoneNumber}\r\n\t */\r\n\tconstructor(countryOrCountryCallingCode, nationalNumber, metadata) {\r\n\t\t// Validate `countryOrCountryCallingCode` argument.\r\n\t\tif (!countryOrCountryCallingCode) {\r\n\t\t\tthrow new TypeError('First argument is required')\r\n\t\t}\r\n\t\tif (typeof countryOrCountryCallingCode !== 'string') {\r\n\t\t\tthrow new TypeError('First argument must be a string')\r\n\t\t}\r\n\r\n\t\t// In case of public API use: `constructor(number, metadata)`.\r\n\t\t// Transform the arguments from `constructor(number, metadata)` to\r\n\t\t// `constructor(countryOrCountryCallingCode, nationalNumber, metadata)`.\r\n\t\tif (countryOrCountryCallingCode[0] === '+' && !nationalNumber) {\r\n\t\t\tthrow new TypeError('`metadata` argument not passed')\r\n\t\t}\r\n\t\tif (isObject(nationalNumber) && isObject(nationalNumber.countries)) {\r\n\t\t\tmetadata = nationalNumber\r\n\t\t\tconst e164Number = countryOrCountryCallingCode\r\n\t\t\tif (!E164_NUMBER_REGEXP.test(e164Number)) {\r\n\t\t\t\tthrow new Error('Invalid `number` argument passed: must consist of a \"+\" followed by digits')\r\n\t\t\t}\r\n\t\t\tconst { countryCallingCode, number } = extractCountryCallingCode(e164Number, undefined, undefined, undefined, metadata)\r\n\t\t\tnationalNumber = number\r\n\t\t\tcountryOrCountryCallingCode = countryCallingCode\r\n\t\t\tif (!nationalNumber) {\r\n\t\t\t\tthrow new Error('Invalid `number` argument passed: too short')\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// Validate `nationalNumber` argument.\r\n\t\tif (!nationalNumber) {\r\n\t\t\tthrow new TypeError('`nationalNumber` argument is required')\r\n\t\t}\r\n\t\tif (typeof nationalNumber !== 'string') {\r\n\t\t\tthrow new TypeError('`nationalNumber` argument must be a string')\r\n\t\t}\r\n\r\n\t\t// Validate `metadata` argument.\r\n\t\tvalidateMetadata(metadata)\r\n\r\n\t\t// Initialize properties.\r\n\t\tconst { country, countryCallingCode } = getCountryAndCountryCallingCode(\r\n\t\t\tcountryOrCountryCallingCode,\r\n\t\t\tmetadata\r\n\t\t)\r\n\t\tthis.country = country\r\n\t\tthis.countryCallingCode = countryCallingCode\r\n\t\tthis.nationalNumber = nationalNumber\r\n\t\tthis.number = '+' + this.countryCallingCode + this.nationalNumber\r\n\t\t// Exclude `metadata` property output from `PhoneNumber.toString()`\r\n\t\t// so that it doesn't clutter the console output of Node.js.\r\n\t\t// Previously, when Node.js did `console.log(new PhoneNumber(...))`,\r\n\t\t// it would output the whole internal structure of the `metadata` object.\r\n\t\tthis.getMetadata = () => metadata\r\n\t}\r\n\r\n\tsetExt(ext) {\r\n\t\tthis.ext = ext\r\n\t}\r\n\r\n\tgetPossibleCountries() {\r\n\t\tif (this.country) {\r\n\t\t\treturn [this.country]\r\n\t\t}\r\n\t\treturn getPossibleCountriesForNumber(\r\n\t\t\tthis.countryCallingCode,\r\n\t\t\tthis.nationalNumber,\r\n\t\t\tthis.getMetadata()\r\n\t\t)\r\n\t}\r\n\r\n\tisPossible() {\r\n\t\treturn isPossibleNumber(this, { v2: true }, this.getMetadata())\r\n\t}\r\n\r\n\tisValid() {\r\n\t\treturn isValidNumber(this, { v2: true }, this.getMetadata())\r\n\t}\r\n\r\n\tisNonGeographic() {\r\n\t\tconst metadata = new Metadata(this.getMetadata())\r\n\t\treturn metadata.isNonGeographicCallingCode(this.countryCallingCode)\r\n\t}\r\n\r\n\tisEqual(phoneNumber) {\r\n\t\treturn this.number === phoneNumber.number && this.ext === phoneNumber.ext\r\n\t}\r\n\r\n\t// This function was originally meant to be an equivalent for `validatePhoneNumberLength()`,\r\n\t// but later it was found out that it doesn't include the possible `TOO_SHORT` result\r\n\t// returned from `parsePhoneNumberWithError()` in the original `validatePhoneNumberLength()`,\r\n\t// so eventually I simply commented out this method from the `PhoneNumber` class\r\n\t// and just left the `validatePhoneNumberLength()` function, even though that one would require\r\n\t// and additional step to also validate the actual country / calling code of the phone number.\r\n\t// validateLength() {\r\n\t// \tconst metadata = new Metadata(this.getMetadata())\r\n\t// \tmetadata.selectNumberingPlan(this.countryCallingCode)\r\n\t// \tconst result = checkNumberLength(this.nationalNumber, metadata)\r\n\t// \tif (result !== 'IS_POSSIBLE') {\r\n\t// \t\treturn result\r\n\t// \t}\r\n\t// }\r\n\r\n\tgetType() {\r\n\t\treturn getNumberType(this, { v2: true }, this.getMetadata())\r\n\t}\r\n\r\n\tformat(format, options) {\r\n\t\treturn formatNumber(\r\n\t\t\tthis,\r\n\t\t\tformat,\r\n\t\t\toptions ? { ...options, v2: true } : { v2: true },\r\n\t\t\tthis.getMetadata()\r\n\t\t)\r\n\t}\r\n\r\n\tformatNational(options) {\r\n\t\treturn this.format('NATIONAL', options)\r\n\t}\r\n\r\n\tformatInternational(options) {\r\n\t\treturn this.format('INTERNATIONAL', options)\r\n\t}\r\n\r\n\tgetURI(options) {\r\n\t\treturn this.format('RFC3966', options)\r\n\t}\r\n}\r\n\r\nconst isCountryCode = (value) => /^[A-Z]{2}$/.test(value)\r\n\r\nfunction getCountryAndCountryCallingCode(countryOrCountryCallingCode, metadataJson) {\r\n\tlet country\r\n\tlet countryCallingCode\r\n\r\n\tconst metadata = new Metadata(metadataJson)\r\n\t// If country code is passed then derive `countryCallingCode` from it.\r\n\t// Also store the country code as `.country`.\r\n\tif (isCountryCode(countryOrCountryCallingCode)) {\r\n\t\tcountry = countryOrCountryCallingCode\r\n\t\tmetadata.selectNumberingPlan(country)\r\n\t\tcountryCallingCode = metadata.countryCallingCode()\r\n\t} else {\r\n\t\tcountryCallingCode = countryOrCountryCallingCode\r\n\t\t/* istanbul ignore if */\r\n\t\tif (USE_NON_GEOGRAPHIC_COUNTRY_CODE) {\r\n\t\t\tif (metadata.isNonGeographicCallingCode(countryCallingCode)) {\r\n\t\t\t\tcountry = '001'\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\treturn {\r\n\t\tcountry,\r\n\t\tcountryCallingCode\r\n\t}\r\n}\r\n\r\nconst E164_NUMBER_REGEXP = /^\\+\\d+$/","import { VALID_DIGITS } from '../../constants.js'\r\n\r\n// The RFC 3966 format for extensions.\r\nconst RFC3966_EXTN_PREFIX = ';ext='\r\n\r\n/**\r\n * Helper method for constructing regular expressions for parsing. Creates\r\n * an expression that captures up to max_length digits.\r\n * @return {string} RegEx pattern to capture extension digits.\r\n */\r\nconst getExtensionDigitsPattern = (maxLength) => `([${VALID_DIGITS}]{1,${maxLength}})`\r\n\r\n/**\r\n * Helper initialiser method to create the regular-expression pattern to match\r\n * extensions.\r\n * Copy-pasted from Google's `libphonenumber`:\r\n * https://github.com/google/libphonenumber/blob/55b2646ec9393f4d3d6661b9c82ef9e258e8b829/javascript/i18n/phonenumbers/phonenumberutil.js#L759-L766\r\n * @return {string} RegEx pattern to capture extensions.\r\n */\r\nexport default function createExtensionPattern(purpose) {\r\n\t// We cap the maximum length of an extension based on the ambiguity of the way\r\n\t// the extension is prefixed. As per ITU, the officially allowed length for\r\n\t// extensions is actually 40, but we don't support this since we haven't seen real\r\n\t// examples and this introduces many false interpretations as the extension labels\r\n\t// are not standardized.\r\n\t/** @type {string} */\r\n\tvar extLimitAfterExplicitLabel = '20';\r\n\t/** @type {string} */\r\n\tvar extLimitAfterLikelyLabel = '15';\r\n\t/** @type {string} */\r\n\tvar extLimitAfterAmbiguousChar = '9';\r\n\t/** @type {string} */\r\n\tvar extLimitWhenNotSure = '6';\r\n\r\n\t/** @type {string} */\r\n\tvar possibleSeparatorsBetweenNumberAndExtLabel = \"[ \\u00A0\\\\t,]*\";\r\n\t// Optional full stop (.) or colon, followed by zero or more spaces/tabs/commas.\r\n\t/** @type {string} */\r\n\tvar possibleCharsAfterExtLabel = \"[:\\\\.\\uFF0E]?[ \\u00A0\\\\t,-]*\";\r\n\t/** @type {string} */\r\n\tvar optionalExtnSuffix = \"#?\";\r\n\r\n\t// Here the extension is called out in more explicit way, i.e mentioning it obvious\r\n\t// patterns like \"ext.\".\r\n\t/** @type {string} */\r\n\tvar explicitExtLabels =\r\n\t \"(?:e?xt(?:ensi(?:o\\u0301?|\\u00F3))?n?|\\uFF45?\\uFF58\\uFF54\\uFF4E?|\\u0434\\u043E\\u0431|anexo)\";\r\n\t// One-character symbols that can be used to indicate an extension, and less\r\n\t// commonly used or more ambiguous extension labels.\r\n\t/** @type {string} */\r\n\tvar ambiguousExtLabels = \"(?:[x\\uFF58#\\uFF03~\\uFF5E]|int|\\uFF49\\uFF4E\\uFF54)\";\r\n\t// When extension is not separated clearly.\r\n\t/** @type {string} */\r\n\tvar ambiguousSeparator = \"[- ]+\";\r\n\t// This is the same as possibleSeparatorsBetweenNumberAndExtLabel, but not matching\r\n\t// comma as extension label may have it.\r\n\t/** @type {string} */\r\n\tvar possibleSeparatorsNumberExtLabelNoComma = \"[ \\u00A0\\\\t]*\";\r\n\t// \",,\" is commonly used for auto dialling the extension when connected. First\r\n\t// comma is matched through possibleSeparatorsBetweenNumberAndExtLabel, so we do\r\n\t// not repeat it here. Semi-colon works in Iphone and Android also to pop up a\r\n\t// button with the extension number following.\r\n\t/** @type {string} */\r\n\tvar autoDiallingAndExtLabelsFound = \"(?:,{2}|;)\";\r\n\r\n\t/** @type {string} */\r\n\tvar rfcExtn = RFC3966_EXTN_PREFIX\r\n\t + getExtensionDigitsPattern(extLimitAfterExplicitLabel);\r\n\t/** @type {string} */\r\n\tvar explicitExtn = possibleSeparatorsBetweenNumberAndExtLabel + explicitExtLabels\r\n\t + possibleCharsAfterExtLabel\r\n\t + getExtensionDigitsPattern(extLimitAfterExplicitLabel)\r\n\t + optionalExtnSuffix;\r\n\t/** @type {string} */\r\n\tvar ambiguousExtn = possibleSeparatorsBetweenNumberAndExtLabel + ambiguousExtLabels\r\n\t + possibleCharsAfterExtLabel\r\n\t+ getExtensionDigitsPattern(extLimitAfterAmbiguousChar)\r\n\t+ optionalExtnSuffix;\r\n\t/** @type {string} */\r\n\tvar americanStyleExtnWithSuffix = ambiguousSeparator\r\n\t+ getExtensionDigitsPattern(extLimitWhenNotSure) + \"#\";\r\n\r\n\t/** @type {string} */\r\n\tvar autoDiallingExtn = possibleSeparatorsNumberExtLabelNoComma\r\n\t + autoDiallingAndExtLabelsFound + possibleCharsAfterExtLabel\r\n\t + getExtensionDigitsPattern(extLimitAfterLikelyLabel)\r\n\t+ optionalExtnSuffix;\r\n\t/** @type {string} */\r\n\tvar onlyCommasExtn = possibleSeparatorsNumberExtLabelNoComma\r\n\t + \"(?:,)+\" + possibleCharsAfterExtLabel\r\n\t + getExtensionDigitsPattern(extLimitAfterAmbiguousChar)\r\n\t + optionalExtnSuffix;\r\n\r\n\t// The first regular expression covers RFC 3966 format, where the extension is added\r\n\t// using \";ext=\". The second more generic where extension is mentioned with explicit\r\n\t// labels like \"ext:\". In both the above cases we allow more numbers in extension than\r\n\t// any other extension labels. The third one captures when single character extension\r\n\t// labels or less commonly used labels are used. In such cases we capture fewer\r\n\t// extension digits in order to reduce the chance of falsely interpreting two\r\n\t// numbers beside each other as a number + extension. The fourth one covers the\r\n\t// special case of American numbers where the extension is written with a hash\r\n\t// at the end, such as \"- 503#\". The fifth one is exclusively for extension\r\n\t// autodialling formats which are used when dialling and in this case we accept longer\r\n\t// extensions. The last one is more liberal on the number of commas that acts as\r\n\t// extension labels, so we have a strict cap on the number of digits in such extensions.\r\n\treturn rfcExtn + \"|\"\r\n\t + explicitExtn + \"|\"\r\n\t + ambiguousExtn + \"|\"\r\n\t + americanStyleExtnWithSuffix + \"|\"\r\n\t + autoDiallingExtn + \"|\"\r\n\t + onlyCommasExtn;\r\n}","import Metadata from '../metadata.js'\r\nimport { VALID_DIGITS } from '../constants.js'\r\n\r\nconst CAPTURING_DIGIT_PATTERN = new RegExp('([' + VALID_DIGITS + '])')\r\n\r\nexport default function stripIddPrefix(number, country, callingCode, metadata) {\r\n\tif (!country) {\r\n\t\treturn\r\n\t}\r\n\t// Check if the number is IDD-prefixed.\r\n\tconst countryMetadata = new Metadata(metadata)\r\n\tcountryMetadata.selectNumberingPlan(country, callingCode)\r\n\tconst IDDPrefixPattern = new RegExp(countryMetadata.IDDPrefix())\r\n\tif (number.search(IDDPrefixPattern) !== 0) {\r\n\t\treturn\r\n\t}\r\n\t// Strip IDD prefix.\r\n\tnumber = number.slice(number.match(IDDPrefixPattern)[0].length)\r\n\t// If there're any digits after an IDD prefix,\r\n\t// then those digits are a country calling code.\r\n\t// Since no country code starts with a `0`,\r\n\t// the code below validates that the next digit (if present) is not `0`.\r\n\tconst matchedGroups = number.match(CAPTURING_DIGIT_PATTERN)\r\n\tif (matchedGroups && matchedGroups[1] != null && matchedGroups[1].length > 0) {\r\n\t\tif (matchedGroups[1] === '0') {\r\n\t\t\treturn\r\n\t\t}\r\n\t}\r\n\treturn number\r\n}","import createExtensionPattern from './createExtensionPattern.js'\r\n\r\n// Regexp of all known extension prefixes used by different regions followed by\r\n// 1 or more valid digits, for use when parsing.\r\nconst EXTN_PATTERN = new RegExp('(?:' + createExtensionPattern() + ')$', 'i')\r\n\r\n// Strips any extension (as in, the part of the number dialled after the call is\r\n// connected, usually indicated with extn, ext, x or similar) from the end of\r\n// the number, and returns it.\r\nexport default function extractExtension(number) {\r\n\tconst start = number.search(EXTN_PATTERN)\r\n\tif (start < 0) {\r\n\t\treturn {}\r\n\t}\r\n\t// If we find a potential extension, and the number preceding this is a viable\r\n\t// number, we assume it is an extension.\r\n\tconst numberWithoutExtension = number.slice(0, start)\r\n\tconst matches = number.match(EXTN_PATTERN)\r\n\tlet i = 1\r\n\twhile (i < matches.length) {\r\n\t\tif (matches[i]) {\r\n\t\t\treturn {\r\n\t\t\t\tnumber: numberWithoutExtension,\r\n\t\t\t\text: matches[i]\r\n\t\t\t}\r\n\t\t}\r\n\t\ti++\r\n\t}\r\n}","// When phone numbers are written in `RFC3966` format — `\"tel:+12133734253\"` —\r\n// they can have their \"calling code\" part written separately in a `phone-context` parameter.\r\n// Example: `\"tel:12133734253;phone-context=+1\"`.\r\n// This function parses the full phone number from the local number and the `phone-context`\r\n// when the `phone-context` contains a `+` sign.\r\n\r\nimport {\r\n VALID_DIGITS,\r\n // PLUS_CHARS\r\n} from '../constants.js'\r\n\r\nexport const PLUS_SIGN = '+'\r\n\r\nconst RFC3966_VISUAL_SEPARATOR_ = '[\\\\-\\\\.\\\\(\\\\)]?'\r\n\r\nconst RFC3966_PHONE_DIGIT_ = '(' + '[' + VALID_DIGITS + ']' + '|' + RFC3966_VISUAL_SEPARATOR_ + ')'\r\n\r\nconst RFC3966_GLOBAL_NUMBER_DIGITS_ =\r\n\t'^' +\r\n\t'\\\\' +\r\n\tPLUS_SIGN +\r\n\tRFC3966_PHONE_DIGIT_ +\r\n\t'*' +\r\n\t'[' + VALID_DIGITS + ']' +\r\n\tRFC3966_PHONE_DIGIT_ +\r\n\t'*' +\r\n\t'$'\r\n\r\n/**\r\n * Regular expression of valid global-number-digits for the phone-context\r\n * parameter, following the syntax defined in RFC3966.\r\n */\r\nconst RFC3966_GLOBAL_NUMBER_DIGITS_PATTERN_ = new RegExp(RFC3966_GLOBAL_NUMBER_DIGITS_, 'g')\r\n\r\n// In this port of Google's library, we don't accept alpha characters in phone numbers.\r\n// const ALPHANUM_ = VALID_ALPHA_ + VALID_DIGITS\r\nconst ALPHANUM_ = VALID_DIGITS\r\n\r\nconst RFC3966_DOMAINLABEL_ = '[' + ALPHANUM_ + ']+((\\\\-)*[' + ALPHANUM_ + '])*'\r\n\r\nconst VALID_ALPHA_ = 'a-zA-Z'\r\nconst RFC3966_TOPLABEL_ = '[' + VALID_ALPHA_ + ']+((\\\\-)*[' + ALPHANUM_ + '])*'\r\n\r\nconst RFC3966_DOMAINNAME_ = '^(' + RFC3966_DOMAINLABEL_ + '\\\\.)*' + RFC3966_TOPLABEL_ + '\\\\.?$'\r\n\r\n/**\r\n * Regular expression of valid domainname for the phone-context parameter,\r\n * following the syntax defined in RFC3966.\r\n */\r\nconst RFC3966_DOMAINNAME_PATTERN_ = new RegExp(RFC3966_DOMAINNAME_, 'g')\r\n\r\nexport const RFC3966_PREFIX_ = 'tel:'\r\nexport const RFC3966_PHONE_CONTEXT_ = ';phone-context='\r\nexport const RFC3966_ISDN_SUBADDRESS_ = ';isub='\r\n\r\n/**\r\n * Extracts the value of the phone-context parameter of `numberToExtractFrom`,\r\n * following the syntax defined in RFC3966.\r\n *\r\n * @param {string} numberToExtractFrom\r\n * @return {string|null} the extracted string (possibly empty), or `null` if no phone-context parameter is found.\r\n */\r\nexport default function extractPhoneContext(numberToExtractFrom) {\r\n\tconst indexOfPhoneContext = numberToExtractFrom.indexOf(RFC3966_PHONE_CONTEXT_)\r\n\t// If no phone-context parameter is present\r\n\tif (indexOfPhoneContext < 0) {\r\n\t\treturn null\r\n\t}\r\n\r\n\tconst phoneContextStart = indexOfPhoneContext + RFC3966_PHONE_CONTEXT_.length\r\n\t// If phone-context parameter is empty\r\n\tif (phoneContextStart >= numberToExtractFrom.length) {\r\n\t\treturn ''\r\n\t}\r\n\r\n\tconst phoneContextEnd = numberToExtractFrom.indexOf(';', phoneContextStart)\r\n\t// If phone-context is not the last parameter\r\n\tif (phoneContextEnd >= 0) {\r\n\t\treturn numberToExtractFrom.substring(phoneContextStart, phoneContextEnd)\r\n\t} else {\r\n\t\treturn numberToExtractFrom.substring(phoneContextStart)\r\n\t}\r\n}\r\n\r\n/**\r\n * Returns whether the value of phoneContext follows the syntax defined in RFC3966.\r\n *\r\n * @param {string|null} phoneContext\r\n * @return {boolean}\r\n */\r\nexport function isPhoneContextValid(phoneContext) {\r\n\tif (phoneContext === null) {\r\n\t\treturn true\r\n\t}\r\n\r\n\tif (phoneContext.length === 0) {\r\n\t\treturn false\r\n\t}\r\n\r\n\t// Does phone-context value match pattern of global-number-digits or domainname.\r\n\treturn RFC3966_GLOBAL_NUMBER_DIGITS_PATTERN_.test(phoneContext) ||\r\n\t\tRFC3966_DOMAINNAME_PATTERN_.test(phoneContext)\r\n}","import extractPhoneContext, {\r\n\tisPhoneContextValid,\r\n\tPLUS_SIGN,\r\n\tRFC3966_PREFIX_,\r\n\tRFC3966_PHONE_CONTEXT_,\r\n\tRFC3966_ISDN_SUBADDRESS_\r\n} from './extractPhoneContext.js'\r\n\r\nimport ParseError from '../ParseError.js'\r\n\r\n/**\r\n * @param {string} numberToParse\r\n * @param {string} nationalNumber\r\n * @return {}\r\n */\r\nexport default function extractFormattedPhoneNumberFromPossibleRfc3966NumberUri(numberToParse, {\r\n\textractFormattedPhoneNumber\r\n}) {\r\n\tconst phoneContext = extractPhoneContext(numberToParse)\r\n\tif (!isPhoneContextValid(phoneContext)) {\r\n\t\tthrow new ParseError('NOT_A_NUMBER')\r\n\t}\r\n\r\n\tlet phoneNumberString\r\n\r\n\tif (phoneContext === null) {\r\n\t\t// Extract a possible number from the string passed in.\r\n\t\t// (this strips leading characters that could not be the start of a phone number)\r\n\t\tphoneNumberString = extractFormattedPhoneNumber(numberToParse) || ''\r\n\t} else {\r\n\t\tphoneNumberString = ''\r\n\r\n\t\t// If the phone context contains a phone number prefix, we need to capture\r\n\t\t// it, whereas domains will be ignored.\r\n\t\tif (phoneContext.charAt(0) === PLUS_SIGN) {\r\n\t\t\tphoneNumberString += phoneContext\r\n\t\t}\r\n\r\n\t\t// Now append everything between the \"tel:\" prefix and the phone-context.\r\n\t\t// This should include the national number, an optional extension or\r\n\t\t// isdn-subaddress component. Note we also handle the case when \"tel:\" is\r\n\t\t// missing, as we have seen in some of the phone number inputs.\r\n\t\t// In that case, we append everything from the beginning.\r\n\t\tconst indexOfRfc3966Prefix = numberToParse.indexOf(RFC3966_PREFIX_)\r\n\t\tlet indexOfNationalNumber\r\n\t\t// RFC 3966 \"tel:\" prefix is preset at this stage because\r\n\t\t// `isPhoneContextValid()` requires it to be present.\r\n\t\t/* istanbul ignore else */\r\n\t\tif (indexOfRfc3966Prefix >= 0) {\r\n\t\t\tindexOfNationalNumber = indexOfRfc3966Prefix + RFC3966_PREFIX_.length\r\n\t\t} else {\r\n\t\t\tindexOfNationalNumber = 0\r\n\t\t}\r\n\t\tconst indexOfPhoneContext = numberToParse.indexOf(RFC3966_PHONE_CONTEXT_)\r\n\t\tphoneNumberString += numberToParse.substring(indexOfNationalNumber, indexOfPhoneContext)\r\n\t}\r\n\r\n\t// Delete the isdn-subaddress and everything after it if it is present.\r\n\t// Note extension won't appear at the same time with isdn-subaddress\r\n\t// according to paragraph 5.3 of the RFC3966 spec.\r\n\tconst indexOfIsdn = phoneNumberString.indexOf(RFC3966_ISDN_SUBADDRESS_)\r\n\tif (indexOfIsdn > 0) {\r\n\t\tphoneNumberString = phoneNumberString.substring(0, indexOfIsdn)\r\n\t}\r\n\t// If both phone context and isdn-subaddress are absent but other\r\n\t// parameters are present, the parameters are left in nationalNumber.\r\n\t// This is because we are concerned about deleting content from a potential\r\n\t// number string when there is no strong evidence that the number is\r\n\t// actually written in RFC3966.\r\n\r\n\tif (phoneNumberString !== '') {\r\n\t\treturn phoneNumberString\r\n\t}\r\n}","// This is a port of Google Android `libphonenumber`'s\r\n// `phonenumberutil.js` of December 31th, 2018.\r\n//\r\n// https://github.com/googlei18n/libphonenumber/commits/master/javascript/i18n/phonenumbers/phonenumberutil.js\r\n\r\nimport {\r\n\tVALID_DIGITS,\r\n\tPLUS_CHARS,\r\n\tMIN_LENGTH_FOR_NSN,\r\n\tMAX_LENGTH_FOR_NSN\r\n} from './constants.js'\r\n\r\nimport ParseError from './ParseError.js'\r\nimport Metadata from './metadata.js'\r\nimport isViablePhoneNumber, { isViablePhoneNumberStart } from './helpers/isViablePhoneNumber.js'\r\nimport extractExtension from './helpers/extension/extractExtension.js'\r\nimport parseIncompletePhoneNumber from './parseIncompletePhoneNumber.js'\r\nimport getCountryCallingCode from './getCountryCallingCode.js'\r\nimport { isPossibleNumber } from './isPossible.js'\r\n// import { parseRFC3966 } from './helpers/RFC3966.js'\r\nimport PhoneNumber from './PhoneNumber.js'\r\nimport matchesEntirely from './helpers/matchesEntirely.js'\r\nimport extractCountryCallingCode from './helpers/extractCountryCallingCode.js'\r\nimport extractNationalNumber from './helpers/extractNationalNumber.js'\r\n// import stripIddPrefix from './helpers/stripIddPrefix.js'\r\nimport getCountryByCallingCode from './helpers/getCountryByCallingCode.js'\r\nimport extractFormattedPhoneNumberFromPossibleRfc3966NumberUri from './helpers/extractFormattedPhoneNumberFromPossibleRfc3966NumberUri.js'\r\n\r\n// We don't allow input strings for parsing to be longer than 250 chars.\r\n// This prevents malicious input from consuming CPU.\r\nconst MAX_INPUT_STRING_LENGTH = 250\r\n\r\n// This consists of the plus symbol, digits, and arabic-indic digits.\r\nconst PHONE_NUMBER_START_PATTERN = new RegExp('[' + PLUS_CHARS + VALID_DIGITS + ']')\r\n\r\n// Regular expression of trailing characters that we want to remove.\r\n// A trailing `#` is sometimes used when writing phone numbers with extensions in US.\r\n// Example: \"+1 (645) 123 1234-910#\" number has extension \"910\".\r\nconst AFTER_PHONE_NUMBER_END_PATTERN = new RegExp('[^' + VALID_DIGITS + '#' + ']+$')\r\n\r\nconst USE_NON_GEOGRAPHIC_COUNTRY_CODE = false\r\n\r\n// Examples:\r\n//\r\n// ```js\r\n// parse('8 (800) 555-35-35', 'RU')\r\n// parse('8 (800) 555-35-35', 'RU', metadata)\r\n// parse('8 (800) 555-35-35', { country: { default: 'RU' } })\r\n// parse('8 (800) 555-35-35', { country: { default: 'RU' } }, metadata)\r\n// parse('+7 800 555 35 35')\r\n// parse('+7 800 555 35 35', metadata)\r\n// ```\r\n//\r\n\r\n/**\r\n * Parses a phone number.\r\n *\r\n * parse('123456789', { defaultCountry: 'RU', v2: true }, metadata)\r\n * parse('123456789', { defaultCountry: 'RU' }, metadata)\r\n * parse('123456789', undefined, metadata)\r\n *\r\n * @param {string} input\r\n * @param {object} [options]\r\n * @param {object} metadata\r\n * @return {object|PhoneNumber?} If `options.v2: true` flag is passed, it returns a `PhoneNumber?` instance. Otherwise, returns an object of shape `{ phone: '...', country: '...' }` (or just `{}` if no phone number was parsed).\r\n */\r\nexport default function parse(text, options, metadata) {\r\n\t// If assigning the `{}` default value is moved to the arguments above,\r\n\t// code coverage would decrease for some weird reason.\r\n\toptions = options || {}\r\n\r\n\tmetadata = new Metadata(metadata)\r\n\r\n\t// Validate `defaultCountry`.\r\n\tif (options.defaultCountry && !metadata.hasCountry(options.defaultCountry)) {\r\n\t\tif (options.v2) {\r\n\t\t\tthrow new ParseError('INVALID_COUNTRY')\r\n\t\t}\r\n\t\tthrow new Error(`Unknown country: ${options.defaultCountry}`)\r\n\t}\r\n\r\n\t// Parse the phone number.\r\n\tconst { number: formattedPhoneNumber, ext, error } = parseInput(text, options.v2, options.extract)\r\n\r\n\t// If the phone number is not viable then return nothing.\r\n\tif (!formattedPhoneNumber) {\r\n\t\tif (options.v2) {\r\n\t\t\tif (error === 'TOO_SHORT') {\r\n\t\t\t\tthrow new ParseError('TOO_SHORT')\r\n\t\t\t}\r\n\t\t\tthrow new ParseError('NOT_A_NUMBER')\r\n\t\t}\r\n\t\treturn {}\r\n\t}\r\n\r\n\tconst {\r\n\t\tcountry,\r\n\t\tnationalNumber,\r\n\t\tcountryCallingCode,\r\n\t\tcountryCallingCodeSource,\r\n\t\tcarrierCode\r\n\t} = parsePhoneNumber(\r\n\t\tformattedPhoneNumber,\r\n\t\toptions.defaultCountry,\r\n\t\toptions.defaultCallingCode,\r\n\t\tmetadata\r\n\t)\r\n\r\n\tif (!metadata.hasSelectedNumberingPlan()) {\r\n\t\tif (options.v2) {\r\n\t\t\tthrow new ParseError('INVALID_COUNTRY')\r\n\t\t}\r\n\t\treturn {}\r\n\t}\r\n\r\n\t// Validate national (significant) number length.\r\n\tif (!nationalNumber || nationalNumber.length < MIN_LENGTH_FOR_NSN) {\r\n\t\t// Won't throw here because the regexp already demands length > 1.\r\n\t\t/* istanbul ignore if */\r\n\t\tif (options.v2) {\r\n\t\t\tthrow new ParseError('TOO_SHORT')\r\n\t\t}\r\n\t\t// Google's demo just throws an error in this case.\r\n\t\treturn {}\r\n\t}\r\n\r\n\t// Validate national (significant) number length.\r\n\t//\r\n\t// A sidenote:\r\n\t//\r\n\t// They say that sometimes national (significant) numbers\r\n\t// can be longer than `MAX_LENGTH_FOR_NSN` (e.g. in Germany).\r\n\t// https://github.com/googlei18n/libphonenumber/blob/7e1748645552da39c4e1ba731e47969d97bdb539/resources/phonenumber.proto#L36\r\n\t// Such numbers will just be discarded.\r\n\t//\r\n\tif (nationalNumber.length > MAX_LENGTH_FOR_NSN) {\r\n\t\tif (options.v2) {\r\n\t\t\tthrow new ParseError('TOO_LONG')\r\n\t\t}\r\n\t\t// Google's demo just throws an error in this case.\r\n\t\treturn {}\r\n\t}\r\n\r\n\tif (options.v2) {\r\n\t\tconst phoneNumber = new PhoneNumber(\r\n\t\t\tcountryCallingCode,\r\n\t\t\tnationalNumber,\r\n\t\t\tmetadata.metadata\r\n\t\t)\r\n\t\tif (country) {\r\n\t\t\tphoneNumber.country = country\r\n\t\t}\r\n\t\tif (carrierCode) {\r\n\t\t\tphoneNumber.carrierCode = carrierCode\r\n\t\t}\r\n\t\tif (ext) {\r\n\t\t\tphoneNumber.ext = ext\r\n\t\t}\r\n\t\tphoneNumber.__countryCallingCodeSource = countryCallingCodeSource\r\n\t\treturn phoneNumber\r\n\t}\r\n\r\n\t// Check if national phone number pattern matches the number.\r\n\t// National number pattern is different for each country,\r\n\t// even for those ones which are part of the \"NANPA\" group.\r\n\tconst valid = (options.extended ? metadata.hasSelectedNumberingPlan() : country) ?\r\n\t\tmatchesEntirely(nationalNumber, metadata.nationalNumberPattern()) :\r\n\t\tfalse\r\n\r\n\tif (!options.extended) {\r\n\t\treturn valid ? result(country, nationalNumber, ext) : {}\r\n\t}\r\n\r\n\t// isInternational: countryCallingCode !== undefined\r\n\r\n\treturn {\r\n\t\tcountry,\r\n\t\tcountryCallingCode,\r\n\t\tcarrierCode,\r\n\t\tvalid,\r\n\t\tpossible: valid ? true : (\r\n\t\t\toptions.extended === true &&\r\n\t\t\tmetadata.possibleLengths() &&\r\n\t\t\tisPossibleNumber(nationalNumber, country, metadata) ? true : false\r\n\t\t),\r\n\t\tphone: nationalNumber,\r\n\t\text\r\n\t}\r\n}\r\n\r\n/**\r\n * Extracts a formatted phone number from text.\r\n * Doesn't guarantee that the extracted phone number\r\n * is a valid phone number (for example, doesn't validate its length).\r\n * @param {string} text\r\n * @param {boolean} [extract] — If `false`, then will parse the entire `text` as a phone number.\r\n * @param {boolean} [throwOnError] — By default, it won't throw if the text is too long.\r\n * @return {string}\r\n * @example\r\n * // Returns \"(213) 373-4253\".\r\n * extractFormattedPhoneNumber(\"Call (213) 373-4253 for assistance.\")\r\n */\r\nfunction extractFormattedPhoneNumber(text, extract, throwOnError) {\r\n\tif (!text) {\r\n\t\treturn\r\n\t}\r\n\tif (text.length > MAX_INPUT_STRING_LENGTH) {\r\n\t\tif (throwOnError) {\r\n\t\t\tthrow new ParseError('TOO_LONG')\r\n\t\t}\r\n\t\treturn\r\n\t}\r\n\tif (extract === false) {\r\n\t\treturn text\r\n\t}\r\n\t// Attempt to extract a possible number from the string passed in\r\n\tconst startsAt = text.search(PHONE_NUMBER_START_PATTERN)\r\n\tif (startsAt < 0) {\r\n\t\treturn\r\n\t}\r\n\treturn text\r\n\t\t// Trim everything to the left of the phone number\r\n\t\t.slice(startsAt)\r\n\t\t// Remove trailing non-numerical characters\r\n\t\t.replace(AFTER_PHONE_NUMBER_END_PATTERN, '')\r\n}\r\n\r\n/**\r\n * @param {string} text - Input.\r\n * @param {boolean} v2 - Legacy API functions don't pass `v2: true` flag.\r\n * @param {boolean} [extract] - Whether to extract a phone number from `text`, or attempt to parse the entire text as a phone number.\r\n * @return {object} `{ ?number, ?ext }`.\r\n */\r\nfunction parseInput(text, v2, extract) {\r\n\t// // Parse RFC 3966 phone number URI.\r\n\t// if (text && text.indexOf('tel:') === 0) {\r\n\t// \treturn parseRFC3966(text)\r\n\t// }\r\n\t// let number = extractFormattedPhoneNumber(text, extract, v2)\r\n\tlet number = extractFormattedPhoneNumberFromPossibleRfc3966NumberUri(text, {\r\n\t\textractFormattedPhoneNumber: (text) => extractFormattedPhoneNumber(text, extract, v2)\r\n\t})\r\n\t// If the phone number is not viable, then abort.\r\n\tif (!number) {\r\n\t\treturn {}\r\n\t}\r\n\tif (!isViablePhoneNumber(number)) {\r\n\t\tif (isViablePhoneNumberStart(number)) {\r\n\t\t\treturn { error: 'TOO_SHORT' }\r\n\t\t}\r\n\t\treturn {}\r\n\t}\r\n\t// Attempt to parse extension first, since it doesn't require region-specific\r\n\t// data and we want to have the non-normalised number here.\r\n\tconst withExtensionStripped = extractExtension(number)\r\n\tif (withExtensionStripped.ext) {\r\n\t\treturn withExtensionStripped\r\n\t}\r\n\treturn { number }\r\n}\r\n\r\n/**\r\n * Creates `parse()` result object.\r\n */\r\nfunction result(country, nationalNumber, ext) {\r\n\tconst result = {\r\n\t\tcountry,\r\n\t\tphone: nationalNumber\r\n\t}\r\n\tif (ext) {\r\n\t\tresult.ext = ext\r\n\t}\r\n\treturn result\r\n}\r\n\r\n/**\r\n * Parses a viable phone number.\r\n * @param {string} formattedPhoneNumber — Example: \"(213) 373-4253\".\r\n * @param {string} [defaultCountry]\r\n * @param {string} [defaultCallingCode]\r\n * @param {Metadata} metadata\r\n * @return {object} Returns `{ country: string?, countryCallingCode: string?, nationalNumber: string? }`.\r\n */\r\nfunction parsePhoneNumber(\r\n\tformattedPhoneNumber,\r\n\tdefaultCountry,\r\n\tdefaultCallingCode,\r\n\tmetadata\r\n) {\r\n\t// Extract calling code from phone number.\r\n\tlet { countryCallingCodeSource, countryCallingCode, number } = extractCountryCallingCode(\r\n\t\tparseIncompletePhoneNumber(formattedPhoneNumber),\r\n\t\tundefined,\r\n\t\tdefaultCountry,\r\n\t\tdefaultCallingCode,\r\n\t\tmetadata.metadata\r\n\t)\r\n\r\n\t// The exact country of the phone number\r\n\tlet country\r\n\r\n\t// If `formattedPhoneNumber` is passed in \"international\" format,\r\n\t// choose a country by `countryCallingCode`.\r\n\tif (countryCallingCode) {\r\n\t\tmetadata.selectNumberingPlan(countryCallingCode)\r\n\t}\r\n\t// Else, if `formattedPhoneNumber` is passed in \"national\" format,\r\n\t// then `number` is defined and `countryCallingCode` is `undefined`.\r\n\telse if (number && (defaultCountry || defaultCallingCode)) {\r\n\t\tmetadata.selectNumberingPlan(defaultCountry, defaultCallingCode)\r\n\t\tif (defaultCountry) {\r\n\t\t\tcountry = defaultCountry\r\n\t\t} else {\r\n\t\t\t/* istanbul ignore if */\r\n\t\t\tif (USE_NON_GEOGRAPHIC_COUNTRY_CODE) {\r\n\t\t\t\tif (metadata.isNonGeographicCallingCode(defaultCallingCode)) {\r\n\t\t\t\t\tcountry = '001'\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t\tcountryCallingCode = defaultCallingCode || getCountryCallingCode(defaultCountry, metadata.metadata)\r\n\t}\r\n\telse return {}\r\n\r\n\tif (!number) {\r\n\t\treturn {\r\n\t\t\tcountryCallingCodeSource,\r\n\t\t\tcountryCallingCode\r\n\t\t}\r\n\t}\r\n\r\n\tconst {\r\n\t\tnationalNumber,\r\n\t\tcarrierCode\r\n\t} = extractNationalNumber(\r\n\t\tparseIncompletePhoneNumber(number),\r\n\t\tcountry,\r\n\t\tmetadata\r\n\t)\r\n\r\n\t// Sometimes there are several countries\r\n\t// corresponding to the same country phone code\r\n\t// (e.g. NANPA countries all having `1` country phone code).\r\n\t// Therefore, to reliably determine the exact country,\r\n\t// national (significant) number should have been parsed first.\r\n\t//\r\n\t// When `metadata.json` is generated, all \"ambiguous\" country phone codes\r\n\t// get their countries populated with the full set of\r\n\t// \"phone number type\" regular expressions.\r\n\t//\r\n\tconst exactCountry = getCountryByCallingCode(countryCallingCode, {\r\n\t\tnationalNumber,\r\n\t\tmetadata\r\n\t})\r\n\tif (exactCountry) {\r\n\t\tcountry = exactCountry\r\n\t\t/* istanbul ignore if */\r\n\t\tif (exactCountry === '001') {\r\n\t\t\t// Can't happen with `USE_NON_GEOGRAPHIC_COUNTRY_CODE` being `false`.\r\n\t\t\t// If `USE_NON_GEOGRAPHIC_COUNTRY_CODE` is set to `true` for some reason,\r\n\t\t\t// then remove the \"istanbul ignore if\".\r\n\t\t} else {\r\n\t\t\tmetadata.selectNumberingPlan(country)\r\n\t\t}\r\n\t}\r\n\r\n\treturn {\r\n\t\tcountry,\r\n\t\tcountryCallingCode,\r\n\t\tcountryCallingCodeSource,\r\n\t\tnationalNumber,\r\n\t\tcarrierCode\r\n\t}\r\n}","import Metadata from '../metadata.js'\r\nimport mergeArrays from './mergeArrays.js'\r\n\r\nexport default function checkNumberLength(nationalNumber, country, metadata) {\r\n\treturn checkNumberLengthForType(nationalNumber, country, undefined, metadata)\r\n}\r\n\r\n// Checks whether a number is possible for a certain `country` based on the number length.\r\n//\r\n// This function is not supported by metadata generated with ancient versions of\r\n// `libphonenumber-js` (before version `1.0.18`) which didn't include \"possible lengths\".\r\n//\r\n// There was also a known issue with `checkNumberLength()` function:\r\n// if a number is possible only in a certain `country` among several `countries`\r\n// that share the same \"country calling code\", that function would check\r\n// the possibility of the phone number only in the \"main\" `country` for the \"country calling code\"\r\n// and would not check if it's actually be possible in the speciifc `country`.\r\n//\r\n// For example, \"+1310xxxx\" numbers are valid in Canada.\r\n// However, they are not possible in the US due to being too short.\r\n// Since Canada and the US share the same country calling code — \"+1\" —\r\n// `checkNumberLength()` function used to return not \"IS_POSSIBLE\" for \"+1310xxxx\" numbers.\r\n//\r\n// In such cases, when using \"/max\" metadata, `isValid()` could output `true`\r\n// but at the same time `isPossible()` could output `false`, which was contradictory.\r\n//\r\n// See https://issuetracker.google.com/issues/335892662 for the discusson in Google's issues.\r\n//\r\n// The solution suggested by Google was implemented: an optional `country` argument\r\n// was added to `checkNumberLength()` function. If present, that `country` will be used\r\n// to check phone number length for that specific `country` rather than the \"main\" country\r\n// for the shared \"country calling code\".\r\n//\r\nexport function checkNumberLengthForType(nationalNumber, country, type, metadata) {\r\n\t// If the exact `country` is specified, it's no necessarily already selected in `metadata`.\r\n\t// Most likely, in cases when there're multiple countries corresponding to the same\r\n\t// \"country calling code\", the \"main\" country for that \"country calling code\" will be selected.\r\n\tif (country) {\r\n\t\tmetadata = new Metadata(metadata.metadata)\r\n\t\tmetadata.selectNumberingPlan(country)\r\n\t}\r\n\r\n\tconst type_info = metadata.type(type)\r\n\r\n\t// There should always be \"<possiblePengths/>\" set for every type element.\r\n\t// This is declared in the XML schema.\r\n\t// For size efficiency, where a sub-description (e.g. fixed-line)\r\n\t// has the same \"<possiblePengths/>\" as the \"general description\", this is missing,\r\n\t// so we fall back to the \"general description\". Where no numbers of the type\r\n\t// exist at all, there is one possible length (-1) which is guaranteed\r\n\t// not to match the length of any real phone number.\r\n\tlet possible_lengths = type_info && type_info.possibleLengths() || metadata.possibleLengths()\r\n\t// let local_lengths = type_info && type.possibleLengthsLocal() || metadata.possibleLengthsLocal()\r\n\r\n\t// Metadata before version `1.0.18` didn't contain `possible_lengths`.\r\n\tif (!possible_lengths) {\r\n\t\treturn 'IS_POSSIBLE'\r\n\t}\r\n\r\n\tif (type === 'FIXED_LINE_OR_MOBILE') {\r\n\t\t// No such country in metadata.\r\n\t\t/* istanbul ignore next */\r\n\t\tif (!metadata.type('FIXED_LINE')) {\r\n\t\t\t// The rare case has been encountered where no fixedLine data is available\r\n\t\t\t// (true for some non-geographic entities), so we just check mobile.\r\n\t\t\treturn checkNumberLengthForType(nationalNumber, country, 'MOBILE', metadata)\r\n\t\t}\r\n\r\n\t\tconst mobile_type = metadata.type('MOBILE')\r\n\t\tif (mobile_type) {\r\n\t\t\t// Merge the mobile data in if there was any. \"Concat\" creates a new\r\n\t\t\t// array, it doesn't edit possible_lengths in place, so we don't need a copy.\r\n\t\t\t// Note that when adding the possible lengths from mobile, we have\r\n\t\t\t// to again check they aren't empty since if they are this indicates\r\n\t\t\t// they are the same as the general desc and should be obtained from there.\r\n\t\t\tpossible_lengths = mergeArrays(possible_lengths, mobile_type.possibleLengths())\r\n\t\t\t// The current list is sorted; we need to merge in the new list and\r\n\t\t\t// re-sort (duplicates are okay). Sorting isn't so expensive because\r\n\t\t\t// the lists are very small.\r\n\r\n\t\t\t// if (local_lengths) {\r\n\t\t\t// \tlocal_lengths = mergeArrays(local_lengths, mobile_type.possibleLengthsLocal())\r\n\t\t\t// } else {\r\n\t\t\t// \tlocal_lengths = mobile_type.possibleLengthsLocal()\r\n\t\t\t// }\r\n\t\t}\r\n\t}\r\n\t// If the type doesn't exist then return 'INVALID_LENGTH'.\r\n\telse if (type && !type_info) {\r\n\t\treturn 'INVALID_LENGTH'\r\n\t}\r\n\r\n\tconst actual_length = nationalNumber.length\r\n\r\n\t// In `libphonenumber-js` all \"local-only\" formats are dropped for simplicity.\r\n\t// // This is safe because there is never an overlap beween the possible lengths\r\n\t// // and the local-only lengths; this is checked at build time.\r\n\t// if (local_lengths && local_lengths.indexOf(nationalNumber.length) >= 0)\r\n\t// {\r\n\t// \treturn 'IS_POSSIBLE_LOCAL_ONLY'\r\n\t// }\r\n\r\n\tconst minimum_length = possible_lengths[0]\r\n\r\n\tif (minimum_length === actual_length) {\r\n\t\treturn 'IS_POSSIBLE'\r\n\t}\r\n\r\n\tif (minimum_length > actual_length) {\r\n\t\treturn 'TOO_SHORT'\r\n\t}\r\n\r\n\tif (possible_lengths[possible_lengths.length - 1] < actual_length) {\r\n\t\treturn 'TOO_LONG'\r\n\t}\r\n\r\n\t// We skip the first element since we've already checked it.\r\n\treturn possible_lengths.indexOf(actual_length, 1) >= 0 ? 'IS_POSSIBLE' : 'INVALID_LENGTH'\r\n}","/**\r\n * Merges two arrays.\r\n * @param {*} a\r\n * @param {*} b\r\n * @return {*}\r\n */\r\nexport default function mergeArrays(a, b) {\r\n\tconst merged = a.slice()\r\n\r\n\tfor (const element of b) {\r\n\t\tif (a.indexOf(element) < 0) {\r\n\t\t\tmerged.push(element)\r\n\t\t}\r\n\t}\r\n\r\n\treturn merged.sort((a, b) => a - b)\r\n\r\n\t// ES6 version, requires Set polyfill.\r\n\t// let merged = new Set(a)\r\n\t// for (const element of b) {\r\n\t// \tmerged.add(i)\r\n\t// }\r\n\t// return Array.from(merged).sort((a, b) => a - b)\r\n}","import Metadata from '../metadata.js'\r\nimport matchesEntirely from './matchesEntirely.js'\r\nimport extractNationalNumber from './extractNationalNumber.js'\r\nimport checkNumberLength from './checkNumberLength.js'\r\nimport getCountryCallingCode from '../getCountryCallingCode.js'\r\n\r\n/**\r\n * Sometimes some people incorrectly input international phone numbers\r\n * without the leading `+`. This function corrects such input.\r\n * @param {string} number — Phone number digits.\r\n * @param {string} [country] — Exact country of the phone number.\r\n * @param {string} [defaultCountry]\r\n * @param {string} [defaultCallingCode]\r\n * @param {object} metadata\r\n * @return {object} `{ countryCallingCode: string?, number: string }`.\r\n */\r\nexport default function extractCountryCallingCodeFromInternationalNumberWithoutPlusSign(\r\n\tnumber,\r\n\tcountry,\r\n\tdefaultCountry,\r\n\tdefaultCallingCode,\r\n\tmetadata\r\n) {\r\n\tconst countryCallingCode = country || defaultCountry\r\n\t\t? getCountryCallingCode(country || defaultCountry, metadata)\r\n\t\t: defaultCallingCode\r\n\r\n\tif (number.indexOf(countryCallingCode) === 0) {\r\n\t\tmetadata = new Metadata(metadata)\r\n\t\tmetadata.selectNumberingPlan(country || defaultCountry, countryCallingCode)\r\n\r\n\t\tconst possibleShorterNumber = number.slice(countryCallingCode.length)\r\n\r\n\t\tconst {\r\n\t\t\tnationalNumber: possibleShorterNationalNumber,\r\n\t\t} = extractNationalNumber(\r\n\t\t\tpossibleShorterNumber,\r\n\t\t\tcountry,\r\n\t\t\tmetadata\r\n\t\t)\r\n\r\n\t\tconst {\r\n\t\t\tnationalNumber\r\n\t\t} = extractNationalNumber(\r\n\t\t\tnumber,\r\n\t\t\tcountry,\r\n\t\t\tmetadata\r\n\t\t)\r\n\r\n\t\t// If the number was not valid before but is valid now,\r\n\t\t// or if it was too long before, we consider the number\r\n\t\t// with the country calling code stripped to be a better result\r\n\t\t// and keep that instead.\r\n\t\t// For example, in Germany (+49), `49` is a valid area code,\r\n\t\t// so if a number starts with `49`, it could be both a valid\r\n\t\t// national German number or an international number without\r\n\t\t// a leading `+`.\r\n\t\tif (\r\n\t\t\t(\r\n\t\t\t\t!matchesEntirely(nationalNumber, metadata.nationalNumberPattern()) &&\r\n\t\t\t\tmatchesEntirely(possibleShorterNationalNumber, metadata.nationalNumberPattern())\r\n\t\t\t)\r\n\t\t\t||\r\n\t\t\tcheckNumberLength(nationalNumber, country, metadata) === 'TOO_LONG'\r\n\t\t) {\r\n\t\t\treturn {\r\n\t\t\t\tcountryCallingCode,\r\n\t\t\t\tnumber: possibleShorterNumber\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\treturn { number }\r\n}","import Metadata from '../metadata.js'\r\n\r\n/**\r\n * Pattern that makes it easy to distinguish whether a region has a single\r\n * international dialing prefix or not. If a region has a single international\r\n * prefix (e.g. 011 in USA), it will be represented as a string that contains\r\n * a sequence of ASCII digits, and possibly a tilde, which signals waiting for\r\n * the tone. If there are multiple available international prefixes in a\r\n * region, they will be represented as a regex string that always contains one\r\n * or more characters that are not ASCII digits or a tilde.\r\n */\r\nconst SINGLE_IDD_PREFIX_REG_EXP = /^[\\d]+(?:[~\\u2053\\u223C\\uFF5E][\\d]+)?$/\r\n\r\n// For regions that have multiple IDD prefixes\r\n// a preferred IDD prefix is returned.\r\nexport default function getIddPrefix(country, callingCode, metadata) {\r\n\tconst countryMetadata = new Metadata(metadata)\r\n\tcountryMetadata.selectNumberingPlan(country, callingCode)\r\n\tif (countryMetadata.defaultIDDPrefix()) {\r\n\t\treturn countryMetadata.defaultIDDPrefix()\r\n\t}\r\n\tif (SINGLE_IDD_PREFIX_REG_EXP.test(countryMetadata.IDDPrefix())) {\r\n\t\treturn countryMetadata.IDDPrefix()\r\n\t}\r\n}\r\n","// This is a port of Google Android `libphonenumber`'s\r\n// `phonenumberutil.js` of December 31th, 2018.\r\n//\r\n// https://github.com/googlei18n/libphonenumber/commits/master/javascript/i18n/phonenumbers/phonenumberutil.js\r\n\r\nimport matchesEntirely from './helpers/matchesEntirely.js'\r\nimport formatNationalNumberUsingFormat from './helpers/formatNationalNumberUsingFormat.js'\r\nimport Metadata, { getCountryCallingCode } from './metadata.js'\r\nimport getIddPrefix from './helpers/getIddPrefix.js'\r\nimport { formatRFC3966 } from './helpers/RFC3966.js'\r\n\r\nconst DEFAULT_OPTIONS = {\r\n\tformatExtension: (formattedNumber, extension, metadata) => `${formattedNumber}${metadata.ext()}${extension}`\r\n}\r\n\r\n/**\r\n * Formats a phone number.\r\n *\r\n * format(phoneNumberInstance, 'INTERNATIONAL', { ..., v2: true }, metadata)\r\n * format(phoneNumberInstance, 'NATIONAL', { ..., v2: true }, metadata)\r\n *\r\n * format({ phone: '8005553535', country: 'RU' }, 'INTERNATIONAL', { ... }, metadata)\r\n * format({ phone: '8005553535', country: 'RU' }, 'NATIONAL', undefined, metadata)\r\n *\r\n * @param {object|PhoneNumber} input — If `options.v2: true` flag is passed, the `input` should be a `PhoneNumber` instance. Otherwise, it should be an object of shape `{ phone: '...', country: '...' }`.\r\n * @param {string} format\r\n * @param {object} [options]\r\n * @param {object} metadata\r\n * @return {string}\r\n */\r\nexport default function formatNumber(input, format, options, metadata) {\r\n\t// Apply default options.\r\n\tif (options) {\r\n\t\t// Using ES6 \"rest spread\" syntax here didn't work with `babel`/`istanbul`\r\n\t\t// for some weird reason: this line of code would cause the code coverage\r\n\t\t// to show as not 100%. That's because `babel`/`istanbul`, for some weird reason,\r\n\t\t// apparently doesn't know how to properly exclude Babel polyfills from code coverage.\r\n\t\t//\r\n\t\t// options = { ...DEFAULT_OPTIONS, ...options }\r\n\t\t//\r\n\t\toptions = merge({}, DEFAULT_OPTIONS, options)\r\n\t} else {\r\n\t\toptions = DEFAULT_OPTIONS\r\n\t}\r\n\r\n\tmetadata = new Metadata(metadata)\r\n\r\n\tif (input.country && input.country !== '001') {\r\n\t\t// Validate `input.country`.\r\n\t\tif (!metadata.hasCountry(input.country)) {\r\n\t\t\tthrow new Error(`Unknown country: ${input.country}`)\r\n\t\t}\r\n\t\tmetadata.selectNumberingPlan(input.country)\r\n\t}\r\n\telse if (input.countryCallingCode) {\r\n\t\tmetadata.selectNumberingPlan(input.countryCallingCode)\r\n\t}\r\n\telse return input.phone || ''\r\n\r\n\tconst countryCallingCode = metadata.countryCallingCode()\r\n\r\n\tconst nationalNumber = options.v2 ? input.nationalNumber : input.phone\r\n\r\n\t// This variable should have been declared inside `case`s\r\n\t// but Babel has a bug and it says \"duplicate variable declaration\".\r\n\tlet number\r\n\r\n\tswitch (format) {\r\n\t\tcase 'NATIONAL':\r\n\t\t\t// Legacy argument support.\r\n\t\t\t// (`{ country: ..., phone: '' }`)\r\n\t\t\tif (!nationalNumber) {\r\n\t\t\t\treturn ''\r\n\t\t\t}\r\n\t\t\tnumber = formatNationalNumber(nationalNumber, input.carrierCode, 'NATIONAL', metadata, options)\r\n\t\t\treturn addExtension(number, input.ext, metadata, options.formatExtension)\r\n\r\n\t\tcase 'INTERNATIONAL':\r\n\t\t\t// Legacy argument support.\r\n\t\t\t// (`{ country: ..., phone: '' }`)\r\n\t\t\tif (!nationalNumber) {\r\n\t\t\t\treturn `+${countryCallingCode}`\r\n\t\t\t}\r\n\t\t\tnumber = formatNationalNumber(nationalNumber, null, 'INTERNATIONAL', metadata, options)\r\n\t\t\tnumber = `+${countryCallingCode} ${number}`\r\n\t\t\treturn addExtension(number, input.ext, metadata, options.formatExtension)\r\n\r\n\t\tcase 'E.164':\r\n\t\t\t// `E.164` doesn't define \"phone number extensions\".\r\n\t\t\treturn `+${countryCallingCode}${nationalNumber}`\r\n\r\n\t\tcase 'RFC3966':\r\n\t\t\treturn formatRFC3966({\r\n\t\t\t\tnumber: `+${countryCallingCode}${nationalNumber}`,\r\n\t\t\t\text: input.ext\r\n\t\t\t})\r\n\r\n\t\t// For reference, here's Google's IDD formatter:\r\n\t\t// https://github.com/google/libphonenumber/blob/32719cf74e68796788d1ca45abc85dcdc63ba5b9/java/libphonenumber/src/com/google/i18n/phonenumbers/PhoneNumberUtil.java#L1546\r\n\t\t// Not saying that this IDD formatter replicates it 1:1, but it seems to work.\r\n\t\t// Who would even need to format phone numbers in IDD format anyway?\r\n\t\tcase 'IDD':\r\n\t\t\tif (!options.fromCountry) {\r\n\t\t\t\treturn\r\n\t\t\t\t// throw new Error('`fromCountry` option not passed for IDD-prefixed formatting.')\r\n\t\t\t}\r\n\t\t\tconst formattedNumber = formatIDD(\r\n\t\t\t\tnationalNumber,\r\n\t\t\t\tinput.carrierCode,\r\n\t\t\t\tcountryCallingCode,\r\n\t\t\t\toptions.fromCountry,\r\n\t\t\t\tmetadata\r\n\t\t\t)\r\n\t\t\treturn addExtension(formattedNumber, input.ext, metadata, options.formatExtension)\r\n\r\n\t\tdefault:\r\n\t\t\tthrow new Error(`Unknown \"format\" argument passed to \"formatNumber()\": \"${format}\"`)\r\n\t}\r\n}\r\n\r\nfunction formatNationalNumber(number, carrierCode, formatAs, metadata, options) {\r\n\tconst format = chooseFormatForNumber(metadata.formats(), number)\r\n\tif (!format) {\r\n\t\treturn number\r\n\t}\r\n\treturn formatNationalNumberUsingFormat(\r\n\t\tnumber,\r\n\t\tformat,\r\n\t\t{\r\n\t\t\tuseInternationalFormat: formatAs === 'INTERNATIONAL',\r\n\t\t\twithNationalPrefix: format.nationalPrefixIsOptionalWhenFormattingInNationalFormat() && (options && options.nationalPrefix === false) ? false : true,\r\n\t\t\tcarrierCode,\r\n\t\t\tmetadata\r\n\t\t}\r\n\t)\r\n}\r\n\r\nexport function chooseFormatForNumber(availableFormats, nationalNumber) {\r\n\t// Using a `for ... of` loop here didn't work with `babel`/`istanbul`:\r\n\t// for some weird reason, it showed code coverage less than 100%.\r\n\t// That's because `babel`/`istanbul`, for some weird reason,\r\n\t// apparently doesn't know how to properly exclude Babel polyfills from code coverage.\r\n\t//\r\n\t// for (const format of availableFormats) { ... }\r\n\t//\r\n\treturn pickFirstMatchingElement(availableFormats, (format) => {\r\n\t\t// Validate leading digits.\r\n\t\t// The test case for \"else path\" could be found by searching for\r\n\t\t// \"format.leadingDigitsPatterns().length === 0\".\r\n\t\tif (format.leadingDigitsPatterns().length > 0) {\r\n\t\t\t// The last leading_digits_pattern is used here, as it is the most detailed\r\n\t\t\tconst lastLeadingDigitsPattern = format.leadingDigitsPatterns()[format.leadingDigitsPatterns().length - 1]\r\n\t\t\t// If leading digits don't match then move on to the next phone number format\r\n\t\t\tif (nationalNumber.search(lastLeadingDigitsPattern) !== 0) {\r\n\t\t\t\treturn false\r\n\t\t\t}\r\n\t\t}\r\n\t\t// Check that the national number matches the phone number format regular expression\r\n\t\treturn matchesEntirely(nationalNumber, format.pattern())\r\n\t})\r\n}\r\n\r\nfunction addExtension(formattedNumber, ext, metadata, formatExtension) {\r\n\treturn ext ? formatExtension(formattedNumber, ext, metadata) : formattedNumber\r\n}\r\n\r\nfunction formatIDD(\r\n\tnationalNumber,\r\n\tcarrierCode,\r\n\tcountryCallingCode,\r\n\tfromCountry,\r\n\tmetadata\r\n) {\r\n\tconst fromCountryCallingCode = getCountryCallingCode(fromCountry, metadata.metadata)\r\n\t// When calling within the same country calling code.\r\n\tif (fromCountryCallingCode === countryCallingCode) {\r\n\t\tconst formattedNumber = formatNationalNumber(nationalNumber, carrierCode, 'NATIONAL', metadata)\r\n\t\t// For NANPA regions, return the national format for these regions\r\n\t\t// but prefix it with the country calling code.\r\n\t\tif (countryCallingCode === '1') {\r\n\t\t\treturn countryCallingCode + ' ' + formattedNumber\r\n\t\t}\r\n\t\t// If regions share a country calling code, the country calling code need\r\n\t\t// not be dialled. This also applies when dialling within a region, so this\r\n\t\t// if clause covers both these cases. Technically this is the case for\r\n\t\t// dialling from La Reunion to other overseas departments of France (French\r\n\t\t// Guiana, Martinique, Guadeloupe), but not vice versa - so we don't cover\r\n\t\t// this edge case for now and for those cases return the version including\r\n\t\t// country calling code. Details here:\r\n\t\t// http://www.petitfute.com/voyage/225-info-pratiques-reunion\r\n\t\t//\r\n\t\treturn formattedNumber\r\n\t}\r\n\tconst iddPrefix = getIddPrefix(fromCountry, undefined, metadata.metadata)\r\n\tif (iddPrefix) {\r\n\t\treturn `${iddPrefix} ${countryCallingCode} ${formatNationalNumber(nationalNumber, null, 'INTERNATIONAL', metadata)}`\r\n\t}\r\n}\r\n\r\nfunction merge(...objects) {\r\n\tlet i = 1\r\n\twhile (i < objects.length) {\r\n\t\tif (objects[i]) {\r\n\t\t\tfor (const key in objects[i]) {\r\n\t\t\t\tobjects[0][key] = objects[i][key]\r\n\t\t\t}\r\n\t\t}\r\n\t\ti++\r\n\t}\r\n\treturn objects[0]\r\n}\r\n\r\nfunction pickFirstMatchingElement(elements, testFunction) {\r\n\tlet i = 0\r\n\twhile (i < elements.length) {\r\n\t\tif (testFunction(elements[i])) {\r\n\t\t\treturn elements[i]\r\n\t\t}\r\n\t\ti++\r\n\t}\r\n}","import Metadata from './metadata.js'\r\nimport checkNumberLength from './helpers/checkNumberLength.js'\r\n\r\n/**\r\n * Checks if a phone number is \"possible\" (basically just checks its length).\r\n *\r\n * isPossible(phoneNumberInstance, { ..., v2: true }, metadata)\r\n *\r\n * isPossible({ phone: '8005553535', country: 'RU' }, { ... }, metadata)\r\n * isPossible({ phone: '8005553535', country: 'RU' }, undefined, metadata)\r\n *\r\n * @param {object|PhoneNumber} input — If `options.v2: true` flag is passed, the `input` should be a `PhoneNumber` instance. Otherwise, it should be an object of shape `{ phone: '...', country: '...' }`.\r\n * @param {object} [options]\r\n * @param {object} metadata\r\n * @return {string}\r\n */\r\nexport default function isPossiblePhoneNumber(input, options, metadata) {\r\n\t/* istanbul ignore if */\r\n\tif (options === undefined) {\r\n\t\toptions = {}\r\n\t}\r\n\r\n\tmetadata = new Metadata(metadata)\r\n\r\n\tif (options.v2) {\r\n\t\tif (!input.countryCallingCode) {\r\n\t\t\tthrow new Error('Invalid phone number object passed')\r\n\t\t}\r\n\t\tmetadata.selectNumberingPlan(input.countryCallingCode)\r\n\t} else {\r\n\t\tif (!input.phone) {\r\n\t\t\treturn false\r\n\t\t}\r\n\t\tif (input.country) {\r\n\t\t\tif (!metadata.hasCountry(input.country)) {\r\n\t\t\t\tthrow new Error(`Unknown country: ${input.country}`)\r\n\t\t\t}\r\n\t\t\tmetadata.selectNumberingPlan(input.country)\r\n\t\t} else {\r\n\t\t\tif (!input.countryCallingCode) {\r\n\t\t\t\tthrow new Error('Invalid phone number object passed')\r\n\t\t\t}\r\n\t\t\tmetadata.selectNumberingPlan(input.countryCallingCode)\r\n\t\t}\r\n\t}\r\n\r\n\t// Old metadata (< 1.0.18) had no \"possible length\" data.\r\n\tif (metadata.possibleLengths()) {\r\n\t\treturn isPossibleNumber(input.phone || input.nationalNumber, input.country, metadata)\r\n\t} else {\r\n\t\t// There was a bug between `1.7.35` and `1.7.37` where \"possible_lengths\"\r\n\t\t// were missing for \"non-geographical\" numbering plans.\r\n\t\t// Just assume the number is possible in such cases:\r\n\t\t// it's unlikely that anyone generated their custom metadata\r\n\t\t// in that short period of time (one day).\r\n\t\t// This code can be removed in some future major version update.\r\n\t\tif (input.countryCallingCode && metadata.isNonGeographicCallingCode(input.countryCallingCode)) {\r\n\t\t\t// \"Non-geographic entities\" did't have `possibleLengths`\r\n\t\t\t// due to a bug in metadata generation process.\r\n\t\t\treturn true\r\n\t\t} else {\r\n\t\t\tthrow new Error('Missing \"possibleLengths\" in metadata. Perhaps the metadata has been generated before v1.0.18.');\r\n\t\t}\r\n\t}\r\n}\r\n\r\nexport function isPossibleNumber(nationalNumber, country, metadata) { //, isInternational) {\r\n\tswitch (checkNumberLength(nationalNumber, country, metadata)) {\r\n\t\tcase 'IS_POSSIBLE':\r\n\t\t\treturn true\r\n\t\t// This library ignores \"local-only\" phone numbers (for simplicity).\r\n\t\t// See the readme for more info on what are \"local-only\" phone numbers.\r\n\t\t// case 'IS_POSSIBLE_LOCAL_ONLY':\r\n\t\t// \treturn !isInternational\r\n\t\tdefault:\r\n\t\t\treturn false\r\n\t}\r\n}","import extractNationalNumberFromPossiblyIncompleteNumber from './extractNationalNumberFromPossiblyIncompleteNumber.js'\r\nimport matchesEntirely from './matchesEntirely.js'\r\nimport checkNumberLength from './checkNumberLength.js'\r\nimport getCountryByCallingCode from './getCountryByCallingCode.js'\r\n\r\n/**\r\n * Strips national prefix and carrier code from a complete phone number.\r\n * The difference from the non-\"FromCompleteNumber\" function is that\r\n * it won't extract national prefix if the resultant number is too short\r\n * to be a complete number for the selected phone numbering plan.\r\n * @param {string} number — Complete phone number digits.\r\n * @param {string?} country — Country, if known.\r\n * @param {Metadata} metadata — Metadata with a phone numbering plan selected.\r\n * @return {object} `{ nationalNumber: string, carrierCode: string? }`.\r\n */\r\nexport default function extractNationalNumber(number, country, metadata) {\r\n\t// Parsing national prefixes and carrier codes\r\n\t// is only required for local phone numbers\r\n\t// but some people don't understand that\r\n\t// and sometimes write international phone numbers\r\n\t// with national prefixes (or maybe even carrier codes).\r\n\t// http://ucken.blogspot.ru/2016/03/trunk-prefixes-in-skype4b.html\r\n\t// Google's original library forgives such mistakes\r\n\t// and so does this library, because it has been requested:\r\n\t// https://github.com/catamphetamine/libphonenumber-js/issues/127\r\n\tconst {\r\n\t\tcarrierCode,\r\n\t\tnationalNumber\r\n\t} = extractNationalNumberFromPossiblyIncompleteNumber(\r\n\t\tnumber,\r\n\t\tmetadata\r\n\t)\r\n\r\n\tif (nationalNumber !== number) {\r\n\t\tif (!shouldHaveExtractedNationalPrefix(number, nationalNumber, metadata)) {\r\n\t\t\t// Don't strip the national prefix.\r\n\t\t\treturn { nationalNumber: number }\r\n\t\t}\r\n\t\t// Check the national (significant) number length after extracting national prefix and carrier code.\r\n\t\t// Legacy generated metadata (before `1.0.18`) didn't support the \"possible lengths\" feature.\r\n\t\tif (metadata.numberingPlan.possibleLengths()) {\r\n\t\t\t// If an exact `country` is not specified, attempt to detect it from the assumed national number.\r\n\t\t\tif (!country) {\r\n\t\t\t\tcountry = getCountryByCallingCode(metadata.numberingPlan.callingCode(), {\r\n\t\t\t\t\tnationalNumber,\r\n\t\t\t\t\tmetadata\r\n\t\t\t\t})\r\n\t\t\t}\r\n\r\n\t\t\t// The number remaining after stripping the national prefix and carrier code\r\n\t\t\t// should be long enough to have a possible length for the country.\r\n\t\t\t// Otherwise, don't strip the national prefix and carrier code,\r\n\t\t\t// since the original number could be a valid number.\r\n\t\t\t// This check has been copy-pasted \"as is\" from Google's original library:\r\n\t\t\t// https://github.com/google/libphonenumber/blob/876268eb1ad6cdc1b7b5bef17fc5e43052702d57/java/libphonenumber/src/com/google/i18n/phonenumbers/PhoneNumberUtil.java#L3236-L3250\r\n\t\t\t// It doesn't check for the \"possibility\" of the original `number`.\r\n\t\t\t// I guess it's fine not checking that one. It works as is anyway.\r\n\t\t\tif (!isPossibleIncompleteNationalNumber(nationalNumber, country, metadata)) {\r\n\t\t\t\t// Don't strip the national prefix.\r\n\t\t\t\treturn { nationalNumber: number }\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\treturn { nationalNumber, carrierCode }\r\n}\r\n\r\n// In some countries, the same digit could be a national prefix\r\n// or a leading digit of a valid phone number.\r\n// For example, in Russia, national prefix is `8`,\r\n// and also `800 555 35 35` is a valid number\r\n// in which `8` is not a national prefix, but the first digit\r\n// of a national (significant) number.\r\n// Same's with Belarus:\r\n// `82004910060` is a valid national (significant) number,\r\n// but `2004910060` is not.\r\n// To support such cases (to prevent the code from always stripping\r\n// national prefix), a condition is imposed: a national prefix\r\n// is not extracted when the original number is \"viable\" and the\r\n// resultant number is not, a \"viable\" national number being the one\r\n// that matches `national_number_pattern`.\r\nfunction shouldHaveExtractedNationalPrefix(nationalNumberBefore, nationalNumberAfter, metadata) {\r\n\t// The equivalent in Google's code is:\r\n\t// https://github.com/google/libphonenumber/blob/e326fa1fc4283bb05eb35cb3c15c18f98a31af33/java/libphonenumber/src/com/google/i18n/phonenumbers/PhoneNumberUtil.java#L2969-L3004\r\n\tif (matchesEntirely(nationalNumberBefore, metadata.nationalNumberPattern()) &&\r\n\t\t!matchesEntirely(nationalNumberAfter, metadata.nationalNumberPattern())) {\r\n\t\treturn false\r\n\t}\r\n\t// This \"is possible\" national number (length) check has been commented out\r\n\t// because it's superceded by the (effectively) same check done in the\r\n\t// `extractNationalNumber()` function after it calls `shouldHaveExtractedNationalPrefix()`.\r\n\t// In other words, why run the same check twice if it could only be run once.\r\n\t// // Check the national (significant) number length after extracting national prefix and carrier code.\r\n\t// // Fixes a minor \"weird behavior\" bug: https://gitlab.com/catamphetamine/libphonenumber-js/-/issues/57\r\n\t// // (Legacy generated metadata (before `1.0.18`) didn't support the \"possible lengths\" feature).\r\n\t// if (metadata.possibleLengths()) {\r\n\t// \tif (isPossibleIncompleteNationalNumber(nationalNumberBefore, metadata) &&\r\n\t// \t\t!isPossibleIncompleteNationalNumber(nationalNumberAfter, metadata)) {\r\n\t// \t\treturn false\r\n\t// \t}\r\n\t// }\r\n\treturn true\r\n}\r\n\r\nfunction isPossibleIncompleteNationalNumber(nationalNumber, country, metadata) {\r\n\tswitch (checkNumberLength(nationalNumber, country, metadata)) {\r\n\t\tcase 'TOO_SHORT':\r\n\t\tcase 'INVALID_LENGTH':\r\n\t\t// This library ignores \"local-only\" phone numbers (for simplicity).\r\n\t\t// See the readme for more info on what are \"local-only\" phone numbers.\r\n\t\t// case 'IS_POSSIBLE_LOCAL_ONLY':\r\n\t\t\treturn false\r\n\t\tdefault:\r\n\t\t\treturn true\r\n\t}\r\n}","import {\r\n\tMIN_LENGTH_FOR_NSN,\r\n\tVALID_DIGITS,\r\n\tVALID_PUNCTUATION,\r\n\tPLUS_CHARS\r\n} from '../constants.js'\r\n\r\nimport createExtensionPattern from './extension/createExtensionPattern.js'\r\n\r\n// Regular expression of viable phone numbers. This is location independent.\r\n// Checks we have at least three leading digits, and only valid punctuation,\r\n// alpha characters and digits in the phone number. Does not include extension\r\n// data. The symbol 'x' is allowed here as valid punctuation since it is often\r\n// used as a placeholder for carrier codes, for example in Brazilian phone\r\n// numbers. We also allow multiple '+' characters at the start.\r\n//\r\n// Corresponds to the following:\r\n// [digits]{minLengthNsn}|\r\n// plus_sign*\r\n// (([punctuation]|[star])*[digits]){3,}([punctuation]|[star]|[digits]|[alpha])*\r\n//\r\n// The first reg-ex is to allow short numbers (two digits long) to be parsed if\r\n// they are entered as \"15\" etc, but only if there is no punctuation in them.\r\n// The second expression restricts the number of digits to three or more, but\r\n// then allows them to be in international form, and to have alpha-characters\r\n// and punctuation. We split up the two reg-exes here and combine them when\r\n// creating the reg-ex VALID_PHONE_NUMBER_PATTERN itself so we can prefix it\r\n// with ^ and append $ to each branch.\r\n//\r\n// \"Note VALID_PUNCTUATION starts with a -,\r\n// so must be the first in the range\" (c) Google devs.\r\n// (wtf did they mean by saying that; probably nothing)\r\n//\r\nconst MIN_LENGTH_PHONE_NUMBER_PATTERN = '[' + VALID_DIGITS + ']{' + MIN_LENGTH_FOR_NSN + '}'\r\n//\r\n// And this is the second reg-exp:\r\n// (see MIN_LENGTH_PHONE_NUMBER_PATTERN for a full description of this reg-exp)\r\n//\r\nexport const VALID_PHONE_NUMBER =\r\n\t'[' + PLUS_CHARS + ']{0,1}' +\r\n\t'(?:' +\r\n\t\t'[' + VALID_PUNCTUATION + ']*' +\r\n\t\t'[' + VALID_DIGITS + ']' +\r\n\t'){3,}' +\r\n\t'[' +\r\n\t\tVALID_PUNCTUATION +\r\n\t\tVALID_DIGITS +\r\n\t']*'\r\n\r\n// This regular expression isn't present in Google's `libphonenumber`\r\n// and is only used to determine whether the phone number being input\r\n// is too short for it to even consider it a \"valid\" number.\r\n// This is just a way to differentiate between a really invalid phone\r\n// number like \"abcde\" and a valid phone number that a user has just\r\n// started inputting, like \"+1\" or \"1\": both these cases would be\r\n// considered `NOT_A_NUMBER` by Google's `libphonenumber`, but this\r\n// library can provide a more detailed error message — whether it's\r\n// really \"not a number\", or is it just a start of a valid phone number.\r\nconst VALID_PHONE_NUMBER_START_REG_EXP = new RegExp(\r\n\t'^' +\r\n\t'[' + PLUS_CHARS + ']{0,1}' +\r\n\t'(?:' +\r\n\t\t'[' + VALID_PUNCTUATION + ']*' +\r\n\t\t'[' + VALID_DIGITS + ']' +\r\n\t'){1,2}' +\r\n\t'$'\r\n, 'i')\r\n\r\nexport const VALID_PHONE_NUMBER_WITH_EXTENSION =\r\n\tVALID_PHONE_NUMBER +\r\n\t// Phone number extensions\r\n\t'(?:' + createExtensionPattern() + ')?'\r\n\r\n// The combined regular expression for valid phone numbers:\r\n//\r\nconst VALID_PHONE_NUMBER_PATTERN = new RegExp(\r\n\t// Either a short two-digit-only phone number\r\n\t'^' +\r\n\t\tMIN_LENGTH_PHONE_NUMBER_PATTERN +\r\n\t'$' +\r\n\t'|' +\r\n\t// Or a longer fully parsed phone number (min 3 characters)\r\n\t'^' +\r\n\t\tVALID_PHONE_NUMBER_WITH_EXTENSION +\r\n\t'$'\r\n, 'i')\r\n\r\n// Checks to see if the string of characters could possibly be a phone number at\r\n// all. At the moment, checks to see that the string begins with at least 2\r\n// digits, ignoring any punctuation commonly found in phone numbers. This method\r\n// does not require the number to be normalized in advance - but does assume\r\n// that leading non-number symbols have been removed, such as by the method\r\n// `extract_possible_number`.\r\n//\r\nexport default function isViablePhoneNumber(number) {\r\n\treturn number.length >= MIN_LENGTH_FOR_NSN &&\r\n\t\tVALID_PHONE_NUMBER_PATTERN.test(number)\r\n}\r\n\r\n// This is just a way to differentiate between a really invalid phone\r\n// number like \"abcde\" and a valid phone number that a user has just\r\n// started inputting, like \"+1\" or \"1\": both these cases would be\r\n// considered `NOT_A_NUMBER` by Google's `libphonenumber`, but this\r\n// library can provide a more detailed error message — whether it's\r\n// really \"not a number\", or is it just a start of a valid phone number.\r\nexport function isViablePhoneNumberStart(number) {\r\n\treturn VALID_PHONE_NUMBER_START_REG_EXP.test(number)\r\n}","import { parseDigit } from './helpers/parseDigits.js'\r\n\r\n/**\r\n * Parses phone number characters from a string.\r\n * Drops all punctuation leaving only digits and the leading `+` sign (if any).\r\n * Also converts wide-ascii and arabic-indic numerals to conventional numerals.\r\n * E.g. in Iraq they don't write `+442323234` but rather `+٤٤٢٣٢٣٢٣٤`.\r\n * @param {string} string\r\n * @return {string}\r\n * @example\r\n * ```js\r\n * // Outputs '8800555'.\r\n * parseIncompletePhoneNumber('8 (800) 555')\r\n * // Outputs '+7800555'.\r\n * parseIncompletePhoneNumber('+7 800 555')\r\n * ```\r\n */\r\nexport default function parseIncompletePhoneNumber(string) {\r\n\tlet result = ''\r\n\t// Using `.split('')` here instead of normal `for ... of`\r\n\t// because the importing application doesn't neccessarily include an ES6 polyfill.\r\n\t// The `.split('')` approach discards \"exotic\" UTF-8 characters\r\n\t// (the ones consisting of four bytes) but digits\r\n\t// (including non-European ones) don't fall into that range\r\n\t// so such \"exotic\" characters would be discarded anyway.\r\n\tfor (const character of string.split('')) {\r\n\t\tresult += parsePhoneNumberCharacter(character, result) || ''\r\n\t}\r\n\treturn result\r\n}\r\n\r\n/**\r\n * Parses next character while parsing phone number digits (including a `+`)\r\n * from text: discards everything except `+` and digits, and `+` is only allowed\r\n * at the start of a phone number.\r\n * For example, is used in `react-phone-number-input` where it uses\r\n * [`input-format`](https://gitlab.com/catamphetamine/input-format).\r\n * @param {string} character - Yet another character from raw input string.\r\n * @param {string?} prevParsedCharacters - Previous parsed characters.\r\n * @param {function?} eventListener - An optional \"on event\" function.\r\n * @return {string?} The parsed character.\r\n */\r\nexport function parsePhoneNumberCharacter(character, prevParsedCharacters, eventListener) {\r\n\t// Only allow a leading `+`.\r\n\tif (character === '+') {\r\n\t\t// If this `+` is not the first parsed character\r\n\t\t// then discard it.\r\n\t\tif (prevParsedCharacters) {\r\n\t\t\t// `eventListener` argument was added to this `export`ed function on Dec 26th, 2023.\r\n\t\t\t// Any 3rd-party code that used to `import` and call this function before that\r\n\t\t\t// won't be passing any `eventListener` argument.\r\n\t\t\t//\r\n\t\t\t// The addition of the `eventListener` argument was to fix the slightly-weird behavior\r\n\t\t\t// of parsing an input string when the user inputs something like `\"2+7\"\r\n\t\t\t// https://github.com/catamphetamine/react-phone-number-input/issues/437\r\n\t\t\t//\r\n\t\t\t// If the parser encounters an unexpected `+` in a string being parsed\r\n\t\t\t// then it simply discards that out-of-place `+` and any following characters.\r\n\t\t\t//\r\n\t\t\tif (typeof eventListener === 'function') {\r\n\t\t\t\teventListener('end')\r\n\t\t\t}\r\n\t\t\treturn\r\n\t\t}\r\n\t\treturn '+'\r\n\t}\r\n\t// Allow digits.\r\n\treturn parseDigit(character)\r\n}","import isViablePhoneNumber from './isViablePhoneNumber.js'\r\n\r\n// https://www.ietf.org/rfc/rfc3966.txt\r\n\r\n/**\r\n * @param {string} text - Phone URI (RFC 3966).\r\n * @return {object} `{ ?number, ?ext }`.\r\n */\r\nexport function parseRFC3966(text) {\r\n\tlet number\r\n\tlet ext\r\n\r\n\t// Replace \"tel:\" with \"tel=\" for parsing convenience.\r\n\ttext = text.replace(/^tel:/, 'tel=')\r\n\r\n\tfor (const part of text.split(';')) {\r\n\t\tconst [name, value] = part.split('=')\r\n\t\tswitch (name) {\r\n\t\t\tcase 'tel':\r\n\t\t\t\tnumber = value\r\n\t\t\t\tbreak\r\n\t\t\tcase 'ext':\r\n\t\t\t\text = value\r\n\t\t\t\tbreak\r\n\t\t\tcase 'phone-context':\r\n\t\t\t\t// Only \"country contexts\" are supported.\r\n\t\t\t\t// \"Domain contexts\" are ignored.\r\n\t\t\t\tif (value[0] === '+') {\r\n\t\t\t\t\tnumber = value + number\r\n\t\t\t\t}\r\n\t\t\t\tbreak\r\n\t\t}\r\n\t}\r\n\r\n\t// If the phone number is not viable, then abort.\r\n\tif (!isViablePhoneNumber(number)) {\r\n\t\treturn {}\r\n\t}\r\n\r\n\tconst result = { number }\r\n\tif (ext) {\r\n\t\tresult.ext = ext\r\n\t}\r\n\treturn result\r\n}\r\n\r\n/**\r\n * @param {object} - `{ ?number, ?extension }`.\r\n * @return {string} Phone URI (RFC 3966).\r\n */\r\nexport function formatRFC3966({ number, ext }) {\r\n\tif (!number) {\r\n\t\treturn ''\r\n\t}\r\n\tif (number[0] !== '+') {\r\n\t\tthrow new Error(`\"formatRFC3966()\" expects \"number\" to be in E.164 format.`)\r\n\t}\r\n\treturn `tel:${number}${ext ? ';ext=' + ext : ''}`\r\n}","import parsePhoneNumberWithError from './parsePhoneNumberWithError_.js'\r\nimport ParseError from './ParseError.js'\r\nimport { isSupportedCountry } from './metadata.js'\r\n\r\nexport default function parsePhoneNumber(text, options, metadata) {\r\n\t// Validate `defaultCountry`.\r\n\tif (options && options.defaultCountry && !isSupportedCountry(options.defaultCountry, metadata)) {\r\n\t\toptions = {\r\n\t\t\t...options,\r\n\t\t\tdefaultCountry: undefined\r\n\t\t}\r\n\t}\r\n\t// Parse phone number.\r\n\ttry {\r\n\t\treturn parsePhoneNumberWithError(text, options, metadata)\r\n\t} catch (error) {\r\n\t\t/* istanbul ignore else */\r\n\t\tif (error instanceof ParseError) {\r\n\t\t\t//\r\n\t\t} else {\r\n\t\t\tthrow error\r\n\t\t}\r\n\t}\r\n}\r\n","import Metadata from './metadata.js'\r\nimport matchesEntirely from './helpers/matchesEntirely.js'\r\nimport getNumberType from './helpers/getNumberType.js'\r\n\r\n/**\r\n * Checks if a given phone number is valid.\r\n *\r\n * isValid(phoneNumberInstance, { ..., v2: true }, metadata)\r\n *\r\n * isPossible({ phone: '8005553535', country: 'RU' }, { ... }, metadata)\r\n * isPossible({ phone: '8005553535', country: 'RU' }, undefined, metadata)\r\n *\r\n * If the `number` is a string, it will be parsed to an object,\r\n * but only if it contains only valid phone number characters (including punctuation).\r\n * If the `number` is an object, it is used as is.\r\n *\r\n * The optional `defaultCountry` argument is the default country.\r\n * I.e. it does not restrict to just that country,\r\n * e.g. in those cases where several countries share\r\n * the same phone numbering rules (NANPA, Britain, etc).\r\n * For example, even though the number `07624 369230`\r\n * belongs to the Isle of Man (\"IM\" country code)\r\n * calling `isValidNumber('07624369230', 'GB', metadata)`\r\n * still returns `true` because the country is not restricted to `GB`,\r\n * it's just that `GB` is the default one for the phone numbering rules.\r\n * For restricting the country see `isValidNumberForRegion()`\r\n * though restricting a country might not be a good idea.\r\n * https://github.com/googlei18n/libphonenumber/blob/master/FAQ.md#when-should-i-use-isvalidnumberforregion\r\n *\r\n * Examples:\r\n *\r\n * ```js\r\n * isValidNumber('+78005553535', metadata)\r\n * isValidNumber('8005553535', 'RU', metadata)\r\n * isValidNumber('88005553535', 'RU', metadata)\r\n * isValidNumber({ phone: '8005553535', country: 'RU' }, metadata)\r\n * ```\r\n */\r\nexport default function isValidNumber(input, options, metadata)\r\n{\r\n\t// If assigning the `{}` default value is moved to the arguments above,\r\n\t// code coverage would decrease for some weird reason.\r\n\toptions = options || {}\r\n\r\n\tmetadata = new Metadata(metadata)\r\n\r\n\tmetadata.selectNumberingPlan(input.country, input.countryCallingCode)\r\n\r\n\t// By default, countries only have type regexps when it's required for\r\n\t// distinguishing different countries having the same `countryCallingCode`.\r\n\tif (metadata.hasTypes()) {\r\n\t\treturn getNumberType(input, options, metadata.metadata) !== undefined\r\n\t}\r\n\r\n\t// If there are no type regexps for this country in metadata then use\r\n\t// `nationalNumberPattern` as a \"better than nothing\" replacement.\r\n\tconst nationalNumber = options.v2 ? input.nationalNumber : input.phone\r\n\treturn matchesEntirely(nationalNumber, metadata.nationalNumberPattern())\r\n}","// Copy-pasted from:\r\n// https://github.com/substack/semver-compare/blob/master/index.js\r\n//\r\n// Inlining this function because some users reported issues with\r\n// importing from `semver-compare` in a browser with ES6 \"native\" modules.\r\n//\r\n// Fixes `semver-compare` not being able to compare versions with alpha/beta/etc \"tags\".\r\n// https://github.com/catamphetamine/libphonenumber-js/issues/381\r\nexport default function(a, b) {\r\n a = a.split('-')\r\n b = b.split('-')\r\n var pa = a[0].split('.')\r\n var pb = b[0].split('.')\r\n for (var i = 0; i < 3; i++) {\r\n var na = Number(pa[i])\r\n var nb = Number(pb[i])\r\n if (na > nb) return 1\r\n if (nb > na) return -1\r\n if (!isNaN(na) && isNaN(nb)) return 1\r\n if (isNaN(na) && !isNaN(nb)) return -1\r\n }\r\n if (a[1] && b[1]) {\r\n return a[1] > b[1] ? 1 : (a[1] < b[1] ? -1 : 0)\r\n }\r\n return !a[1] && b[1] ? 1 : (a[1] && !b[1] ? -1 : 0)\r\n}","import compare from './tools/semver-compare.js'\r\nimport isObject from './helpers/isObject.js'\r\n\r\n// Added \"possibleLengths\" and renamed\r\n// \"country_phone_code_to_countries\" to \"country_calling_codes\".\r\nconst V2 = '1.0.18'\r\n\r\n// Added \"idd_prefix\" and \"default_idd_prefix\".\r\nconst V3 = '1.2.0'\r\n\r\n// Moved `001` country code to \"nonGeographic\" section of metadata.\r\nconst V4 = '1.7.35'\r\n\r\nconst DEFAULT_EXT_PREFIX = ' ext. '\r\n\r\nconst CALLING_CODE_REG_EXP = /^\\d+$/\r\n\r\n/**\r\n * See: https://gitlab.com/catamphetamine/libphonenumber-js/blob/master/METADATA.md\r\n */\r\nexport default class Metadata {\r\n\tconstructor(metadata) {\r\n\t\tvalidateMetadata(metadata)\r\n\t\tthis.metadata = metadata\r\n\t\tsetVersion.call(this, metadata)\r\n\t}\r\n\r\n\tgetCountries() {\r\n\t\treturn Object.keys(this.metadata.countries).filter(_ => _ !== '001')\r\n\t}\r\n\r\n\tgetCountryMetadata(countryCode) {\r\n\t\treturn this.metadata.countries[countryCode]\r\n\t}\r\n\r\n\tnonGeographic() {\r\n\t\tif (this.v1 || this.v2 || this.v3) return\r\n\t\t// `nonGeographical` was a typo.\r\n\t\t// It's present in metadata generated from `1.7.35` to `1.7.37`.\r\n\t\t// The test case could be found by searching for \"nonGeographical\".\r\n\t\treturn this.metadata.nonGeographic || this.metadata.nonGeographical\r\n\t}\r\n\r\n\thasCountry(country) {\r\n\t\treturn this.getCountryMetadata(country) !== undefined\r\n\t}\r\n\r\n\thasCallingCode(callingCode) {\r\n\t\tif (this.getCountryCodesForCallingCode(callingCode)) {\r\n\t\t\treturn true\r\n\t\t}\r\n\t\tif (this.nonGeographic()) {\r\n\t\t\tif (this.nonGeographic()[callingCode]) {\r\n\t\t\t\treturn true\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\t// A hacky workaround for old custom metadata (generated before V4).\r\n\t\t\tconst countryCodes = this.countryCallingCodes()[callingCode]\r\n\t\t\tif (countryCodes && countryCodes.length === 1 && countryCodes[0] === '001') {\r\n\t\t\t\treturn true\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tisNonGeographicCallingCode(callingCode) {\r\n\t\tif (this.nonGeographic()) {\r\n\t\t\treturn this.nonGeographic()[callingCode] ? true : false\r\n\t\t} else {\r\n\t\t\treturn this.getCountryCodesForCallingCode(callingCode) ? false : true\r\n\t\t}\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tcountry(countryCode) {\r\n\t\treturn this.selectNumberingPlan(countryCode)\r\n\t}\r\n\r\n\tselectNumberingPlan(countryCode, callingCode) {\r\n\t\t// Supports just passing `callingCode` as the first argument.\r\n\t\tif (countryCode && CALLING_CODE_REG_EXP.test(countryCode)) {\r\n\t\t\tcallingCode = countryCode\r\n\t\t\tcountryCode = null\r\n\t\t}\r\n\t\tif (countryCode && countryCode !== '001') {\r\n\t\t\tif (!this.hasCountry(countryCode)) {\r\n\t\t\t\tthrow new Error(`Unknown country: ${countryCode}`)\r\n\t\t\t}\r\n\t\t\tthis.numberingPlan = new NumberingPlan(this.getCountryMetadata(countryCode), this)\r\n\t\t} else if (callingCode) {\r\n\t\t\tif (!this.hasCallingCode(callingCode)) {\r\n\t\t\t\tthrow new Error(`Unknown calling code: ${callingCode}`)\r\n\t\t\t}\r\n\t\t\tthis.numberingPlan = new NumberingPlan(this.getNumberingPlanMetadata(callingCode), this)\r\n\t\t} else {\r\n\t\t\tthis.numberingPlan = undefined\r\n\t\t}\r\n\t\treturn this\r\n\t}\r\n\r\n\tgetCountryCodesForCallingCode(callingCode) {\r\n\t\tconst countryCodes = this.countryCallingCodes()[callingCode]\r\n\t\tif (countryCodes) {\r\n\t\t\t// Metadata before V4 included \"non-geographic entity\" calling codes\r\n\t\t\t// inside `country_calling_codes` (for example, `\"881\":[\"001\"]`).\r\n\t\t\t// Now the semantics of `country_calling_codes` has changed:\r\n\t\t\t// it's specifically for \"countries\" now.\r\n\t\t\t// Older versions of custom metadata will simply skip parsing\r\n\t\t\t// \"non-geographic entity\" phone numbers with new versions\r\n\t\t\t// of this library: it's not considered a bug,\r\n\t\t\t// because such numbers are extremely rare,\r\n\t\t\t// and developers extremely rarely use custom metadata.\r\n\t\t\tif (countryCodes.length === 1 && countryCodes[0].length === 3) {\r\n\t\t\t\treturn\r\n\t\t\t}\r\n\t\t\treturn countryCodes\r\n\t\t}\r\n\t}\r\n\r\n\tgetCountryCodeForCallingCode(callingCode) {\r\n\t\tconst countryCodes = this.getCountryCodesForCallingCode(callingCode)\r\n\t\tif (countryCodes) {\r\n\t\t\treturn countryCodes[0]\r\n\t\t}\r\n\t}\r\n\r\n\tgetNumberingPlanMetadata(callingCode) {\r\n\t\tconst countryCode = this.getCountryCodeForCallingCode(callingCode)\r\n\t\tif (countryCode) {\r\n\t\t\treturn this.getCountryMetadata(countryCode)\r\n\t\t}\r\n\t\tif (this.nonGeographic()) {\r\n\t\t\tconst metadata = this.nonGeographic()[callingCode]\r\n\t\t\tif (metadata) {\r\n\t\t\t\treturn metadata\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\t// A hacky workaround for old custom metadata (generated before V4).\r\n\t\t\t// In that metadata, there was no concept of \"non-geographic\" metadata\r\n\t\t\t// so metadata for `001` country code was stored along with other countries.\r\n\t\t\t// The test case can be found by searching for:\r\n\t\t\t// \"should work around `nonGeographic` metadata not existing\".\r\n\t\t\tconst countryCodes = this.countryCallingCodes()[callingCode]\r\n\t\t\tif (countryCodes && countryCodes.length === 1 && countryCodes[0] === '001') {\r\n\t\t\t\treturn this.metadata.countries['001']\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tcountryCallingCode() {\r\n\t\treturn this.numberingPlan.callingCode()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tIDDPrefix() {\r\n\t\treturn this.numberingPlan.IDDPrefix()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tdefaultIDDPrefix() {\r\n\t\treturn this.numberingPlan.defaultIDDPrefix()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tnationalNumberPattern() {\r\n\t\treturn this.numberingPlan.nationalNumberPattern()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tpossibleLengths() {\r\n\t\treturn this.numberingPlan.possibleLengths()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tformats() {\r\n\t\treturn this.numberingPlan.formats()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tnationalPrefixForParsing() {\r\n\t\treturn this.numberingPlan.nationalPrefixForParsing()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tnationalPrefixTransformRule() {\r\n\t\treturn this.numberingPlan.nationalPrefixTransformRule()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tleadingDigits() {\r\n\t\treturn this.numberingPlan.leadingDigits()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\thasTypes() {\r\n\t\treturn this.numberingPlan.hasTypes()\r\n\t}\r\n\r\n\t// Deprecated.\r\n\ttype(type) {\r\n\t\treturn this.numberingPlan.type(type)\r\n\t}\r\n\r\n\t// Deprecated.\r\n\text() {\r\n\t\treturn this.numberingPlan.ext()\r\n\t}\r\n\r\n\tcountryCallingCodes() {\r\n\t\tif (this.v1) return this.metadata.country_phone_code_to_countries\r\n\t\treturn this.metadata.country_calling_codes\r\n\t}\r\n\r\n\t// Deprecated.\r\n\tchooseCountryByCountryCallingCode(callingCode) {\r\n\t\treturn this.selectNumberingPlan(callingCode)\r\n\t}\r\n\r\n\thasSelectedNumberingPlan() {\r\n\t\treturn this.numberingPlan !== undefined\r\n\t}\r\n}\r\n\r\nclass NumberingPlan {\r\n\tconstructor(metadata, globalMetadataObject) {\r\n\t\tthis.globalMetadataObject = globalMetadataObject\r\n\t\tthis.metadata = metadata\r\n\t\tsetVersion.call(this, globalMetadataObject.metadata)\r\n\t}\r\n\r\n\tcallingCode() {\r\n\t\treturn this.metadata[0]\r\n\t}\r\n\r\n\t// Formatting information for regions which share\r\n\t// a country calling code is contained by only one region\r\n\t// for performance reasons. For example, for NANPA region\r\n\t// (\"North American Numbering Plan Administration\",\r\n\t// which includes USA, Canada, Cayman Islands, Bahamas, etc)\r\n\t// it will be contained in the metadata for `US`.\r\n\tgetDefaultCountryMetadataForRegion() {\r\n\t\treturn this.globalMetadataObject.getNumberingPlanMetadata(this.callingCode())\r\n\t}\r\n\r\n\t// Is always present.\r\n\tIDDPrefix() {\r\n\t\tif (this.v1 || this.v2) return\r\n\t\treturn this.metadata[1]\r\n\t}\r\n\r\n\t// Is only present when a country supports multiple IDD prefixes.\r\n\tdefaultIDDPrefix() {\r\n\t\tif (this.v1 || this.v2) return\r\n\t\treturn this.metadata[12]\r\n\t}\r\n\r\n\tnationalNumberPattern() {\r\n\t\tif (this.v1 || this.v2) return this.metadata[1]\r\n\t\treturn this.metadata[2]\r\n\t}\r\n\r\n\t// \"possible length\" data is always present in Google's metadata.\r\n\tpossibleLengths() {\r\n\t\tif (this.v1) return\r\n\t\treturn this.metadata[this.v2 ? 2 : 3]\r\n\t}\r\n\r\n\t_getFormats(metadata) {\r\n\t\treturn metadata[this.v1 ? 2 : this.v2 ? 3 : 4]\r\n\t}\r\n\r\n\t// For countries of the same region (e.g. NANPA)\r\n\t// formats are all stored in the \"main\" country for that region.\r\n\t// E.g. \"RU\" and \"KZ\", \"US\" and \"CA\".\r\n\tformats() {\r\n\t\tconst formats = this._getFormats(this.metadata) || this._getFormats(this.getDefaultCountryMetadataForRegion()) || []\r\n\t\treturn formats.map(_ => new Format(_, this))\r\n\t}\r\n\r\n\tnationalPrefix() {\r\n\t\treturn this.metadata[this.v1 ? 3 : this.v2 ? 4 : 5]\r\n\t}\r\n\r\n\t_getNationalPrefixFormattingRule(metadata) {\r\n\t\treturn metadata[this.v1 ? 4 : this.v2 ? 5 : 6]\r\n\t}\r\n\r\n\t// For countries of the same region (e.g. NANPA)\r\n\t// national prefix formatting rule is stored in the \"main\" country for that region.\r\n\t// E.g. \"RU\" and \"KZ\", \"US\" and \"CA\".\r\n\tnationalPrefixFormattingRule() {\r\n\t\treturn this._getNationalPrefixFormattingRule(this.metadata) || this._getNationalPrefixFormattingRule(this.getDefaultCountryMetadataForRegion())\r\n\t}\r\n\r\n\t_nationalPrefixForParsing() {\r\n\t\treturn this.metadata[this.v1 ? 5 : this.v2 ? 6 : 7]\r\n\t}\r\n\r\n\tnationalPrefixForParsing() {\r\n\t\t// If `national_prefix_for_parsing` is not set explicitly,\r\n\t\t// then infer it from `national_prefix` (if any)\r\n\t\treturn this._nationalPrefixForParsing() || this.nationalPrefix()\r\n\t}\r\n\r\n\tnationalPrefixTransformRule() {\r\n\t\treturn this.metadata[this.v1 ? 6 : this.v2 ? 7 : 8]\r\n\t}\r\n\r\n\t_getNationalPrefixIsOptionalWhenFormatting() {\r\n\t\treturn !!this.metadata[this.v1 ? 7 : this.v2 ? 8 : 9]\r\n\t}\r\n\r\n\t// For countries of the same region (e.g. NANPA)\r\n\t// \"national prefix is optional when formatting\" flag is\r\n\t// stored in the \"main\" country for that region.\r\n\t// E.g. \"RU\" and \"KZ\", \"US\" and \"CA\".\r\n\tnationalPrefixIsOptionalWhenFormattingInNationalFormat() {\r\n\t\treturn this._getNationalPrefixIsOptionalWhenFormatting(this.metadata) ||\r\n\t\t\tthis._getNationalPrefixIsOptionalWhenFormatting(this.getDefaultCountryMetadataForRegion())\r\n\t}\r\n\r\n\tleadingDigits() {\r\n\t\treturn this.metadata[this.v1 ? 8 : this.v2 ? 9 : 10]\r\n\t}\r\n\r\n\ttypes() {\r\n\t\treturn this.metadata[this.v1 ? 9 : this.v2 ? 10 : 11]\r\n\t}\r\n\r\n\thasTypes() {\r\n\t\t// Versions 1.2.0 - 1.2.4: can be `[]`.\r\n\t\t/* istanbul ignore next */\r\n\t\tif (this.types() && this.types().length === 0) {\r\n\t\t\treturn false\r\n\t\t}\r\n\t\t// Versions <= 1.2.4: can be `undefined`.\r\n\t\t// Version >= 1.2.5: can be `0`.\r\n\t\treturn !!this.types()\r\n\t}\r\n\r\n\ttype(type) {\r\n\t\tif (this.hasTypes() && getType(this.types(), type)) {\r\n\t\t\treturn new Type(getType(this.types(), type), this)\r\n\t\t}\r\n\t}\r\n\r\n\text() {\r\n\t\tif (this.v1 || this.v2) return DEFAULT_EXT_PREFIX\r\n\t\treturn this.metadata[13] || DEFAULT_EXT_PREFIX\r\n\t}\r\n}\r\n\r\nclass Format {\r\n\tconstructor(format, metadata) {\r\n\t\tthis._format = format\r\n\t\tthis.metadata = metadata\r\n\t}\r\n\r\n\tpattern() {\r\n\t\treturn this._format[0]\r\n\t}\r\n\r\n\tformat() {\r\n\t\treturn this._format[1]\r\n\t}\r\n\r\n\tleadingDigitsPatterns() {\r\n\t\treturn this._format[2] || []\r\n\t}\r\n\r\n\tnationalPrefixFormattingRule() {\r\n\t\treturn this._format[3] || this.metadata.nationalPrefixFormattingRule()\r\n\t}\r\n\r\n\tnationalPrefixIsOptionalWhenFormattingInNationalFormat() {\r\n\t\treturn !!this._format[4] || this.metadata.nationalPrefixIsOptionalWhenFormattingInNationalFormat()\r\n\t}\r\n\r\n\tnationalPrefixIsMandatoryWhenFormattingInNationalFormat() {\r\n\t\t// National prefix is omitted if there's no national prefix formatting rule\r\n\t\t// set for this country, or when the national prefix formatting rule\r\n\t\t// contains no national prefix itself, or when this rule is set but\r\n\t\t// national prefix is optional for this phone number format\r\n\t\t// (and it is not enforced explicitly)\r\n\t\treturn this.usesNationalPrefix() && !this.nationalPrefixIsOptionalWhenFormattingInNationalFormat()\r\n\t}\r\n\r\n\t// Checks whether national prefix formatting rule contains national prefix.\r\n\tusesNationalPrefix() {\r\n\t\treturn this.nationalPrefixFormattingRule() &&\r\n\t\t\t// Check that national prefix formatting rule is not a \"dummy\" one.\r\n\t\t\t!FIRST_GROUP_ONLY_PREFIX_PATTERN.test(this.nationalPrefixFormattingRule())\r\n\t\t\t// In compressed metadata, `this.nationalPrefixFormattingRule()` is `0`\r\n\t\t\t// when `national_prefix_formatting_rule` is not present.\r\n\t\t\t// So, `true` or `false` are returned explicitly here, so that\r\n\t\t\t// `0` number isn't returned.\r\n\t\t\t? true\r\n\t\t\t: false\r\n\t}\r\n\r\n\tinternationalFormat() {\r\n\t\treturn this._format[5] || this.format()\r\n\t}\r\n}\r\n\r\n/**\r\n * A pattern that is used to determine if the national prefix formatting rule\r\n * has the first group only, i.e., does not start with the national prefix.\r\n * Note that the pattern explicitly allows for unbalanced parentheses.\r\n */\r\nconst FIRST_GROUP_ONLY_PREFIX_PATTERN = /^\\(?\\$1\\)?$/\r\n\r\nclass Type {\r\n\tconstructor(type, metadata) {\r\n\t\tthis.type = type\r\n\t\tthis.metadata = metadata\r\n\t}\r\n\r\n\tpattern() {\r\n\t\tif (this.metadata.v1) return this.type\r\n\t\treturn this.type[0]\r\n\t}\r\n\r\n\tpossibleLengths() {\r\n\t\tif (this.metadata.v1) return\r\n\t\treturn this.type[1] || this.metadata.possibleLengths()\r\n\t}\r\n}\r\n\r\nfunction getType(types, type) {\r\n\tswitch (type) {\r\n\t\tcase 'FIXED_LINE':\r\n\t\t\treturn types[0]\r\n\t\tcase 'MOBILE':\r\n\t\t\treturn types[1]\r\n\t\tcase 'TOLL_FREE':\r\n\t\t\treturn types[2]\r\n\t\tcase 'PREMIUM_RATE':\r\n\t\t\treturn types[3]\r\n\t\tcase 'PERSONAL_NUMBER':\r\n\t\t\treturn types[4]\r\n\t\tcase 'VOICEMAIL':\r\n\t\t\treturn types[5]\r\n\t\tcase 'UAN':\r\n\t\t\treturn types[6]\r\n\t\tcase 'PAGER':\r\n\t\t\treturn types[7]\r\n\t\tcase 'VOIP':\r\n\t\t\treturn types[8]\r\n\t\tcase 'SHARED_COST':\r\n\t\t\treturn types[9]\r\n\t}\r\n}\r\n\r\nexport function validateMetadata(metadata) {\r\n\tif (!metadata) {\r\n\t\tthrow new Error('[libphonenumber-js] `metadata` argument not passed. Check your arguments.')\r\n\t}\r\n\r\n\t// `country_phone_code_to_countries` was renamed to `country_calling_codes` in `1.0.18`.\r\n\t// For that reason, it's not used in this detection algorithm.\r\n\t// Instead, it detects by `countries: {}` property existence.\r\n\tif (!isObject(metadata) || !isObject(metadata.countries)) {\r\n\t\tthrow new Error(`[libphonenumber-js] \\`metadata\\` argument was passed but it's not a valid metadata. Must be an object having \\`.countries\\` child object property. Got ${isObject(metadata) ? 'an object of shape: { ' + Object.keys(metadata).join(', ') + ' }' : 'a ' + typeOf(metadata) + ': ' + metadata}.`)\r\n\t}\r\n}\r\n\r\n// Babel transforms `typeof` into some \"branches\"\r\n// so istanbul will show this as \"branch not covered\".\r\n/* istanbul ignore next */\r\nconst typeOf = _ => typeof _\r\n\r\n/**\r\n * Returns extension prefix for a country.\r\n * @param {string} country\r\n * @param {object} metadata\r\n * @return {string?}\r\n * @example\r\n * // Returns \" ext. \"\r\n * getExtPrefix(\"US\")\r\n */\r\nexport function getExtPrefix(country, metadata) {\r\n\tmetadata = new Metadata(metadata)\r\n\tif (metadata.hasCountry(country)) {\r\n\t\treturn metadata.selectNumberingPlan(country).ext()\r\n\t}\r\n\treturn DEFAULT_EXT_PREFIX\r\n}\r\n\r\n/**\r\n * Returns \"country calling code\" for a country.\r\n * Throws an error if the country doesn't exist or isn't supported by this library.\r\n * @param {string} country\r\n * @param {object} metadata\r\n * @return {string}\r\n * @example\r\n * // Returns \"44\"\r\n * getCountryCallingCode(\"GB\")\r\n */\r\nexport function getCountryCallingCode(country, metadata) {\r\n\tmetadata = new Metadata(metadata)\r\n\tif (metadata.hasCountry(country)) {\r\n\t\treturn metadata.selectNumberingPlan(country).countryCallingCode()\r\n\t}\r\n\tthrow new Error(`Unknown country: ${country}`)\r\n}\r\n\r\nexport function isSupportedCountry(country, metadata) {\r\n\t// metadata = new Metadata(metadata)\r\n\t// return metadata.hasCountry(country)\r\n\treturn metadata.countries.hasOwnProperty(country)\r\n}\r\n\r\nfunction setVersion(metadata) {\r\n\tconst { version } = metadata\r\n\tif (typeof version === 'number') {\r\n\t\tthis.v1 = version === 1\r\n\t\tthis.v2 = version === 2\r\n\t\tthis.v3 = version === 3\r\n\t\tthis.v4 = version === 4\r\n\t} else {\r\n\t\tif (!version) {\r\n\t\t\tthis.v1 = true\r\n\t\t} else if (compare(version, V3) === -1) {\r\n\t\t\tthis.v2 = true\r\n\t\t} else if (compare(version, V4) === -1) {\r\n\t\t\tthis.v3 = true\r\n\t\t} else {\r\n\t\t\tthis.v4 = true\r\n\t\t}\r\n\t}\r\n}\r\n\r\n// const ISO_COUNTRY_CODE = /^[A-Z]{2}$/\r\n// function isCountryCode(countryCode) {\r\n// \treturn ISO_COUNTRY_CODE.test(countryCodeOrCountryCallingCode)\r\n// }","import Metadata from '../metadata.js'\r\nimport getNumberType from './getNumberType.js'\r\n\r\n// Returns the exact country that the `nationalPhoneNumber` belongs to\r\n// in cases of ambiguity, i.e. when multiple countries share the same \"country calling code\".\r\nexport default function getCountryByNationalNumber(nationalPhoneNumber, {\r\n\tcountries,\r\n\tmetadata\r\n}) {\r\n\t// Re-create `metadata` because it will be selecting a `country`.\r\n\tmetadata = new Metadata(metadata)\r\n\r\n\t// const matchingCountries = []\r\n\r\n\tfor (const country of countries) {\r\n\t\tmetadata.selectNumberingPlan(country)\r\n\t\t// \"Leading digits\" patterns are only defined for about 20% of all countries.\r\n\t\t// By definition, matching \"leading digits\" is a sufficient but not a necessary\r\n\t\t// condition for a phone number to belong to a country.\r\n\t\t// The point of \"leading digits\" check is that it's the fastest one to get a match.\r\n\t\t// https://gitlab.com/catamphetamine/libphonenumber-js/blob/master/METADATA.md#leading_digits\r\n\t\t// I'd suppose that \"leading digits\" patterns are mutually exclusive for different countries\r\n\t\t// because of the intended use of that feature.\r\n\t\tif (metadata.leadingDigits()) {\r\n\t\t\tif (nationalPhoneNumber &&\r\n\t\t\t\tnationalPhoneNumber.search(metadata.leadingDigits()) === 0) {\r\n\t\t\t\treturn country\r\n\t\t\t}\r\n\t\t}\r\n\t\t// Else perform full validation with all of those\r\n\t\t// fixed-line/mobile/etc regular expressions.\r\n\t\telse if (getNumberType({ phone: nationalPhoneNumber, country }, undefined, metadata.metadata)) {\r\n\t\t\t// When multiple countries share the same \"country calling code\",\r\n\t\t\t// type patterns aren't guaranteed to be unique among them.\r\n\t\t\t// For example, both `US` and `CA` have the same pattern for `toll_free` numbers.\r\n\t\t\t// https://gitlab.com/catamphetamine/libphonenumber-js/-/issues/103#note_1417147572\r\n\t\t\t//\r\n\t\t\t// That means that this `if` condition could be `true` for multiple countries from the list.\r\n\t\t\t// Currently, it just returns the first one, which is also the \"main\" country for the \"country calling code\".\r\n\t\t\t// In an example with `toll_free` numbers above, `\"US\"` would be returned even though\r\n\t\t\t// it could as well be `\"CA\"`.\r\n\t\t\t//\r\n\t\t\t// There was also a time when this attempted to be overly smart\r\n\t\t\t// and kept track of all such multiple matching countries\r\n\t\t\t// and then picked the one that matched the `defaultCountry`, if provided.\r\n\t\t\t// For example, with `toll_free` numbers above, and with `defaultCountry: \"CA\"`,\r\n\t\t\t// it would've returned `\"CA\"` instead of `\"US\"`.\r\n\t\t\t// Later it turned out that such \"overly smart\" behavior turned out to be just confusing,\r\n\t\t\t// so this \"overly smart\" country detection was reverted to returning the \"main\" country\r\n\t\t\t// for the \"country calling code\".\r\n\t\t\t// https://gitlab.com/catamphetamine/libphonenumber-js/-/issues/154\r\n\t\t\t//\r\n\t\t\treturn country\r\n\t\t\t//\r\n\t\t\t// The \"overly smart\" behavior code:\r\n\t\t\t//\r\n\t\t\t// if (defaultCountry) {\r\n\t\t\t// \tif (country === defaultCountry) {\r\n\t\t\t// \t\treturn country\r\n\t\t\t// \t} else {\r\n\t\t\t// \t\tmatchingCountries.push(country)\r\n\t\t\t// \t}\r\n\t\t\t// } else {\r\n\t\t\t// \treturn country\r\n\t\t\t// }\r\n\t\t}\r\n\t}\r\n\r\n\t// // Return the first (\"main\") one of the `matchingCountries`.\r\n\t// if (matchingCountries.length > 0) {\r\n\t// \treturn matchingCountries[0]\r\n\t// }\r\n}","import Metadata from '../metadata.js'\r\nimport matchesEntirely from './matchesEntirely.js'\r\n\r\nconst NON_FIXED_LINE_PHONE_TYPES = [\r\n\t'MOBILE',\r\n\t'PREMIUM_RATE',\r\n\t'TOLL_FREE',\r\n\t'SHARED_COST',\r\n\t'VOIP',\r\n\t'PERSONAL_NUMBER',\r\n\t'PAGER',\r\n\t'UAN',\r\n\t'VOICEMAIL'\r\n]\r\n\r\n// Finds out national phone number type (fixed line, mobile, etc)\r\nexport default function getNumberType(input, options, metadata)\r\n{\r\n\t// If assigning the `{}` default value is moved to the arguments above,\r\n\t// code coverage would decrease for some weird reason.\r\n\toptions = options || {}\r\n\r\n\t// When `parse()` returns an empty object — `{}` —\r\n\t// that means that the phone number is malformed,\r\n\t// so it can't possibly be valid.\r\n\tif (!input.country && !input.countryCallingCode) {\r\n\t\treturn\r\n\t}\r\n\r\n\tmetadata = new Metadata(metadata)\r\n\r\n\tmetadata.selectNumberingPlan(input.country, input.countryCallingCode)\r\n\r\n\tconst nationalNumber = options.v2 ? input.nationalNumber : input.phone\r\n\r\n\t// The following is copy-pasted from the original function:\r\n\t// https://github.com/googlei18n/libphonenumber/blob/3ea547d4fbaa2d0b67588904dfa5d3f2557c27ff/javascript/i18n/phonenumbers/phonenumberutil.js#L2835\r\n\r\n\t// Is this national number even valid for this country\r\n\tif (!matchesEntirely(nationalNumber, metadata.nationalNumberPattern())) {\r\n\t\treturn\r\n\t}\r\n\r\n\t// Is it fixed line number\r\n\tif (isNumberTypeEqualTo(nationalNumber, 'FIXED_LINE', metadata)) {\r\n\t\t// Because duplicate regular expressions are removed\r\n\t\t// to reduce metadata size, if \"mobile\" pattern is \"\"\r\n\t\t// then it means it was removed due to being a duplicate of the fixed-line pattern.\r\n\t\t//\r\n\t\tif (metadata.type('MOBILE') && metadata.type('MOBILE').pattern() === '') {\r\n\t\t\treturn 'FIXED_LINE_OR_MOBILE'\r\n\t\t}\r\n\r\n\t\t// `MOBILE` type pattern isn't included if it matched `FIXED_LINE` one.\r\n\t\t// For example, for \"US\" country.\r\n\t\t// Old metadata (< `1.0.18`) had a specific \"types\" data structure\r\n\t\t// that happened to be `undefined` for `MOBILE` in that case.\r\n\t\t// Newer metadata (>= `1.0.18`) has another data structure that is\r\n\t\t// not `undefined` for `MOBILE` in that case (it's just an empty array).\r\n\t\t// So this `if` is just for backwards compatibility with old metadata.\r\n\t\tif (!metadata.type('MOBILE')) {\r\n\t\t\treturn 'FIXED_LINE_OR_MOBILE'\r\n\t\t}\r\n\r\n\t\t// Check if the number happens to qualify as both fixed line and mobile.\r\n\t\t// (no such country in the minimal metadata set)\r\n\t\t/* istanbul ignore if */\r\n\t\tif (isNumberTypeEqualTo(nationalNumber, 'MOBILE', metadata)) {\r\n\t\t\treturn 'FIXED_LINE_OR_MOBILE'\r\n\t\t}\r\n\r\n\t\treturn 'FIXED_LINE'\r\n\t}\r\n\r\n\tfor (const type of NON_FIXED_LINE_PHONE_TYPES) {\r\n\t\tif (isNumberTypeEqualTo(nationalNumber, type, metadata)) {\r\n\t\t\treturn type\r\n\t\t}\r\n\t}\r\n}\r\n\r\nexport function isNumberTypeEqualTo(nationalNumber, type, metadata) {\r\n\ttype = metadata.type(type)\r\n\tif (!type || !type.pattern()) {\r\n\t\treturn false\r\n\t}\r\n\t// Check if any possible number lengths are present;\r\n\t// if so, we use them to avoid checking\r\n\t// the validation pattern if they don't match.\r\n\t// If they are absent, this means they match\r\n\t// the general description, which we have\r\n\t// already checked before a specific number type.\r\n\tif (type.possibleLengths() &&\r\n\t\ttype.possibleLengths().indexOf(nationalNumber.length) < 0) {\r\n\t\treturn false\r\n\t}\r\n\treturn matchesEntirely(nationalNumber, type.pattern())\r\n}"],"names":["USE_NON_GEOGRAPHIC_COUNTRY_CODE","getCountryByCallingCode","callingCode","_ref","nationalPhoneNumber","nationalNumber","metadata","isNonGeographicCallingCode","possibleCountries","getCountryCodesForCallingCode","length","getCountryByNationalNumber","countries","applyInternationalSeparatorStyle","formattedNumber","replace","RegExp","concat","VALID_PUNCTUATION","trim","MIN_LENGTH_FOR_NSN","MAX_LENGTH_FOR_NSN","MAX_LENGTH_COUNTRY_CODE","VALID_DIGITS","WHITESPACE","PLUS_CHARS","objectConstructor","constructor","isObject","object","undefined","FIRST_GROUP_PATTERN","formatNationalNumberUsingFormat","number","format","useInternationalFormat","withNationalPrefix","carrierCode","pattern","internationalFormat","nationalPrefixFormattingRule","isValidPhoneNumber","_normalizeArguments","normalizeArguments","arguments","text","options","_objectSpread","extract","phoneNumber","parsePhoneNumber","isValid","args","_Array$prototype$slic2","_slicedToArray","Array","prototype","slice","call","arg_1","arg_2","arg_3","arg_4","TypeError","Error","defaultCountry","ParseError","_Error","code","_this","_classCallCheck","_callSuper","Object","setPrototypeOf","name","_inherits","_wrapNativeSuper","matchesEntirely","regularExpressionText","test","extractNationalNumberFromPossiblyIncompleteNumber","numberingPlan","nationalPrefixForParsing","prefixPattern","prefixMatch","exec","nationalPrefix","capturedGroupsCount","hasCapturedGroups","nationalPrefixTransformRule","prefixBeforeNationalNumber","possiblePositionOfTheFirstCapturedGroup","indexOf","parsePhoneNumberWithError","parse","v2","DIGITS","parseDigit","character","parseDigits","string","_step","result","_iterator","_createForOfIteratorHelperLoose","split","done","digit","value","extractCountryCallingCode","country","defaultCallingCode","isNumberWithIddPrefix","numberWithoutIDD","stripIddPrefix","_extractCountryCallin","extractCountryCallingCodeFromInternationalNumberWithoutPlusSign","countryCallingCode","shorterNumber","countryCallingCodeSource","Metadata","i","_countryCallingCode","hasCallingCode","selectNumberingPlan","getPossibleCountriesForNumber","filter","_metadata","possibleLengths","couldNationalNumberBelongToCountry","PhoneNumber","countryOrCountryCallingCode","e164Number","E164_NUMBER_REGEXP","validateMetadata","_getCountryAndCountry","metadataJson","isCountryCode","getCountryAndCountryCallingCode","this","getMetadata","key","ext","isPossibleNumber","isValidNumber","getNumberType","_format","formatNumber","RFC3966_EXTN_PREFIX","getExtensionDigitsPattern","maxLength","createExtensionPattern","purpose","possibleSeparatorsBetweenNumberAndExtLabel","possibleCharsAfterExtLabel","optionalExtnSuffix","possibleSeparatorsNumberExtLabelNoComma","CAPTURING_DIGIT_PATTERN","countryMetadata","IDDPrefixPattern","IDDPrefix","search","matchedGroups","match","EXTN_PATTERN","PLUS_SIGN","RFC3966_PHONE_DIGIT_","RFC3966_GLOBAL_NUMBER_DIGITS_","RFC3966_GLOBAL_NUMBER_DIGITS_PATTERN_","ALPHANUM_","RFC3966_DOMAINNAME_PATTERN_","RFC3966_PREFIX_","RFC3966_PHONE_CONTEXT_","RFC3966_ISDN_SUBADDRESS_","extractFormattedPhoneNumberFromPossibleRfc3966NumberUri","numberToParse","phoneNumberString","extractFormattedPhoneNumber","phoneContext","numberToExtractFrom","indexOfPhoneContext","phoneContextStart","phoneContextEnd","substring","extractPhoneContext","isPhoneContextValid","charAt","indexOfNationalNumber","indexOfRfc3966Prefix","indexOfIsdn","MAX_INPUT_STRING_LENGTH","PHONE_NUMBER_START_PATTERN","AFTER_PHONE_NUMBER_END_PATTERN","hasCountry","_parseInput","throwOnError","startsAt","_extractFormattedPhoneNumber","isViablePhoneNumber","isViablePhoneNumberStart","error","withExtensionStripped","start","numberWithoutExtension","matches","extractExtension","parseInput","formattedPhoneNumber","_parsePhoneNumber","parseIncompletePhoneNumber","getCountryCallingCode","_extractNationalNumbe","extractNationalNumber","exactCountry","hasSelectedNumberingPlan","__countryCallingCodeSource","valid","extended","nationalNumberPattern","possible","phone","checkNumberLength","checkNumberLengthForType","type","type_info","possible_lengths","mobile_type","a","b","merged","element","push","sort","mergeArrays","actual_length","minimum_length","possibleShorterNumber","possibleShorterNationalNumber","SINGLE_IDD_PREFIX_REG_EXP","DEFAULT_OPTIONS","formatExtension","extension","input","_len","objects","_key","merge","addExtension","formatNationalNumber","formatRFC3966","fromCountry","fromCountryCallingCode","iddPrefix","defaultIDDPrefix","getIddPrefix","formatIDD","formatAs","chooseFormatForNumber","formats","nationalPrefixIsOptionalWhenFormattingInNationalFormat","availableFormats","elements","testFunction","pickFirstMatchingElement","leadingDigitsPatterns","lastLeadingDigitsPattern","isPossiblePhoneNumber","nationalNumberBefore","nationalNumberAfter","shouldHaveExtractedNationalPrefix","isPossibleIncompleteNationalNumber","MIN_LENGTH_PHONE_NUMBER_PATTERN","VALID_PHONE_NUMBER","VALID_PHONE_NUMBER_START_REG_EXP","VALID_PHONE_NUMBER_WITH_EXTENSION","VALID_PHONE_NUMBER_PATTERN","parsePhoneNumberCharacter","prevParsedCharacters","eventListener","parseRFC3966","_part$split2","isSupportedCountry","hasTypes","pa","pb","na","Number","nb","isNaN","DEFAULT_EXT_PREFIX","CALLING_CODE_REG_EXP","_createClass","setVersion","keys","_","countryCode","v1","v3","nonGeographic","nonGeographical","getCountryMetadata","countryCodes","countryCallingCodes","NumberingPlan","getNumberingPlanMetadata","getCountryCodeForCallingCode","leadingDigits","_type","country_phone_code_to_countries","country_calling_codes","globalMetadataObject","_getFormats","getDefaultCountryMetadataForRegion","map","Format","_getNationalPrefixFormattingRule","_nationalPrefixForParsing","_getNationalPrefixIsOptionalWhenFormatting","types","_type2","getType","Type","usesNationalPrefix","FIRST_GROUP_ONLY_PREFIX_PATTERN","join","typeOf","_typeof","getExtPrefix","hasOwnProperty","version","v4","compare","NON_FIXED_LINE_PHONE_TYPES","isNumberTypeEqualTo"],"ignoreList":[],"sourceRoot":""}