@based/schema 0.0.9 → 0.0.11
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/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/set/collections.js +52 -19
- package/dist/set/collections.js.map +1 -1
- package/dist/set/error.d.ts +5 -2
- package/dist/set/error.js +10 -3
- package/dist/set/error.js.map +1 -1
- package/dist/set/index.d.ts +2 -2
- package/dist/set/index.js +67 -12
- package/dist/set/index.js.map +1 -1
- package/dist/set/number.js +37 -23
- package/dist/set/number.js.map +1 -1
- package/dist/set/parseDefaultAndValue.js +5 -3
- package/dist/set/parseDefaultAndValue.js.map +1 -1
- package/dist/set/references.js +12 -5
- package/dist/set/references.js.map +1 -1
- package/dist/set/rest.js +4 -4
- package/dist/set/rest.js.map +1 -1
- package/dist/set/string.js +48 -31
- package/dist/set/string.js.map +1 -1
- package/dist/set2/index.js +1 -0
- package/dist/set2/index.js.map +1 -0
- package/dist/types.d.ts +10 -2
- package/dist/types.js.map +1 -1
- package/dist/updateSchema.d.ts +2 -0
- package/dist/updateSchema.js +16 -0
- package/dist/updateSchema.js.map +1 -0
- package/dist/validateSchema.js +5 -1
- package/dist/validateSchema.js.map +1 -1
- package/dist/walker.d.ts +50 -0
- package/dist/walker.js +83 -0
- package/dist/walker.js.map +1 -0
- package/package.json +1 -1
- package/src/index.ts +2 -0
- package/src/set/collections.ts +56 -21
- package/src/set/error.ts +14 -3
- package/src/set/index.ts +87 -12
- package/src/set/number.ts +39 -22
- package/src/set/parseDefaultAndValue.ts +13 -3
- package/src/set/references.ts +11 -5
- package/src/set/rest.ts +4 -4
- package/src/set/string.ts +78 -35
- package/src/set2/index.ts +0 -0
- package/src/types.ts +18 -11
- package/src/updateSchema.ts +18 -0
- package/src/validateSchema.ts +6 -1
- package/src/walker.ts +152 -0
- package/test/number.ts +646 -0
- package/test/reference.ts +207 -0
- package/test/setWalker.ts +223 -53
- package/test/string.ts +183 -0
- package/test/text.ts +171 -0
- package/test/validateSchema.ts +0 -1
- package/test/walker.ts +99 -0
- package/dist/deepPartial.js +0 -3
- package/dist/deepPartial.js.map +0 -1
- package/dist/schema.d.ts +0 -1
- package/dist/schema.js +0 -3
- package/dist/schema.js.map +0 -1
- package/dist/set/checkDefaultAndValue.d.ts +0 -3
- package/dist/set/checkDefaultAndValue.js +0 -33
- package/dist/set/checkDefaultAndValue.js.map +0 -1
- package/dist/set/enum.d.ts +0 -2
- package/dist/set/enum.js +0 -15
- package/dist/set/enum.js.map +0 -1
- package/dist/set/fieldValidator.d.ts +0 -6
- package/dist/set/fieldValidator.js +0 -144
- package/dist/set/fieldValidator.js.map +0 -1
- package/dist/set/handleError.d.ts +0 -1
- package/dist/set/handleError.js +0 -9
- package/dist/set/handleError.js.map +0 -1
- package/dist/set/number copy.d.ts +0 -4
- package/dist/set/number copy.js +0 -57
- package/dist/set/number copy.js.map +0 -1
- package/dist/set/rest copy.d.ts +0 -5
- package/dist/set/rest copy.js +0 -53
- package/dist/set/rest copy.js.map +0 -1
- package/dist/setWalker.d.ts +0 -11
- package/dist/setWalker.js +0 -189
- package/dist/setWalker.js.map +0 -1
- package/dist/transformers.d.ts +0 -3
- package/dist/transformers.js +0 -18
- package/dist/transformers.js.map +0 -1
- package/dist/typeWalker.d.ts +0 -3
- package/dist/typeWalker.js +0 -18
- package/dist/typeWalker.js.map +0 -1
- package/dist/validate.d.ts +0 -4
- package/dist/validate.js +0 -34
- package/dist/validate.js.map +0 -1
- package/dist/validateFields.d.ts +0 -4
- package/dist/validateFields.js +0 -34
- package/dist/validateFields.js.map +0 -1
- package/dist/validateSchema copy.d.ts +0 -4
- package/dist/validateSchema copy.js +0 -34
- package/dist/validateSchema copy.js.map +0 -1
- /package/dist/{deepPartial.d.ts → set2/index.d.ts} +0 -0
package/test/string.ts
ADDED
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
import test from 'ava'
|
|
2
|
+
import { BasedSchema, setWalker, BasedSetHandlers } from '../src/index'
|
|
3
|
+
|
|
4
|
+
const schema: BasedSchema = {
|
|
5
|
+
types: {
|
|
6
|
+
bla: {
|
|
7
|
+
prefix: 'bl',
|
|
8
|
+
fields: {
|
|
9
|
+
name: {
|
|
10
|
+
minLength: 3,
|
|
11
|
+
maxLength: 6,
|
|
12
|
+
type: 'string',
|
|
13
|
+
},
|
|
14
|
+
phonkName: {
|
|
15
|
+
type: 'string',
|
|
16
|
+
pattern: '\\${1,4}',
|
|
17
|
+
},
|
|
18
|
+
bla: {
|
|
19
|
+
type: 'set',
|
|
20
|
+
items: { type: 'string', minLength: 3, maxLength: 6 },
|
|
21
|
+
},
|
|
22
|
+
},
|
|
23
|
+
},
|
|
24
|
+
},
|
|
25
|
+
$defs: {},
|
|
26
|
+
languages: ['en'],
|
|
27
|
+
root: {
|
|
28
|
+
fields: {},
|
|
29
|
+
},
|
|
30
|
+
prefixToTypeMapping: {
|
|
31
|
+
bl: 'bla',
|
|
32
|
+
},
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
const createHandlers = (): {
|
|
36
|
+
results: { path: (number | string)[]; value: any }[]
|
|
37
|
+
handlers: BasedSetHandlers
|
|
38
|
+
} => {
|
|
39
|
+
const results: { path: (number | string)[]; value: any }[] = []
|
|
40
|
+
const handlers = {
|
|
41
|
+
collect: ({ path, value, typeSchema, fieldSchema, target }) => {
|
|
42
|
+
results.push({ path, value })
|
|
43
|
+
},
|
|
44
|
+
checkRequiredFields: async (paths) => {
|
|
45
|
+
return true
|
|
46
|
+
},
|
|
47
|
+
referenceFilterCondition: async (id, filter) => {
|
|
48
|
+
return true
|
|
49
|
+
},
|
|
50
|
+
}
|
|
51
|
+
return { results, handlers }
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
test('string max length', async (t) => {
|
|
55
|
+
const { handlers, results } = createHandlers()
|
|
56
|
+
await t.throwsAsync(
|
|
57
|
+
setWalker(
|
|
58
|
+
schema,
|
|
59
|
+
{
|
|
60
|
+
$id: 'bl1',
|
|
61
|
+
name: 'ax',
|
|
62
|
+
},
|
|
63
|
+
handlers
|
|
64
|
+
)
|
|
65
|
+
)
|
|
66
|
+
await t.throwsAsync(
|
|
67
|
+
setWalker(
|
|
68
|
+
schema,
|
|
69
|
+
{
|
|
70
|
+
$id: 'bl1',
|
|
71
|
+
name: 'axaxaxax',
|
|
72
|
+
},
|
|
73
|
+
handlers
|
|
74
|
+
)
|
|
75
|
+
)
|
|
76
|
+
await setWalker(
|
|
77
|
+
schema,
|
|
78
|
+
{
|
|
79
|
+
$id: 'bl1',
|
|
80
|
+
name: 'xaxx',
|
|
81
|
+
},
|
|
82
|
+
handlers
|
|
83
|
+
)
|
|
84
|
+
t.deepEqual(results, [{ path: ['name'], value: 'xaxx' }])
|
|
85
|
+
})
|
|
86
|
+
|
|
87
|
+
test('set with strings', async (t) => {
|
|
88
|
+
const { handlers, results } = createHandlers()
|
|
89
|
+
await t.throwsAsync(
|
|
90
|
+
setWalker(
|
|
91
|
+
schema,
|
|
92
|
+
{
|
|
93
|
+
$id: 'bl1',
|
|
94
|
+
bla: ['ax', 'axa', 'axxxxa'],
|
|
95
|
+
},
|
|
96
|
+
handlers
|
|
97
|
+
)
|
|
98
|
+
)
|
|
99
|
+
t.deepEqual(results, [])
|
|
100
|
+
await setWalker(
|
|
101
|
+
schema,
|
|
102
|
+
{
|
|
103
|
+
$id: 'bl1',
|
|
104
|
+
bla: ['axx', 'axxxx', 'blaaa'],
|
|
105
|
+
},
|
|
106
|
+
handlers
|
|
107
|
+
)
|
|
108
|
+
t.deepEqual(results, [
|
|
109
|
+
{ path: ['bla'], value: { $value: ['axx', 'axxxx', 'blaaa'] } },
|
|
110
|
+
])
|
|
111
|
+
})
|
|
112
|
+
|
|
113
|
+
test('string pattern', async (t) => {
|
|
114
|
+
const { handlers, results } = createHandlers()
|
|
115
|
+
await t.throwsAsync(
|
|
116
|
+
setWalker(
|
|
117
|
+
schema,
|
|
118
|
+
{
|
|
119
|
+
$id: 'bl1',
|
|
120
|
+
phonkName: 'blabla',
|
|
121
|
+
},
|
|
122
|
+
handlers
|
|
123
|
+
)
|
|
124
|
+
)
|
|
125
|
+
t.deepEqual(results, [])
|
|
126
|
+
await setWalker(
|
|
127
|
+
schema,
|
|
128
|
+
{
|
|
129
|
+
$id: 'bl1',
|
|
130
|
+
phonkName: 'bla$',
|
|
131
|
+
},
|
|
132
|
+
handlers
|
|
133
|
+
)
|
|
134
|
+
t.deepEqual(results, [{ path: ['phonkName'], value: 'bla$' }])
|
|
135
|
+
})
|
|
136
|
+
|
|
137
|
+
test('setting $default', async (t) => {
|
|
138
|
+
const { handlers, results } = createHandlers()
|
|
139
|
+
await t.throwsAsync(
|
|
140
|
+
setWalker(
|
|
141
|
+
schema,
|
|
142
|
+
{
|
|
143
|
+
$id: 'bl1',
|
|
144
|
+
phonkName: { $default: 'blabla' },
|
|
145
|
+
},
|
|
146
|
+
handlers
|
|
147
|
+
)
|
|
148
|
+
)
|
|
149
|
+
t.deepEqual(results, [])
|
|
150
|
+
await setWalker(
|
|
151
|
+
schema,
|
|
152
|
+
{
|
|
153
|
+
$id: 'bl1',
|
|
154
|
+
phonkName: { $default: 'bla$' },
|
|
155
|
+
},
|
|
156
|
+
handlers
|
|
157
|
+
)
|
|
158
|
+
t.deepEqual(results, [{ path: ['phonkName'], value: { $default: 'bla$' } }])
|
|
159
|
+
})
|
|
160
|
+
|
|
161
|
+
test('setting $value', async (t) => {
|
|
162
|
+
const { handlers, results } = createHandlers()
|
|
163
|
+
await t.throwsAsync(
|
|
164
|
+
setWalker(
|
|
165
|
+
schema,
|
|
166
|
+
{
|
|
167
|
+
$id: 'bl1',
|
|
168
|
+
phonkName: { $value: 'blabla' },
|
|
169
|
+
},
|
|
170
|
+
handlers
|
|
171
|
+
)
|
|
172
|
+
)
|
|
173
|
+
t.deepEqual(results, [])
|
|
174
|
+
await setWalker(
|
|
175
|
+
schema,
|
|
176
|
+
{
|
|
177
|
+
$id: 'bl1',
|
|
178
|
+
phonkName: { $value: 'bla$' },
|
|
179
|
+
},
|
|
180
|
+
handlers
|
|
181
|
+
)
|
|
182
|
+
t.deepEqual(results, [{ path: ['phonkName'], value: { $value: 'bla$' } }])
|
|
183
|
+
})
|
package/test/text.ts
ADDED
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
import test from 'ava'
|
|
2
|
+
import { BasedSchema, setWalker, BasedSetOptionalHandlers } from '../src/index'
|
|
3
|
+
|
|
4
|
+
const schema: BasedSchema = {
|
|
5
|
+
types: {
|
|
6
|
+
bla: {
|
|
7
|
+
prefix: 'bl',
|
|
8
|
+
fields: {
|
|
9
|
+
name: {
|
|
10
|
+
minLength: 3,
|
|
11
|
+
maxLength: 6,
|
|
12
|
+
type: 'text',
|
|
13
|
+
},
|
|
14
|
+
},
|
|
15
|
+
},
|
|
16
|
+
},
|
|
17
|
+
$defs: {},
|
|
18
|
+
languages: ['en', 'de'],
|
|
19
|
+
root: {
|
|
20
|
+
fields: {},
|
|
21
|
+
},
|
|
22
|
+
prefixToTypeMapping: {
|
|
23
|
+
bl: 'bla',
|
|
24
|
+
},
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
const createHandlers = (): {
|
|
28
|
+
results: { path: (number | string)[]; value: any }[]
|
|
29
|
+
handlers: BasedSetOptionalHandlers
|
|
30
|
+
} => {
|
|
31
|
+
const results: { path: (number | string)[]; value: any }[] = []
|
|
32
|
+
const handlers = {
|
|
33
|
+
collect: ({ path, value, typeSchema, fieldSchema, target }) => {
|
|
34
|
+
console.log('collect', path)
|
|
35
|
+
results.push({ path, value })
|
|
36
|
+
},
|
|
37
|
+
checkRequiredFields: async (paths) => {
|
|
38
|
+
return true
|
|
39
|
+
},
|
|
40
|
+
referenceFilterCondition: async (id, filter) => {
|
|
41
|
+
return true
|
|
42
|
+
},
|
|
43
|
+
}
|
|
44
|
+
return { results, handlers }
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
test('text max length', async (t) => {
|
|
48
|
+
const { handlers, results } = createHandlers()
|
|
49
|
+
await t.throwsAsync(
|
|
50
|
+
setWalker(
|
|
51
|
+
schema,
|
|
52
|
+
{
|
|
53
|
+
$id: 'bl1',
|
|
54
|
+
name: {
|
|
55
|
+
de: 'ax',
|
|
56
|
+
nl: 'axa',
|
|
57
|
+
},
|
|
58
|
+
},
|
|
59
|
+
handlers
|
|
60
|
+
)
|
|
61
|
+
)
|
|
62
|
+
await t.throwsAsync(
|
|
63
|
+
setWalker(
|
|
64
|
+
schema,
|
|
65
|
+
{
|
|
66
|
+
$id: 'bl1',
|
|
67
|
+
$language: 'de',
|
|
68
|
+
name: 'axaxaxax',
|
|
69
|
+
},
|
|
70
|
+
handlers
|
|
71
|
+
)
|
|
72
|
+
)
|
|
73
|
+
await setWalker(
|
|
74
|
+
schema,
|
|
75
|
+
{
|
|
76
|
+
$id: 'bl1',
|
|
77
|
+
$language: 'en',
|
|
78
|
+
name: 'xaxx',
|
|
79
|
+
},
|
|
80
|
+
handlers
|
|
81
|
+
)
|
|
82
|
+
t.deepEqual(results, [{ path: ['name'], value: { en: 'xaxx' } }])
|
|
83
|
+
})
|
|
84
|
+
|
|
85
|
+
test('text wrong language', async (t) => {
|
|
86
|
+
const { handlers, results } = createHandlers()
|
|
87
|
+
await t.throwsAsync(
|
|
88
|
+
setWalker(
|
|
89
|
+
schema,
|
|
90
|
+
{
|
|
91
|
+
$id: 'bl1',
|
|
92
|
+
name: {
|
|
93
|
+
de: 'xaxx',
|
|
94
|
+
nl: 'xaxx',
|
|
95
|
+
es: 'flap',
|
|
96
|
+
},
|
|
97
|
+
},
|
|
98
|
+
handlers
|
|
99
|
+
)
|
|
100
|
+
)
|
|
101
|
+
|
|
102
|
+
await setWalker(
|
|
103
|
+
schema,
|
|
104
|
+
{
|
|
105
|
+
$id: 'bl1',
|
|
106
|
+
$language: 'de',
|
|
107
|
+
name: 'blabla',
|
|
108
|
+
},
|
|
109
|
+
handlers
|
|
110
|
+
)
|
|
111
|
+
|
|
112
|
+
//TODO fix
|
|
113
|
+
t.deepEqual(results, [
|
|
114
|
+
{ path: ['name', 'de'], value: 'blabla' },
|
|
115
|
+
{ path: ['name'], value: { de: 'blabla' } },
|
|
116
|
+
])
|
|
117
|
+
})
|
|
118
|
+
|
|
119
|
+
test('default', async (t) => {
|
|
120
|
+
const { handlers, results } = createHandlers()
|
|
121
|
+
await setWalker(
|
|
122
|
+
schema,
|
|
123
|
+
{
|
|
124
|
+
$id: 'bl1',
|
|
125
|
+
$language: 'de',
|
|
126
|
+
name: { $default: 'xaxx' },
|
|
127
|
+
},
|
|
128
|
+
handlers
|
|
129
|
+
)
|
|
130
|
+
await setWalker(
|
|
131
|
+
schema,
|
|
132
|
+
{
|
|
133
|
+
$id: 'bl1',
|
|
134
|
+
$language: 'de',
|
|
135
|
+
name: { de: { $default: 'xaxx' } },
|
|
136
|
+
},
|
|
137
|
+
handlers
|
|
138
|
+
)
|
|
139
|
+
t.deepEqual(results, [
|
|
140
|
+
{ path: ['name'], value: { de: { $default: 'xaxx' } } },
|
|
141
|
+
{ path: ['name'], value: { de: { $default: 'xaxx' } } },
|
|
142
|
+
])
|
|
143
|
+
})
|
|
144
|
+
|
|
145
|
+
test('value', async (t) => {
|
|
146
|
+
const { handlers, results } = createHandlers()
|
|
147
|
+
await t.throwsAsync(
|
|
148
|
+
setWalker(
|
|
149
|
+
schema,
|
|
150
|
+
{
|
|
151
|
+
$id: 'bl1',
|
|
152
|
+
$language: 'de',
|
|
153
|
+
name: { $value: 'xaxx' },
|
|
154
|
+
},
|
|
155
|
+
handlers
|
|
156
|
+
)
|
|
157
|
+
)
|
|
158
|
+
t.deepEqual(results, [])
|
|
159
|
+
|
|
160
|
+
await setWalker(
|
|
161
|
+
schema,
|
|
162
|
+
{
|
|
163
|
+
$id: 'bl1',
|
|
164
|
+
$language: 'de',
|
|
165
|
+
name: { de: { $value: 'xaxx' } },
|
|
166
|
+
},
|
|
167
|
+
handlers
|
|
168
|
+
)
|
|
169
|
+
console.log('-------------->', results)
|
|
170
|
+
t.deepEqual(results, [{ path: ['name', 'de'], value: { $value: 'xaxx' } }])
|
|
171
|
+
})
|
package/test/validateSchema.ts
CHANGED
package/test/walker.ts
ADDED
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
import test from 'ava'
|
|
2
|
+
import { BasedSchema, validateType, walk } from '../src/index'
|
|
3
|
+
|
|
4
|
+
const schema: BasedSchema = {
|
|
5
|
+
types: {
|
|
6
|
+
bla: {
|
|
7
|
+
prefix: 'bl',
|
|
8
|
+
fields: {
|
|
9
|
+
name: {
|
|
10
|
+
minLength: 3,
|
|
11
|
+
maxLength: 6,
|
|
12
|
+
type: 'string',
|
|
13
|
+
},
|
|
14
|
+
phonkName: {
|
|
15
|
+
type: 'string',
|
|
16
|
+
pattern: '\\${1,4}',
|
|
17
|
+
},
|
|
18
|
+
bla: {
|
|
19
|
+
type: 'set',
|
|
20
|
+
items: { type: 'string', minLength: 3, maxLength: 6 },
|
|
21
|
+
},
|
|
22
|
+
},
|
|
23
|
+
},
|
|
24
|
+
},
|
|
25
|
+
$defs: {},
|
|
26
|
+
languages: ['en'],
|
|
27
|
+
root: {
|
|
28
|
+
fields: {},
|
|
29
|
+
},
|
|
30
|
+
prefixToTypeMapping: {
|
|
31
|
+
bl: 'bla',
|
|
32
|
+
},
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
test('walker', async (t) => {
|
|
36
|
+
const x = await walk(
|
|
37
|
+
{
|
|
38
|
+
schema,
|
|
39
|
+
init: async () => {
|
|
40
|
+
console.log('init!\n')
|
|
41
|
+
return { lullz: true }
|
|
42
|
+
},
|
|
43
|
+
parsers: {
|
|
44
|
+
keys: {
|
|
45
|
+
$list: async (args) => {
|
|
46
|
+
return {
|
|
47
|
+
...args,
|
|
48
|
+
value: { flapdrol: true },
|
|
49
|
+
}
|
|
50
|
+
},
|
|
51
|
+
},
|
|
52
|
+
fields: {
|
|
53
|
+
// string: () => {}
|
|
54
|
+
},
|
|
55
|
+
any: async (args) => {
|
|
56
|
+
return args
|
|
57
|
+
},
|
|
58
|
+
},
|
|
59
|
+
collect: (args) => {
|
|
60
|
+
// console.log(' lulz collect dat command', args.path)
|
|
61
|
+
return args.path.join('.')
|
|
62
|
+
},
|
|
63
|
+
backtrack: (collectedCommands) => {
|
|
64
|
+
console.log(' \n-----------BACK TRACK GOOD GO', collectedCommands)
|
|
65
|
+
// if return next btrack will not receive backtrack from commands
|
|
66
|
+
return collectedCommands
|
|
67
|
+
},
|
|
68
|
+
requiresAsyncValidaton: async (validateType) => {
|
|
69
|
+
// console.info('lullz async validaion at the end!')
|
|
70
|
+
return true
|
|
71
|
+
},
|
|
72
|
+
},
|
|
73
|
+
{
|
|
74
|
+
gurk: [1, 2, 3, 4],
|
|
75
|
+
x: {
|
|
76
|
+
y: {
|
|
77
|
+
z: {
|
|
78
|
+
a: 10,
|
|
79
|
+
b: 20,
|
|
80
|
+
gur: {
|
|
81
|
+
x: true,
|
|
82
|
+
y: true,
|
|
83
|
+
$list: {
|
|
84
|
+
$sort: true,
|
|
85
|
+
},
|
|
86
|
+
},
|
|
87
|
+
c: 40,
|
|
88
|
+
$list: true,
|
|
89
|
+
},
|
|
90
|
+
},
|
|
91
|
+
},
|
|
92
|
+
}
|
|
93
|
+
)
|
|
94
|
+
|
|
95
|
+
console.info('------------')
|
|
96
|
+
// console.info(x)
|
|
97
|
+
|
|
98
|
+
t.true(true)
|
|
99
|
+
})
|
package/dist/deepPartial.js
DELETED
package/dist/deepPartial.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"deepPartial.js","sourceRoot":"","sources":["../src/deepPartial.ts"],"names":[],"mappings":""}
|
package/dist/schema.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export type Schema = {};
|
package/dist/schema.js
DELETED
package/dist/schema.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"schema.js","sourceRoot":"","sources":["../src/schema.ts"],"names":[],"mappings":""}
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.parseValueAndDefault = void 0;
|
|
7
|
-
const error_1 = require("./error");
|
|
8
|
-
const parsers_1 = __importDefault(require("./parsers"));
|
|
9
|
-
const parseValueAndDefault = async (path, value, fieldSchema, typeSchema, target, handlers, noCollect) => {
|
|
10
|
-
let handled = false;
|
|
11
|
-
if (typeof value === 'object') {
|
|
12
|
-
const typeDef = fieldSchema.type ?? ('enum' in fieldSchema ? 'enum' : '');
|
|
13
|
-
const parse = parsers_1.default[typeDef];
|
|
14
|
-
if (value.$value !== undefined) {
|
|
15
|
-
// TODO: for errors handle path a bit smarter...
|
|
16
|
-
parse(path, value.$value, fieldSchema, typeSchema, target, handlers, true);
|
|
17
|
-
handled = true;
|
|
18
|
-
}
|
|
19
|
-
if (value.$default !== undefined) {
|
|
20
|
-
if (value.$value !== undefined) {
|
|
21
|
-
(0, error_1.error)(path, error_1.ParseError.valueAndDefault);
|
|
22
|
-
}
|
|
23
|
-
parse(path, value.$default, fieldSchema, typeSchema, target, handlers, true);
|
|
24
|
-
handled = true;
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
if (handled && !noCollect) {
|
|
28
|
-
handlers.collect({ path, value, typeSchema, fieldSchema, target });
|
|
29
|
-
}
|
|
30
|
-
return handled;
|
|
31
|
-
};
|
|
32
|
-
exports.parseValueAndDefault = parseValueAndDefault;
|
|
33
|
-
//# sourceMappingURL=checkDefaultAndValue.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"checkDefaultAndValue.js","sourceRoot":"","sources":["../../src/set/checkDefaultAndValue.ts"],"names":[],"mappings":";;;;;;AAEA,mCAA2C;AAC3C,wDAA+B;AAExB,MAAM,oBAAoB,GAAoC,KAAK,EACxE,IAAI,EACJ,KAAK,EACL,WAAW,EACX,UAAU,EACV,MAAM,EACN,QAAQ,EACR,SAAS,EACS,EAAE;IACpB,IAAI,OAAO,GAAG,KAAK,CAAA;IACnB,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;QAC7B,MAAM,OAAO,GAAG,WAAW,CAAC,IAAI,IAAI,CAAC,MAAM,IAAI,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAA;QACzE,MAAM,KAAK,GAAG,iBAAO,CAAC,OAAO,CAAC,CAAA;QAC9B,IAAI,KAAK,CAAC,MAAM,KAAK,SAAS,EAAE;YAC9B,gDAAgD;YAChD,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAA;YAC1E,OAAO,GAAG,IAAI,CAAA;SACf;QACD,IAAI,KAAK,CAAC,QAAQ,KAAK,SAAS,EAAE;YAChC,IAAI,KAAK,CAAC,MAAM,KAAK,SAAS,EAAE;gBAC9B,IAAA,aAAK,EAAC,IAAI,EAAE,kBAAU,CAAC,eAAe,CAAC,CAAA;aACxC;YACD,KAAK,CACH,IAAI,EACJ,KAAK,CAAC,QAAQ,EACd,WAAW,EACX,UAAU,EACV,MAAM,EACN,QAAQ,EACR,IAAI,CACL,CAAA;YACD,OAAO,GAAG,IAAI,CAAA;SACf;KACF;IACD,IAAI,OAAO,IAAI,CAAC,SAAS,EAAE;QACzB,QAAQ,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,EAAE,CAAC,CAAA;KACnE;IACD,OAAO,OAAO,CAAA;AAChB,CAAC,CAAA;AAtCY,QAAA,oBAAoB,wBAsChC"}
|
package/dist/set/enum.d.ts
DELETED
package/dist/set/enum.js
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
() => {
|
|
4
|
-
if ('enum' in fieldSchema) {
|
|
5
|
-
const enumValues = fieldSchema.enum;
|
|
6
|
-
for (let i = 0; i < enumValues.length; i++) {
|
|
7
|
-
if (deepEqual(enumValues[i], value)) {
|
|
8
|
-
collect(path, i, typeSchema, fieldSchema, target);
|
|
9
|
-
return;
|
|
10
|
-
}
|
|
11
|
-
}
|
|
12
|
-
throw createError(path, target.type, 'enum', value);
|
|
13
|
-
}
|
|
14
|
-
};
|
|
15
|
-
//# sourceMappingURL=enum.js.map
|
package/dist/set/enum.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"enum.js","sourceRoot":"","sources":["../../src/set/enum.ts"],"names":[],"mappings":";;AAAoB,GAAG,EAAE;IAErB,IAAI,MAAM,IAAI,WAAW,EAAE;QACvB,MAAM,UAAU,GAAG,WAAW,CAAC,IAAI,CAAA;QACnC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC1C,IAAI,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE;gBACnC,OAAO,CAAC,IAAI,EAAE,CAAC,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,CAAC,CAAA;gBACjD,OAAM;aACP;SACF;QACD,MAAM,WAAW,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,CAAC,CAAA;KACpD;AACP,CAAC,CAAA"}
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import { BasedSchemaField, BasedSchemaType, BasedSetTarget } from '../types';
|
|
2
|
-
declare const fieldValidator: {
|
|
3
|
-
[key: string]: (path: (string | number)[], value: any, fieldSchema: BasedSchemaField, typeSchema: BasedSchemaType, target: BasedSetTarget, collect: (path: (string | number)[], value: any, // parsed value
|
|
4
|
-
typeSchema: BasedSchemaType, fieldSchema: BasedSchemaField, target: BasedSetTarget) => void) => void;
|
|
5
|
-
};
|
|
6
|
-
export default fieldValidator;
|