michangarrito/apps/backend/node_modules/libphonenumber-js/source/normalizeArguments.js
rckrdmrd 97f407c661 [MIGRATION-V2] feat: Migrar michangarrito a estructura v2
- Prefijo v2: MCH
- TRACEABILITY-MASTER.yml creado
- Listo para integracion como submodulo

Workspace: v2.0.0 | SIMCO: v4.0.0
2026-01-10 11:28:54 -06:00

55 lines
1.3 KiB
JavaScript

import isObject from './helpers/isObject.js'
// Extracts the following properties from function arguments:
// * input `text`
// * `options` object
// * `metadata` JSON
export default function normalizeArguments(args) {
const [arg_1, arg_2, arg_3, arg_4] = Array.prototype.slice.call(args)
let text
let options
let metadata
// If the phone number is passed as a string.
// `parsePhoneNumber('88005553535', ...)`.
if (typeof arg_1 === 'string') {
text = arg_1
}
else throw new TypeError('A text for parsing must be a string.')
// If "default country" argument is being passed then move it to `options`.
// `parsePhoneNumber('88005553535', 'RU', [options], metadata)`.
if (!arg_2 || typeof arg_2 === 'string')
{
if (arg_4) {
options = arg_3
metadata = arg_4
} else {
options = undefined
metadata = arg_3
}
if (arg_2) {
options = { defaultCountry: arg_2, ...options }
}
}
// `defaultCountry` is not passed.
// Example: `parsePhoneNumber('+78005553535', [options], metadata)`.
else if (isObject(arg_2))
{
if (arg_3) {
options = arg_2
metadata = arg_3
} else {
metadata = arg_2
}
}
else throw new Error(`Invalid second argument: ${arg_2}`)
return {
text,
options,
metadata
}
}