@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.
Files changed (127) hide show
  1. package/dist/ts-json.d.ts +1826 -0
  2. package/dist/tsdoc-metadata.json +11 -0
  3. package/lib/index.d.ts +5 -0
  4. package/lib/index.d.ts.map +1 -0
  5. package/lib/index.js +42 -0
  6. package/lib/index.js.map +1 -0
  7. package/lib/packlets/context/compositeJsonMap.d.ts +60 -0
  8. package/lib/packlets/context/compositeJsonMap.d.ts.map +1 -0
  9. package/lib/packlets/context/compositeJsonMap.js +105 -0
  10. package/lib/packlets/context/compositeJsonMap.js.map +1 -0
  11. package/lib/packlets/context/contextHelpers.d.ts +116 -0
  12. package/lib/packlets/context/contextHelpers.d.ts.map +1 -0
  13. package/lib/packlets/context/contextHelpers.js +191 -0
  14. package/lib/packlets/context/contextHelpers.js.map +1 -0
  15. package/lib/packlets/context/index.d.ts +4 -0
  16. package/lib/packlets/context/index.d.ts.map +1 -0
  17. package/lib/packlets/context/index.js +31 -0
  18. package/lib/packlets/context/index.js.map +1 -0
  19. package/lib/packlets/context/jsonContext.d.ts +84 -0
  20. package/lib/packlets/context/jsonContext.d.ts.map +1 -0
  21. package/lib/packlets/context/jsonContext.js +41 -0
  22. package/lib/packlets/context/jsonContext.js.map +1 -0
  23. package/lib/packlets/converters/converters.d.ts +54 -0
  24. package/lib/packlets/converters/converters.d.ts.map +1 -0
  25. package/lib/packlets/converters/converters.js +105 -0
  26. package/lib/packlets/converters/converters.js.map +1 -0
  27. package/lib/packlets/converters/file.d.ts +83 -0
  28. package/lib/packlets/converters/file.d.ts.map +1 -0
  29. package/lib/packlets/converters/file.js +162 -0
  30. package/lib/packlets/converters/file.js.map +1 -0
  31. package/lib/packlets/converters/index.d.ts +5 -0
  32. package/lib/packlets/converters/index.d.ts.map +1 -0
  33. package/lib/packlets/converters/index.js +56 -0
  34. package/lib/packlets/converters/index.js.map +1 -0
  35. package/lib/packlets/converters/jsonConverter.d.ts +276 -0
  36. package/lib/packlets/converters/jsonConverter.d.ts.map +1 -0
  37. package/lib/packlets/converters/jsonConverter.js +310 -0
  38. package/lib/packlets/converters/jsonConverter.js.map +1 -0
  39. package/lib/packlets/editor/common.d.ts +67 -0
  40. package/lib/packlets/editor/common.d.ts.map +1 -0
  41. package/lib/packlets/editor/common.js +3 -0
  42. package/lib/packlets/editor/common.js.map +1 -0
  43. package/lib/packlets/editor/index.d.ts +8 -0
  44. package/lib/packlets/editor/index.d.ts.map +1 -0
  45. package/{jsonEditor → lib/packlets/editor}/index.js +15 -9
  46. package/lib/packlets/editor/index.js.map +1 -0
  47. package/lib/packlets/editor/jsonEditor.d.ts +155 -0
  48. package/lib/packlets/editor/jsonEditor.d.ts.map +1 -0
  49. package/lib/packlets/editor/jsonEditor.js +332 -0
  50. package/lib/packlets/editor/jsonEditor.js.map +1 -0
  51. package/lib/packlets/editor/jsonEditorRule.d.ts +64 -0
  52. package/lib/packlets/editor/jsonEditorRule.d.ts.map +1 -0
  53. package/lib/packlets/editor/jsonEditorRule.js +54 -0
  54. package/lib/packlets/editor/jsonEditorRule.js.map +1 -0
  55. package/lib/packlets/editor/jsonEditorState.d.ts +125 -0
  56. package/lib/packlets/editor/jsonEditorState.d.ts.map +1 -0
  57. package/lib/packlets/editor/jsonEditorState.js +177 -0
  58. package/lib/packlets/editor/jsonEditorState.js.map +1 -0
  59. package/lib/packlets/editor/jsonReferenceMap.d.ts +303 -0
  60. package/lib/packlets/editor/jsonReferenceMap.d.ts.map +1 -0
  61. package/lib/packlets/editor/jsonReferenceMap.js +324 -0
  62. package/lib/packlets/editor/jsonReferenceMap.js.map +1 -0
  63. package/lib/packlets/editor/rules/conditional.d.ts +107 -0
  64. package/lib/packlets/editor/rules/conditional.d.ts.map +1 -0
  65. package/lib/packlets/editor/rules/conditional.js +167 -0
  66. package/lib/packlets/editor/rules/conditional.js.map +1 -0
  67. package/{jsonEditor → lib/packlets/editor}/rules/index.d.ts +1 -0
  68. package/lib/packlets/editor/rules/index.d.ts.map +1 -0
  69. package/lib/packlets/editor/rules/index.js +42 -0
  70. package/lib/packlets/editor/rules/index.js.map +1 -0
  71. package/lib/packlets/editor/rules/multivalue.d.ts +94 -0
  72. package/lib/packlets/editor/rules/multivalue.d.ts.map +1 -0
  73. package/lib/packlets/editor/rules/multivalue.js +141 -0
  74. package/lib/packlets/editor/rules/multivalue.js.map +1 -0
  75. package/lib/packlets/editor/rules/references.d.ts +69 -0
  76. package/lib/packlets/editor/rules/references.d.ts.map +1 -0
  77. package/lib/packlets/editor/rules/references.js +159 -0
  78. package/lib/packlets/editor/rules/references.js.map +1 -0
  79. package/lib/packlets/editor/rules/templates.d.ts +74 -0
  80. package/lib/packlets/editor/rules/templates.d.ts.map +1 -0
  81. package/lib/packlets/editor/rules/templates.js +127 -0
  82. package/lib/packlets/editor/rules/templates.js.map +1 -0
  83. package/lib/packlets/json/common.d.ts +85 -0
  84. package/lib/packlets/json/common.d.ts.map +1 -0
  85. package/lib/packlets/json/common.js +123 -0
  86. package/lib/packlets/json/common.js.map +1 -0
  87. package/lib/packlets/json/index.d.ts +2 -0
  88. package/lib/packlets/json/index.d.ts.map +1 -0
  89. package/lib/packlets/json/index.js +39 -0
  90. package/lib/packlets/json/index.js.map +1 -0
  91. package/package.json +58 -49
  92. package/common.d.ts +0 -58
  93. package/common.js +0 -116
  94. package/compositeJsonMap.d.ts +0 -47
  95. package/compositeJsonMap.js +0 -97
  96. package/contextHelpers.d.ts +0 -21
  97. package/contextHelpers.js +0 -101
  98. package/converters.d.ts +0 -37
  99. package/converters.js +0 -92
  100. package/file.d.ts +0 -60
  101. package/file.js +0 -140
  102. package/index.d.ts +0 -10
  103. package/index.js +0 -62
  104. package/jsonContext.d.ts +0 -74
  105. package/jsonContext.js +0 -40
  106. package/jsonConverter.d.ts +0 -229
  107. package/jsonConverter.js +0 -292
  108. package/jsonEditor/common.d.ts +0 -36
  109. package/jsonEditor/common.js +0 -3
  110. package/jsonEditor/index.d.ts +0 -5
  111. package/jsonEditor/jsonEditor.d.ts +0 -74
  112. package/jsonEditor/jsonEditor.js +0 -259
  113. package/jsonEditor/jsonEditorRule.d.ts +0 -47
  114. package/jsonEditor/jsonEditorRule.js +0 -44
  115. package/jsonEditor/jsonEditorState.d.ts +0 -24
  116. package/jsonEditor/jsonEditorState.js +0 -86
  117. package/jsonEditor/rules/conditional.d.ts +0 -84
  118. package/jsonEditor/rules/conditional.js +0 -146
  119. package/jsonEditor/rules/index.js +0 -21
  120. package/jsonEditor/rules/multivalue.d.ts +0 -78
  121. package/jsonEditor/rules/multivalue.js +0 -129
  122. package/jsonEditor/rules/references.d.ts +0 -62
  123. package/jsonEditor/rules/references.js +0 -158
  124. package/jsonEditor/rules/templates.d.ts +0 -56
  125. package/jsonEditor/rules/templates.js +0 -115
  126. package/jsonReferenceMap.d.ts +0 -138
  127. package/jsonReferenceMap.js +0 -202
@@ -1,146 +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.ConditionalJsonEditorRule = void 0;
25
- const ts_utils_1 = require("@fgv/ts-utils");
26
- const common_1 = require("../../common");
27
- const jsonEditorRule_1 = require("../jsonEditorRule");
28
- /**
29
- * The Conditional JSON editor rule evaluates properties with conditional keys,
30
- * omitting non-matching keys and merging keys that match, or default keys only
31
- * if no other keys match.
32
- *
33
- * The default syntax for a conditional key is:
34
- * "?value1=value2" - matches if value1 and value2 are the same, is ignored otherwise.
35
- * "?value" - matches if value is a non-empty, non-whitespace string. Is ignored otherwise.
36
- * "?default" - matches only if no other conditional blocks in the same object were matched
37
- */
38
- class ConditionalJsonEditorRule extends jsonEditorRule_1.JsonEditorRuleBase {
39
- /**
40
- * Creates a new @see ConditionalJsonEditorRule
41
- * @param options Optional configuration options used for this rule
42
- */
43
- constructor(options) {
44
- super();
45
- this._options = options;
46
- }
47
- /**
48
- * Creates a new @see ConditionalJsonEditorRule
49
- * @param options Optional configuration options used for this rule
50
- */
51
- static create(options) {
52
- return (0, ts_utils_1.captureResult)(() => new ConditionalJsonEditorRule(options));
53
- }
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, value, state) {
65
- var _a;
66
- const result = this._tryParseCondition(key, state).onSuccess((deferred) => {
67
- if ((0, common_1.isJsonObject)(value)) {
68
- const rtrn = { ...deferred, value };
69
- return (0, ts_utils_1.succeedWithDetail)(rtrn, 'deferred');
70
- }
71
- return (0, ts_utils_1.failWithDetail)(`${key}: conditional body must be object`, 'error');
72
- });
73
- if (result.isFailure() && (result.detail === 'error')) {
74
- return state.failValidation('invalidPropertyName', result.message, (_a = this._options) === null || _a === void 0 ? void 0 : _a.validation);
75
- }
76
- return result;
77
- }
78
- /**
79
- * Finalizes any deferred conditional properties. If the only deferred property is
80
- * default, that property is emitted. Otherwise all matching properties are emitted.
81
- * @param finalized The deferred properties to be considered for merge
82
- * @param _state The editor state for the object being edited
83
- */
84
- finalizeProperties(finalized, _state) {
85
- let toMerge = finalized;
86
- if (finalized.length > 1) {
87
- if (finalized.find((o) => o.matchType === 'match') !== undefined) {
88
- toMerge = finalized.filter((o) => (o.matchType === 'match') || (o.matchType === 'unconditional'));
89
- }
90
- }
91
- return (0, ts_utils_1.succeedWithDetail)(toMerge.map((o) => o.value).filter(common_1.isJsonObject), 'edited');
92
- }
93
- /**
94
- * Determines if a given property key is conditional. Derived classes can override this
95
- * method to use a different format for conditional properties.
96
- * @param key The key of the property to consider.
97
- * @param state The editor state of the object being edited.
98
- * @returns Success with detail 'deferred' and a @see ConditionalJsonKeyResult describing the
99
- * match for a default or matching conditional property. Fails with detail 'ignore' for
100
- * a non-matching conditional property. Fails with detail 'error' if an error occurs
101
- * or with detail 'inapplicable' if the key does not represent a conditional property.
102
- */
103
- _tryParseCondition(key, state) {
104
- var _a, _b;
105
- if (key.startsWith('?')) {
106
- // ignore everything after any #
107
- key = key.split('#')[0].trim();
108
- if (key === '?default') {
109
- return (0, ts_utils_1.succeedWithDetail)({ matchType: 'default' }, 'deferred');
110
- }
111
- const parts = key.substring(1).split(/(=|>=|<=|>|<|!=)/);
112
- if (parts.length === 3) {
113
- if (!this._compare(parts[0].trim(), parts[2].trim(), parts[1])) {
114
- return (0, ts_utils_1.failWithDetail)(`Condition ${key} does not match`, 'ignore');
115
- }
116
- return (0, ts_utils_1.succeedWithDetail)({ matchType: 'match' }, 'deferred');
117
- }
118
- else if (parts.length === 1) {
119
- if (parts[0].trim().length === 0) {
120
- return (0, ts_utils_1.failWithDetail)(`Condition ${key} does not match`, 'ignore');
121
- }
122
- return (0, ts_utils_1.succeedWithDetail)({ matchType: 'match' }, 'deferred');
123
- }
124
- const message = `Malformed condition token ${key}`;
125
- return state.failValidation('invalidPropertyName', message, (_a = this._options) === null || _a === void 0 ? void 0 : _a.validation);
126
- }
127
- else if ((((_b = this._options) === null || _b === void 0 ? void 0 : _b.flattenUnconditionalValues) !== false) && key.startsWith('!')) {
128
- return (0, ts_utils_1.succeedWithDetail)({ matchType: 'unconditional' }, 'deferred');
129
- }
130
- return (0, ts_utils_1.failWithDetail)('inapplicable', 'inapplicable');
131
- }
132
- _compare(left, right, operator) {
133
- switch (operator) {
134
- case '=': return left === right;
135
- case '>': return left > right;
136
- case '<': return left < right;
137
- case '>=': return left >= right;
138
- case '<=': return left <= right;
139
- case '!=': return left !== right;
140
- }
141
- // istanbul ignore next: unreachable
142
- return false;
143
- }
144
- }
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, JsonEditorOptions, JsonPropertyEditFailureReason } from '../common';\nimport { JsonObject, JsonValue, isJsonObject } from '../../common';\nimport { JsonEditorRuleBase } from '../jsonEditorRule';\nimport { JsonEditorState } from '../jsonEditorState';\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"]}
@@ -1,21 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
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);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./conditional"), exports);
18
- __exportStar(require("./multivalue"), exports);
19
- __exportStar(require("./references"), exports);
20
- __exportStar(require("./templates"), exports);
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvanNvbkVkaXRvci9ydWxlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsZ0RBQThCO0FBQzlCLCtDQUE2QjtBQUM3QiwrQ0FBNkI7QUFDN0IsOENBQTRCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jb25kaXRpb25hbCc7XG5leHBvcnQgKiBmcm9tICcuL211bHRpdmFsdWUnO1xuZXhwb3J0ICogZnJvbSAnLi9yZWZlcmVuY2VzJztcbmV4cG9ydCAqIGZyb20gJy4vdGVtcGxhdGVzJztcbiJdfQ==
@@ -1,78 +0,0 @@
1
- import { DetailedResult, Result } from '@fgv/ts-utils';
2
- import { JsonContext, VariableValue } from '../../jsonContext';
3
- import { JsonEditFailureReason, JsonEditorOptions, JsonPropertyEditFailureReason } from '../common';
4
- import { JsonObject, JsonValue } from '../../common';
5
- import { JsonEditorRuleBase } from '../jsonEditorRule';
6
- import { JsonEditorState } from '../jsonEditorState';
7
- /**
8
- * Represents the parts of a multi-value property key.
9
- */
10
- export interface MultiValuePropertyParts {
11
- /**
12
- * The original matched token
13
- */
14
- readonly token: string;
15
- /**
16
- * The name of the variable used to project each possible
17
- * property value into the child values or objects being
18
- * resolved.
19
- */
20
- readonly propertyVariable: string;
21
- /**
22
- * The set of property values to be expanded
23
- */
24
- readonly propertyValues: string[];
25
- /**
26
- * If true, the resolved values are added as an array
27
- * with the name of the propertyVariable. If false,
28
- * values are added as individual properties with names
29
- * that correspond the value.
30
- */
31
- readonly asArray: boolean;
32
- }
33
- /**
34
- * The Multi-Value JSON editor rule expands matching keys multiple
35
- * times, projecting the value into the template context for any
36
- * child objects rendered by the rule.
37
- *
38
- * The default syntax for a multi-value key is:
39
- * "[[var]]=value1,value2,value3"
40
- * Where "var" is the name of the variable that will be passed to
41
- * child template resolution, and "value1,value2,value3" is a
42
- * comma-separated list of values to be expanded.
43
- */
44
- export declare class MultiValueJsonEditorRule extends JsonEditorRuleBase {
45
- protected _options?: JsonEditorOptions;
46
- /**
47
- * Creates a new MultiValueJsonEditorRule.
48
- * @param options Optional configuration options
49
- */
50
- constructor(options?: JsonEditorOptions);
51
- /**
52
- * Creates a new MultiValueJsonEditorRule.
53
- * @param options Optional configuration options
54
- */
55
- static create(options?: JsonEditorOptions): Result<MultiValueJsonEditorRule>;
56
- /**
57
- * Evaluates a property for multi-value expansion.
58
- * @param key The key of the property to be considered
59
- * @param value The value of the property to be considered
60
- * @param state The editor state for the object being edited
61
- * @returns Returns Success with an object containing the fully-resolved child
62
- * values to be merged for matching multi-value property. Fails with
63
- * detail 'error' if an error occurs or with detail 'inapplicable' if
64
- * the property key is not a conditional property.
65
- */
66
- editProperty(key: string, value: JsonValue, state: JsonEditorState): DetailedResult<JsonObject, JsonPropertyEditFailureReason>;
67
- protected _deriveContext(state: JsonEditorState, ...values: VariableValue[]): Result<JsonContext | undefined>;
68
- /**
69
- * Determines if a given property key is multi-value. Derived classes can override this
70
- * method to use a different format for multi-value properties.
71
- * @param key The key of the property to consider.
72
- * @param state The editor state of the object being edited.
73
- * @returns Success with detail 'deferred' and a @see MultiValuePropertyParts describing the
74
- * match for matching multi-value property. Fails with detail 'error' if an error occurs
75
- * or with detail 'inapplicable' if the key does not represent a multi-value property.
76
- */
77
- protected _tryParse(token: string, state: JsonEditorState): DetailedResult<MultiValuePropertyParts, JsonEditFailureReason>;
78
- }
@@ -1,129 +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.MultiValueJsonEditorRule = void 0;
25
- const ts_utils_1 = require("@fgv/ts-utils");
26
- const jsonEditorRule_1 = require("../jsonEditorRule");
27
- /**
28
- * The Multi-Value JSON editor rule expands matching keys multiple
29
- * times, projecting the value into the template context for any
30
- * child objects rendered by the rule.
31
- *
32
- * The default syntax for a multi-value key is:
33
- * "[[var]]=value1,value2,value3"
34
- * Where "var" is the name of the variable that will be passed to
35
- * child template resolution, and "value1,value2,value3" is a
36
- * comma-separated list of values to be expanded.
37
- */
38
- class MultiValueJsonEditorRule extends jsonEditorRule_1.JsonEditorRuleBase {
39
- /**
40
- * Creates a new MultiValueJsonEditorRule.
41
- * @param options Optional configuration options
42
- */
43
- constructor(options) {
44
- super();
45
- this._options = options;
46
- }
47
- /**
48
- * Creates a new MultiValueJsonEditorRule.
49
- * @param options Optional configuration options
50
- */
51
- static create(options) {
52
- return (0, ts_utils_1.captureResult)(() => new MultiValueJsonEditorRule(options));
53
- }
54
- /**
55
- * Evaluates a property for multi-value expansion.
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 an object containing the fully-resolved child
60
- * values to be merged for matching multi-value property. Fails with
61
- * detail 'error' if an error occurs or with detail 'inapplicable' if
62
- * the property key is not a conditional property.
63
- */
64
- editProperty(key, value, state) {
65
- const json = {};
66
- const result = this._tryParse(key, state).onSuccess((parts) => {
67
- return (0, ts_utils_1.allSucceed)(parts.propertyValues.map((pv) => {
68
- return this._deriveContext(state, [parts.propertyVariable, pv]).onSuccess((ctx) => {
69
- return state.editor.clone(value, ctx).onSuccess((cloned) => {
70
- json[pv] = cloned;
71
- return (0, ts_utils_1.succeedWithDetail)(cloned);
72
- });
73
- });
74
- }), json).onSuccess(() => {
75
- if (parts.asArray) {
76
- const arrayRtrn = {};
77
- arrayRtrn[parts.propertyVariable] = Array.from(Object.values(json));
78
- return (0, ts_utils_1.succeed)(arrayRtrn);
79
- }
80
- return (0, ts_utils_1.succeed)(json);
81
- }).withFailureDetail('error');
82
- });
83
- if (result.isFailure() && (result.detail === 'error')) {
84
- return state.failValidation('invalidPropertyName', result.message);
85
- }
86
- return result;
87
- }
88
- _deriveContext(state, ...values) {
89
- var _a;
90
- return state.extendContext((_a = this._options) === null || _a === void 0 ? void 0 : _a.context, { vars: values });
91
- }
92
- /**
93
- * Determines if a given property key is multi-value. Derived classes can override this
94
- * method to use a different format for multi-value properties.
95
- * @param key The key of the property to consider.
96
- * @param state The editor state of the object being edited.
97
- * @returns Success with detail 'deferred' and a @see MultiValuePropertyParts describing the
98
- * match for matching multi-value property. Fails with detail 'error' if an error occurs
99
- * or with detail 'inapplicable' if the key does not represent a multi-value property.
100
- */
101
- _tryParse(token, state) {
102
- var _a;
103
- let parts = [];
104
- let asArray = false;
105
- if (token.startsWith('[[')) {
106
- parts = token.substring(2).split(']]=');
107
- asArray = true;
108
- }
109
- else if (token.startsWith('*')) {
110
- parts = token.substring(1).split('=');
111
- asArray = false;
112
- }
113
- else {
114
- return (0, ts_utils_1.failWithDetail)(token, 'inapplicable');
115
- }
116
- if (parts.length !== 2) {
117
- const message = `Malformed multi-value property: ${token}`;
118
- return state.failValidation('invalidPropertyName', message, (_a = this._options) === null || _a === void 0 ? void 0 : _a.validation);
119
- }
120
- if (parts[1].includes('{{')) {
121
- return (0, ts_utils_1.failWithDetail)('unresolved template', 'inapplicable');
122
- }
123
- const propertyVariable = parts[0];
124
- const propertyValues = parts[1].split(',');
125
- return (0, ts_utils_1.succeedWithDetail)({ token, propertyVariable, propertyValues, asArray });
126
- }
127
- }
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, JsonEditorOptions, JsonPropertyEditFailureReason } from '../common';\nimport { JsonObject, JsonValue } from '../../common';\n\nimport { JsonEditorRuleBase } from '../jsonEditorRule';\nimport { JsonEditorState } from '../jsonEditorState';\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"]}
@@ -1,62 +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 { JsonContext } from '../../jsonContext';
5
- import { JsonEditorRuleBase } from '../jsonEditorRule';
6
- import { JsonEditorState } from '../jsonEditorState';
7
- /**
8
- * The Reference JSON editor rule replaces property keys or values that match
9
- * some known object with a copy of that referenced object, formatted according
10
- * to the current context.
11
- *
12
- * A property key is matched if it matches any known referenceable value.
13
- * - If the value of the matched key is 'default', then the entire object is formatted
14
- * with the current context, flattened and merged into the current object.
15
- * - If the value of the matched key is some other string, then the entire
16
- * object is formatted with the current context, and the child of the resulting
17
- * object at the specified path is flattened and merged into the current object.
18
- * - If the value of the matched key is an object, then the entire object is
19
- * formatted with the current context extended to include any properties of
20
- * that object, flattened, and merged into the current object.
21
- * - It is an error if the referenced value is not an object.
22
- *
23
- * Any property, array or literal value is matched if it matches any known
24
- * referenceable value. The referenced value is replaced by the referenced
25
- * value, formatted using the current editor context.
26
- */
27
- export declare class ReferenceJsonEditorRule extends JsonEditorRuleBase {
28
- protected _options?: JsonEditorOptions;
29
- /**
30
- * Creates a new @see ReferenceJsonEditorRule.
31
- * @param options Optional configuration options for this rule
32
- */
33
- constructor(options?: JsonEditorOptions);
34
- /**
35
- * Creates a new @see ReferenceJsonEditorRule.
36
- * @param options Optional configuration options for this rule
37
- */
38
- static create(options?: JsonEditorOptions): Result<ReferenceJsonEditorRule>;
39
- /**
40
- * Evaluates a property for reference expansion.
41
- * @param key The key of the property to be considered
42
- * @param value The value of the property to be considered
43
- * @param state The editor state for the object being edited
44
- * @returns If the reference is successful, returns Success with a JsonObject to
45
- * be flattened and merged into the current object. Fails with detail 'inapplicable'
46
- * for non-reference keys or with detail 'error' if an error occurs.
47
- */
48
- editProperty(key: string, value: JsonValue, state: JsonEditorState): DetailedResult<JsonObject, JsonPropertyEditFailureReason>;
49
- /**
50
- * Evaluates a property, array or literal value for reference replacement.
51
- * @param value The value to be evaluated
52
- * @param state The editor state for the object being edited
53
- */
54
- editValue(value: JsonValue, state: JsonEditorState): DetailedResult<JsonValue, JsonEditFailureReason>;
55
- /**
56
- * Gets the template variables to use given the value of some property whose name matched a
57
- * resource plus the base template context.
58
- * @param supplied The string or object supplied in the source json
59
- * @param baseVars The context in effect at the point of resolution
60
- */
61
- protected _extendContext(state: JsonEditorState, supplied: JsonValue): Result<JsonContext | undefined>;
62
- }