string.js 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. 'use strict';
  2. exports.__esModule = true;
  3. var _rule = require('../rule/');
  4. var _rule2 = _interopRequireDefault(_rule);
  5. var _util = require('../util');
  6. function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
  7. /**
  8. * Performs validation for string types.
  9. *
  10. * @param rule The validation rule.
  11. * @param value The value of the field on the source object.
  12. * @param callback The callback function.
  13. * @param source The source object being validated.
  14. * @param options The validation options.
  15. * @param options.messages The validation messages.
  16. */
  17. function string(rule, value, callback, source, options) {
  18. var errors = [];
  19. var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
  20. if (validate) {
  21. if ((0, _util.isEmptyValue)(value, 'string') && !rule.required) {
  22. return callback();
  23. }
  24. _rule2['default'].required(rule, value, source, errors, options, 'string');
  25. if (!(0, _util.isEmptyValue)(value, 'string')) {
  26. _rule2['default'].type(rule, value, source, errors, options);
  27. _rule2['default'].range(rule, value, source, errors, options);
  28. _rule2['default'].pattern(rule, value, source, errors, options);
  29. if (rule.whitespace === true) {
  30. _rule2['default'].whitespace(rule, value, source, errors, options);
  31. }
  32. }
  33. }
  34. callback(errors);
  35. }
  36. exports['default'] = string;
  37. module.exports = exports['default'];