@fgv/ts-json 1.9.6 → 2.0.2-alpha.0
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/ts-json.d.ts +1826 -0
- package/dist/tsdoc-metadata.json +11 -0
- package/lib/index.d.ts +5 -0
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +42 -0
- package/lib/index.js.map +1 -0
- package/lib/packlets/context/compositeJsonMap.d.ts +60 -0
- package/lib/packlets/context/compositeJsonMap.d.ts.map +1 -0
- package/lib/packlets/context/compositeJsonMap.js +105 -0
- package/lib/packlets/context/compositeJsonMap.js.map +1 -0
- package/lib/packlets/context/contextHelpers.d.ts +116 -0
- package/lib/packlets/context/contextHelpers.d.ts.map +1 -0
- package/lib/packlets/context/contextHelpers.js +191 -0
- package/lib/packlets/context/contextHelpers.js.map +1 -0
- package/lib/packlets/context/index.d.ts +4 -0
- package/lib/packlets/context/index.d.ts.map +1 -0
- package/lib/packlets/context/index.js +31 -0
- package/lib/packlets/context/index.js.map +1 -0
- package/lib/packlets/context/jsonContext.d.ts +84 -0
- package/lib/packlets/context/jsonContext.d.ts.map +1 -0
- package/lib/packlets/context/jsonContext.js +41 -0
- package/lib/packlets/context/jsonContext.js.map +1 -0
- package/lib/packlets/converters/converters.d.ts +54 -0
- package/lib/packlets/converters/converters.d.ts.map +1 -0
- package/lib/packlets/converters/converters.js +105 -0
- package/lib/packlets/converters/converters.js.map +1 -0
- package/lib/packlets/converters/file.d.ts +83 -0
- package/lib/packlets/converters/file.d.ts.map +1 -0
- package/lib/packlets/converters/file.js +162 -0
- package/lib/packlets/converters/file.js.map +1 -0
- package/lib/packlets/converters/index.d.ts +5 -0
- package/lib/packlets/converters/index.d.ts.map +1 -0
- package/lib/packlets/converters/index.js +56 -0
- package/lib/packlets/converters/index.js.map +1 -0
- package/lib/packlets/converters/jsonConverter.d.ts +276 -0
- package/lib/packlets/converters/jsonConverter.d.ts.map +1 -0
- package/lib/packlets/converters/jsonConverter.js +310 -0
- package/lib/packlets/converters/jsonConverter.js.map +1 -0
- package/lib/packlets/editor/common.d.ts +67 -0
- package/lib/packlets/editor/common.d.ts.map +1 -0
- package/lib/packlets/editor/common.js +3 -0
- package/lib/packlets/editor/common.js.map +1 -0
- package/lib/packlets/editor/index.d.ts +8 -0
- package/lib/packlets/editor/index.d.ts.map +1 -0
- package/{jsonEditor → lib/packlets/editor}/index.js +15 -9
- package/lib/packlets/editor/index.js.map +1 -0
- package/lib/packlets/editor/jsonEditor.d.ts +155 -0
- package/lib/packlets/editor/jsonEditor.d.ts.map +1 -0
- package/lib/packlets/editor/jsonEditor.js +332 -0
- package/lib/packlets/editor/jsonEditor.js.map +1 -0
- package/lib/packlets/editor/jsonEditorRule.d.ts +64 -0
- package/lib/packlets/editor/jsonEditorRule.d.ts.map +1 -0
- package/lib/packlets/editor/jsonEditorRule.js +54 -0
- package/lib/packlets/editor/jsonEditorRule.js.map +1 -0
- package/lib/packlets/editor/jsonEditorState.d.ts +125 -0
- package/lib/packlets/editor/jsonEditorState.d.ts.map +1 -0
- package/lib/packlets/editor/jsonEditorState.js +177 -0
- package/lib/packlets/editor/jsonEditorState.js.map +1 -0
- package/lib/packlets/editor/jsonReferenceMap.d.ts +303 -0
- package/lib/packlets/editor/jsonReferenceMap.d.ts.map +1 -0
- package/lib/packlets/editor/jsonReferenceMap.js +324 -0
- package/lib/packlets/editor/jsonReferenceMap.js.map +1 -0
- package/lib/packlets/editor/rules/conditional.d.ts +107 -0
- package/lib/packlets/editor/rules/conditional.d.ts.map +1 -0
- package/lib/packlets/editor/rules/conditional.js +167 -0
- package/lib/packlets/editor/rules/conditional.js.map +1 -0
- package/{jsonEditor → lib/packlets/editor}/rules/index.d.ts +1 -0
- package/lib/packlets/editor/rules/index.d.ts.map +1 -0
- package/lib/packlets/editor/rules/index.js +42 -0
- package/lib/packlets/editor/rules/index.js.map +1 -0
- package/lib/packlets/editor/rules/multivalue.d.ts +94 -0
- package/lib/packlets/editor/rules/multivalue.d.ts.map +1 -0
- package/lib/packlets/editor/rules/multivalue.js +141 -0
- package/lib/packlets/editor/rules/multivalue.js.map +1 -0
- package/lib/packlets/editor/rules/references.d.ts +69 -0
- package/lib/packlets/editor/rules/references.d.ts.map +1 -0
- package/lib/packlets/editor/rules/references.js +159 -0
- package/lib/packlets/editor/rules/references.js.map +1 -0
- package/lib/packlets/editor/rules/templates.d.ts +74 -0
- package/lib/packlets/editor/rules/templates.d.ts.map +1 -0
- package/lib/packlets/editor/rules/templates.js +127 -0
- package/lib/packlets/editor/rules/templates.js.map +1 -0
- package/lib/packlets/json/common.d.ts +85 -0
- package/lib/packlets/json/common.d.ts.map +1 -0
- package/lib/packlets/json/common.js +123 -0
- package/lib/packlets/json/common.js.map +1 -0
- package/lib/packlets/json/index.d.ts +2 -0
- package/lib/packlets/json/index.d.ts.map +1 -0
- package/lib/packlets/json/index.js +39 -0
- package/lib/packlets/json/index.js.map +1 -0
- package/package.json +58 -49
- package/common.d.ts +0 -58
- package/common.js +0 -116
- package/compositeJsonMap.d.ts +0 -47
- package/compositeJsonMap.js +0 -97
- package/contextHelpers.d.ts +0 -21
- package/contextHelpers.js +0 -101
- package/converters.d.ts +0 -37
- package/converters.js +0 -92
- package/file.d.ts +0 -60
- package/file.js +0 -140
- package/index.d.ts +0 -10
- package/index.js +0 -62
- package/jsonContext.d.ts +0 -74
- package/jsonContext.js +0 -40
- package/jsonConverter.d.ts +0 -229
- package/jsonConverter.js +0 -292
- package/jsonEditor/common.d.ts +0 -36
- package/jsonEditor/common.js +0 -3
- package/jsonEditor/index.d.ts +0 -5
- package/jsonEditor/jsonEditor.d.ts +0 -74
- package/jsonEditor/jsonEditor.js +0 -259
- package/jsonEditor/jsonEditorRule.d.ts +0 -47
- package/jsonEditor/jsonEditorRule.js +0 -44
- package/jsonEditor/jsonEditorState.d.ts +0 -24
- package/jsonEditor/jsonEditorState.js +0 -86
- package/jsonEditor/rules/conditional.d.ts +0 -84
- package/jsonEditor/rules/conditional.js +0 -146
- package/jsonEditor/rules/index.js +0 -21
- package/jsonEditor/rules/multivalue.d.ts +0 -78
- package/jsonEditor/rules/multivalue.js +0 -129
- package/jsonEditor/rules/references.d.ts +0 -62
- package/jsonEditor/rules/references.js +0 -158
- package/jsonEditor/rules/templates.d.ts +0 -56
- package/jsonEditor/rules/templates.js +0 -115
- package/jsonReferenceMap.d.ts +0 -138
- package/jsonReferenceMap.js +0 -202
package/jsonEditor/jsonEditor.js
DELETED
|
@@ -1,259 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/*
|
|
3
|
-
* Copyright (c) 2020 Erik Fortune
|
|
4
|
-
*
|
|
5
|
-
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
-
* of this software and associated documentation files (the "Software"), to deal
|
|
7
|
-
* in the Software without restriction, including without limitation the rights
|
|
8
|
-
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
-
* copies of the Software, and to permit persons to whom the Software is
|
|
10
|
-
* furnished to do so, subject to the following conditions:
|
|
11
|
-
*
|
|
12
|
-
* The above copyright notice and this permission notice shall be included in all
|
|
13
|
-
* copies or substantial portions of the Software.
|
|
14
|
-
*
|
|
15
|
-
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
-
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
-
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
-
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
-
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
-
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
-
* SOFTWARE.
|
|
22
|
-
*/
|
|
23
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
24
|
-
exports.JsonEditor = void 0;
|
|
25
|
-
const rules_1 = require("./rules");
|
|
26
|
-
const ts_utils_1 = require("@fgv/ts-utils");
|
|
27
|
-
const common_1 = require("../common");
|
|
28
|
-
const jsonEditorState_1 = require("./jsonEditorState");
|
|
29
|
-
/**
|
|
30
|
-
* The JsonEditor can be used to edit JSON objects in place or to clone any JSON value,
|
|
31
|
-
* applying a default context and optional set of editor rules that were supplied at
|
|
32
|
-
* initialization.
|
|
33
|
-
*/
|
|
34
|
-
class JsonEditor {
|
|
35
|
-
constructor(options, rules) {
|
|
36
|
-
this.options = JsonEditor._getDefaultOptions(options).orThrow();
|
|
37
|
-
this._rules = rules || JsonEditor.getDefaultRules(this.options).orThrow();
|
|
38
|
-
}
|
|
39
|
-
/**
|
|
40
|
-
* Default singleton @see JsonEditor for simple use. Applies all rules
|
|
41
|
-
* but with no default context.
|
|
42
|
-
*/
|
|
43
|
-
static get default() {
|
|
44
|
-
if (!JsonEditor._default) {
|
|
45
|
-
const rules = this.getDefaultRules().orDefault();
|
|
46
|
-
JsonEditor._default = new JsonEditor(undefined, rules);
|
|
47
|
-
}
|
|
48
|
-
return JsonEditor._default;
|
|
49
|
-
}
|
|
50
|
-
/**
|
|
51
|
-
* Constructs a new @see JsonEditor
|
|
52
|
-
* @param options Optional configuration an context for this editor
|
|
53
|
-
* @param rules Optional set of rules used by this editor
|
|
54
|
-
*/
|
|
55
|
-
static create(options, rules) {
|
|
56
|
-
return (0, ts_utils_1.captureResult)(() => new JsonEditor(options, rules));
|
|
57
|
-
}
|
|
58
|
-
/**
|
|
59
|
-
* Gets the default set of rules to be applied for a given set of options.
|
|
60
|
-
* By default, all available rules (templates, conditionals, multi-value and references)
|
|
61
|
-
* are applied.
|
|
62
|
-
* @param options The options used to initialize all rules
|
|
63
|
-
*/
|
|
64
|
-
static getDefaultRules(options) {
|
|
65
|
-
return (0, ts_utils_1.mapResults)([
|
|
66
|
-
rules_1.TemplatedJsonEditorRule.create(options),
|
|
67
|
-
rules_1.ConditionalJsonEditorRule.create(options),
|
|
68
|
-
rules_1.MultiValueJsonEditorRule.create(options),
|
|
69
|
-
rules_1.ReferenceJsonEditorRule.create(options),
|
|
70
|
-
]);
|
|
71
|
-
}
|
|
72
|
-
static _getDefaultOptions(options) {
|
|
73
|
-
const context = options === null || options === void 0 ? void 0 : options.context;
|
|
74
|
-
let validation = options === null || options === void 0 ? void 0 : options.validation;
|
|
75
|
-
if (validation === undefined) {
|
|
76
|
-
validation = {
|
|
77
|
-
onInvalidPropertyName: 'error',
|
|
78
|
-
onInvalidPropertyValue: 'error',
|
|
79
|
-
onUndefinedPropertyValue: 'ignore',
|
|
80
|
-
};
|
|
81
|
-
}
|
|
82
|
-
return (0, ts_utils_1.succeed)({ context, validation });
|
|
83
|
-
}
|
|
84
|
-
/**
|
|
85
|
-
* Merges a supplied source object into a supplied target, updating the target object.
|
|
86
|
-
* @param target The target object to be updated
|
|
87
|
-
* @param src The source object to be merged
|
|
88
|
-
* @param runtimeContext An optional @see JsonContext supplying variables and references
|
|
89
|
-
*/
|
|
90
|
-
mergeObjectInPlace(target, src, runtimeContext) {
|
|
91
|
-
const state = new jsonEditorState_1.JsonEditorState(this, this.options, runtimeContext);
|
|
92
|
-
return this._mergeObjectInPlace(target, src, state).onSuccess((merged) => {
|
|
93
|
-
return this._finalizeAndMerge(merged, state);
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
/**
|
|
97
|
-
* Merges multiple supplied source objects into a supplied target, updating the target
|
|
98
|
-
* object and using the default context supplied at creation time.
|
|
99
|
-
* @param target The target object to be updated
|
|
100
|
-
* @param srcObjects Objects to be merged into the target object, in the order supplied.
|
|
101
|
-
*/
|
|
102
|
-
mergeObjectsInPlace(target, srcObjects) {
|
|
103
|
-
return this.mergeObjectsInPlaceWithContext(this.options.context, target, srcObjects);
|
|
104
|
-
}
|
|
105
|
-
/**
|
|
106
|
-
* Merges multiple supplied source objects into a supplied target, updating the target
|
|
107
|
-
* object and using an optional context supplied in the call.
|
|
108
|
-
* @param context An optional @see JsonContext supplying variables and references
|
|
109
|
-
* @param target The target object to be updated
|
|
110
|
-
* @param srcObjects Objects to be merged into the target object, in the order supplied.
|
|
111
|
-
*/
|
|
112
|
-
mergeObjectsInPlaceWithContext(context, base, srcObjects) {
|
|
113
|
-
for (const src of srcObjects) {
|
|
114
|
-
const mergeResult = this.mergeObjectInPlace(base, src, context);
|
|
115
|
-
if (mergeResult.isFailure()) {
|
|
116
|
-
return mergeResult.withFailureDetail('error');
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
return (0, ts_utils_1.succeedWithDetail)(base);
|
|
120
|
-
}
|
|
121
|
-
/**
|
|
122
|
-
* Deep clones a supplied JSON value, applying all editor rules and a default
|
|
123
|
-
* or optionally supplied context
|
|
124
|
-
* @param src The @see JsonValue to be cloned
|
|
125
|
-
* @param context An optional @see JsonContext supplying variables and references
|
|
126
|
-
*/
|
|
127
|
-
clone(src, context) {
|
|
128
|
-
const state = new jsonEditorState_1.JsonEditorState(this, this.options, context);
|
|
129
|
-
let value = src;
|
|
130
|
-
let valueResult = this._editValue(src, state);
|
|
131
|
-
while (valueResult.isSuccess()) {
|
|
132
|
-
value = valueResult.value;
|
|
133
|
-
valueResult = this._editValue(value, state);
|
|
134
|
-
}
|
|
135
|
-
if ((valueResult.detail === 'error') || (valueResult.detail === 'ignore')) {
|
|
136
|
-
return valueResult;
|
|
137
|
-
}
|
|
138
|
-
if ((0, common_1.isJsonPrimitive)(value) || (value === null)) {
|
|
139
|
-
return (0, ts_utils_1.succeedWithDetail)(value, 'edited');
|
|
140
|
-
}
|
|
141
|
-
else if ((0, common_1.isJsonObject)(value)) {
|
|
142
|
-
return this.mergeObjectInPlace({}, value, state.context).withFailureDetail('error');
|
|
143
|
-
}
|
|
144
|
-
else if ((0, common_1.isJsonArray)(value)) {
|
|
145
|
-
return this._cloneArray(value, state.context);
|
|
146
|
-
}
|
|
147
|
-
else if (value === undefined) {
|
|
148
|
-
return state.failValidation('undefinedPropertyValue');
|
|
149
|
-
}
|
|
150
|
-
return state.failValidation('invalidPropertyValue', `Cannot convert invalid JSON: "${JSON.stringify(value)}"`);
|
|
151
|
-
}
|
|
152
|
-
_mergeObjectInPlace(target, src, state) {
|
|
153
|
-
for (const key in src) {
|
|
154
|
-
if (src.hasOwnProperty(key)) {
|
|
155
|
-
const propResult = this._editProperty(key, src[key], state);
|
|
156
|
-
if (propResult.isSuccess()) {
|
|
157
|
-
if (propResult.detail === 'deferred') {
|
|
158
|
-
state.defer(propResult.value);
|
|
159
|
-
}
|
|
160
|
-
else {
|
|
161
|
-
const mergeResult = this._mergeObjectInPlace(target, propResult.value, state);
|
|
162
|
-
if (mergeResult.isFailure()) {
|
|
163
|
-
return mergeResult;
|
|
164
|
-
}
|
|
165
|
-
}
|
|
166
|
-
}
|
|
167
|
-
else if (propResult.detail === 'inapplicable') {
|
|
168
|
-
const valueResult = this.clone(src[key], state.context).onSuccess((cloned) => {
|
|
169
|
-
return this._mergeClonedProperty(target, key, cloned, state);
|
|
170
|
-
});
|
|
171
|
-
if (valueResult.isFailure() && (valueResult.detail === 'error')) {
|
|
172
|
-
return (0, ts_utils_1.fail)(`${key}: ${valueResult.message}`);
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
else if (propResult.detail !== 'ignore') {
|
|
176
|
-
return (0, ts_utils_1.fail)(`${key}: ${propResult.message}`);
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
else {
|
|
180
|
-
return (0, ts_utils_1.fail)(`${key}: Cannot merge inherited properties`);
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
return (0, ts_utils_1.succeed)(target);
|
|
184
|
-
}
|
|
185
|
-
_cloneArray(src, context) {
|
|
186
|
-
const results = src.map((v) => {
|
|
187
|
-
return this.clone(v, context);
|
|
188
|
-
});
|
|
189
|
-
return (0, ts_utils_1.mapDetailedResults)(results, ['ignore']).onSuccess((converted) => {
|
|
190
|
-
return (0, ts_utils_1.succeed)(converted);
|
|
191
|
-
}).withFailureDetail('error');
|
|
192
|
-
}
|
|
193
|
-
_mergeClonedProperty(target, key, newValue, state) {
|
|
194
|
-
const existing = target[key];
|
|
195
|
-
// merge is called right after clone so this should never happen
|
|
196
|
-
// since clone itself will have failed
|
|
197
|
-
// istanbul ignore else
|
|
198
|
-
if ((0, common_1.isJsonPrimitive)(newValue)) {
|
|
199
|
-
target[key] = newValue;
|
|
200
|
-
return (0, ts_utils_1.succeedWithDetail)(newValue, 'edited');
|
|
201
|
-
}
|
|
202
|
-
else if ((0, common_1.isJsonObject)(newValue)) {
|
|
203
|
-
if ((0, common_1.isJsonObject)(existing)) {
|
|
204
|
-
return this.mergeObjectInPlace(existing, newValue, state.context).withFailureDetail('error');
|
|
205
|
-
}
|
|
206
|
-
target[key] = newValue;
|
|
207
|
-
return (0, ts_utils_1.succeedWithDetail)(newValue, 'edited');
|
|
208
|
-
}
|
|
209
|
-
else if ((0, common_1.isJsonArray)(newValue)) {
|
|
210
|
-
if ((0, common_1.isJsonArray)(existing)) {
|
|
211
|
-
target[key] = existing.concat(...newValue);
|
|
212
|
-
return (0, ts_utils_1.succeedWithDetail)(target[key], 'edited');
|
|
213
|
-
}
|
|
214
|
-
target[key] = newValue;
|
|
215
|
-
return (0, ts_utils_1.succeedWithDetail)(newValue, 'edited');
|
|
216
|
-
}
|
|
217
|
-
else {
|
|
218
|
-
return (0, ts_utils_1.failWithDetail)(`Invalid JSON: ${JSON.stringify(newValue)}`, 'error');
|
|
219
|
-
}
|
|
220
|
-
}
|
|
221
|
-
_editProperty(key, value, state) {
|
|
222
|
-
for (const rule of this._rules) {
|
|
223
|
-
const ruleResult = rule.editProperty(key, value, state);
|
|
224
|
-
if (ruleResult.isSuccess() || (ruleResult.detail !== 'inapplicable')) {
|
|
225
|
-
return ruleResult;
|
|
226
|
-
}
|
|
227
|
-
}
|
|
228
|
-
return (0, ts_utils_1.failWithDetail)('inapplicable', 'inapplicable');
|
|
229
|
-
}
|
|
230
|
-
_editValue(value, state) {
|
|
231
|
-
for (const rule of this._rules) {
|
|
232
|
-
const ruleResult = rule.editValue(value, state);
|
|
233
|
-
if (ruleResult.isSuccess() || (ruleResult.detail !== 'inapplicable')) {
|
|
234
|
-
return ruleResult;
|
|
235
|
-
}
|
|
236
|
-
}
|
|
237
|
-
return (0, ts_utils_1.failWithDetail)('inapplicable', 'inapplicable');
|
|
238
|
-
}
|
|
239
|
-
_finalizeAndMerge(target, state) {
|
|
240
|
-
const deferred = state.deferred;
|
|
241
|
-
if (deferred.length > 0) {
|
|
242
|
-
for (const rule of this._rules) {
|
|
243
|
-
const ruleResult = rule.finalizeProperties(deferred, state);
|
|
244
|
-
if (ruleResult.isSuccess()) {
|
|
245
|
-
return this.mergeObjectsInPlaceWithContext(state.context, target, ruleResult.value).withFailureDetail('error');
|
|
246
|
-
}
|
|
247
|
-
else if (ruleResult.detail === 'ignore') {
|
|
248
|
-
(0, ts_utils_1.succeedWithDetail)(target, 'edited');
|
|
249
|
-
}
|
|
250
|
-
else if (ruleResult.detail !== 'inapplicable') {
|
|
251
|
-
return (0, ts_utils_1.failWithDetail)(ruleResult.message, ruleResult.detail);
|
|
252
|
-
}
|
|
253
|
-
}
|
|
254
|
-
}
|
|
255
|
-
return (0, ts_utils_1.succeedWithDetail)(target, 'edited');
|
|
256
|
-
}
|
|
257
|
-
}
|
|
258
|
-
exports.JsonEditor = JsonEditor;
|
|
259
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jsonEditor.js","sourceRoot":"","sources":["../../src/jsonEditor/jsonEditor.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2020 Erik Fortune\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\n\nimport {\n    ConditionalJsonEditorRule,\n    MultiValueJsonEditorRule,\n    ReferenceJsonEditorRule,\n    TemplatedJsonEditorRule,\n} from './rules';\nimport {\n    DetailedResult,\n    Result,\n    captureResult,\n    fail,\n    failWithDetail,\n    mapDetailedResults,\n    mapResults,\n    succeed,\n    succeedWithDetail,\n} from '@fgv/ts-utils';\n\nimport { IJsonCloneEditor, JsonEditFailureReason, JsonEditorOptions, JsonEditorValidationOptions, JsonPropertyEditFailureReason } from './common';\nimport { JsonArray, JsonObject, JsonValue, isJsonArray, isJsonObject, isJsonPrimitive } from '../common';\n\nimport { JsonContext } from '../jsonContext';\nimport { JsonEditorRule } from './jsonEditorRule';\nimport { JsonEditorState } from './jsonEditorState';\n\n/**\n * The JsonEditor can be used to edit JSON objects in place or to clone any JSON value,\n * applying a default context and optional set of editor rules that were supplied at\n * initialization.\n */\nexport class JsonEditor implements IJsonCloneEditor {\n    // eslint-disable-next-line no-use-before-define\n    protected static _default?: JsonEditor;\n\n    /**\n     * Full set of @see JsonEditorOptions in effect for this rule.\n     */\n    public options: JsonEditorOptions;\n    protected _rules: JsonEditorRule[];\n\n    protected constructor(options?: Partial<JsonEditorOptions>, rules?: JsonEditorRule[]) {\n        this.options = JsonEditor._getDefaultOptions(options).orThrow();\n        this._rules = rules || JsonEditor.getDefaultRules(this.options).orThrow();\n    }\n\n    /**\n     * Default singleton @see JsonEditor for simple use. Applies all rules\n     * but with no default context.\n     */\n    public static get default(): JsonEditor {\n        if (!JsonEditor._default) {\n            const rules = this.getDefaultRules().orDefault();\n            JsonEditor._default = new JsonEditor(undefined, rules);\n        }\n        return JsonEditor._default;\n    }\n\n    /**\n     * Constructs a new @see JsonEditor\n     * @param options Optional configuration an context for this editor\n     * @param rules Optional set of rules used by this editor\n     */\n    public static create(options?: Partial<JsonEditorOptions>, rules?: JsonEditorRule[]): Result<JsonEditor> {\n        return captureResult(() => new JsonEditor(options, rules));\n    }\n\n    /**\n     * Gets the default set of rules to be applied for a given set of options.\n     * By default, all available rules (templates, conditionals, multi-value and references)\n     * are applied.\n     * @param options The options used to initialize all rules\n     */\n    public static getDefaultRules(options?: JsonEditorOptions): Result<JsonEditorRule[]> {\n        return mapResults<JsonEditorRule>([\n            TemplatedJsonEditorRule.create(options),\n            ConditionalJsonEditorRule.create(options),\n            MultiValueJsonEditorRule.create(options),\n            ReferenceJsonEditorRule.create(options),\n        ]);\n    }\n\n    protected static _getDefaultOptions(options?: Partial<JsonEditorOptions>): Result<JsonEditorOptions> {\n        const context: JsonContext|undefined = options?.context;\n        let validation: JsonEditorValidationOptions|undefined = options?.validation;\n        if (validation === undefined) {\n            validation = {\n                onInvalidPropertyName: 'error',\n                onInvalidPropertyValue: 'error',\n                onUndefinedPropertyValue: 'ignore',\n            };\n        }\n        return succeed({ context, validation });\n    }\n\n    /**\n     * Merges a supplied source object into a supplied target, updating the target object.\n     * @param target The target object to be updated\n     * @param src The source object to be merged\n     * @param runtimeContext An optional @see JsonContext supplying variables and references\n     */\n    public mergeObjectInPlace(target: JsonObject, src: JsonObject, runtimeContext?: JsonContext): Result<JsonObject> {\n        const state = new JsonEditorState(this, this.options, runtimeContext);\n        return this._mergeObjectInPlace(target, src, state).onSuccess((merged) => {\n            return this._finalizeAndMerge(merged, state);\n        });\n    }\n\n    /**\n     * Merges multiple supplied source objects into a supplied target, updating the target\n     * object and using the default context supplied at creation time.\n     * @param target The target object to be updated\n     * @param srcObjects Objects to be merged into the target object, in the order supplied.\n     */\n    public mergeObjectsInPlace(target: JsonObject, srcObjects: JsonObject[]): Result<JsonObject> {\n        return this.mergeObjectsInPlaceWithContext(this.options.context, target, srcObjects);\n    }\n\n    /**\n     * Merges multiple supplied source objects into a supplied target, updating the target\n     * object and using an optional context supplied in the call.\n     * @param context An optional @see JsonContext supplying variables and references\n     * @param target The target object to be updated\n     * @param srcObjects Objects to be merged into the target object, in the order supplied.\n     */\n    public mergeObjectsInPlaceWithContext(context: JsonContext|undefined, base: JsonObject, srcObjects: JsonObject[]): Result<JsonObject> {\n        for (const src of srcObjects) {\n            const mergeResult = this.mergeObjectInPlace(base, src, context);\n            if (mergeResult.isFailure()) {\n                return mergeResult.withFailureDetail('error');\n            }\n        }\n        return succeedWithDetail(base);\n    }\n\n    /**\n     * Deep clones a supplied JSON value, applying all editor rules and a default\n     * or optionally supplied context\n     * @param src The @see JsonValue to be cloned\n     * @param context An optional @see JsonContext supplying variables and references\n     */\n    public clone(src: JsonValue, context?: JsonContext): DetailedResult<JsonValue, JsonEditFailureReason> {\n        const state = new JsonEditorState(this, this.options, context);\n        let value = src;\n        let valueResult = this._editValue(src, state);\n\n        while (valueResult.isSuccess()) {\n            value = valueResult.value;\n            valueResult = this._editValue(value, state);\n        }\n\n        if ((valueResult.detail === 'error') || (valueResult.detail === 'ignore')) {\n            return valueResult;\n        }\n\n        if (isJsonPrimitive(value) || (value === null)) {\n            return succeedWithDetail(value, 'edited');\n        }\n        else if (isJsonObject(value)) {\n            return this.mergeObjectInPlace({}, value, state.context).withFailureDetail('error');\n        }\n        else if (isJsonArray(value)) {\n            return this._cloneArray(value, state.context);\n        }\n        else if (value === undefined) {\n            return state.failValidation('undefinedPropertyValue');\n        }\n        return state.failValidation('invalidPropertyValue', `Cannot convert invalid JSON: \"${JSON.stringify(value)}\"`);\n    }\n\n    protected _mergeObjectInPlace(target: JsonObject, src: JsonObject, state: JsonEditorState): Result<JsonObject> {\n        for (const key in src) {\n            if (src.hasOwnProperty(key)) {\n                const propResult = this._editProperty(key, src[key], state);\n                if (propResult.isSuccess()) {\n                    if (propResult.detail === 'deferred') {\n                        state.defer(propResult.value);\n                    }\n                    else {\n                        const mergeResult = this._mergeObjectInPlace(target, propResult.value, state);\n                        if (mergeResult.isFailure()) {\n                            return mergeResult;\n                        }\n                    }\n                }\n                else if (propResult.detail === 'inapplicable') {\n                    const valueResult = this.clone(src[key], state.context).onSuccess((cloned) => {\n                        return this._mergeClonedProperty(target, key, cloned, state);\n                    });\n\n                    if (valueResult.isFailure() && (valueResult.detail === 'error')) {\n                        return fail(`${key}: ${valueResult.message}`);\n                    }\n                }\n                else if (propResult.detail !== 'ignore') {\n                    return fail(`${key}: ${propResult.message}`);\n                }\n            }\n            else {\n                return fail(`${key}: Cannot merge inherited properties`);\n            }\n        }\n        return succeed(target);\n    }\n\n    protected _cloneArray(src: JsonArray, context?: JsonContext): DetailedResult<JsonArray, JsonEditFailureReason> {\n        const results = src.map((v) => {\n            return this.clone(v, context);\n        });\n\n        return mapDetailedResults<JsonValue, JsonEditFailureReason>(results, ['ignore']).onSuccess((converted) => {\n            return succeed(converted);\n        }).withFailureDetail('error');\n    }\n\n    protected _mergeClonedProperty(target: JsonObject, key: string, newValue: JsonValue, state: JsonEditorState): DetailedResult<JsonValue, JsonEditFailureReason> {\n        const existing = target[key];\n\n        // merge is called right after clone so this should never happen\n        // since clone itself will have failed\n        // istanbul ignore else\n        if (isJsonPrimitive(newValue)) {\n            target[key] = newValue;\n            return succeedWithDetail(newValue, 'edited');\n        }\n        else if (isJsonObject(newValue)) {\n            if (isJsonObject(existing)) {\n                return this.mergeObjectInPlace(existing, newValue, state.context).withFailureDetail('error');\n            }\n            target[key] = newValue;\n            return succeedWithDetail(newValue, 'edited');\n        }\n        else if (isJsonArray(newValue)) {\n            if (isJsonArray(existing)) {\n                target[key] = existing.concat(...newValue);\n                return succeedWithDetail(target[key], 'edited');\n            }\n            target[key] = newValue;\n            return succeedWithDetail(newValue, 'edited');\n        }\n        else {\n            return failWithDetail(`Invalid JSON: ${JSON.stringify(newValue)}`, 'error');\n        }\n    }\n\n    protected _editProperty(key: string, value: JsonValue, state: JsonEditorState): DetailedResult<JsonObject, JsonPropertyEditFailureReason> {\n        for (const rule of this._rules) {\n            const ruleResult = rule.editProperty(key, value, state);\n            if (ruleResult.isSuccess() || (ruleResult.detail !== 'inapplicable')) {\n                return ruleResult;\n            }\n        }\n        return failWithDetail('inapplicable', 'inapplicable');\n    }\n\n    protected _editValue(value: JsonValue, state: JsonEditorState): DetailedResult<JsonValue, JsonEditFailureReason> {\n        for (const rule of this._rules) {\n            const ruleResult = rule.editValue(value, state);\n            if (ruleResult.isSuccess() || (ruleResult.detail !== 'inapplicable')) {\n                return ruleResult;\n            }\n        }\n        return failWithDetail('inapplicable', 'inapplicable');\n    }\n\n    protected _finalizeAndMerge(target: JsonObject, state: JsonEditorState): DetailedResult<JsonObject, JsonEditFailureReason> {\n        const deferred = state.deferred;\n        if (deferred.length > 0) {\n            for (const rule of this._rules) {\n                const ruleResult = rule.finalizeProperties(deferred, state);\n                if (ruleResult.isSuccess()) {\n                    return this.mergeObjectsInPlaceWithContext(state.context, target, ruleResult.value).withFailureDetail('error');\n                }\n                else if (ruleResult.detail === 'ignore') {\n                    succeedWithDetail(target, 'edited');\n                }\n                else if (ruleResult.detail !== 'inapplicable') {\n                    return failWithDetail(ruleResult.message, ruleResult.detail);\n                }\n            }\n        }\n        return succeedWithDetail(target, 'edited');\n    }\n}\n\n"]}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
import { DetailedResult } from '@fgv/ts-utils';
|
|
2
|
-
import { JsonEditFailureReason, JsonPropertyEditFailureReason } from './common';
|
|
3
|
-
import { JsonObject, JsonValue } from '../common';
|
|
4
|
-
import { JsonEditorState } from './jsonEditorState';
|
|
5
|
-
export interface JsonEditorRule {
|
|
6
|
-
/**
|
|
7
|
-
* Called by a JSON editor to possibly edit one of the properties being merged into a target object.
|
|
8
|
-
* @param key The key of the property to be edited
|
|
9
|
-
* @param value The value of the property to be edited
|
|
10
|
-
* @param state Editor state which applies to the edit
|
|
11
|
-
* @returns If the property was edited, returns Success with a JSON object containing the edited results
|
|
12
|
-
* and with detail 'edited'. If this property should be deferred for later consideration or merg, Succeeds
|
|
13
|
-
* with detail 'deferred' and an JsonObject to be finalized. If the rule does not affect this property,
|
|
14
|
-
* fails with detail 'inapplicable'. If an error occurred while processing the error, returns Failure with
|
|
15
|
-
* detail 'error'.
|
|
16
|
-
*/
|
|
17
|
-
editProperty(key: string, value: JsonValue, state: JsonEditorState): DetailedResult<JsonObject, JsonPropertyEditFailureReason>;
|
|
18
|
-
/**
|
|
19
|
-
* Called by a JSON editor to possibly edit a property value or array element
|
|
20
|
-
* @param value The value to be edited
|
|
21
|
-
* @param state Editor state which applies to the edit
|
|
22
|
-
* @returns Returns success with the JsonValue to be inserted, with detail 'edited' if the value was
|
|
23
|
-
* edited. Returns failure with 'inapplicable' if the rule does not affect this value. Fails with
|
|
24
|
-
* detail 'ignore' if the value is to be ignored, or with 'error' if an error occurs.
|
|
25
|
-
*/
|
|
26
|
-
editValue(value: JsonValue, state: JsonEditorState): DetailedResult<JsonValue, JsonEditFailureReason>;
|
|
27
|
-
/**
|
|
28
|
-
* Called for each rule after all properties have been merged. Any properties that were deferred
|
|
29
|
-
* during the initial edit pass are supplied as input.
|
|
30
|
-
* @param deferred Any objects that were deferred during the first edit pass
|
|
31
|
-
* @param state Editor state which applies to the edit
|
|
32
|
-
* @returns On successful return, any returned objects are merged in order and finalization
|
|
33
|
-
* is stopped. Finalization is also stopped on Failure with detail 'ignore.' On failure
|
|
34
|
-
* with detail 'inapplicable', finalization continues with the next rule. Fails with an
|
|
35
|
-
* error detail 'error' and an informative message if an error occurs.
|
|
36
|
-
*/
|
|
37
|
-
finalizeProperties(deferred: JsonObject[], state: JsonEditorState): DetailedResult<JsonObject[], JsonEditFailureReason>;
|
|
38
|
-
}
|
|
39
|
-
/**
|
|
40
|
-
* Default base implementation of JsonEditor rule returns inapplicable for all operations so that
|
|
41
|
-
* derived classes need only implement the operations they actually support.
|
|
42
|
-
*/
|
|
43
|
-
export declare class JsonEditorRuleBase implements JsonEditorRule {
|
|
44
|
-
editProperty(_key: string, _value: JsonValue, _state: JsonEditorState): DetailedResult<JsonObject, JsonPropertyEditFailureReason>;
|
|
45
|
-
editValue(_value: JsonValue, _state: JsonEditorState): DetailedResult<JsonValue, JsonEditFailureReason>;
|
|
46
|
-
finalizeProperties(_deferred: JsonObject[], _state: JsonEditorState): DetailedResult<JsonObject[], JsonEditFailureReason>;
|
|
47
|
-
}
|
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/*
|
|
3
|
-
* Copyright (c) 2020 Erik Fortune
|
|
4
|
-
*
|
|
5
|
-
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
-
* of this software and associated documentation files (the "Software"), to deal
|
|
7
|
-
* in the Software without restriction, including without limitation the rights
|
|
8
|
-
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
-
* copies of the Software, and to permit persons to whom the Software is
|
|
10
|
-
* furnished to do so, subject to the following conditions:
|
|
11
|
-
*
|
|
12
|
-
* The above copyright notice and this permission notice shall be included in all
|
|
13
|
-
* copies or substantial portions of the Software.
|
|
14
|
-
*
|
|
15
|
-
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
-
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
-
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
-
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
-
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
-
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
-
* SOFTWARE.
|
|
22
|
-
*/
|
|
23
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
24
|
-
exports.JsonEditorRuleBase = void 0;
|
|
25
|
-
const ts_utils_1 = require("@fgv/ts-utils");
|
|
26
|
-
/**
|
|
27
|
-
* Default base implementation of JsonEditor rule returns inapplicable for all operations so that
|
|
28
|
-
* derived classes need only implement the operations they actually support.
|
|
29
|
-
*/
|
|
30
|
-
class JsonEditorRuleBase {
|
|
31
|
-
// istanbul ignore next
|
|
32
|
-
editProperty(_key, _value, _state) {
|
|
33
|
-
// istanbul ignore next
|
|
34
|
-
return (0, ts_utils_1.failWithDetail)('inapplicable', 'inapplicable');
|
|
35
|
-
}
|
|
36
|
-
editValue(_value, _state) {
|
|
37
|
-
return (0, ts_utils_1.failWithDetail)('inapplicable', 'inapplicable');
|
|
38
|
-
}
|
|
39
|
-
finalizeProperties(_deferred, _state) {
|
|
40
|
-
return (0, ts_utils_1.failWithDetail)('inapplicable', 'inapplicable');
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
exports.JsonEditorRuleBase = JsonEditorRuleBase;
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoianNvbkVkaXRvclJ1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvanNvbkVkaXRvci9qc29uRWRpdG9yUnVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBb0JHOzs7QUFFSCw0Q0FBK0Q7QUE0Qy9EOzs7R0FHRztBQUNILE1BQWEsa0JBQWtCO0lBQzNCLHVCQUF1QjtJQUNoQixZQUFZLENBQUMsSUFBWSxFQUFFLE1BQWlCLEVBQUUsTUFBdUI7UUFDeEUsdUJBQXVCO1FBQ3ZCLE9BQU8sSUFBQSx5QkFBYyxFQUFDLGNBQWMsRUFBRSxjQUFjLENBQUMsQ0FBQztJQUMxRCxDQUFDO0lBRU0sU0FBUyxDQUFDLE1BQWlCLEVBQUUsTUFBdUI7UUFDdkQsT0FBTyxJQUFBLHlCQUFjLEVBQUMsY0FBYyxFQUFFLGNBQWMsQ0FBQyxDQUFDO0lBQzFELENBQUM7SUFFTSxrQkFBa0IsQ0FBQyxTQUF1QixFQUFFLE1BQXVCO1FBQ3RFLE9BQU8sSUFBQSx5QkFBYyxFQUFDLGNBQWMsRUFBRSxjQUFjLENBQUMsQ0FBQztJQUMxRCxDQUFDO0NBQ0o7QUFkRCxnREFjQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjAgRXJpayBGb3J0dW5lXG4gKlxuICogUGVybWlzc2lvbiBpcyBoZXJlYnkgZ3JhbnRlZCwgZnJlZSBvZiBjaGFyZ2UsIHRvIGFueSBwZXJzb24gb2J0YWluaW5nIGEgY29weVxuICogb2YgdGhpcyBzb2Z0d2FyZSBhbmQgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIGZpbGVzICh0aGUgXCJTb2Z0d2FyZVwiKSwgdG8gZGVhbFxuICogaW4gdGhlIFNvZnR3YXJlIHdpdGhvdXQgcmVzdHJpY3Rpb24sIGluY2x1ZGluZyB3aXRob3V0IGxpbWl0YXRpb24gdGhlIHJpZ2h0c1xuICogdG8gdXNlLCBjb3B5LCBtb2RpZnksIG1lcmdlLCBwdWJsaXNoLCBkaXN0cmlidXRlLCBzdWJsaWNlbnNlLCBhbmQvb3Igc2VsbFxuICogY29waWVzIG9mIHRoZSBTb2Z0d2FyZSwgYW5kIHRvIHBlcm1pdCBwZXJzb25zIHRvIHdob20gdGhlIFNvZnR3YXJlIGlzXG4gKiBmdXJuaXNoZWQgdG8gZG8gc28sIHN1YmplY3QgdG8gdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOlxuICpcbiAqIFRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlIGFuZCB0aGlzIHBlcm1pc3Npb24gbm90aWNlIHNoYWxsIGJlIGluY2x1ZGVkIGluIGFsbFxuICogY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS5cbiAqXG4gKiBUSEUgU09GVFdBUkUgSVMgUFJPVklERUQgXCJBUyBJU1wiLCBXSVRIT1VUIFdBUlJBTlRZIE9GIEFOWSBLSU5ELCBFWFBSRVNTIE9SXG4gKiBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPIFRIRSBXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSxcbiAqIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFIEFORCBOT05JTkZSSU5HRU1FTlQuIElOIE5PIEVWRU5UIFNIQUxMIFRIRVxuICogQVVUSE9SUyBPUiBDT1BZUklHSFQgSE9MREVSUyBCRSBMSUFCTEUgRk9SIEFOWSBDTEFJTSwgREFNQUdFUyBPUiBPVEhFUlxuICogTElBQklMSVRZLCBXSEVUSEVSIElOIEFOIEFDVElPTiBPRiBDT05UUkFDVCwgVE9SVCBPUiBPVEhFUldJU0UsIEFSSVNJTkcgRlJPTSxcbiAqIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU4gVEhFXG4gKiBTT0ZUV0FSRS5cbiAqL1xuXG5pbXBvcnQgeyBEZXRhaWxlZFJlc3VsdCwgZmFpbFdpdGhEZXRhaWwgfSBmcm9tICdAZmd2L3RzLXV0aWxzJztcbmltcG9ydCB7IEpzb25FZGl0RmFpbHVyZVJlYXNvbiwgSnNvblByb3BlcnR5RWRpdEZhaWx1cmVSZWFzb24gfSBmcm9tICcuL2NvbW1vbic7XG5pbXBvcnQgeyBKc29uT2JqZWN0LCBKc29uVmFsdWUgfSBmcm9tICcuLi9jb21tb24nO1xuXG5pbXBvcnQgeyBKc29uRWRpdG9yU3RhdGUgfSBmcm9tICcuL2pzb25FZGl0b3JTdGF0ZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSnNvbkVkaXRvclJ1bGUge1xuICAgIC8qKlxuICAgICAqIENhbGxlZCBieSBhIEpTT04gZWRpdG9yIHRvIHBvc3NpYmx5IGVkaXQgb25lIG9mIHRoZSBwcm9wZXJ0aWVzIGJlaW5nIG1lcmdlZCBpbnRvIGEgdGFyZ2V0IG9iamVjdC5cbiAgICAgKiBAcGFyYW0ga2V5IFRoZSBrZXkgb2YgdGhlIHByb3BlcnR5IHRvIGJlIGVkaXRlZFxuICAgICAqIEBwYXJhbSB2YWx1ZSBUaGUgdmFsdWUgb2YgdGhlIHByb3BlcnR5IHRvIGJlIGVkaXRlZFxuICAgICAqIEBwYXJhbSBzdGF0ZSBFZGl0b3Igc3RhdGUgd2hpY2ggYXBwbGllcyB0byB0aGUgZWRpdFxuICAgICAqIEByZXR1cm5zIElmIHRoZSBwcm9wZXJ0eSB3YXMgZWRpdGVkLCByZXR1cm5zIFN1Y2Nlc3Mgd2l0aCBhIEpTT04gb2JqZWN0IGNvbnRhaW5pbmcgdGhlIGVkaXRlZCByZXN1bHRzXG4gICAgICogYW5kIHdpdGggZGV0YWlsICdlZGl0ZWQnLiBJZiB0aGlzIHByb3BlcnR5IHNob3VsZCBiZSBkZWZlcnJlZCBmb3IgbGF0ZXIgY29uc2lkZXJhdGlvbiBvciBtZXJnLCBTdWNjZWVkc1xuICAgICAqIHdpdGggZGV0YWlsICdkZWZlcnJlZCcgYW5kIGFuIEpzb25PYmplY3QgdG8gYmUgZmluYWxpemVkLiAgSWYgdGhlIHJ1bGUgZG9lcyBub3QgYWZmZWN0IHRoaXMgcHJvcGVydHksXG4gICAgICogZmFpbHMgd2l0aCBkZXRhaWwgJ2luYXBwbGljYWJsZScuIElmIGFuIGVycm9yIG9jY3VycmVkIHdoaWxlIHByb2Nlc3NpbmcgdGhlIGVycm9yLCByZXR1cm5zIEZhaWx1cmUgd2l0aFxuICAgICAqIGRldGFpbCAnZXJyb3InLlxuICAgICAqL1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby11c2UtYmVmb3JlLWRlZmluZVxuICAgIGVkaXRQcm9wZXJ0eShrZXk6IHN0cmluZywgdmFsdWU6IEpzb25WYWx1ZSwgc3RhdGU6IEpzb25FZGl0b3JTdGF0ZSk6IERldGFpbGVkUmVzdWx0PEpzb25PYmplY3QsIEpzb25Qcm9wZXJ0eUVkaXRGYWlsdXJlUmVhc29uPjtcblxuICAgIC8qKlxuICAgICAqIENhbGxlZCBieSBhIEpTT04gZWRpdG9yIHRvIHBvc3NpYmx5IGVkaXQgYSBwcm9wZXJ0eSB2YWx1ZSBvciBhcnJheSBlbGVtZW50XG4gICAgICogQHBhcmFtIHZhbHVlIFRoZSB2YWx1ZSB0byBiZSBlZGl0ZWRcbiAgICAgKiBAcGFyYW0gc3RhdGUgRWRpdG9yIHN0YXRlIHdoaWNoIGFwcGxpZXMgdG8gdGhlIGVkaXRcbiAgICAgKiBAcmV0dXJucyBSZXR1cm5zIHN1Y2Nlc3Mgd2l0aCB0aGUgSnNvblZhbHVlIHRvIGJlIGluc2VydGVkLCB3aXRoIGRldGFpbCAnZWRpdGVkJyBpZiB0aGUgdmFsdWUgd2FzXG4gICAgICogZWRpdGVkLiAgUmV0dXJucyBmYWlsdXJlIHdpdGggJ2luYXBwbGljYWJsZScgaWYgdGhlIHJ1bGUgZG9lcyBub3QgYWZmZWN0IHRoaXMgdmFsdWUuICBGYWlscyB3aXRoXG4gICAgICogZGV0YWlsICdpZ25vcmUnIGlmIHRoZSB2YWx1ZSBpcyB0byBiZSBpZ25vcmVkLCBvciB3aXRoICdlcnJvcicgaWYgYW4gZXJyb3Igb2NjdXJzLlxuICAgICAqL1xuICAgIGVkaXRWYWx1ZSh2YWx1ZTogSnNvblZhbHVlLCBzdGF0ZTogSnNvbkVkaXRvclN0YXRlKTogRGV0YWlsZWRSZXN1bHQ8SnNvblZhbHVlLCBKc29uRWRpdEZhaWx1cmVSZWFzb24+O1xuXG4gICAgLyoqXG4gICAgICogQ2FsbGVkIGZvciBlYWNoIHJ1bGUgYWZ0ZXIgYWxsIHByb3BlcnRpZXMgaGF2ZSBiZWVuIG1lcmdlZC4gIEFueSBwcm9wZXJ0aWVzIHRoYXQgd2VyZSBkZWZlcnJlZFxuICAgICAqIGR1cmluZyB0aGUgaW5pdGlhbCBlZGl0IHBhc3MgYXJlIHN1cHBsaWVkIGFzIGlucHV0LlxuICAgICAqIEBwYXJhbSBkZWZlcnJlZCBBbnkgb2JqZWN0cyB0aGF0IHdlcmUgZGVmZXJyZWQgZHVyaW5nIHRoZSBmaXJzdCBlZGl0IHBhc3NcbiAgICAgKiBAcGFyYW0gc3RhdGUgRWRpdG9yIHN0YXRlIHdoaWNoIGFwcGxpZXMgdG8gdGhlIGVkaXRcbiAgICAgKiBAcmV0dXJucyBPbiBzdWNjZXNzZnVsIHJldHVybiwgYW55IHJldHVybmVkIG9iamVjdHMgYXJlIG1lcmdlZCBpbiBvcmRlciBhbmQgZmluYWxpemF0aW9uXG4gICAgICogaXMgc3RvcHBlZC4gRmluYWxpemF0aW9uIGlzIGFsc28gc3RvcHBlZCBvbiBGYWlsdXJlIHdpdGggZGV0YWlsICdpZ25vcmUuJyBPbiBmYWlsdXJlXG4gICAgICogd2l0aCBkZXRhaWwgJ2luYXBwbGljYWJsZScsIGZpbmFsaXphdGlvbiBjb250aW51ZXMgd2l0aCB0aGUgbmV4dCBydWxlLiBGYWlscyB3aXRoIGFuXG4gICAgICogZXJyb3IgZGV0YWlsICdlcnJvcicgYW5kIGFuIGluZm9ybWF0aXZlIG1lc3NhZ2UgaWYgYW4gZXJyb3Igb2NjdXJzLlxuICAgICAqL1xuICAgIGZpbmFsaXplUHJvcGVydGllcyhkZWZlcnJlZDogSnNvbk9iamVjdFtdLCBzdGF0ZTogSnNvbkVkaXRvclN0YXRlKTogRGV0YWlsZWRSZXN1bHQ8SnNvbk9iamVjdFtdLCBKc29uRWRpdEZhaWx1cmVSZWFzb24+O1xufVxuXG4vKipcbiAqIERlZmF1bHQgYmFzZSBpbXBsZW1lbnRhdGlvbiBvZiBKc29uRWRpdG9yIHJ1bGUgcmV0dXJucyBpbmFwcGxpY2FibGUgZm9yIGFsbCBvcGVyYXRpb25zIHNvIHRoYXRcbiAqIGRlcml2ZWQgY2xhc3NlcyBuZWVkIG9ubHkgaW1wbGVtZW50IHRoZSBvcGVyYXRpb25zIHRoZXkgYWN0dWFsbHkgc3VwcG9ydC5cbiAqL1xuZXhwb3J0IGNsYXNzIEpzb25FZGl0b3JSdWxlQmFzZSBpbXBsZW1lbnRzIEpzb25FZGl0b3JSdWxlIHtcbiAgICAvLyBpc3RhbmJ1bCBpZ25vcmUgbmV4dFxuICAgIHB1YmxpYyBlZGl0UHJvcGVydHkoX2tleTogc3RyaW5nLCBfdmFsdWU6IEpzb25WYWx1ZSwgX3N0YXRlOiBKc29uRWRpdG9yU3RhdGUpOiBEZXRhaWxlZFJlc3VsdDxKc29uT2JqZWN0LCBKc29uUHJvcGVydHlFZGl0RmFpbHVyZVJlYXNvbj4ge1xuICAgICAgICAvLyBpc3RhbmJ1bCBpZ25vcmUgbmV4dFxuICAgICAgICByZXR1cm4gZmFpbFdpdGhEZXRhaWwoJ2luYXBwbGljYWJsZScsICdpbmFwcGxpY2FibGUnKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZWRpdFZhbHVlKF92YWx1ZTogSnNvblZhbHVlLCBfc3RhdGU6IEpzb25FZGl0b3JTdGF0ZSk6IERldGFpbGVkUmVzdWx0PEpzb25WYWx1ZSwgSnNvbkVkaXRGYWlsdXJlUmVhc29uPiB7XG4gICAgICAgIHJldHVybiBmYWlsV2l0aERldGFpbCgnaW5hcHBsaWNhYmxlJywgJ2luYXBwbGljYWJsZScpO1xuICAgIH1cblxuICAgIHB1YmxpYyBmaW5hbGl6ZVByb3BlcnRpZXMoX2RlZmVycmVkOiBKc29uT2JqZWN0W10sIF9zdGF0ZTogSnNvbkVkaXRvclN0YXRlKTogRGV0YWlsZWRSZXN1bHQ8SnNvbk9iamVjdFtdLCBKc29uRWRpdEZhaWx1cmVSZWFzb24+IHtcbiAgICAgICAgcmV0dXJuIGZhaWxXaXRoRGV0YWlsKCdpbmFwcGxpY2FibGUnLCAnaW5hcHBsaWNhYmxlJyk7XG4gICAgfVxufVxuIl19
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { DetailedFailure, Result } from '@fgv/ts-utils';
|
|
2
|
-
import { IJsonCloneEditor, JsonEditFailureReason, JsonEditorOptions, JsonEditorValidationOptions, JsonEditorValidationRules } from './common';
|
|
3
|
-
import { JsonContext, JsonReferenceMap, TemplateVars, VariableValue } from '../jsonContext';
|
|
4
|
-
import { JsonObject } from '../common';
|
|
5
|
-
export declare class JsonEditorState {
|
|
6
|
-
protected static _nextId: number;
|
|
7
|
-
readonly editor: IJsonCloneEditor;
|
|
8
|
-
readonly options: JsonEditorOptions;
|
|
9
|
-
protected readonly _deferred: JsonObject[];
|
|
10
|
-
protected readonly _id: number;
|
|
11
|
-
constructor(editor: IJsonCloneEditor, baseOptions: JsonEditorOptions, runtimeContext?: JsonContext);
|
|
12
|
-
get context(): JsonContext | undefined;
|
|
13
|
-
get deferred(): JsonObject[];
|
|
14
|
-
protected static _getEffectiveOptions(options: JsonEditorOptions, context?: JsonContext): Result<JsonEditorOptions>;
|
|
15
|
-
defer(obj: JsonObject): void;
|
|
16
|
-
getVars(defaultContext?: JsonContext): TemplateVars | undefined;
|
|
17
|
-
getRefs(defaultContext?: JsonContext): JsonReferenceMap | undefined;
|
|
18
|
-
getContext(defaultContext?: JsonContext): JsonContext | undefined;
|
|
19
|
-
extendContext(baseContext: JsonContext | undefined, add: {
|
|
20
|
-
vars?: VariableValue[];
|
|
21
|
-
refs?: JsonReferenceMap[];
|
|
22
|
-
}): Result<JsonContext | undefined>;
|
|
23
|
-
failValidation<T = JsonObject>(rule: JsonEditorValidationRules, message?: string, validation?: JsonEditorValidationOptions): DetailedFailure<T, JsonEditFailureReason>;
|
|
24
|
-
}
|
|
@@ -1,86 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/*
|
|
3
|
-
* Copyright (c) 2020 Erik Fortune
|
|
4
|
-
*
|
|
5
|
-
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
-
* of this software and associated documentation files (the "Software"), to deal
|
|
7
|
-
* in the Software without restriction, including without limitation the rights
|
|
8
|
-
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
-
* copies of the Software, and to permit persons to whom the Software is
|
|
10
|
-
* furnished to do so, subject to the following conditions:
|
|
11
|
-
*
|
|
12
|
-
* The above copyright notice and this permission notice shall be included in all
|
|
13
|
-
* copies or substantial portions of the Software.
|
|
14
|
-
*
|
|
15
|
-
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
-
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
-
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
-
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
-
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
-
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
-
* SOFTWARE.
|
|
22
|
-
*/
|
|
23
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
24
|
-
exports.JsonEditorState = void 0;
|
|
25
|
-
const ts_utils_1 = require("@fgv/ts-utils");
|
|
26
|
-
const contextHelpers_1 = require("../contextHelpers");
|
|
27
|
-
class JsonEditorState {
|
|
28
|
-
constructor(editor, baseOptions, runtimeContext) {
|
|
29
|
-
this._deferred = [];
|
|
30
|
-
this.editor = editor;
|
|
31
|
-
this.options = JsonEditorState._getEffectiveOptions(baseOptions, runtimeContext).orThrow();
|
|
32
|
-
this._id = JsonEditorState._nextId++;
|
|
33
|
-
}
|
|
34
|
-
get context() { return this.options.context; }
|
|
35
|
-
get deferred() {
|
|
36
|
-
return this._deferred;
|
|
37
|
-
}
|
|
38
|
-
static _getEffectiveOptions(options, context) {
|
|
39
|
-
if (!context) {
|
|
40
|
-
return (0, ts_utils_1.succeed)(options);
|
|
41
|
-
}
|
|
42
|
-
return contextHelpers_1.JsonContextHelper.mergeContext(options.context, context).onSuccess((merged) => {
|
|
43
|
-
return (0, ts_utils_1.succeed)({ context: merged, validation: options.validation });
|
|
44
|
-
});
|
|
45
|
-
}
|
|
46
|
-
defer(obj) {
|
|
47
|
-
this._deferred.push(obj);
|
|
48
|
-
}
|
|
49
|
-
getVars(defaultContext) {
|
|
50
|
-
var _a, _b;
|
|
51
|
-
return (_b = (_a = this.options.context) === null || _a === void 0 ? void 0 : _a.vars) !== null && _b !== void 0 ? _b : defaultContext === null || defaultContext === void 0 ? void 0 : defaultContext.vars;
|
|
52
|
-
}
|
|
53
|
-
getRefs(defaultContext) {
|
|
54
|
-
var _a, _b;
|
|
55
|
-
return (_b = (_a = this.options.context) === null || _a === void 0 ? void 0 : _a.refs) !== null && _b !== void 0 ? _b : defaultContext === null || defaultContext === void 0 ? void 0 : defaultContext.refs;
|
|
56
|
-
}
|
|
57
|
-
getContext(defaultContext) {
|
|
58
|
-
return contextHelpers_1.JsonContextHelper.mergeContext(defaultContext, this.options.context).orDefault();
|
|
59
|
-
}
|
|
60
|
-
extendContext(baseContext, add) {
|
|
61
|
-
const context = this.getContext(baseContext);
|
|
62
|
-
return contextHelpers_1.JsonContextHelper.extendContext(context, add);
|
|
63
|
-
}
|
|
64
|
-
failValidation(rule, message, validation) {
|
|
65
|
-
let detail = 'error';
|
|
66
|
-
const effective = validation !== null && validation !== void 0 ? validation : this.options.validation;
|
|
67
|
-
switch (rule) {
|
|
68
|
-
case 'invalidPropertyName':
|
|
69
|
-
detail = (effective.onInvalidPropertyName !== 'ignore') ? 'error' : 'inapplicable';
|
|
70
|
-
break;
|
|
71
|
-
case 'invalidPropertyValue':
|
|
72
|
-
detail = (effective.onInvalidPropertyValue !== 'ignore') ? 'error' : 'ignore';
|
|
73
|
-
break;
|
|
74
|
-
case 'undefinedPropertyValue':
|
|
75
|
-
detail = (effective.onUndefinedPropertyValue !== 'error') ? 'ignore' : 'error';
|
|
76
|
-
// istanbul ignore next
|
|
77
|
-
message = message !== null && message !== void 0 ? message : 'Cannot convert undefined to JSON';
|
|
78
|
-
break;
|
|
79
|
-
}
|
|
80
|
-
// istanbul ignore next
|
|
81
|
-
return (0, ts_utils_1.failWithDetail)(message !== null && message !== void 0 ? message : rule, detail);
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
exports.JsonEditorState = JsonEditorState;
|
|
85
|
-
JsonEditorState._nextId = 0;
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jsonEditorState.js","sourceRoot":"","sources":["../../src/jsonEditor/jsonEditorState.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2020 Erik Fortune\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\n\nimport { DetailedFailure, Result, failWithDetail, succeed } from '@fgv/ts-utils';\nimport { IJsonCloneEditor, JsonEditFailureReason, JsonEditorOptions, JsonEditorValidationOptions, JsonEditorValidationRules, JsonPropertyEditFailureReason } from './common';\nimport { JsonContext, JsonReferenceMap, TemplateVars, VariableValue } from '../jsonContext';\n\nimport { JsonContextHelper } from '../contextHelpers';\nimport { JsonObject } from '../common';\n\nexport class JsonEditorState {\n    protected static _nextId = 0;\n\n    public readonly editor: IJsonCloneEditor;\n\n    public readonly options: JsonEditorOptions;\n    protected readonly _deferred: JsonObject[] = [];\n    protected readonly _id: number;\n\n    public constructor(editor: IJsonCloneEditor, baseOptions: JsonEditorOptions, runtimeContext?: JsonContext) {\n        this.editor = editor;\n        this.options = JsonEditorState._getEffectiveOptions(baseOptions, runtimeContext).orThrow();\n        this._id = JsonEditorState._nextId++;\n    }\n\n    public get context(): JsonContext|undefined { return this.options.context; }\n\n    public get deferred(): JsonObject[] {\n        return this._deferred;\n    }\n\n    protected static _getEffectiveOptions(options: JsonEditorOptions, context?: JsonContext): Result<JsonEditorOptions> {\n        if (!context) {\n            return succeed(options);\n        }\n        return JsonContextHelper.mergeContext(options.context, context).onSuccess((merged) => {\n            return succeed({ context: merged, validation: options.validation });\n        });\n    }\n\n    public defer(obj: JsonObject): void {\n        this._deferred.push(obj);\n    }\n\n    public getVars(defaultContext?: JsonContext): TemplateVars|undefined {\n        return this.options.context?.vars ?? defaultContext?.vars;\n    }\n\n    public getRefs(defaultContext?: JsonContext): JsonReferenceMap|undefined {\n        return this.options.context?.refs ?? defaultContext?.refs;\n    }\n\n    public getContext(defaultContext?: JsonContext): JsonContext|undefined {\n        return JsonContextHelper.mergeContext(defaultContext, this.options.context).orDefault();\n    }\n\n    public extendContext(baseContext: JsonContext|undefined, add: { vars?: VariableValue[], refs?: JsonReferenceMap[] }): Result<JsonContext|undefined> {\n        const context = this.getContext(baseContext);\n        return JsonContextHelper.extendContext(context, add);\n    }\n\n    public failValidation<T=JsonObject>(\n        rule: JsonEditorValidationRules,\n        message?: string,\n        validation?: JsonEditorValidationOptions,\n    ): DetailedFailure<T, JsonEditFailureReason> {\n        let detail: JsonPropertyEditFailureReason = 'error';\n        const effective = validation ?? this.options.validation;\n        switch (rule) {\n            case 'invalidPropertyName':\n                detail = (effective.onInvalidPropertyName !== 'ignore') ? 'error' : 'inapplicable';\n                break;\n            case 'invalidPropertyValue':\n                detail = (effective.onInvalidPropertyValue !== 'ignore') ? 'error' : 'ignore';\n                break;\n            case 'undefinedPropertyValue':\n                detail = (effective.onUndefinedPropertyValue !== 'error') ? 'ignore' : 'error';\n                // istanbul ignore next\n                message = message ?? 'Cannot convert undefined to JSON';\n                break;\n        }\n        // istanbul ignore next\n        return failWithDetail(message ?? rule, detail);\n    }\n}\n"]}
|
|
@@ -1,84 +0,0 @@
|
|
|
1
|
-
import { DetailedResult, Result } from '@fgv/ts-utils';
|
|
2
|
-
import { JsonEditFailureReason, JsonEditorOptions, JsonPropertyEditFailureReason } from '../common';
|
|
3
|
-
import { JsonObject, JsonValue } from '../../common';
|
|
4
|
-
import { JsonEditorRuleBase } from '../jsonEditorRule';
|
|
5
|
-
import { JsonEditorState } from '../jsonEditorState';
|
|
6
|
-
/**
|
|
7
|
-
* Returned by the _tryMatch method of the @see ConditionalJsonEditorRule
|
|
8
|
-
* to indicate whether a successful match was due to a matching condition
|
|
9
|
-
* or a default value.
|
|
10
|
-
*/
|
|
11
|
-
export interface ConditionalJsonKeyResult extends JsonObject {
|
|
12
|
-
matchType: 'default' | 'match' | 'unconditional';
|
|
13
|
-
}
|
|
14
|
-
/**
|
|
15
|
-
* On a successful match, the @see ConditionalJsonEditorRule stores a
|
|
16
|
-
* ConditionalJsonDeferredObject describing the matching result, to
|
|
17
|
-
* be resolved at finalization time.
|
|
18
|
-
*/
|
|
19
|
-
export interface ConditionalJsonDeferredObject extends ConditionalJsonKeyResult {
|
|
20
|
-
value: JsonValue;
|
|
21
|
-
}
|
|
22
|
-
/**
|
|
23
|
-
* Configuration options for the Conditional JSON editor rule
|
|
24
|
-
*/
|
|
25
|
-
export interface ConditionalJsonRuleOptions extends Partial<JsonEditorOptions> {
|
|
26
|
-
/**
|
|
27
|
-
* If true (default) then properties with unconditional names
|
|
28
|
-
* (which start with !) are flattened.
|
|
29
|
-
*/
|
|
30
|
-
flattenUnconditionalValues?: boolean;
|
|
31
|
-
}
|
|
32
|
-
/**
|
|
33
|
-
* The Conditional JSON editor rule evaluates properties with conditional keys,
|
|
34
|
-
* omitting non-matching keys and merging keys that match, or default keys only
|
|
35
|
-
* if no other keys match.
|
|
36
|
-
*
|
|
37
|
-
* The default syntax for a conditional key is:
|
|
38
|
-
* "?value1=value2" - matches if value1 and value2 are the same, is ignored otherwise.
|
|
39
|
-
* "?value" - matches if value is a non-empty, non-whitespace string. Is ignored otherwise.
|
|
40
|
-
* "?default" - matches only if no other conditional blocks in the same object were matched
|
|
41
|
-
*/
|
|
42
|
-
export declare class ConditionalJsonEditorRule extends JsonEditorRuleBase {
|
|
43
|
-
protected _options?: ConditionalJsonRuleOptions;
|
|
44
|
-
/**
|
|
45
|
-
* Creates a new @see ConditionalJsonEditorRule
|
|
46
|
-
* @param options Optional configuration options used for this rule
|
|
47
|
-
*/
|
|
48
|
-
constructor(options?: ConditionalJsonRuleOptions);
|
|
49
|
-
/**
|
|
50
|
-
* Creates a new @see ConditionalJsonEditorRule
|
|
51
|
-
* @param options Optional configuration options used for this rule
|
|
52
|
-
*/
|
|
53
|
-
static create(options?: ConditionalJsonRuleOptions): Result<ConditionalJsonEditorRule>;
|
|
54
|
-
/**
|
|
55
|
-
* Evaluates a property for conditional application.
|
|
56
|
-
* @param key The key of the property to be considered
|
|
57
|
-
* @param value The value of the property to be considered
|
|
58
|
-
* @param state The editor state for the object being edited
|
|
59
|
-
* @returns Returns Success with detail 'deferred' and a @see ConditionalJsonDeferredObject
|
|
60
|
-
* for a matching, default or unconditional key. Fails with detail 'ignore' for a
|
|
61
|
-
* non-matching conditional and with detail 'error' if an error occurs. Otherwise
|
|
62
|
-
* fails with detail 'inapplicable'.
|
|
63
|
-
*/
|
|
64
|
-
editProperty(key: string, value: JsonValue, state: JsonEditorState): DetailedResult<JsonObject, JsonPropertyEditFailureReason>;
|
|
65
|
-
/**
|
|
66
|
-
* Finalizes any deferred conditional properties. If the only deferred property is
|
|
67
|
-
* default, that property is emitted. Otherwise all matching properties are emitted.
|
|
68
|
-
* @param finalized The deferred properties to be considered for merge
|
|
69
|
-
* @param _state The editor state for the object being edited
|
|
70
|
-
*/
|
|
71
|
-
finalizeProperties(finalized: JsonObject[], _state: JsonEditorState): DetailedResult<JsonObject[], JsonEditFailureReason>;
|
|
72
|
-
/**
|
|
73
|
-
* Determines if a given property key is conditional. Derived classes can override this
|
|
74
|
-
* method to use a different format for conditional properties.
|
|
75
|
-
* @param key The key of the property to consider.
|
|
76
|
-
* @param state The editor state of the object being edited.
|
|
77
|
-
* @returns Success with detail 'deferred' and a @see ConditionalJsonKeyResult describing the
|
|
78
|
-
* match for a default or matching conditional property. Fails with detail 'ignore' for
|
|
79
|
-
* a non-matching conditional property. Fails with detail 'error' if an error occurs
|
|
80
|
-
* or with detail 'inapplicable' if the key does not represent a conditional property.
|
|
81
|
-
*/
|
|
82
|
-
protected _tryParseCondition(key: string, state: JsonEditorState): DetailedResult<ConditionalJsonKeyResult, JsonPropertyEditFailureReason>;
|
|
83
|
-
protected _compare(left: string, right: string, operator: string): boolean;
|
|
84
|
-
}
|