@fgv/ts-json 1.0.1 → 1.8.1
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/LICENSE +0 -0
- package/README.md +0 -0
- package/common.d.ts +3 -3
- package/common.js +10 -10
- package/contextHelpers.d.ts +0 -0
- package/contextHelpers.js +10 -10
- package/converters.d.ts +0 -0
- package/converters.js +0 -0
- package/file.d.ts +1 -1
- package/file.js +16 -12
- package/index.d.ts +0 -0
- package/index.js +6 -2
- package/jsonContext.d.ts +4 -4
- package/jsonContext.js +2 -2
- package/jsonConverter.d.ts +5 -5
- package/jsonConverter.js +16 -16
- package/jsonEditor/index.d.ts +0 -0
- package/jsonEditor/index.js +6 -2
- package/jsonEditor/jsonEditor.d.ts +5 -5
- package/jsonEditor/jsonEditor.js +43 -43
- package/jsonEditor/jsonEditorRule.d.ts +2 -2
- package/jsonEditor/jsonEditorRule.js +4 -4
- package/jsonEditor/jsonEditorState.d.ts +3 -3
- package/jsonEditor/jsonEditorState.js +9 -9
- package/jsonEditor/rules/conditional.d.ts +0 -0
- package/jsonEditor/rules/conditional.js +13 -13
- package/jsonEditor/rules/index.d.ts +0 -0
- package/jsonEditor/rules/index.js +6 -2
- package/jsonEditor/rules/multivalue.d.ts +0 -0
- package/jsonEditor/rules/multivalue.js +9 -9
- package/jsonEditor/rules/references.d.ts +0 -0
- package/jsonEditor/rules/references.js +9 -9
- package/jsonEditor/rules/templates.d.ts +0 -0
- package/jsonEditor/rules/templates.js +8 -8
- package/jsonReferenceMap.d.ts +1 -1
- package/jsonReferenceMap.js +25 -25
- package/package.json +14 -14
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { DetailedResult } from '@fgv/ts-utils';
|
|
2
2
|
import { JsonObject, JsonValue } from '../common';
|
|
3
3
|
import { JsonEditorState } from './jsonEditorState';
|
|
4
|
-
export
|
|
5
|
-
export
|
|
4
|
+
export type JsonEditFailureReason = 'ignore' | 'inapplicable' | 'edited' | 'error';
|
|
5
|
+
export type JsonPropertyEditFailureReason = JsonEditFailureReason | 'deferred';
|
|
6
6
|
export interface JsonEditorRule {
|
|
7
7
|
/**
|
|
8
8
|
* Called by a JSON editor to possibly edit one of the properties being merged into a target object.
|
|
@@ -31,14 +31,14 @@ class JsonEditorRuleBase {
|
|
|
31
31
|
// istanbul ignore next
|
|
32
32
|
editProperty(_key, _value, _state) {
|
|
33
33
|
// istanbul ignore next
|
|
34
|
-
return ts_utils_1.failWithDetail('inapplicable', 'inapplicable');
|
|
34
|
+
return (0, ts_utils_1.failWithDetail)('inapplicable', 'inapplicable');
|
|
35
35
|
}
|
|
36
36
|
editValue(_value, _state) {
|
|
37
|
-
return ts_utils_1.failWithDetail('inapplicable', 'inapplicable');
|
|
37
|
+
return (0, ts_utils_1.failWithDetail)('inapplicable', 'inapplicable');
|
|
38
38
|
}
|
|
39
39
|
finalizeProperties(_deferred, _state) {
|
|
40
|
-
return ts_utils_1.failWithDetail('inapplicable', 'inapplicable');
|
|
40
|
+
return (0, ts_utils_1.failWithDetail)('inapplicable', 'inapplicable');
|
|
41
41
|
}
|
|
42
42
|
}
|
|
43
43
|
exports.JsonEditorRuleBase = JsonEditorRuleBase;
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoianNvbkVkaXRvclJ1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvanNvbkVkaXRvci9qc29uRWRpdG9yUnVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBb0JHOzs7QUFFSCw0Q0FBK0Q7QUE4Qy9EOzs7R0FHRztBQUNILE1BQWEsa0JBQWtCO0lBQzNCLHVCQUF1QjtJQUNoQixZQUFZLENBQUMsSUFBWSxFQUFFLE1BQWlCLEVBQUUsTUFBdUI7UUFDeEUsdUJBQXVCO1FBQ3ZCLE9BQU8sSUFBQSx5QkFBYyxFQUFDLGNBQWMsRUFBRSxjQUFjLENBQUMsQ0FBQztJQUMxRCxDQUFDO0lBRU0sU0FBUyxDQUFDLE1BQWlCLEVBQUUsTUFBdUI7UUFDdkQsT0FBTyxJQUFBLHlCQUFjLEVBQUMsY0FBYyxFQUFFLGNBQWMsQ0FBQyxDQUFDO0lBQzFELENBQUM7SUFFTSxrQkFBa0IsQ0FBQyxTQUF1QixFQUFFLE1BQXVCO1FBQ3RFLE9BQU8sSUFBQSx5QkFBYyxFQUFDLGNBQWMsRUFBRSxjQUFjLENBQUMsQ0FBQztJQUMxRCxDQUFDO0NBQ0o7QUFkRCxnREFjQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjAgRXJpayBGb3J0dW5lXG4gKlxuICogUGVybWlzc2lvbiBpcyBoZXJlYnkgZ3JhbnRlZCwgZnJlZSBvZiBjaGFyZ2UsIHRvIGFueSBwZXJzb24gb2J0YWluaW5nIGEgY29weVxuICogb2YgdGhpcyBzb2Z0d2FyZSBhbmQgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIGZpbGVzICh0aGUgXCJTb2Z0d2FyZVwiKSwgdG8gZGVhbFxuICogaW4gdGhlIFNvZnR3YXJlIHdpdGhvdXQgcmVzdHJpY3Rpb24sIGluY2x1ZGluZyB3aXRob3V0IGxpbWl0YXRpb24gdGhlIHJpZ2h0c1xuICogdG8gdXNlLCBjb3B5LCBtb2RpZnksIG1lcmdlLCBwdWJsaXNoLCBkaXN0cmlidXRlLCBzdWJsaWNlbnNlLCBhbmQvb3Igc2VsbFxuICogY29waWVzIG9mIHRoZSBTb2Z0d2FyZSwgYW5kIHRvIHBlcm1pdCBwZXJzb25zIHRvIHdob20gdGhlIFNvZnR3YXJlIGlzXG4gKiBmdXJuaXNoZWQgdG8gZG8gc28sIHN1YmplY3QgdG8gdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOlxuICpcbiAqIFRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlIGFuZCB0aGlzIHBlcm1pc3Npb24gbm90aWNlIHNoYWxsIGJlIGluY2x1ZGVkIGluIGFsbFxuICogY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS5cbiAqXG4gKiBUSEUgU09GVFdBUkUgSVMgUFJPVklERUQgXCJBUyBJU1wiLCBXSVRIT1VUIFdBUlJBTlRZIE9GIEFOWSBLSU5ELCBFWFBSRVNTIE9SXG4gKiBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPIFRIRSBXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSxcbiAqIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFIEFORCBOT05JTkZSSU5HRU1FTlQuIElOIE5PIEVWRU5UIFNIQUxMIFRIRVxuICogQVVUSE9SUyBPUiBDT1BZUklHSFQgSE9MREVSUyBCRSBMSUFCTEUgRk9SIEFOWSBDTEFJTSwgREFNQUdFUyBPUiBPVEhFUlxuICogTElBQklMSVRZLCBXSEVUSEVSIElOIEFOIEFDVElPTiBPRiBDT05UUkFDVCwgVE9SVCBPUiBPVEhFUldJU0UsIEFSSVNJTkcgRlJPTSxcbiAqIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU4gVEhFXG4gKiBTT0ZUV0FSRS5cbiAqL1xuXG5pbXBvcnQgeyBEZXRhaWxlZFJlc3VsdCwgZmFpbFdpdGhEZXRhaWwgfSBmcm9tICdAZmd2L3RzLXV0aWxzJztcbmltcG9ydCB7IEpzb25PYmplY3QsIEpzb25WYWx1ZSB9IGZyb20gJy4uL2NvbW1vbic7XG5cbmltcG9ydCB7IEpzb25FZGl0b3JTdGF0ZSB9IGZyb20gJy4vanNvbkVkaXRvclN0YXRlJztcblxuZXhwb3J0IHR5cGUgSnNvbkVkaXRGYWlsdXJlUmVhc29uID0gJ2lnbm9yZSd8J2luYXBwbGljYWJsZSd8J2VkaXRlZCd8J2Vycm9yJztcbmV4cG9ydCB0eXBlIEpzb25Qcm9wZXJ0eUVkaXRGYWlsdXJlUmVhc29uID0gSnNvbkVkaXRGYWlsdXJlUmVhc29ufCdkZWZlcnJlZCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSnNvbkVkaXRvclJ1bGUge1xuICAgIC8qKlxuICAgICAqIENhbGxlZCBieSBhIEpTT04gZWRpdG9yIHRvIHBvc3NpYmx5IGVkaXQgb25lIG9mIHRoZSBwcm9wZXJ0aWVzIGJlaW5nIG1lcmdlZCBpbnRvIGEgdGFyZ2V0IG9iamVjdC5cbiAgICAgKiBAcGFyYW0ga2V5IFRoZSBrZXkgb2YgdGhlIHByb3BlcnR5IHRvIGJlIGVkaXRlZFxuICAgICAqIEBwYXJhbSB2YWx1ZSBUaGUgdmFsdWUgb2YgdGhlIHByb3BlcnR5IHRvIGJlIGVkaXRlZFxuICAgICAqIEBwYXJhbSBzdGF0ZSBFZGl0b3Igc3RhdGUgd2hpY2ggYXBwbGllcyB0byB0aGUgZWRpdFxuICAgICAqIEByZXR1cm5zIElmIHRoZSBwcm9wZXJ0eSB3YXMgZWRpdGVkLCByZXR1cm5zIFN1Y2Nlc3Mgd2l0aCBhIEpTT04gb2JqZWN0IGNvbnRhaW5pbmcgdGhlIGVkaXRlZCByZXN1bHRzXG4gICAgICogYW5kIHdpdGggZGV0YWlsICdlZGl0ZWQnLiBJZiB0aGlzIHByb3BlcnR5IHNob3VsZCBiZSBkZWZlcnJlZCBmb3IgbGF0ZXIgY29uc2lkZXJhdGlvbiBvciBtZXJnLCBTdWNjZWVkc1xuICAgICAqIHdpdGggZGV0YWlsICdkZWZlcnJlZCcgYW5kIGFuIEpzb25PYmplY3QgdG8gYmUgZmluYWxpemVkLiAgSWYgdGhlIHJ1bGUgZG9lcyBub3QgYWZmZWN0IHRoaXMgcHJvcGVydHksXG4gICAgICogZmFpbHMgd2l0aCBkZXRhaWwgJ2luYXBwbGljYWJsZScuIElmIGFuIGVycm9yIG9jY3VycmVkIHdoaWxlIHByb2Nlc3NpbmcgdGhlIGVycm9yLCByZXR1cm5zIEZhaWx1cmUgd2l0aFxuICAgICAqIGRldGFpbCAnZXJyb3InLlxuICAgICAqL1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby11c2UtYmVmb3JlLWRlZmluZVxuICAgIGVkaXRQcm9wZXJ0eShrZXk6IHN0cmluZywgdmFsdWU6IEpzb25WYWx1ZSwgc3RhdGU6IEpzb25FZGl0b3JTdGF0ZSk6IERldGFpbGVkUmVzdWx0PEpzb25PYmplY3QsIEpzb25Qcm9wZXJ0eUVkaXRGYWlsdXJlUmVhc29uPjtcblxuICAgIC8qKlxuICAgICAqIENhbGxlZCBieSBhIEpTT04gZWRpdG9yIHRvIHBvc3NpYmx5IGVkaXQgYSBwcm9wZXJ0eSB2YWx1ZSBvciBhcnJheSBlbGVtZW50XG4gICAgICogQHBhcmFtIHZhbHVlIFRoZSB2YWx1ZSB0byBiZSBlZGl0ZWRcbiAgICAgKiBAcGFyYW0gc3RhdGUgRWRpdG9yIHN0YXRlIHdoaWNoIGFwcGxpZXMgdG8gdGhlIGVkaXRcbiAgICAgKiBAcmV0dXJucyBSZXR1cm5zIHN1Y2Nlc3Mgd2l0aCB0aGUgSnNvblZhbHVlIHRvIGJlIGluc2VydGVkLCB3aXRoIGRldGFpbCAnZWRpdGVkJyBpZiB0aGUgdmFsdWUgd2FzXG4gICAgICogZWRpdGVkLiAgUmV0dXJucyBmYWlsdXJlIHdpdGggJ2luYXBwbGljYWJsZScgaWYgdGhlIHJ1bGUgZG9lcyBub3QgYWZmZWN0IHRoaXMgdmFsdWUuICBGYWlscyB3aXRoXG4gICAgICogZGV0YWlsICdpZ25vcmUnIGlmIHRoZSB2YWx1ZSBpcyB0byBiZSBpZ25vcmVkLCBvciB3aXRoICdlcnJvcicgaWYgYW4gZXJyb3Igb2NjdXJzLlxuICAgICAqL1xuICAgIGVkaXRWYWx1ZSh2YWx1ZTogSnNvblZhbHVlLCBzdGF0ZTogSnNvbkVkaXRvclN0YXRlKTogRGV0YWlsZWRSZXN1bHQ8SnNvblZhbHVlLCBKc29uRWRpdEZhaWx1cmVSZWFzb24+O1xuXG4gICAgLyoqXG4gICAgICogQ2FsbGVkIGZvciBlYWNoIHJ1bGUgYWZ0ZXIgYWxsIHByb3BlcnRpZXMgaGF2ZSBiZWVuIG1lcmdlZC4gIEFueSBwcm9wZXJ0aWVzIHRoYXQgd2VyZSBkZWZlcnJlZFxuICAgICAqIGR1cmluZyB0aGUgaW5pdGlhbCBlZGl0IHBhc3MgYXJlIHN1cHBsaWVkIGFzIGlucHV0LlxuICAgICAqIEBwYXJhbSBkZWZlcnJlZCBBbnkgb2JqZWN0cyB0aGF0IHdlcmUgZGVmZXJyZWQgZHVyaW5nIHRoZSBmaXJzdCBlZGl0IHBhc3NcbiAgICAgKiBAcGFyYW0gc3RhdGUgRWRpdG9yIHN0YXRlIHdoaWNoIGFwcGxpZXMgdG8gdGhlIGVkaXRcbiAgICAgKiBAcmV0dXJucyBPbiBzdWNjZXNzZnVsIHJldHVybiwgYW55IHJldHVybmVkIG9iamVjdHMgYXJlIG1lcmdlZCBpbiBvcmRlciBhbmQgZmluYWxpemF0aW9uXG4gICAgICogaXMgc3RvcHBlZC4gRmluYWxpemF0aW9uIGlzIGFsc28gc3RvcHBlZCBvbiBGYWlsdXJlIHdpdGggZGV0YWlsICdpZ25vcmUuJyBPbiBmYWlsdXJlXG4gICAgICogd2l0aCBkZXRhaWwgJ2luYXBwbGljYWJsZScsIGZpbmFsaXphdGlvbiBjb250aW51ZXMgd2l0aCB0aGUgbmV4dCBydWxlLiBGYWlscyB3aXRoIGFuXG4gICAgICogZXJyb3IgZGV0YWlsICdlcnJvcicgYW5kIGFuIGluZm9ybWF0aXZlIG1lc3NhZ2UgaWYgYW4gZXJyb3Igb2NjdXJzLlxuICAgICAqL1xuICAgIGZpbmFsaXplUHJvcGVydGllcyhkZWZlcnJlZDogSnNvbk9iamVjdFtdLCBzdGF0ZTogSnNvbkVkaXRvclN0YXRlKTogRGV0YWlsZWRSZXN1bHQ8SnNvbk9iamVjdFtdLCBKc29uRWRpdEZhaWx1cmVSZWFzb24+O1xufVxuXG4vKipcbiAqIERlZmF1bHQgYmFzZSBpbXBsZW1lbnRhdGlvbiBvZiBKc29uRWRpdG9yIHJ1bGUgcmV0dXJucyBpbmFwcGxpY2FibGUgZm9yIGFsbCBvcGVyYXRpb25zIHNvIHRoYXRcbiAqIGRlcml2ZWQgY2xhc3NlcyBuZWVkIG9ubHkgaW1wbGVtZW50IHRoZSBvcGVyYXRpb25zIHRoZXkgYWN0dWFsbHkgc3VwcG9ydC5cbiAqL1xuZXhwb3J0IGNsYXNzIEpzb25FZGl0b3JSdWxlQmFzZSBpbXBsZW1lbnRzIEpzb25FZGl0b3JSdWxlIHtcbiAgICAvLyBpc3RhbmJ1bCBpZ25vcmUgbmV4dFxuICAgIHB1YmxpYyBlZGl0UHJvcGVydHkoX2tleTogc3RyaW5nLCBfdmFsdWU6IEpzb25WYWx1ZSwgX3N0YXRlOiBKc29uRWRpdG9yU3RhdGUpOiBEZXRhaWxlZFJlc3VsdDxKc29uT2JqZWN0LCBKc29uUHJvcGVydHlFZGl0RmFpbHVyZVJlYXNvbj4ge1xuICAgICAgICAvLyBpc3RhbmJ1bCBpZ25vcmUgbmV4dFxuICAgICAgICByZXR1cm4gZmFpbFdpdGhEZXRhaWwoJ2luYXBwbGljYWJsZScsICdpbmFwcGxpY2FibGUnKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZWRpdFZhbHVlKF92YWx1ZTogSnNvblZhbHVlLCBfc3RhdGU6IEpzb25FZGl0b3JTdGF0ZSk6IERldGFpbGVkUmVzdWx0PEpzb25WYWx1ZSwgSnNvbkVkaXRGYWlsdXJlUmVhc29uPiB7XG4gICAgICAgIHJldHVybiBmYWlsV2l0aERldGFpbCgnaW5hcHBsaWNhYmxlJywgJ2luYXBwbGljYWJsZScpO1xuICAgIH1cblxuICAgIHB1YmxpYyBmaW5hbGl6ZVByb3BlcnRpZXMoX2RlZmVycmVkOiBKc29uT2JqZWN0W10sIF9zdGF0ZTogSnNvbkVkaXRvclN0YXRlKTogRGV0YWlsZWRSZXN1bHQ8SnNvbk9iamVjdFtdLCBKc29uRWRpdEZhaWx1cmVSZWFzb24+IHtcbiAgICAgICAgcmV0dXJuIGZhaWxXaXRoRGV0YWlsKCdpbmFwcGxpY2FibGUnLCAnaW5hcHBsaWNhYmxlJyk7XG4gICAgfVxufVxuIl19
|
|
@@ -3,7 +3,7 @@ import { JsonContext, JsonReferenceMap, TemplateVars, VariableValue } from '../j
|
|
|
3
3
|
import { JsonEditFailureReason } from './jsonEditorRule';
|
|
4
4
|
import { JsonEditor } from './jsonEditor';
|
|
5
5
|
import { JsonObject } from '../common';
|
|
6
|
-
export
|
|
6
|
+
export type JsonEditorValidationRules = 'invalidPropertyName' | 'invalidPropertyValue' | 'undefinedPropertyValue';
|
|
7
7
|
export interface JsonEditorValidationOptions {
|
|
8
8
|
/**
|
|
9
9
|
* If onInvalidPropertyName is 'error' (default) then any property name
|
|
@@ -34,14 +34,14 @@ export interface JsonEditorOptions {
|
|
|
34
34
|
export declare class JsonEditorState {
|
|
35
35
|
protected static _nextId: number;
|
|
36
36
|
readonly editor: JsonEditor;
|
|
37
|
-
get context(): JsonContext | undefined;
|
|
38
37
|
readonly options: JsonEditorOptions;
|
|
39
38
|
protected readonly _deferred: JsonObject[];
|
|
40
39
|
protected readonly _id: number;
|
|
41
40
|
constructor(editor: JsonEditor, baseOptions: JsonEditorOptions, runtimeContext?: JsonContext);
|
|
41
|
+
get context(): JsonContext | undefined;
|
|
42
|
+
get deferred(): JsonObject[];
|
|
42
43
|
protected static _getEffectiveOptions(options: JsonEditorOptions, context?: JsonContext): Result<JsonEditorOptions>;
|
|
43
44
|
defer(obj: JsonObject): void;
|
|
44
|
-
get deferred(): JsonObject[];
|
|
45
45
|
getVars(defaultContext?: JsonContext): TemplateVars | undefined;
|
|
46
46
|
getRefs(defaultContext?: JsonContext): JsonReferenceMap | undefined;
|
|
47
47
|
getContext(defaultContext?: JsonContext): JsonContext | undefined;
|
|
@@ -28,24 +28,24 @@ class JsonEditorState {
|
|
|
28
28
|
constructor(editor, baseOptions, runtimeContext) {
|
|
29
29
|
this._deferred = [];
|
|
30
30
|
this.editor = editor;
|
|
31
|
-
this.options = JsonEditorState._getEffectiveOptions(baseOptions, runtimeContext).
|
|
31
|
+
this.options = JsonEditorState._getEffectiveOptions(baseOptions, runtimeContext).orThrow();
|
|
32
32
|
this._id = JsonEditorState._nextId++;
|
|
33
33
|
}
|
|
34
34
|
get context() { return this.options.context; }
|
|
35
|
+
get deferred() {
|
|
36
|
+
return this._deferred;
|
|
37
|
+
}
|
|
35
38
|
static _getEffectiveOptions(options, context) {
|
|
36
39
|
if (!context) {
|
|
37
|
-
return ts_utils_1.succeed(options);
|
|
40
|
+
return (0, ts_utils_1.succeed)(options);
|
|
38
41
|
}
|
|
39
42
|
return contextHelpers_1.JsonContextHelper.mergeContext(options.context, context).onSuccess((merged) => {
|
|
40
|
-
return ts_utils_1.succeed({ context: merged, validation: options.validation });
|
|
43
|
+
return (0, ts_utils_1.succeed)({ context: merged, validation: options.validation });
|
|
41
44
|
});
|
|
42
45
|
}
|
|
43
46
|
defer(obj) {
|
|
44
47
|
this._deferred.push(obj);
|
|
45
48
|
}
|
|
46
|
-
get deferred() {
|
|
47
|
-
return this._deferred;
|
|
48
|
-
}
|
|
49
49
|
getVars(defaultContext) {
|
|
50
50
|
var _a, _b;
|
|
51
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;
|
|
@@ -55,7 +55,7 @@ class JsonEditorState {
|
|
|
55
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
56
|
}
|
|
57
57
|
getContext(defaultContext) {
|
|
58
|
-
return contextHelpers_1.JsonContextHelper.mergeContext(defaultContext, this.options.context).
|
|
58
|
+
return contextHelpers_1.JsonContextHelper.mergeContext(defaultContext, this.options.context).orDefault();
|
|
59
59
|
}
|
|
60
60
|
extendContext(baseContext, add) {
|
|
61
61
|
const context = this.getContext(baseContext);
|
|
@@ -78,9 +78,9 @@ class JsonEditorState {
|
|
|
78
78
|
break;
|
|
79
79
|
}
|
|
80
80
|
// istanbul ignore next
|
|
81
|
-
return ts_utils_1.failWithDetail(message !== null && message !== void 0 ? message : rule, detail);
|
|
81
|
+
return (0, ts_utils_1.failWithDetail)(message !== null && message !== void 0 ? message : rule, detail);
|
|
82
82
|
}
|
|
83
83
|
}
|
|
84
84
|
exports.JsonEditorState = JsonEditorState;
|
|
85
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 { JsonContext, JsonReferenceMap, TemplateVars, VariableValue } from '../jsonContext';\nimport { JsonEditFailureReason, JsonPropertyEditFailureReason } from './jsonEditorRule';\n\nimport { JsonContextHelper } from '../contextHelpers';\nimport { JsonEditor } from './jsonEditor';\nimport { JsonObject } from '../common';\n\nexport type JsonEditorValidationRules = 'invalidPropertyName'|'invalidPropertyValue'|'undefinedPropertyValue';\n\nexport interface JsonEditorValidationOptions {\n    /**\n     * If onInvalidPropertyName is 'error' (default) then any property name\n     * that is invalid after template rendering causes an error and stops\n     * conversion.  If onInvalidPropertyName is 'ignore', then names which\n     * are invalid after template rendering are passed through unchanged.\n     */\n    onInvalidPropertyName: 'error'|'ignore';\n\n    /**\n     * If onInvalidPropertyValue is 'error' (default) then any illegal\n     * property value other than undefined causes an error and stops\n     * conversion.  If onInvalidPropertyValue is 'ignore' then any\n     * invalid property values are silently ignored.\n     */\n    onInvalidPropertyValue: 'error'|'ignore';\n\n    /**\n     * If onUnknownPropertyValue is error, then any property with\n     * value undefined will cause an error and stop conversion.  If\n     * onUndefinedPropertyValue is 'ignore' (default) then any\n     * property with value undefined is silently ignored.\n     */\n    onUndefinedPropertyValue: 'error'|'ignore';\n}\n\nexport interface JsonEditorOptions {\n    context?: JsonContext;\n    validation: JsonEditorValidationOptions;\n}\n\nexport class JsonEditorState {\n    protected static _nextId = 0;\n\n    public readonly editor: JsonEditor;\n\n    public get context(): JsonContext|undefined { return this.options.context; }\n    public readonly options: JsonEditorOptions;\n    protected readonly _deferred: JsonObject[] = [];\n    protected readonly _id: number;\n\n    public constructor(editor: JsonEditor, baseOptions: JsonEditorOptions, runtimeContext?: JsonContext) {\n        this.editor = editor;\n        this.options = JsonEditorState._getEffectiveOptions(baseOptions, runtimeContext).getValueOrThrow();\n        this._id = JsonEditorState._nextId++;\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 get deferred(): JsonObject[] {\n        return this._deferred;\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).getValueOrDefault();\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"]}
|
|
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 { JsonContext, JsonReferenceMap, TemplateVars, VariableValue } from '../jsonContext';\nimport { JsonEditFailureReason, JsonPropertyEditFailureReason } from './jsonEditorRule';\n\nimport { JsonContextHelper } from '../contextHelpers';\nimport { JsonEditor } from './jsonEditor';\nimport { JsonObject } from '../common';\n\nexport type JsonEditorValidationRules = 'invalidPropertyName'|'invalidPropertyValue'|'undefinedPropertyValue';\n\nexport interface JsonEditorValidationOptions {\n    /**\n     * If onInvalidPropertyName is 'error' (default) then any property name\n     * that is invalid after template rendering causes an error and stops\n     * conversion.  If onInvalidPropertyName is 'ignore', then names which\n     * are invalid after template rendering are passed through unchanged.\n     */\n    onInvalidPropertyName: 'error'|'ignore';\n\n    /**\n     * If onInvalidPropertyValue is 'error' (default) then any illegal\n     * property value other than undefined causes an error and stops\n     * conversion.  If onInvalidPropertyValue is 'ignore' then any\n     * invalid property values are silently ignored.\n     */\n    onInvalidPropertyValue: 'error'|'ignore';\n\n    /**\n     * If onUnknownPropertyValue is error, then any property with\n     * value undefined will cause an error and stop conversion.  If\n     * onUndefinedPropertyValue is 'ignore' (default) then any\n     * property with value undefined is silently ignored.\n     */\n    onUndefinedPropertyValue: 'error'|'ignore';\n}\n\nexport interface JsonEditorOptions {\n    context?: JsonContext;\n    validation: JsonEditorValidationOptions;\n}\n\nexport class JsonEditorState {\n    protected static _nextId = 0;\n\n    public readonly editor: JsonEditor;\n\n    public readonly options: JsonEditorOptions;\n    protected readonly _deferred: JsonObject[] = [];\n    protected readonly _id: number;\n\n    public constructor(editor: JsonEditor, 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"]}
|
|
File without changes
|
|
@@ -49,7 +49,7 @@ class ConditionalJsonEditorRule extends jsonEditorRule_1.JsonEditorRuleBase {
|
|
|
49
49
|
* @param options Optional configuration options used for this rule
|
|
50
50
|
*/
|
|
51
51
|
static create(options) {
|
|
52
|
-
return ts_utils_1.captureResult(() => new ConditionalJsonEditorRule(options));
|
|
52
|
+
return (0, ts_utils_1.captureResult)(() => new ConditionalJsonEditorRule(options));
|
|
53
53
|
}
|
|
54
54
|
/**
|
|
55
55
|
* Evaluates a property for conditional application.
|
|
@@ -64,11 +64,11 @@ class ConditionalJsonEditorRule extends jsonEditorRule_1.JsonEditorRuleBase {
|
|
|
64
64
|
editProperty(key, value, state) {
|
|
65
65
|
var _a;
|
|
66
66
|
const result = this._tryParseCondition(key, state).onSuccess((deferred) => {
|
|
67
|
-
if (common_1.isJsonObject(value)) {
|
|
67
|
+
if ((0, common_1.isJsonObject)(value)) {
|
|
68
68
|
const rtrn = { ...deferred, value };
|
|
69
|
-
return ts_utils_1.succeedWithDetail(rtrn, 'deferred');
|
|
69
|
+
return (0, ts_utils_1.succeedWithDetail)(rtrn, 'deferred');
|
|
70
70
|
}
|
|
71
|
-
return ts_utils_1.failWithDetail(`${key}: conditional body must be object`, 'error');
|
|
71
|
+
return (0, ts_utils_1.failWithDetail)(`${key}: conditional body must be object`, 'error');
|
|
72
72
|
});
|
|
73
73
|
if (result.isFailure() && (result.detail === 'error')) {
|
|
74
74
|
return state.failValidation('invalidPropertyName', result.message, (_a = this._options) === null || _a === void 0 ? void 0 : _a.validation);
|
|
@@ -88,7 +88,7 @@ class ConditionalJsonEditorRule extends jsonEditorRule_1.JsonEditorRuleBase {
|
|
|
88
88
|
toMerge = finalized.filter((o) => (o.matchType === 'match') || (o.matchType === 'unconditional'));
|
|
89
89
|
}
|
|
90
90
|
}
|
|
91
|
-
return ts_utils_1.succeedWithDetail(toMerge.map((o) => o.value).filter(common_1.isJsonObject), 'edited');
|
|
91
|
+
return (0, ts_utils_1.succeedWithDetail)(toMerge.map((o) => o.value).filter(common_1.isJsonObject), 'edited');
|
|
92
92
|
}
|
|
93
93
|
/**
|
|
94
94
|
* Determines if a given property key is conditional. Derived classes can override this
|
|
@@ -106,28 +106,28 @@ class ConditionalJsonEditorRule extends jsonEditorRule_1.JsonEditorRuleBase {
|
|
|
106
106
|
// ignore everything after any #
|
|
107
107
|
key = key.split('#')[0].trim();
|
|
108
108
|
if (key === '?default') {
|
|
109
|
-
return ts_utils_1.succeedWithDetail({ matchType: 'default' }, 'deferred');
|
|
109
|
+
return (0, ts_utils_1.succeedWithDetail)({ matchType: 'default' }, 'deferred');
|
|
110
110
|
}
|
|
111
111
|
const parts = key.substring(1).split(/(=|>=|<=|>|<|!=)/);
|
|
112
112
|
if (parts.length === 3) {
|
|
113
113
|
if (!this._compare(parts[0].trim(), parts[2].trim(), parts[1])) {
|
|
114
|
-
return ts_utils_1.failWithDetail(`Condition ${key} does not match`, 'ignore');
|
|
114
|
+
return (0, ts_utils_1.failWithDetail)(`Condition ${key} does not match`, 'ignore');
|
|
115
115
|
}
|
|
116
|
-
return ts_utils_1.succeedWithDetail({ matchType: 'match' }, 'deferred');
|
|
116
|
+
return (0, ts_utils_1.succeedWithDetail)({ matchType: 'match' }, 'deferred');
|
|
117
117
|
}
|
|
118
118
|
else if (parts.length === 1) {
|
|
119
119
|
if (parts[0].trim().length === 0) {
|
|
120
|
-
return ts_utils_1.failWithDetail(`Condition ${key} does not match`, 'ignore');
|
|
120
|
+
return (0, ts_utils_1.failWithDetail)(`Condition ${key} does not match`, 'ignore');
|
|
121
121
|
}
|
|
122
|
-
return ts_utils_1.succeedWithDetail({ matchType: 'match' }, 'deferred');
|
|
122
|
+
return (0, ts_utils_1.succeedWithDetail)({ matchType: 'match' }, 'deferred');
|
|
123
123
|
}
|
|
124
124
|
const message = `Malformed condition token ${key}`;
|
|
125
125
|
return state.failValidation('invalidPropertyName', message, (_a = this._options) === null || _a === void 0 ? void 0 : _a.validation);
|
|
126
126
|
}
|
|
127
127
|
else if ((((_b = this._options) === null || _b === void 0 ? void 0 : _b.flattenUnconditionalValues) !== false) && key.startsWith('!')) {
|
|
128
|
-
return ts_utils_1.succeedWithDetail({ matchType: 'unconditional' }, 'deferred');
|
|
128
|
+
return (0, ts_utils_1.succeedWithDetail)({ matchType: 'unconditional' }, 'deferred');
|
|
129
129
|
}
|
|
130
|
-
return ts_utils_1.failWithDetail('inapplicable', 'inapplicable');
|
|
130
|
+
return (0, ts_utils_1.failWithDetail)('inapplicable', 'inapplicable');
|
|
131
131
|
}
|
|
132
132
|
_compare(left, right, operator) {
|
|
133
133
|
switch (operator) {
|
|
@@ -143,4 +143,4 @@ class ConditionalJsonEditorRule extends jsonEditorRule_1.JsonEditorRuleBase {
|
|
|
143
143
|
}
|
|
144
144
|
}
|
|
145
145
|
exports.ConditionalJsonEditorRule = ConditionalJsonEditorRule;
|
|
146
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"conditional.js","sourceRoot":"","sources":["../../../src/jsonEditor/rules/conditional.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 { DetailedResult, Result, captureResult, failWithDetail, succeedWithDetail } from '@fgv/ts-utils';\nimport { JsonEditFailureReason, JsonEditorRuleBase, JsonPropertyEditFailureReason } from '../jsonEditorRule';\nimport { JsonEditorOptions, JsonEditorState } from '../jsonEditorState';\nimport { JsonObject, JsonValue, isJsonObject } from '../../common';\n\n/**\n * Returned by the _tryMatch method of the @see ConditionalJsonEditorRule\n * to indicate whether a successful match was due to a matching condition\n * or a default value.\n */\nexport interface ConditionalJsonKeyResult extends JsonObject {\n    matchType: 'default'|'match'|'unconditional';\n}\n\n/**\n * On a successful match, the @see ConditionalJsonEditorRule stores a\n * ConditionalJsonDeferredObject describing the matching result, to\n * be resolved at finalization time.\n */\nexport interface ConditionalJsonDeferredObject extends ConditionalJsonKeyResult{\n    value: JsonValue;\n}\n\n/**\n * Configuration options for the Conditional JSON editor rule\n */\nexport interface ConditionalJsonRuleOptions extends Partial<JsonEditorOptions> {\n    /**\n     * If true (default) then properties with unconditional names\n     * (which start with !) are flattened.\n     */\n    flattenUnconditionalValues?: boolean;\n}\n\n/**\n * The Conditional JSON editor rule evaluates properties with conditional keys,\n * omitting non-matching keys and merging keys that match, or default keys only\n * if no other keys match.\n *\n * The default syntax for a conditional key is:\n *    \"?value1=value2\" - matches if value1 and value2 are the same, is ignored otherwise.\n *    \"?value\" - matches if value is a non-empty, non-whitespace string. Is ignored otherwise.\n *    \"?default\" - matches only if no other conditional blocks in the same object were matched\n */\nexport class ConditionalJsonEditorRule extends JsonEditorRuleBase {\n    protected _options?: ConditionalJsonRuleOptions;\n\n    /**\n     * Creates a new @see ConditionalJsonEditorRule\n     * @param options Optional configuration options used for this rule\n     */\n    public constructor(options?: ConditionalJsonRuleOptions) {\n        super();\n        this._options = options;\n    }\n\n    /**\n     * Creates a new @see ConditionalJsonEditorRule\n     * @param options Optional configuration options used for this rule\n     */\n    public static create(options?: ConditionalJsonRuleOptions): Result<ConditionalJsonEditorRule> {\n        return captureResult(() => new ConditionalJsonEditorRule(options));\n    }\n\n    /**\n     * Evaluates a property for conditional application.\n     * @param key The key of the property to be considered\n     * @param value The value of the property to be considered\n     * @param state The editor state for the object being edited\n     * @returns Returns Success with detail 'deferred' and a @see ConditionalJsonDeferredObject\n     * for a matching, default or unconditional key. Fails with detail 'ignore' for a\n     * non-matching conditional and with detail 'error' if an error occurs. Otherwise\n     * fails with detail 'inapplicable'.\n     */\n    public editProperty(key: string, value: JsonValue, state: JsonEditorState): DetailedResult<JsonObject, JsonPropertyEditFailureReason> {\n        const result = this._tryParseCondition(key, state).onSuccess((deferred) => {\n            if (isJsonObject(value)) {\n                const rtrn: ConditionalJsonDeferredObject = { ...deferred, value };\n                return succeedWithDetail(rtrn, 'deferred');\n            }\n            return failWithDetail<JsonObject, JsonPropertyEditFailureReason>(`${key}: conditional body must be object`, 'error');\n        });\n\n        if (result.isFailure() && (result.detail === 'error')) {\n            return state.failValidation('invalidPropertyName', result.message, this._options?.validation);\n        }\n\n        return result;\n    }\n\n    /**\n     * Finalizes any deferred conditional properties. If the only deferred property is\n     * default, that property is emitted. Otherwise all matching properties are emitted.\n     * @param finalized The deferred properties to be considered for merge\n     * @param _state The editor state for the object being edited\n     */\n    public finalizeProperties(finalized: JsonObject[], _state: JsonEditorState): DetailedResult<JsonObject[], JsonEditFailureReason> {\n        let toMerge = finalized;\n        if (finalized.length > 1) {\n            if (finalized.find((o) => o.matchType === 'match') !== undefined) {\n                toMerge = finalized.filter((o) => (o.matchType === 'match') || (o.matchType === 'unconditional'));\n            }\n        }\n        return succeedWithDetail(toMerge.map((o) => o.value).filter(isJsonObject), 'edited');\n    }\n\n    /**\n     * Determines if a given property key is conditional. Derived classes can override this\n     * method to use a different format for conditional properties.\n     * @param key The key of the property to consider.\n     * @param state The editor state of the object being edited.\n     * @returns Success with detail 'deferred' and a @see ConditionalJsonKeyResult describing the\n     * match for a default or matching conditional property.  Fails with detail 'ignore' for\n     * a non-matching conditional property. Fails with detail 'error' if an error occurs\n     * or with detail 'inapplicable' if the key does not represent a conditional property.\n     */\n    protected _tryParseCondition(key: string, state: JsonEditorState): DetailedResult<ConditionalJsonKeyResult, JsonPropertyEditFailureReason> {\n        if (key.startsWith('?')) {\n            // ignore everything after any #\n            key = key.split('#')[0].trim();\n\n            if (key === '?default') {\n                return succeedWithDetail({ matchType: 'default' }, 'deferred');\n            }\n\n            const parts = key.substring(1).split(/(=|>=|<=|>|<|!=)/);\n            if (parts.length === 3) {\n                if (!this._compare(parts[0].trim(), parts[2].trim(), parts[1])) {\n                    return failWithDetail(`Condition ${key} does not match`, 'ignore');\n                }\n                return succeedWithDetail({ matchType: 'match' }, 'deferred');\n            }\n            else if (parts.length === 1) {\n                if (parts[0].trim().length === 0) {\n                    return failWithDetail(`Condition ${key} does not match`, 'ignore');\n                }\n                return succeedWithDetail({ matchType: 'match' }, 'deferred');\n            }\n            const message = `Malformed condition token ${key}`;\n            return state.failValidation('invalidPropertyName', message, this._options?.validation);\n        }\n        else if ((this._options?.flattenUnconditionalValues !== false) && key.startsWith('!')) {\n            return succeedWithDetail({ matchType: 'unconditional' }, 'deferred');\n        }\n        return failWithDetail('inapplicable', 'inapplicable');\n    }\n\n    protected _compare(left: string, right: string, operator: string): boolean {\n        switch (operator) {\n            case '=': return left === right;\n            case '>': return left > right;\n            case '<': return left < right;\n            case '>=': return left >= right;\n            case '<=': return left <= right;\n            case '!=': return left !== right;\n        }\n        // istanbul ignore next: unreachable\n        return false;\n    }\n}\n"]}
|
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"conditional.js","sourceRoot":"","sources":["../../../src/jsonEditor/rules/conditional.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 { DetailedResult, Result, captureResult, failWithDetail, succeedWithDetail } from '@fgv/ts-utils';\nimport { JsonEditFailureReason, JsonEditorRuleBase, JsonPropertyEditFailureReason } from '../jsonEditorRule';\nimport { JsonEditorOptions, JsonEditorState } from '../jsonEditorState';\nimport { JsonObject, JsonValue, isJsonObject } from '../../common';\n\n/**\n * Returned by the _tryMatch method of the @see ConditionalJsonEditorRule\n * to indicate whether a successful match was due to a matching condition\n * or a default value.\n */\nexport interface ConditionalJsonKeyResult extends JsonObject {\n    matchType: 'default'|'match'|'unconditional';\n}\n\n/**\n * On a successful match, the @see ConditionalJsonEditorRule stores a\n * ConditionalJsonDeferredObject describing the matching result, to\n * be resolved at finalization time.\n */\nexport interface ConditionalJsonDeferredObject extends ConditionalJsonKeyResult{\n    value: JsonValue;\n}\n\n/**\n * Configuration options for the Conditional JSON editor rule\n */\nexport interface ConditionalJsonRuleOptions extends Partial<JsonEditorOptions> {\n    /**\n     * If true (default) then properties with unconditional names\n     * (which start with !) are flattened.\n     */\n    flattenUnconditionalValues?: boolean;\n}\n\n/**\n * The Conditional JSON editor rule evaluates properties with conditional keys,\n * omitting non-matching keys and merging keys that match, or default keys only\n * if no other keys match.\n *\n * The default syntax for a conditional key is:\n *    \"?value1=value2\" - matches if value1 and value2 are the same, is ignored otherwise.\n *    \"?value\" - matches if value is a non-empty, non-whitespace string. Is ignored otherwise.\n *    \"?default\" - matches only if no other conditional blocks in the same object were matched\n */\nexport class ConditionalJsonEditorRule extends JsonEditorRuleBase {\n    protected _options?: ConditionalJsonRuleOptions;\n\n    /**\n     * Creates a new @see ConditionalJsonEditorRule\n     * @param options Optional configuration options used for this rule\n     */\n    public constructor(options?: ConditionalJsonRuleOptions) {\n        super();\n        this._options = options;\n    }\n\n    /**\n     * Creates a new @see ConditionalJsonEditorRule\n     * @param options Optional configuration options used for this rule\n     */\n    public static create(options?: ConditionalJsonRuleOptions): Result<ConditionalJsonEditorRule> {\n        return captureResult(() => new ConditionalJsonEditorRule(options));\n    }\n\n    /**\n     * Evaluates a property for conditional application.\n     * @param key The key of the property to be considered\n     * @param value The value of the property to be considered\n     * @param state The editor state for the object being edited\n     * @returns Returns Success with detail 'deferred' and a @see ConditionalJsonDeferredObject\n     * for a matching, default or unconditional key. Fails with detail 'ignore' for a\n     * non-matching conditional and with detail 'error' if an error occurs. Otherwise\n     * fails with detail 'inapplicable'.\n     */\n    public editProperty(key: string, value: JsonValue, state: JsonEditorState): DetailedResult<JsonObject, JsonPropertyEditFailureReason> {\n        const result = this._tryParseCondition(key, state).onSuccess((deferred) => {\n            if (isJsonObject(value)) {\n                const rtrn: ConditionalJsonDeferredObject = { ...deferred, value };\n                return succeedWithDetail(rtrn, 'deferred');\n            }\n            return failWithDetail<JsonObject, JsonPropertyEditFailureReason>(`${key}: conditional body must be object`, 'error');\n        });\n\n        if (result.isFailure() && (result.detail === 'error')) {\n            return state.failValidation('invalidPropertyName', result.message, this._options?.validation);\n        }\n\n        return result;\n    }\n\n    /**\n     * Finalizes any deferred conditional properties. If the only deferred property is\n     * default, that property is emitted. Otherwise all matching properties are emitted.\n     * @param finalized The deferred properties to be considered for merge\n     * @param _state The editor state for the object being edited\n     */\n    public finalizeProperties(finalized: JsonObject[], _state: JsonEditorState): DetailedResult<JsonObject[], JsonEditFailureReason> {\n        let toMerge = finalized;\n        if (finalized.length > 1) {\n            if (finalized.find((o) => o.matchType === 'match') !== undefined) {\n                toMerge = finalized.filter((o) => (o.matchType === 'match') || (o.matchType === 'unconditional'));\n            }\n        }\n        return succeedWithDetail(toMerge.map((o) => o.value).filter(isJsonObject), 'edited');\n    }\n\n    /**\n     * Determines if a given property key is conditional. Derived classes can override this\n     * method to use a different format for conditional properties.\n     * @param key The key of the property to consider.\n     * @param state The editor state of the object being edited.\n     * @returns Success with detail 'deferred' and a @see ConditionalJsonKeyResult describing the\n     * match for a default or matching conditional property.  Fails with detail 'ignore' for\n     * a non-matching conditional property. Fails with detail 'error' if an error occurs\n     * or with detail 'inapplicable' if the key does not represent a conditional property.\n     */\n    protected _tryParseCondition(key: string, state: JsonEditorState): DetailedResult<ConditionalJsonKeyResult, JsonPropertyEditFailureReason> {\n        if (key.startsWith('?')) {\n            // ignore everything after any #\n            key = key.split('#')[0].trim();\n\n            if (key === '?default') {\n                return succeedWithDetail({ matchType: 'default' }, 'deferred');\n            }\n\n            const parts = key.substring(1).split(/(=|>=|<=|>|<|!=)/);\n            if (parts.length === 3) {\n                if (!this._compare(parts[0].trim(), parts[2].trim(), parts[1])) {\n                    return failWithDetail(`Condition ${key} does not match`, 'ignore');\n                }\n                return succeedWithDetail({ matchType: 'match' }, 'deferred');\n            }\n            else if (parts.length === 1) {\n                if (parts[0].trim().length === 0) {\n                    return failWithDetail(`Condition ${key} does not match`, 'ignore');\n                }\n                return succeedWithDetail({ matchType: 'match' }, 'deferred');\n            }\n            const message = `Malformed condition token ${key}`;\n            return state.failValidation('invalidPropertyName', message, this._options?.validation);\n        }\n        else if ((this._options?.flattenUnconditionalValues !== false) && key.startsWith('!')) {\n            return succeedWithDetail({ matchType: 'unconditional' }, 'deferred');\n        }\n        return failWithDetail('inapplicable', 'inapplicable');\n    }\n\n    protected _compare(left: string, right: string, operator: string): boolean {\n        switch (operator) {\n            case '=': return left === right;\n            case '>': return left > right;\n            case '<': return left < right;\n            case '>=': return left >= right;\n            case '<=': return left <= right;\n            case '!=': return left !== right;\n        }\n        // istanbul ignore next: unreachable\n        return false;\n    }\n}\n"]}
|
|
File without changes
|
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -14,4 +18,4 @@ __exportStar(require("./conditional"), exports);
|
|
|
14
18
|
__exportStar(require("./multivalue"), exports);
|
|
15
19
|
__exportStar(require("./references"), exports);
|
|
16
20
|
__exportStar(require("./templates"), exports);
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvanNvbkVkaXRvci9ydWxlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsZ0RBQThCO0FBQzlCLCtDQUE2QjtBQUM3QiwrQ0FBNkI7QUFDN0IsOENBQTRCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jb25kaXRpb25hbCc7XG5leHBvcnQgKiBmcm9tICcuL211bHRpdmFsdWUnO1xuZXhwb3J0ICogZnJvbSAnLi9yZWZlcmVuY2VzJztcbmV4cG9ydCAqIGZyb20gJy4vdGVtcGxhdGVzJztcbiJdfQ==
|
|
File without changes
|
|
@@ -49,7 +49,7 @@ class MultiValueJsonEditorRule extends jsonEditorRule_1.JsonEditorRuleBase {
|
|
|
49
49
|
* @param options Optional configuration options
|
|
50
50
|
*/
|
|
51
51
|
static create(options) {
|
|
52
|
-
return ts_utils_1.captureResult(() => new MultiValueJsonEditorRule(options));
|
|
52
|
+
return (0, ts_utils_1.captureResult)(() => new MultiValueJsonEditorRule(options));
|
|
53
53
|
}
|
|
54
54
|
/**
|
|
55
55
|
* Evaluates a property for multi-value expansion.
|
|
@@ -64,20 +64,20 @@ class MultiValueJsonEditorRule extends jsonEditorRule_1.JsonEditorRuleBase {
|
|
|
64
64
|
editProperty(key, value, state) {
|
|
65
65
|
const json = {};
|
|
66
66
|
const result = this._tryParse(key, state).onSuccess((parts) => {
|
|
67
|
-
return ts_utils_1.allSucceed(parts.propertyValues.map((pv) => {
|
|
67
|
+
return (0, ts_utils_1.allSucceed)(parts.propertyValues.map((pv) => {
|
|
68
68
|
return this._deriveContext(state, [parts.propertyVariable, pv]).onSuccess((ctx) => {
|
|
69
69
|
return state.editor.clone(value, ctx).onSuccess((cloned) => {
|
|
70
70
|
json[pv] = cloned;
|
|
71
|
-
return ts_utils_1.succeedWithDetail(cloned);
|
|
71
|
+
return (0, ts_utils_1.succeedWithDetail)(cloned);
|
|
72
72
|
});
|
|
73
73
|
});
|
|
74
74
|
}), json).onSuccess(() => {
|
|
75
75
|
if (parts.asArray) {
|
|
76
76
|
const arrayRtrn = {};
|
|
77
77
|
arrayRtrn[parts.propertyVariable] = Array.from(Object.values(json));
|
|
78
|
-
return ts_utils_1.succeed(arrayRtrn);
|
|
78
|
+
return (0, ts_utils_1.succeed)(arrayRtrn);
|
|
79
79
|
}
|
|
80
|
-
return ts_utils_1.succeed(json);
|
|
80
|
+
return (0, ts_utils_1.succeed)(json);
|
|
81
81
|
}).withFailureDetail('error');
|
|
82
82
|
});
|
|
83
83
|
if (result.isFailure() && (result.detail === 'error')) {
|
|
@@ -111,19 +111,19 @@ class MultiValueJsonEditorRule extends jsonEditorRule_1.JsonEditorRuleBase {
|
|
|
111
111
|
asArray = false;
|
|
112
112
|
}
|
|
113
113
|
else {
|
|
114
|
-
return ts_utils_1.failWithDetail(token, 'inapplicable');
|
|
114
|
+
return (0, ts_utils_1.failWithDetail)(token, 'inapplicable');
|
|
115
115
|
}
|
|
116
116
|
if (parts.length !== 2) {
|
|
117
117
|
const message = `Malformed multi-value property: ${token}`;
|
|
118
118
|
return state.failValidation('invalidPropertyName', message, (_a = this._options) === null || _a === void 0 ? void 0 : _a.validation);
|
|
119
119
|
}
|
|
120
120
|
if (parts[1].includes('{{')) {
|
|
121
|
-
return ts_utils_1.failWithDetail('unresolved template', 'inapplicable');
|
|
121
|
+
return (0, ts_utils_1.failWithDetail)('unresolved template', 'inapplicable');
|
|
122
122
|
}
|
|
123
123
|
const propertyVariable = parts[0];
|
|
124
124
|
const propertyValues = parts[1].split(',');
|
|
125
|
-
return ts_utils_1.succeedWithDetail({ token, propertyVariable, propertyValues, asArray });
|
|
125
|
+
return (0, ts_utils_1.succeedWithDetail)({ token, propertyVariable, propertyValues, asArray });
|
|
126
126
|
}
|
|
127
127
|
}
|
|
128
128
|
exports.MultiValueJsonEditorRule = MultiValueJsonEditorRule;
|
|
129
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multivalue.js","sourceRoot":"","sources":["../../../src/jsonEditor/rules/multivalue.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 { DetailedResult, Result, allSucceed, captureResult, failWithDetail, succeed, succeedWithDetail } from '@fgv/ts-utils';\nimport { JsonContext, VariableValue } from '../../jsonContext';\nimport { JsonEditFailureReason, JsonEditorRuleBase, JsonPropertyEditFailureReason } from '../jsonEditorRule';\nimport { JsonEditorOptions, JsonEditorState } from '../jsonEditorState';\nimport { JsonObject, JsonValue } from '../../common';\n\n/**\n * Represents the parts of a multi-value property key.\n */\nexport interface MultiValuePropertyParts {\n    /**\n     * The original matched token\n     */\n    readonly token: string;\n\n    /**\n     * The name of the variable used to project each possible\n     * property value into the child values or objects being\n     * resolved.\n     */\n    readonly propertyVariable: string;\n\n    /**\n     * The set of property values to be expanded\n     */\n    readonly propertyValues: string[];\n\n    /**\n     * If true, the resolved values are added as an array\n     * with the name of the propertyVariable. If false,\n     * values are added as individual properties with names\n     * that correspond the value.\n     */\n    readonly asArray: boolean;\n}\n\n/**\n * The Multi-Value JSON editor rule expands matching keys multiple\n * times, projecting the value into the template context for any\n * child objects rendered by the rule.\n *\n * The default syntax for a multi-value key is:\n *  \"[[var]]=value1,value2,value3\"\n * Where \"var\" is the name of the variable that will be passed to\n * child template resolution, and \"value1,value2,value3\" is a\n * comma-separated list of values to be expanded.\n */\nexport class MultiValueJsonEditorRule extends JsonEditorRuleBase {\n    protected _options?: JsonEditorOptions;\n\n    /**\n     * Creates a new MultiValueJsonEditorRule.\n     * @param options Optional configuration options\n     */\n    public constructor(options?: JsonEditorOptions) {\n        super();\n        this._options = options;\n    }\n\n    /**\n     * Creates a new MultiValueJsonEditorRule.\n     * @param options Optional configuration options\n     */\n    public static create(options?: JsonEditorOptions): Result<MultiValueJsonEditorRule> {\n        return captureResult(() => new MultiValueJsonEditorRule(options));\n    }\n\n    /**\n     * Evaluates a property for multi-value expansion.\n     * @param key The key of the property to be considered\n     * @param value The value of the property to be considered\n     * @param state The editor state for the object being edited\n     * @returns Returns Success with an object containing the fully-resolved child\n     * values to be merged for matching multi-value property. Fails with\n     * detail 'error' if an error occurs or with detail 'inapplicable' if\n     * the property key is not a conditional property.\n     */\n    public editProperty(key: string, value: JsonValue, state: JsonEditorState): DetailedResult<JsonObject, JsonPropertyEditFailureReason> {\n        const json: JsonObject = {};\n        const result = this._tryParse(key, state).onSuccess((parts) => {\n            return allSucceed(parts.propertyValues.map((pv) => {\n                return this._deriveContext(state, [parts.propertyVariable, pv]).onSuccess((ctx) => {\n                    return state.editor.clone(value, ctx).onSuccess((cloned) => {\n                        json[pv] = cloned;\n                        return succeedWithDetail(cloned);\n                    });\n                });\n            }), json).onSuccess(() => {\n                if (parts.asArray) {\n                    const arrayRtrn: JsonObject = {};\n                    arrayRtrn[parts.propertyVariable] = Array.from(Object.values(json));\n                    return succeed(arrayRtrn);\n                }\n                return succeed(json);\n            }).withFailureDetail('error');\n        });\n\n        if (result.isFailure() && (result.detail === 'error')) {\n            return state.failValidation('invalidPropertyName', result.message);\n        }\n        return result;\n    }\n\n    protected _deriveContext(state: JsonEditorState, ...values: VariableValue[]): Result<JsonContext|undefined> {\n        return state.extendContext(this._options?.context, { vars: values });\n    }\n\n    /**\n     * Determines if a given property key is multi-value. Derived classes can override this\n     * method to use a different format for multi-value properties.\n     * @param key The key of the property to consider.\n     * @param state The editor state of the object being edited.\n     * @returns Success with detail 'deferred' and a @see MultiValuePropertyParts describing the\n     * match for matching multi-value property.  Fails with detail 'error' if an error occurs\n     * or with detail 'inapplicable' if the key does not represent a multi-value property.\n     */\n    protected _tryParse(token: string, state: JsonEditorState): DetailedResult<MultiValuePropertyParts, JsonEditFailureReason> {\n        let parts: string[] = [];\n        let asArray = false;\n\n        if (token.startsWith('[[')) {\n            parts = token.substring(2).split(']]=');\n            asArray = true;\n        }\n        else if (token.startsWith('*')) {\n            parts = token.substring(1).split('=');\n            asArray = false;\n        }\n        else {\n            return failWithDetail(token, 'inapplicable');\n        }\n\n        if (parts.length !== 2) {\n            const message = `Malformed multi-value property: ${token}`;\n            return state.failValidation('invalidPropertyName', message, this._options?.validation);\n        }\n\n        if (parts[1].includes('{{')) {\n            return failWithDetail('unresolved template', 'inapplicable');\n        }\n\n        const propertyVariable = parts[0];\n        const propertyValues = parts[1].split(',');\n        return succeedWithDetail({ token, propertyVariable, propertyValues, asArray });\n    }\n}\n"]}
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multivalue.js","sourceRoot":"","sources":["../../../src/jsonEditor/rules/multivalue.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 { DetailedResult, Result, allSucceed, captureResult, failWithDetail, succeed, succeedWithDetail } from '@fgv/ts-utils';\nimport { JsonContext, VariableValue } from '../../jsonContext';\nimport { JsonEditFailureReason, JsonEditorRuleBase, JsonPropertyEditFailureReason } from '../jsonEditorRule';\nimport { JsonEditorOptions, JsonEditorState } from '../jsonEditorState';\nimport { JsonObject, JsonValue } from '../../common';\n\n/**\n * Represents the parts of a multi-value property key.\n */\nexport interface MultiValuePropertyParts {\n    /**\n     * The original matched token\n     */\n    readonly token: string;\n\n    /**\n     * The name of the variable used to project each possible\n     * property value into the child values or objects being\n     * resolved.\n     */\n    readonly propertyVariable: string;\n\n    /**\n     * The set of property values to be expanded\n     */\n    readonly propertyValues: string[];\n\n    /**\n     * If true, the resolved values are added as an array\n     * with the name of the propertyVariable. If false,\n     * values are added as individual properties with names\n     * that correspond the value.\n     */\n    readonly asArray: boolean;\n}\n\n/**\n * The Multi-Value JSON editor rule expands matching keys multiple\n * times, projecting the value into the template context for any\n * child objects rendered by the rule.\n *\n * The default syntax for a multi-value key is:\n *  \"[[var]]=value1,value2,value3\"\n * Where \"var\" is the name of the variable that will be passed to\n * child template resolution, and \"value1,value2,value3\" is a\n * comma-separated list of values to be expanded.\n */\nexport class MultiValueJsonEditorRule extends JsonEditorRuleBase {\n    protected _options?: JsonEditorOptions;\n\n    /**\n     * Creates a new MultiValueJsonEditorRule.\n     * @param options Optional configuration options\n     */\n    public constructor(options?: JsonEditorOptions) {\n        super();\n        this._options = options;\n    }\n\n    /**\n     * Creates a new MultiValueJsonEditorRule.\n     * @param options Optional configuration options\n     */\n    public static create(options?: JsonEditorOptions): Result<MultiValueJsonEditorRule> {\n        return captureResult(() => new MultiValueJsonEditorRule(options));\n    }\n\n    /**\n     * Evaluates a property for multi-value expansion.\n     * @param key The key of the property to be considered\n     * @param value The value of the property to be considered\n     * @param state The editor state for the object being edited\n     * @returns Returns Success with an object containing the fully-resolved child\n     * values to be merged for matching multi-value property. Fails with\n     * detail 'error' if an error occurs or with detail 'inapplicable' if\n     * the property key is not a conditional property.\n     */\n    public editProperty(key: string, value: JsonValue, state: JsonEditorState): DetailedResult<JsonObject, JsonPropertyEditFailureReason> {\n        const json: JsonObject = {};\n        const result = this._tryParse(key, state).onSuccess((parts) => {\n            return allSucceed(parts.propertyValues.map((pv) => {\n                return this._deriveContext(state, [parts.propertyVariable, pv]).onSuccess((ctx) => {\n                    return state.editor.clone(value, ctx).onSuccess((cloned) => {\n                        json[pv] = cloned;\n                        return succeedWithDetail(cloned);\n                    });\n                });\n            }), json).onSuccess(() => {\n                if (parts.asArray) {\n                    const arrayRtrn: JsonObject = {};\n                    arrayRtrn[parts.propertyVariable] = Array.from(Object.values(json));\n                    return succeed(arrayRtrn);\n                }\n                return succeed(json);\n            }).withFailureDetail('error');\n        });\n\n        if (result.isFailure() && (result.detail === 'error')) {\n            return state.failValidation('invalidPropertyName', result.message);\n        }\n        return result;\n    }\n\n    protected _deriveContext(state: JsonEditorState, ...values: VariableValue[]): Result<JsonContext|undefined> {\n        return state.extendContext(this._options?.context, { vars: values });\n    }\n\n    /**\n     * Determines if a given property key is multi-value. Derived classes can override this\n     * method to use a different format for multi-value properties.\n     * @param key The key of the property to consider.\n     * @param state The editor state of the object being edited.\n     * @returns Success with detail 'deferred' and a @see MultiValuePropertyParts describing the\n     * match for matching multi-value property.  Fails with detail 'error' if an error occurs\n     * or with detail 'inapplicable' if the key does not represent a multi-value property.\n     */\n    protected _tryParse(token: string, state: JsonEditorState): DetailedResult<MultiValuePropertyParts, JsonEditFailureReason> {\n        let parts: string[] = [];\n        let asArray = false;\n\n        if (token.startsWith('[[')) {\n            parts = token.substring(2).split(']]=');\n            asArray = true;\n        }\n        else if (token.startsWith('*')) {\n            parts = token.substring(1).split('=');\n            asArray = false;\n        }\n        else {\n            return failWithDetail(token, 'inapplicable');\n        }\n\n        if (parts.length !== 2) {\n            const message = `Malformed multi-value property: ${token}`;\n            return state.failValidation('invalidPropertyName', message, this._options?.validation);\n        }\n\n        if (parts[1].includes('{{')) {\n            return failWithDetail('unresolved template', 'inapplicable');\n        }\n\n        const propertyVariable = parts[0];\n        const propertyValues = parts[1].split(',');\n        return succeedWithDetail({ token, propertyVariable, propertyValues, asArray });\n    }\n}\n"]}
|
|
File without changes
|