@bedrockio/yada 1.0.4 → 1.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/.eslintignore ADDED
@@ -0,0 +1 @@
1
+ dist
@@ -27,4 +27,5 @@ class TypeSchema extends _Schema.default {
27
27
  };
28
28
  }
29
29
  }
30
- exports.default = TypeSchema;
30
+ exports.default = TypeSchema;
31
+ module.exports = exports.default;
package/dist/cjs/array.js CHANGED
@@ -125,4 +125,5 @@ class ArraySchema extends _Schema.default {
125
125
  }
126
126
  }
127
127
  var _default = (0, _utils.wrapSchema)(ArraySchema);
128
- exports.default = _default;
128
+ exports.default = _default;
129
+ module.exports = exports.default;
@@ -26,4 +26,5 @@ class BooleanSchema extends _TypeSchema.default {
26
26
  }
27
27
  }
28
28
  var _default = (0, _utils.wrapSchema)(BooleanSchema);
29
- exports.default = _default;
29
+ exports.default = _default;
30
+ module.exports = exports.default;
package/dist/cjs/date.js CHANGED
@@ -127,4 +127,5 @@ class DateSchema extends _Schema.default {
127
127
  }
128
128
  }
129
129
  var _default = (0, _utils.wrapSchema)(DateSchema);
130
- exports.default = _default;
130
+ exports.default = _default;
131
+ module.exports = exports.default;
package/dist/cjs/index.js CHANGED
@@ -9,13 +9,8 @@ var _number = _interopRequireDefault(require("./number"));
9
9
  var _object = _interopRequireDefault(require("./object"));
10
10
  var _string = _interopRequireDefault(require("./string"));
11
11
  var _utils = require("./utils");
12
- exports.isSchema = _utils.isSchema;
13
- exports.isSchemaError = _utils.isSchemaError;
14
12
  var _localization = require("./localization");
15
- exports.useLocalizer = _localization.useLocalizer;
16
- exports.getLocalizerTemplates = _localization.getLocalizerTemplates;
17
13
  var _errors = require("./errors");
18
- exports.LocalizedError = _errors.LocalizedError;
19
14
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
20
15
  const allow = (0, _utils.wrapArgs)('allow');
21
16
  const reject = (0, _utils.wrapArgs)('reject');
@@ -31,6 +26,12 @@ var _default = {
31
26
  any,
32
27
  allow,
33
28
  reject,
34
- custom
29
+ custom,
30
+ isSchema: _utils.isSchema,
31
+ isSchemaError: _utils.isSchemaError,
32
+ useLocalizer: _localization.useLocalizer,
33
+ getLocalizerTemplates: _localization.getLocalizerTemplates,
34
+ LocalizedError: _errors.LocalizedError
35
35
  };
36
- exports.default = _default;
36
+ exports.default = _default;
37
+ module.exports = exports.default;
@@ -88,4 +88,5 @@ class NumberSchema extends _TypeSchema.default {
88
88
  }
89
89
  }
90
90
  var _default = (0, _utils.wrapSchema)(NumberSchema);
91
- exports.default = _default;
91
+ exports.default = _default;
92
+ module.exports = exports.default;
@@ -102,4 +102,5 @@ class ObjectSchema extends _TypeSchema.default {
102
102
  }
103
103
  }
104
104
  var _default = (0, _utils.wrapSchema)(ObjectSchema);
105
- exports.default = _default;
105
+ exports.default = _default;
106
+ module.exports = exports.default;
@@ -9,6 +9,7 @@ var _utils = require("./utils");
9
9
  var _password = require("./password");
10
10
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
11
11
  const SLUG_REG = /^[a-z0-9]+(?:-[a-z0-9]+)*$/;
12
+ const PHONE_REG = /^\+?[1-9]\d{1,14}$/;
12
13
  class StringSchema extends _TypeSchema.default {
13
14
  constructor() {
14
15
  super(String);
@@ -90,6 +91,13 @@ class StringSchema extends _TypeSchema.default {
90
91
  }
91
92
  });
92
93
  }
94
+ phone() {
95
+ return this.format('phone', str => {
96
+ if (!PHONE_REG.test(str)) {
97
+ throw new _errors.LocalizedError('Must be a valid phone number.');
98
+ }
99
+ });
100
+ }
93
101
  hex() {
94
102
  return this.format('hex', str => {
95
103
  if (!_validator.default.isHexadecimal(str)) {
@@ -277,4 +285,5 @@ class StringSchema extends _TypeSchema.default {
277
285
  }
278
286
  }
279
287
  var _default = (0, _utils.wrapSchema)(StringSchema);
280
- exports.default = _default;
288
+ exports.default = _default;
289
+ module.exports = exports.default;
package/package.json CHANGED
@@ -1,9 +1,9 @@
1
1
  {
2
2
  "name": "@bedrockio/yada",
3
- "version": "1.0.4",
3
+ "version": "1.0.6",
4
4
  "description": "Validation library inspired by Joi.",
5
5
  "scripts": {
6
- "test": "NODE_OPTIONS=--experimental-vm-modules jest",
6
+ "test": "NODE_OPTIONS='--experimental-vm-modules --no-warnings' jest",
7
7
  "lint": "eslint",
8
8
  "build": "scripts/build",
9
9
  "prepublishOnly": "npm run build"
@@ -15,13 +15,14 @@
15
15
  "author": "Andrew Plummer <plummer.andrew@gmail.com>",
16
16
  "license": "MIT",
17
17
  "dependencies": {
18
- "validator": "^13.7.0"
18
+ "validator": "^13.9.0"
19
19
  },
20
20
  "devDependencies": {
21
21
  "@babel/cli": "^7.19.3",
22
22
  "@babel/core": "^7.19.6",
23
23
  "@babel/preset-env": "^7.19.4",
24
24
  "@bedrockio/prettier-config": "^1.0.2",
25
+ "babel-plugin-add-module-exports": "^1.0.4",
25
26
  "eslint": "^8.26.0",
26
27
  "eslint-plugin-bedrock": "^1.0.17",
27
28
  "jest": "^29.2.2",
package/src/index.js CHANGED
@@ -25,9 +25,6 @@ export default {
25
25
  allow,
26
26
  reject,
27
27
  custom,
28
- };
29
-
30
- export {
31
28
  isSchema,
32
29
  isSchemaError,
33
30
  useLocalizer,
package/src/string.js CHANGED
@@ -12,6 +12,7 @@ import {
12
12
  } from './password';
13
13
 
14
14
  const SLUG_REG = /^[a-z0-9]+(?:-[a-z0-9]+)*$/;
15
+ const PHONE_REG = /^\+?[1-9]\d{1,14}$/;
15
16
 
16
17
  class StringSchema extends TypeSchema {
17
18
  constructor() {
@@ -98,6 +99,14 @@ class StringSchema extends TypeSchema {
98
99
  });
99
100
  }
100
101
 
102
+ phone() {
103
+ return this.format('phone', (str) => {
104
+ if (!PHONE_REG.test(str)) {
105
+ throw new LocalizedError('Must be a valid phone number.');
106
+ }
107
+ });
108
+ }
109
+
101
110
  hex() {
102
111
  return this.format('hex', (str) => {
103
112
  if (!validator.isHexadecimal(str)) {