@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 +1 -0
- package/dist/cjs/TypeSchema.js +2 -1
- package/dist/cjs/array.js +2 -1
- package/dist/cjs/boolean.js +2 -1
- package/dist/cjs/date.js +2 -1
- package/dist/cjs/index.js +8 -7
- package/dist/cjs/number.js +2 -1
- package/dist/cjs/object.js +2 -1
- package/dist/cjs/string.js +10 -1
- package/package.json +4 -3
- package/src/index.js +0 -3
- package/src/string.js +9 -0
- package/test/all.test.js +1876 -0
package/.eslintignore
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
dist
|
package/dist/cjs/TypeSchema.js
CHANGED
package/dist/cjs/array.js
CHANGED
package/dist/cjs/boolean.js
CHANGED
package/dist/cjs/date.js
CHANGED
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;
|
package/dist/cjs/number.js
CHANGED
package/dist/cjs/object.js
CHANGED
package/dist/cjs/string.js
CHANGED
|
@@ -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.
|
|
3
|
+
"version": "1.0.6",
|
|
4
4
|
"description": "Validation library inspired by Joi.",
|
|
5
5
|
"scripts": {
|
|
6
|
-
"test": "NODE_OPTIONS
|
|
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.
|
|
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
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)) {
|