class-validator
Version:
Decorator-based property validation for classes.
40 lines • 1.9 kB
JavaScript
import { buildMessage, ValidateBy } from '../common/ValidateBy';
import { parsePhoneNumberFromString } from 'libphonenumber-js';
export var IS_PHONE_NUMBER = 'isPhoneNumber';
/**
* Checks if the string is a valid phone number. To successfully validate any phone number the text must include
* the intl. calling code, if the calling code wont be provided then the region must be set.
*
* @param value the potential phone number string to test
* @param region 2 characters uppercase country code (e.g. DE, US, CH) for country specific validation.
* If text doesn't start with the international calling code (e.g. +41), then you must set this parameter.
*/
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. To successfully validate any phone number the text must include
* the intl. calling code, if the calling code wont be provided then the region must be set.
*
* @param region 2 characters uppercase country code (e.g. DE, US, CH) for country specific validation.
* If text doesn't start with the international calling code (e.g. +41), then you must set this parameter.
*/
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 + '$property must be a valid phone number'; }, validationOptions),
},
}, validationOptions);
}
//# sourceMappingURL=IsPhoneNumber.js.map