%PDF- %PDF-
Direktori : /var/www/html/node_modules/yup/es/ |
Current File : /var/www/html/node_modules/yup/es/number.js |
import { number as locale } from './locale'; import isAbsent from './util/isAbsent'; import BaseSchema from './schema'; let isNaN = value => value != +value; export function create() { return new NumberSchema(); } export default class NumberSchema extends BaseSchema { constructor() { super({ type: 'number' }); this.withMutation(() => { this.transform(function (value) { let parsed = value; if (typeof parsed === 'string') { parsed = parsed.replace(/\s/g, ''); if (parsed === '') return NaN; // don't use parseFloat to avoid positives on alpha-numeric strings parsed = +parsed; } if (this.isType(parsed)) return parsed; return parseFloat(parsed); }); }); } _typeCheck(value) { if (value instanceof Number) value = value.valueOf(); return typeof value === 'number' && !isNaN(value); } min(min, message = locale.min) { return this.test({ message, name: 'min', exclusive: true, params: { min }, test(value) { return isAbsent(value) || value >= this.resolve(min); } }); } max(max, message = locale.max) { return this.test({ message, name: 'max', exclusive: true, params: { max }, test(value) { return isAbsent(value) || value <= this.resolve(max); } }); } lessThan(less, message = locale.lessThan) { return this.test({ message, name: 'max', exclusive: true, params: { less }, test(value) { return isAbsent(value) || value < this.resolve(less); } }); } moreThan(more, message = locale.moreThan) { return this.test({ message, name: 'min', exclusive: true, params: { more }, test(value) { return isAbsent(value) || value > this.resolve(more); } }); } positive(msg = locale.positive) { return this.moreThan(0, msg); } negative(msg = locale.negative) { return this.lessThan(0, msg); } integer(message = locale.integer) { return this.test({ name: 'integer', message, test: val => isAbsent(val) || Number.isInteger(val) }); } truncate() { return this.transform(value => !isAbsent(value) ? value | 0 : value); } round(method) { var _method; let avail = ['ceil', 'floor', 'round', 'trunc']; method = ((_method = method) == null ? void 0 : _method.toLowerCase()) || 'round'; // this exists for symemtry with the new Math.trunc if (method === 'trunc') return this.truncate(); if (avail.indexOf(method.toLowerCase()) === -1) throw new TypeError('Only valid options for round() are: ' + avail.join(', ')); return this.transform(value => !isAbsent(value) ? Math[method](value) : value); } } create.prototype = NumberSchema.prototype; // // Number Interfaces //