UNPKG

class-validator-multi-lang

Version:
37 lines 1.55 kB
import { buildMessage, ValidateBy } from '../common/ValidateBy'; import { parsePhoneNumberFromString } from 'libphonenumber-js'; import { getText } from '../get-text'; export var IS_PHONE_NUMBER = 'isPhoneNumber'; /** * Checks if the string is a valid phone number. * @param value the potential phone number string to test * @param {string} region 2 characters uppercase country code (e.g. DE, US, CH). * If users must enter the intl. prefix (e.g. +41), then you may pass "ZZ" or null as region. */ export function isPhoneNumber(value, region) { try { var phoneNum = parsePhoneNumberFromString(value, region); var result = phoneNum === null || phoneNum === void 0 ? void 0 : phoneNum.isValid(); return !!result; } catch (error) { // logging? return false; } } /** * Checks if the string is a valid phone number. * @param region 2 characters uppercase country code (e.g. DE, US, CH). * If users must enter the intl. prefix (e.g. +41), then you may pass "ZZ" or null as region. */ export function IsPhoneNumber(region, validationOptions) { return ValidateBy({ name: IS_PHONE_NUMBER, constraints: [region], validator: { validate: function (value, args) { return isPhoneNumber(value, args.constraints[0]); }, defaultMessage: buildMessage(function (eachPrefix) { return eachPrefix + getText('$property must be a valid phone number'); }, validationOptions), }, }, validationOptions); } //# sourceMappingURL=IsPhoneNumber.js.map