@fgv/ts-json 1.0.0 → 1.4.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 +3 -3
- package/jsonConverter.js +11 -11
- package/jsonEditor/index.d.ts +0 -0
- package/jsonEditor/index.js +6 -2
- package/jsonEditor/jsonEditor.d.ts +5 -5
- package/jsonEditor/jsonEditor.js +41 -41
- package/jsonEditor/jsonEditorRule.d.ts +2 -2
- package/jsonEditor/jsonEditorRule.js +4 -4
- package/jsonEditor/jsonEditorState.d.ts +3 -3
- package/jsonEditor/jsonEditorState.js +7 -7
- 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 +23 -23
- package/package.json +14 -14
package/LICENSE
CHANGED
|
File without changes
|
package/README.md
CHANGED
|
File without changes
|
package/common.d.ts
CHANGED
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
import { Result } from '@fgv/ts-utils';
|
|
2
|
-
export
|
|
2
|
+
export type JsonPrimitive = boolean | number | string | null;
|
|
3
3
|
export interface JsonObject {
|
|
4
4
|
[key: string]: JsonValue;
|
|
5
5
|
}
|
|
6
|
-
export
|
|
6
|
+
export type JsonValue = JsonPrimitive | JsonObject | JsonArray;
|
|
7
7
|
export interface JsonArray extends Array<JsonValue> {
|
|
8
8
|
}
|
|
9
9
|
/**
|
|
10
10
|
* Classes of JSON value
|
|
11
11
|
*/
|
|
12
|
-
export
|
|
12
|
+
export type JsonValueType = 'primitive' | 'object' | 'array';
|
|
13
13
|
/**
|
|
14
14
|
* Test if an unknown is a JsonValue
|
|
15
15
|
* @param from The unknown to be tested
|
package/common.js
CHANGED
|
@@ -63,15 +63,15 @@ exports.isJsonArray = isJsonArray;
|
|
|
63
63
|
*/
|
|
64
64
|
function classifyJsonValue(from) {
|
|
65
65
|
if (isJsonPrimitive(from)) {
|
|
66
|
-
return ts_utils_1.succeed('primitive');
|
|
66
|
+
return (0, ts_utils_1.succeed)('primitive');
|
|
67
67
|
}
|
|
68
68
|
else if (isJsonObject(from)) {
|
|
69
|
-
return ts_utils_1.succeed('object');
|
|
69
|
+
return (0, ts_utils_1.succeed)('object');
|
|
70
70
|
}
|
|
71
71
|
else if (isJsonArray(from)) {
|
|
72
|
-
return ts_utils_1.succeed('array');
|
|
72
|
+
return (0, ts_utils_1.succeed)('array');
|
|
73
73
|
}
|
|
74
|
-
return ts_utils_1.fail(`Invalid JSON: ${from}`);
|
|
74
|
+
return (0, ts_utils_1.fail)(`Invalid JSON: ${from}`);
|
|
75
75
|
}
|
|
76
76
|
exports.classifyJsonValue = classifyJsonValue;
|
|
77
77
|
/**
|
|
@@ -87,14 +87,14 @@ function pickJsonValue(src, path) {
|
|
|
87
87
|
if (result && isJsonObject(result)) {
|
|
88
88
|
result = result[part];
|
|
89
89
|
if (result === undefined) {
|
|
90
|
-
return ts_utils_1.fail(`${path}: child '${part}' does not exist`);
|
|
90
|
+
return (0, ts_utils_1.fail)(`${path}: child '${part}' does not exist`);
|
|
91
91
|
}
|
|
92
92
|
}
|
|
93
93
|
else {
|
|
94
|
-
return ts_utils_1.fail(`${path}: child '${part}' does not exist`);
|
|
94
|
+
return (0, ts_utils_1.fail)(`${path}: child '${part}' does not exist`);
|
|
95
95
|
}
|
|
96
96
|
}
|
|
97
|
-
return ts_utils_1.succeed(result);
|
|
97
|
+
return (0, ts_utils_1.succeed)(result);
|
|
98
98
|
}
|
|
99
99
|
exports.pickJsonValue = pickJsonValue;
|
|
100
100
|
/**
|
|
@@ -107,10 +107,10 @@ exports.pickJsonValue = pickJsonValue;
|
|
|
107
107
|
function pickJsonObject(src, path) {
|
|
108
108
|
return pickJsonValue(src, path).onSuccess((v) => {
|
|
109
109
|
if (!isJsonObject(v)) {
|
|
110
|
-
return ts_utils_1.fail(`${path}: not an object`);
|
|
110
|
+
return (0, ts_utils_1.fail)(`${path}: not an object`);
|
|
111
111
|
}
|
|
112
|
-
return ts_utils_1.succeed(v);
|
|
112
|
+
return (0, ts_utils_1.succeed)(v);
|
|
113
113
|
});
|
|
114
114
|
}
|
|
115
115
|
exports.pickJsonObject = pickJsonObject;
|
|
116
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
116
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common.js","sourceRoot":"","sources":["../src/common.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;GAoBG;;;AAEH,4CAAsD;AAgBtD;;;;;GAKG;AACH,SAAgB,eAAe,CAAC,IAAa;IACzC,OAAO,CAAC,CAAC,OAAO,IAAI,KAAK,SAAS,CAAC,IAAI,CAAC,OAAO,IAAI,KAAK,QAAQ,CAAC,IAAI,CAAC,OAAO,IAAI,KAAK,QAAQ,CAAC,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC,CAAC;AACxH,CAAC;AAFD,0CAEC;AAED;;;;;GAKG;AACH,SAAgB,YAAY,CAAC,IAAa;IACtC,OAAO,CAAC,CAAC,OAAO,IAAI,KAAK,QAAQ,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClE,CAAC;AAFD,oCAEC;AAED;;;;;GAKG;AACH,SAAgB,WAAW,CAAC,IAAa;IACrC,OAAO,CAAC,OAAO,IAAI,KAAK,QAAQ,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;AAC7D,CAAC;AAFD,kCAEC;AAED;;;;;;;GAOG;AACH,SAAgB,iBAAiB,CAAC,IAAa;IAC3C,IAAI,eAAe,CAAC,IAAI,CAAC,EAAE;QACvB,OAAO,IAAA,kBAAO,EAAC,WAAW,CAAC,CAAC;KAC/B;SACI,IAAI,YAAY,CAAC,IAAI,CAAC,EAAE;QACzB,OAAO,IAAA,kBAAO,EAAC,QAAQ,CAAC,CAAC;KAC5B;SACI,IAAI,WAAW,CAAC,IAAI,CAAC,EAAE;QACxB,OAAO,IAAA,kBAAO,EAAC,OAAO,CAAC,CAAC;KAC3B;IACD,OAAO,IAAA,eAAI,EAAC,iBAAiB,IAAI,EAAE,CAAC,CAAC;AACzC,CAAC;AAXD,8CAWC;AAED;;;;;;GAMG;AACH,SAAgB,aAAa,CAAC,GAAe,EAAE,IAAY;IACvD,IAAI,MAAM,GAAc,GAAG,CAAC;IAC5B,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;QAChC,IAAI,MAAM,IAAI,YAAY,CAAC,MAAM,CAAC,EAAE;YAChC,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;YACtB,IAAI,MAAM,KAAK,SAAS,EAAE;gBACtB,OAAO,IAAA,eAAI,EAAC,GAAG,IAAI,YAAY,IAAI,kBAAkB,CAAC,CAAC;aAC1D;SACJ;aACI;YACD,OAAO,IAAA,eAAI,EAAC,GAAG,IAAI,YAAY,IAAI,kBAAkB,CAAC,CAAC;SAC1D;KACJ;IACD,OAAO,IAAA,kBAAO,EAAC,MAAM,CAAC,CAAC;AAC3B,CAAC;AAdD,sCAcC;AAED;;;;;;GAMG;AACH,SAAgB,cAAc,CAAC,GAAe,EAAE,IAAY;IACxD,OAAO,aAAa,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;QAC5C,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE;YAClB,OAAO,IAAA,eAAI,EAAC,GAAG,IAAI,iBAAiB,CAAC,CAAC;SACzC;QACD,OAAO,IAAA,kBAAO,EAAC,CAAC,CAAC,CAAC;IACtB,CAAC,CAAC,CAAC;AACP,CAAC;AAPD,wCAOC","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 { Result, fail, succeed } from '@fgv/ts-utils';\n\n/* eslint-disable no-use-before-define */\n\nexport type JsonPrimitive = boolean | number | string | null;\nexport interface JsonObject { [key: string]: JsonValue }\n\nexport type JsonValue = JsonPrimitive | JsonObject | JsonArray;\n// eslint-disable-next-line @typescript-eslint/no-empty-interface\nexport interface JsonArray extends Array<JsonValue> { }\n\n/**\n * Classes of JSON value\n */\nexport type JsonValueType = 'primitive'|'object'|'array';\n\n/**\n * Test if an unknown is a JsonValue\n * @param from The unknown to be tested\n * @returns true if the supplied parameter is a valid JSON primitive,\n * false otherwise.\n */\nexport function isJsonPrimitive(from: unknown): from is JsonPrimitive {\n    return ((typeof from === 'boolean') || (typeof from === 'number') || (typeof from === 'string') || (from === null));\n}\n\n/**\n * Test if an unknown is potentially a JsonObject\n * @param from The unknown to be tested\n * @returns true if the supplied parameter is a non-array object,\n * false otherwise.\n */\nexport function isJsonObject(from: unknown): from is JsonObject {\n    return ((typeof from === 'object') && (!Array.isArray(from)));\n}\n\n/**\n * Test if an unknown is potentially a JsonArary\n * @param from The unknown to be tested\n * @returns true if the supplied parameter is an array object,\n * false otherwise\n */\nexport function isJsonArray(from: unknown): from is JsonArray {\n    return (typeof from === 'object') && Array.isArray(from);\n}\n\n/**\n * Identifies whether some unknown value is a primitive,\n * object or array. Fails for any value that cannot be\n * converted to JSON (e.g. a function) _but_ this is a\n * shallow test - it does not test the properties of an\n * object or elements in an array.\n * @param from The unknown value to be tested\n */\nexport function classifyJsonValue(from: unknown): Result<JsonValueType> {\n    if (isJsonPrimitive(from)) {\n        return succeed('primitive');\n    }\n    else if (isJsonObject(from)) {\n        return succeed('object');\n    }\n    else if (isJsonArray(from)) {\n        return succeed('array');\n    }\n    return fail(`Invalid JSON: ${from}`);\n}\n\n/**\n * Picks a nested field from a supplied JsonObject\n * @param src The object from which the field is to be picked\n * @param path Dot-separated path of the member to be picked\n * @returns Success with the property if the path is valid, Failure\n * otherwise.\n */\nexport function pickJsonValue(src: JsonObject, path: string): Result<JsonValue> {\n    let result: JsonValue = src;\n    for (const part of path.split('.')) {\n        if (result && isJsonObject(result)) {\n            result = result[part];\n            if (result === undefined) {\n                return fail(`${path}: child '${part}' does not exist`);\n            }\n        }\n        else {\n            return fail(`${path}: child '${part}' does not exist`);\n        }\n    }\n    return succeed(result);\n}\n\n/**\n * Picks a nested JsonObject from a supplied JsonObject\n * @param src The object from which the field is to be picked\n * @param path Dot-separated path of the member to be picked\n * @returns Success with the property if the path is valid and the value\n * is an object. Returns failure with details if an error occurs.\n */\nexport function pickJsonObject(src: JsonObject, path: string): Result<JsonObject> {\n    return pickJsonValue(src, path).onSuccess((v) => {\n        if (!isJsonObject(v)) {\n            return fail(`${path}: not an object`);\n        }\n        return succeed(v);\n    });\n}\n"]}
|
package/contextHelpers.d.ts
CHANGED
|
File without changes
|
package/contextHelpers.js
CHANGED
|
@@ -30,7 +30,7 @@ class JsonContextHelper {
|
|
|
30
30
|
this._context = context;
|
|
31
31
|
}
|
|
32
32
|
static create(context) {
|
|
33
|
-
return ts_utils_1.captureResult(() => new JsonContextHelper(context));
|
|
33
|
+
return (0, ts_utils_1.captureResult)(() => new JsonContextHelper(context));
|
|
34
34
|
}
|
|
35
35
|
static extendContextVars(baseContext, vars) {
|
|
36
36
|
var _a, _b;
|
|
@@ -38,7 +38,7 @@ class JsonContextHelper {
|
|
|
38
38
|
const extend = (_a = baseContext === null || baseContext === void 0 ? void 0 : baseContext.extendVars) !== null && _a !== void 0 ? _a : jsonContext_1.defaultExtendVars;
|
|
39
39
|
return extend((_b = baseContext === null || baseContext === void 0 ? void 0 : baseContext.vars) !== null && _b !== void 0 ? _b : {}, vars);
|
|
40
40
|
}
|
|
41
|
-
return ts_utils_1.succeed(baseContext === null || baseContext === void 0 ? void 0 : baseContext.vars);
|
|
41
|
+
return (0, ts_utils_1.succeed)(baseContext === null || baseContext === void 0 ? void 0 : baseContext.vars);
|
|
42
42
|
}
|
|
43
43
|
static extendContextRefs(baseContext, refs) {
|
|
44
44
|
if (refs && (refs.length > 0)) {
|
|
@@ -46,21 +46,21 @@ class JsonContextHelper {
|
|
|
46
46
|
if (full.length > 1) {
|
|
47
47
|
return jsonReferenceMap_1.CompositeJsonMap.create(full);
|
|
48
48
|
}
|
|
49
|
-
return ts_utils_1.succeed(full[0]);
|
|
49
|
+
return (0, ts_utils_1.succeed)(full[0]);
|
|
50
50
|
}
|
|
51
|
-
return ts_utils_1.succeed(baseContext === null || baseContext === void 0 ? void 0 : baseContext.refs);
|
|
51
|
+
return (0, ts_utils_1.succeed)(baseContext === null || baseContext === void 0 ? void 0 : baseContext.refs);
|
|
52
52
|
}
|
|
53
53
|
static extendContext(baseContext, add) {
|
|
54
54
|
return JsonContextHelper.extendContextVars(baseContext, (add === null || add === void 0 ? void 0 : add.vars) || []).onSuccess((vars) => {
|
|
55
55
|
return JsonContextHelper.extendContextRefs(baseContext, (add === null || add === void 0 ? void 0 : add.refs) || []).onSuccess((refs) => {
|
|
56
56
|
if (!vars && !refs && !(baseContext === null || baseContext === void 0 ? void 0 : baseContext.extendVars)) {
|
|
57
|
-
return ts_utils_1.succeed(undefined);
|
|
57
|
+
return (0, ts_utils_1.succeed)(undefined);
|
|
58
58
|
}
|
|
59
59
|
const rtrn = { vars, refs };
|
|
60
60
|
if (baseContext === null || baseContext === void 0 ? void 0 : baseContext.extendVars) {
|
|
61
61
|
rtrn.extendVars = baseContext.extendVars;
|
|
62
62
|
}
|
|
63
|
-
return ts_utils_1.succeed(rtrn);
|
|
63
|
+
return (0, ts_utils_1.succeed)(rtrn);
|
|
64
64
|
});
|
|
65
65
|
});
|
|
66
66
|
}
|
|
@@ -78,11 +78,11 @@ class JsonContextHelper {
|
|
|
78
78
|
else if (baseContext.hasOwnProperty('extendVars')) {
|
|
79
79
|
rtrn.extendVars = baseContext.extendVars;
|
|
80
80
|
}
|
|
81
|
-
return ts_utils_1.succeed(rtrn);
|
|
81
|
+
return (0, ts_utils_1.succeed)(rtrn);
|
|
82
82
|
}
|
|
83
|
-
return ts_utils_1.succeed(baseContext);
|
|
83
|
+
return (0, ts_utils_1.succeed)(baseContext);
|
|
84
84
|
}
|
|
85
|
-
return ts_utils_1.succeed(add);
|
|
85
|
+
return (0, ts_utils_1.succeed)(add);
|
|
86
86
|
}
|
|
87
87
|
extendVars(vars) {
|
|
88
88
|
return JsonContextHelper.extendContextVars(this._context, vars);
|
|
@@ -98,4 +98,4 @@ class JsonContextHelper {
|
|
|
98
98
|
}
|
|
99
99
|
}
|
|
100
100
|
exports.JsonContextHelper = JsonContextHelper;
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contextHelpers.js","sourceRoot":"","sources":["../src/contextHelpers.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 { JsonContext, JsonReferenceMap, TemplateVars, VariableValue, defaultExtendVars } from './jsonContext';\nimport { Result, captureResult, succeed } from '@fgv/ts-utils';\nimport { CompositeJsonMap } from './jsonReferenceMap';\n\nexport class JsonContextHelper {\n    protected _context?: JsonContext;\n\n    public constructor(context?: JsonContext) {\n        this._context = context;\n    }\n\n    public static create(context?: JsonContext): Result<JsonContextHelper> {\n        return captureResult(() => new JsonContextHelper(context));\n    }\n\n    public static extendContextVars(baseContext: JsonContext|undefined, vars?: VariableValue[]): Result<TemplateVars|undefined> {\n        if (vars && (vars.length > 0)) {\n            const extend = baseContext?.extendVars ?? defaultExtendVars;\n            return extend(baseContext?.vars ?? {}, vars);\n        }\n        return succeed(baseContext?.vars);\n    }\n\n    public static extendContextRefs(baseContext: JsonContext|undefined, refs?: JsonReferenceMap[]): Result<JsonReferenceMap|undefined> {\n        if (refs && (refs.length > 0)) {\n            const full = baseContext?.refs ? [...refs, baseContext.refs] : refs;\n            if (full.length > 1) {\n                return CompositeJsonMap.create(full);\n            }\n            return succeed(full[0]);\n        }\n        return succeed(baseContext?.refs);\n    }\n\n    public static extendContext(baseContext?: JsonContext|undefined, add?: { vars?: VariableValue[], refs?: JsonReferenceMap[] }): Result<JsonContext|undefined> {\n        return JsonContextHelper.extendContextVars(baseContext, add?.vars || []).onSuccess((vars) => {\n            return JsonContextHelper.extendContextRefs(baseContext, add?.refs || []).onSuccess((refs) => {\n                if (!vars && !refs && !baseContext?.extendVars) {\n                    return succeed(undefined);\n                }\n                const rtrn: JsonContext = { vars, refs };\n                if (baseContext?.extendVars) {\n                    rtrn.extendVars = baseContext.extendVars;\n                }\n                return succeed(rtrn);\n            });\n        });\n    }\n\n    public static mergeContext(baseContext: JsonContext|undefined, add: JsonContext|undefined): Result<JsonContext|undefined> {\n        if (baseContext) {\n            if (add) {\n                const rtrn: JsonContext = {\n                    vars: add.vars ?? baseContext.vars,\n                    refs: add.refs ?? baseContext.refs,\n                };\n                if (add.hasOwnProperty('extendVars')) {\n                    rtrn.extendVars = add.extendVars;\n                }\n                else if (baseContext.hasOwnProperty('extendVars')) {\n                    rtrn.extendVars = baseContext.extendVars;\n                }\n                return succeed(rtrn);\n            }\n            return succeed(baseContext);\n        }\n        return succeed(add);\n    }\n\n    public extendVars(vars?: VariableValue[]): Result<TemplateVars|undefined> {\n        return JsonContextHelper.extendContextVars(this._context, vars);\n    }\n\n    public extendRefs(refs?: JsonReferenceMap[]): Result<JsonReferenceMap|undefined> {\n        return JsonContextHelper.extendContextRefs(this._context, refs);\n    }\n\n    public extendContext(add?: { vars?: VariableValue[], refs?: JsonReferenceMap[] }): Result<JsonContext|undefined> {\n        return JsonContextHelper.extendContext(this._context, add);\n    }\n\n    public mergeContext(merge?: JsonContext): Result<JsonContext|undefined> {\n        return JsonContextHelper.mergeContext(this._context, merge);\n    }\n}\n"]}
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contextHelpers.js","sourceRoot":"","sources":["../src/contextHelpers.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 { JsonContext, JsonReferenceMap, TemplateVars, VariableValue, defaultExtendVars } from './jsonContext';\nimport { Result, captureResult, succeed } from '@fgv/ts-utils';\nimport { CompositeJsonMap } from './jsonReferenceMap';\n\nexport class JsonContextHelper {\n    protected _context?: JsonContext;\n\n    public constructor(context?: JsonContext) {\n        this._context = context;\n    }\n\n    public static create(context?: JsonContext): Result<JsonContextHelper> {\n        return captureResult(() => new JsonContextHelper(context));\n    }\n\n    public static extendContextVars(baseContext: JsonContext|undefined, vars?: VariableValue[]): Result<TemplateVars|undefined> {\n        if (vars && (vars.length > 0)) {\n            const extend = baseContext?.extendVars ?? defaultExtendVars;\n            return extend(baseContext?.vars ?? {}, vars);\n        }\n        return succeed(baseContext?.vars);\n    }\n\n    public static extendContextRefs(baseContext: JsonContext|undefined, refs?: JsonReferenceMap[]): Result<JsonReferenceMap|undefined> {\n        if (refs && (refs.length > 0)) {\n            const full = baseContext?.refs ? [...refs, baseContext.refs] : refs;\n            if (full.length > 1) {\n                return CompositeJsonMap.create(full);\n            }\n            return succeed(full[0]);\n        }\n        return succeed(baseContext?.refs);\n    }\n\n    public static extendContext(baseContext?: JsonContext|undefined, add?: { vars?: VariableValue[], refs?: JsonReferenceMap[] }): Result<JsonContext|undefined> {\n        return JsonContextHelper.extendContextVars(baseContext, add?.vars || []).onSuccess((vars) => {\n            return JsonContextHelper.extendContextRefs(baseContext, add?.refs || []).onSuccess((refs) => {\n                if (!vars && !refs && !baseContext?.extendVars) {\n                    return succeed(undefined);\n                }\n                const rtrn: JsonContext = { vars, refs };\n                if (baseContext?.extendVars) {\n                    rtrn.extendVars = baseContext.extendVars;\n                }\n                return succeed(rtrn);\n            });\n        });\n    }\n\n    public static mergeContext(baseContext: JsonContext|undefined, add: JsonContext|undefined): Result<JsonContext|undefined> {\n        if (baseContext) {\n            if (add) {\n                const rtrn: JsonContext = {\n                    vars: add.vars ?? baseContext.vars,\n                    refs: add.refs ?? baseContext.refs,\n                };\n                if (add.hasOwnProperty('extendVars')) {\n                    rtrn.extendVars = add.extendVars;\n                }\n                else if (baseContext.hasOwnProperty('extendVars')) {\n                    rtrn.extendVars = baseContext.extendVars;\n                }\n                return succeed(rtrn);\n            }\n            return succeed(baseContext);\n        }\n        return succeed(add);\n    }\n\n    public extendVars(vars?: VariableValue[]): Result<TemplateVars|undefined> {\n        return JsonContextHelper.extendContextVars(this._context, vars);\n    }\n\n    public extendRefs(refs?: JsonReferenceMap[]): Result<JsonReferenceMap|undefined> {\n        return JsonContextHelper.extendContextRefs(this._context, refs);\n    }\n\n    public extendContext(add?: { vars?: VariableValue[], refs?: JsonReferenceMap[] }): Result<JsonContext|undefined> {\n        return JsonContextHelper.extendContext(this._context, add);\n    }\n\n    public mergeContext(merge?: JsonContext): Result<JsonContext|undefined> {\n        return JsonContextHelper.mergeContext(this._context, merge);\n    }\n}\n"]}
|
package/converters.d.ts
CHANGED
|
File without changes
|
package/converters.js
CHANGED
|
File without changes
|
package/file.d.ts
CHANGED
|
@@ -40,7 +40,7 @@ export interface ReadDirectoryItem<T> {
|
|
|
40
40
|
* @param options Options to control conversion and filtering
|
|
41
41
|
*/
|
|
42
42
|
export declare function convertJsonDirectorySync<T>(srcPath: string, options: DirectoryConvertOptions<T>): Result<ReadDirectoryItem<T>[]>;
|
|
43
|
-
export
|
|
43
|
+
export type ItemNameTransformFunction<T> = (name: string, item: T) => Result<string>;
|
|
44
44
|
export interface DirectoryToMapConvertOptions<T, TC = unknown> extends DirectoryConvertOptions<T, TC> {
|
|
45
45
|
transformName?: ItemNameTransformFunction<T>;
|
|
46
46
|
}
|
package/file.js
CHANGED
|
@@ -22,7 +22,11 @@
|
|
|
22
22
|
*/
|
|
23
23
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
24
24
|
if (k2 === undefined) k2 = k;
|
|
25
|
-
Object.
|
|
25
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
26
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
27
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
28
|
+
}
|
|
29
|
+
Object.defineProperty(o, k2, desc);
|
|
26
30
|
}) : (function(o, m, k, k2) {
|
|
27
31
|
if (k2 === undefined) k2 = k;
|
|
28
32
|
o[k2] = m[k];
|
|
@@ -49,7 +53,7 @@ const ts_utils_1 = require("@fgv/ts-utils");
|
|
|
49
53
|
* @param srcPath Path of the file to read
|
|
50
54
|
*/
|
|
51
55
|
function readJsonFileSync(srcPath) {
|
|
52
|
-
return ts_utils_1.captureResult(() => {
|
|
56
|
+
return (0, ts_utils_1.captureResult)(() => {
|
|
53
57
|
const fullPath = path.resolve(srcPath);
|
|
54
58
|
const body = fs.readFileSync(fullPath, 'utf8').toString();
|
|
55
59
|
return JSON.parse(body);
|
|
@@ -73,7 +77,7 @@ exports.convertJsonFileSync = convertJsonFileSync;
|
|
|
73
77
|
* @param options Options to control conversion and filtering
|
|
74
78
|
*/
|
|
75
79
|
function convertJsonDirectorySync(srcPath, options) {
|
|
76
|
-
return ts_utils_1.captureResult(() => {
|
|
80
|
+
return (0, ts_utils_1.captureResult)(() => {
|
|
77
81
|
const fullPath = path.resolve(srcPath);
|
|
78
82
|
if (!fs.statSync(fullPath).isDirectory()) {
|
|
79
83
|
throw new Error(`${fullPath}: Not a directory`);
|
|
@@ -83,21 +87,21 @@ function convertJsonDirectorySync(srcPath, options) {
|
|
|
83
87
|
if (fi.isFile() && (path.extname(fi.name) === '.json')) {
|
|
84
88
|
const filePath = path.resolve(fullPath, fi.name);
|
|
85
89
|
return convertJsonFileSync(filePath, options.converter).onSuccess((payload) => {
|
|
86
|
-
return ts_utils_1.succeed({
|
|
90
|
+
return (0, ts_utils_1.succeed)({
|
|
87
91
|
filename: fi.name,
|
|
88
92
|
item: payload,
|
|
89
93
|
});
|
|
90
94
|
}).onFailure((message) => {
|
|
91
|
-
return ts_utils_1.fail(`${fi.name}: ${message}`);
|
|
95
|
+
return (0, ts_utils_1.fail)(`${fi.name}: ${message}`);
|
|
92
96
|
});
|
|
93
97
|
}
|
|
94
98
|
return undefined;
|
|
95
99
|
}).filter((r) => r !== undefined);
|
|
96
|
-
return ts_utils_1.mapResults(results).getValueOrThrow();
|
|
100
|
+
return (0, ts_utils_1.mapResults)(results).getValueOrThrow();
|
|
97
101
|
});
|
|
98
102
|
}
|
|
99
103
|
exports.convertJsonDirectorySync = convertJsonDirectorySync;
|
|
100
|
-
const defaultNameTransformer = (n) => ts_utils_1.succeed(n);
|
|
104
|
+
const defaultNameTransformer = (n) => (0, ts_utils_1.succeed)(n);
|
|
101
105
|
/**
|
|
102
106
|
* Reads and converts all JSON files from a directory, returning a map
|
|
103
107
|
* indexed by file base name (i.e. minus the extension) with an optional
|
|
@@ -109,13 +113,13 @@ function convertJsonDirectoryToMapSync(srcPath, options) {
|
|
|
109
113
|
return convertJsonDirectorySync(srcPath, options).onSuccess((items) => {
|
|
110
114
|
var _a;
|
|
111
115
|
const transformName = (_a = options.transformName) !== null && _a !== void 0 ? _a : defaultNameTransformer;
|
|
112
|
-
return ts_utils_1.mapResults(items.map((item) => {
|
|
116
|
+
return (0, ts_utils_1.mapResults)(items.map((item) => {
|
|
113
117
|
const basename = path.basename(item.filename, '.json');
|
|
114
118
|
return transformName(basename, item.item).onSuccess((name) => {
|
|
115
|
-
return ts_utils_1.succeed([name, item.item]);
|
|
119
|
+
return (0, ts_utils_1.succeed)([name, item.item]);
|
|
116
120
|
});
|
|
117
121
|
})).onSuccess((items) => {
|
|
118
|
-
return ts_utils_1.succeed(new Map(items));
|
|
122
|
+
return (0, ts_utils_1.succeed)(new Map(items));
|
|
119
123
|
});
|
|
120
124
|
});
|
|
121
125
|
}
|
|
@@ -126,11 +130,11 @@ exports.convertJsonDirectoryToMapSync = convertJsonDirectoryToMapSync;
|
|
|
126
130
|
* @param value The JSON object to be written
|
|
127
131
|
*/
|
|
128
132
|
function writeJsonFileSync(srcPath, value) {
|
|
129
|
-
return ts_utils_1.captureResult(() => {
|
|
133
|
+
return (0, ts_utils_1.captureResult)(() => {
|
|
130
134
|
const fullPath = path.resolve(srcPath);
|
|
131
135
|
fs.writeFileSync(fullPath, JSON.stringify(value, undefined, 2));
|
|
132
136
|
return true;
|
|
133
137
|
});
|
|
134
138
|
}
|
|
135
139
|
exports.writeJsonFileSync = writeJsonFileSync;
|
|
136
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file.js","sourceRoot":"","sources":["../src/file.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 * as fs from 'fs';\nimport * as path from 'path';\nimport { Converter, Result, captureResult, fail, mapResults, succeed } from '@fgv/ts-utils';\n\nimport { JsonValue } from './common';\n\n/**\n * Convenience function to read type-safe JSON from a file\n * @param srcPath Path of the file to read\n */\nexport function readJsonFileSync(srcPath: string): Result<JsonValue> {\n    return captureResult(() => {\n        const fullPath = path.resolve(srcPath);\n        const body = fs.readFileSync(fullPath, 'utf8').toString();\n        return JSON.parse(body) as JsonValue;\n    });\n}\n\n/**\n * Convenience function to read a JSON file and apply a supplied converter\n * @param srcPath Path of the file to read\n * @param converter Converter used to convert the file contents\n */\nexport function convertJsonFileSync<T>(srcPath: string, converter: Converter<T>): Result<T> {\n    return readJsonFileSync(srcPath).onSuccess((json) => {\n        return converter.convert(json);\n    });\n}\n\n/**\n * Options for directory conversion\n * TODO: add filtering, allowed and excluded\n */\nexport interface DirectoryConvertOptions<T, TC=unknown> {\n    /**\n     * The converter used to convert incoming JSON objects\n     */\n    converter: Converter<T, TC>;\n}\n\n/**\n * Return value for one item in a directory conversion\n */\nexport interface ReadDirectoryItem<T> {\n    /**\n     * Relative name of the file that was processed\n     */\n    filename: string;\n\n    /**\n     * The payload of the file\n     */\n    item: T;\n}\n\n/**\n * Reads all JSON files from a directory and apply a supplied converter\n * @param srcPath The path of the folder to be read\n * @param options Options to control conversion and filtering\n */\nexport function convertJsonDirectorySync<T>(srcPath: string, options: DirectoryConvertOptions<T>): Result<ReadDirectoryItem<T>[]> {\n    return captureResult<ReadDirectoryItem<T>[]>(() => {\n        const fullPath = path.resolve(srcPath);\n        if (!fs.statSync(fullPath).isDirectory()) {\n            throw new Error(`${fullPath}: Not a directory`);\n        }\n        const files = fs.readdirSync(fullPath, { withFileTypes: true });\n        const results = files.map((fi) => {\n            if (fi.isFile() && (path.extname(fi.name) === '.json')) {\n                const filePath = path.resolve(fullPath, fi.name);\n                return convertJsonFileSync(filePath, options.converter).onSuccess((payload) => {\n                    return succeed({\n                        filename: fi.name,\n                        item: payload,\n                    });\n                }).onFailure((message) => {\n                    return fail(`${fi.name}: ${message}`);\n                });\n            }\n            return undefined;\n        }).filter((r): r is Result<ReadDirectoryItem<T>> => r !== undefined);\n        return mapResults(results).getValueOrThrow();\n    });\n}\n\nexport type ItemNameTransformFunction<T> = (name: string, item: T) => Result<string>;\n\nexport interface DirectoryToMapConvertOptions<T, TC=unknown> extends DirectoryConvertOptions<T, TC> {\n    transformName?: ItemNameTransformFunction<T>;\n}\n\nconst defaultNameTransformer = (n:string): Result<string> => succeed(n);\n\n/**\n * Reads and converts all JSON files from a directory, returning a map\n * indexed by file base name (i.e. minus the extension) with an optional\n * name transformation applied if present.\n * @param srcPath The path of the folder to be read\n * @param options Options to control conversion and filtering\n */\nexport function convertJsonDirectoryToMapSync<T, TC=unknown>(srcPath: string, options: DirectoryToMapConvertOptions<T, TC>): Result<Map<string, T>> {\n    return convertJsonDirectorySync(srcPath, options).onSuccess((items) => {\n        const transformName = options.transformName ?? defaultNameTransformer;\n        return mapResults(items.map((item) => {\n            const basename = path.basename(item.filename, '.json');\n            return transformName(basename, item.item).onSuccess((name) => {\n                return succeed<[string, T]>([name, item.item]);\n            });\n        })).onSuccess((items) => {\n            return succeed(new Map<string, T>(items));\n        });\n    });\n}\n\n/**\n * Convenience function to write type-safe JSON to a file\n * @param srcPath Path of the file to write\n * @param value The JSON object to be written\n */\nexport function writeJsonFileSync(srcPath: string, value: JsonValue): Result<boolean> {\n    return captureResult(() => {\n        const fullPath = path.resolve(srcPath);\n        fs.writeFileSync(fullPath, JSON.stringify(value, undefined, 2));\n        return true;\n    });\n}\n"]}
|
|
140
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file.js","sourceRoot":"","sources":["../src/file.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 * as fs from 'fs';\nimport * as path from 'path';\nimport { Converter, Result, captureResult, fail, mapResults, succeed } from '@fgv/ts-utils';\n\nimport { JsonValue } from './common';\n\n/**\n * Convenience function to read type-safe JSON from a file\n * @param srcPath Path of the file to read\n */\nexport function readJsonFileSync(srcPath: string): Result<JsonValue> {\n    return captureResult(() => {\n        const fullPath = path.resolve(srcPath);\n        const body = fs.readFileSync(fullPath, 'utf8').toString();\n        return JSON.parse(body) as JsonValue;\n    });\n}\n\n/**\n * Convenience function to read a JSON file and apply a supplied converter\n * @param srcPath Path of the file to read\n * @param converter Converter used to convert the file contents\n */\nexport function convertJsonFileSync<T>(srcPath: string, converter: Converter<T>): Result<T> {\n    return readJsonFileSync(srcPath).onSuccess((json) => {\n        return converter.convert(json);\n    });\n}\n\n/**\n * Options for directory conversion\n * TODO: add filtering, allowed and excluded\n */\nexport interface DirectoryConvertOptions<T, TC=unknown> {\n    /**\n     * The converter used to convert incoming JSON objects\n     */\n    converter: Converter<T, TC>;\n}\n\n/**\n * Return value for one item in a directory conversion\n */\nexport interface ReadDirectoryItem<T> {\n    /**\n     * Relative name of the file that was processed\n     */\n    filename: string;\n\n    /**\n     * The payload of the file\n     */\n    item: T;\n}\n\n/**\n * Reads all JSON files from a directory and apply a supplied converter\n * @param srcPath The path of the folder to be read\n * @param options Options to control conversion and filtering\n */\nexport function convertJsonDirectorySync<T>(srcPath: string, options: DirectoryConvertOptions<T>): Result<ReadDirectoryItem<T>[]> {\n    return captureResult<ReadDirectoryItem<T>[]>(() => {\n        const fullPath = path.resolve(srcPath);\n        if (!fs.statSync(fullPath).isDirectory()) {\n            throw new Error(`${fullPath}: Not a directory`);\n        }\n        const files = fs.readdirSync(fullPath, { withFileTypes: true });\n        const results = files.map((fi) => {\n            if (fi.isFile() && (path.extname(fi.name) === '.json')) {\n                const filePath = path.resolve(fullPath, fi.name);\n                return convertJsonFileSync(filePath, options.converter).onSuccess((payload) => {\n                    return succeed({\n                        filename: fi.name,\n                        item: payload,\n                    });\n                }).onFailure((message) => {\n                    return fail(`${fi.name}: ${message}`);\n                });\n            }\n            return undefined;\n        }).filter((r): r is Result<ReadDirectoryItem<T>> => r !== undefined);\n        return mapResults(results).getValueOrThrow();\n    });\n}\n\nexport type ItemNameTransformFunction<T> = (name: string, item: T) => Result<string>;\n\nexport interface DirectoryToMapConvertOptions<T, TC=unknown> extends DirectoryConvertOptions<T, TC> {\n    transformName?: ItemNameTransformFunction<T>;\n}\n\nconst defaultNameTransformer = (n:string): Result<string> => succeed(n);\n\n/**\n * Reads and converts all JSON files from a directory, returning a map\n * indexed by file base name (i.e. minus the extension) with an optional\n * name transformation applied if present.\n * @param srcPath The path of the folder to be read\n * @param options Options to control conversion and filtering\n */\nexport function convertJsonDirectoryToMapSync<T, TC=unknown>(srcPath: string, options: DirectoryToMapConvertOptions<T, TC>): Result<Map<string, T>> {\n    return convertJsonDirectorySync(srcPath, options).onSuccess((items) => {\n        const transformName = options.transformName ?? defaultNameTransformer;\n        return mapResults(items.map((item) => {\n            const basename = path.basename(item.filename, '.json');\n            return transformName(basename, item.item).onSuccess((name) => {\n                return succeed<[string, T]>([name, item.item]);\n            });\n        })).onSuccess((items) => {\n            return succeed(new Map<string, T>(items));\n        });\n    });\n}\n\n/**\n * Convenience function to write type-safe JSON to a file\n * @param srcPath Path of the file to write\n * @param value The JSON object to be written\n */\nexport function writeJsonFileSync(srcPath: string, value: JsonValue): Result<boolean> {\n    return captureResult(() => {\n        const fullPath = path.resolve(srcPath);\n        fs.writeFileSync(fullPath, JSON.stringify(value, undefined, 2));\n        return true;\n    });\n}\n"]}
|
package/index.d.ts
CHANGED
|
File without changes
|
package/index.js
CHANGED
|
@@ -22,7 +22,11 @@
|
|
|
22
22
|
*/
|
|
23
23
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
24
24
|
if (k2 === undefined) k2 = k;
|
|
25
|
-
Object.
|
|
25
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
26
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
27
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
28
|
+
}
|
|
29
|
+
Object.defineProperty(o, k2, desc);
|
|
26
30
|
}) : (function(o, m, k, k2) {
|
|
27
31
|
if (k2 === undefined) k2 = k;
|
|
28
32
|
o[k2] = m[k];
|
|
@@ -54,4 +58,4 @@ Object.defineProperty(exports, "PrefixedJsonMap", { enumerable: true, get: funct
|
|
|
54
58
|
Object.defineProperty(exports, "SimpleJsonMap", { enumerable: true, get: function () { return jsonReferenceMap_1.SimpleJsonMap; } });
|
|
55
59
|
exports.Converters = __importStar(require("./converters"));
|
|
56
60
|
exports.File = __importStar(require("./file"));
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9CRzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFSCwyQ0FBeUI7QUFDekIsa0RBQWdDO0FBQ2hDLDBEQUF3QztBQUV4QyxrRUFBa0Q7QUFDbEQsdURBSTRCO0FBSHhCLG9IQUFBLGdCQUFnQixPQUFBO0FBQ2hCLG1IQUFBLGVBQWUsT0FBQTtBQUNmLGlIQUFBLGFBQWEsT0FBQTtBQVFqQiwyREFBMkM7QUFDM0MsK0NBQStCIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAyMCBFcmlrIEZvcnR1bmVcbiAqXG4gKiBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBvYnRhaW5pbmcgYSBjb3B5XG4gKiBvZiB0aGlzIHNvZnR3YXJlIGFuZCBhc3NvY2lhdGVkIGRvY3VtZW50YXRpb24gZmlsZXMgKHRoZSBcIlNvZnR3YXJlXCIpLCB0byBkZWFsXG4gKiBpbiB0aGUgU29mdHdhcmUgd2l0aG91dCByZXN0cmljdGlvbiwgaW5jbHVkaW5nIHdpdGhvdXQgbGltaXRhdGlvbiB0aGUgcmlnaHRzXG4gKiB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsIGRpc3RyaWJ1dGUsIHN1YmxpY2Vuc2UsIGFuZC9vciBzZWxsXG4gKiBjb3BpZXMgb2YgdGhlIFNvZnR3YXJlLCBhbmQgdG8gcGVybWl0IHBlcnNvbnMgdG8gd2hvbSB0aGUgU29mdHdhcmUgaXNcbiAqIGZ1cm5pc2hlZCB0byBkbyBzbywgc3ViamVjdCB0byB0aGUgZm9sbG93aW5nIGNvbmRpdGlvbnM6XG4gKlxuICogVGhlIGFib3ZlIGNvcHlyaWdodCBub3RpY2UgYW5kIHRoaXMgcGVybWlzc2lvbiBub3RpY2Ugc2hhbGwgYmUgaW5jbHVkZWQgaW4gYWxsXG4gKiBjb3BpZXMgb3Igc3Vic3RhbnRpYWwgcG9ydGlvbnMgb2YgdGhlIFNvZnR3YXJlLlxuICpcbiAqIFRIRSBTT0ZUV0FSRSBJUyBQUk9WSURFRCBcIkFTIElTXCIsIFdJVEhPVVQgV0FSUkFOVFkgT0YgQU5ZIEtJTkQsIEVYUFJFU1MgT1JcbiAqIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE8gVEhFIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZLFxuICogRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQU5EIE5PTklORlJJTkdFTUVOVC4gSU4gTk8gRVZFTlQgU0hBTEwgVEhFXG4gKiBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFIExJQUJMRSBGT1IgQU5ZIENMQUlNLCBEQU1BR0VTIE9SIE9USEVSXG4gKiBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQU4gQUNUSU9OIE9GIENPTlRSQUNULCBUT1JUIE9SIE9USEVSV0lTRSwgQVJJU0lORyBGUk9NLFxuICogT1VUIE9GIE9SIElOIENPTk5FQ1RJT04gV0lUSCBUSEUgU09GVFdBUkUgT1IgVEhFIFVTRSBPUiBPVEhFUiBERUFMSU5HUyBJTiBUSEVcbiAqIFNPRlRXQVJFLlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vY29tbW9uJztcbmV4cG9ydCAqIGZyb20gJy4vanNvbkNvbnZlcnRlcic7XG5leHBvcnQgKiBmcm9tICcuL2pzb25FZGl0b3IvanNvbkVkaXRvcic7XG5leHBvcnQgeyBKc29uRWRpdG9yT3B0aW9ucywgSnNvbkVkaXRvclZhbGlkYXRpb25PcHRpb25zIH0gZnJvbSAnLi9qc29uRWRpdG9yL2pzb25FZGl0b3JTdGF0ZSc7XG5leHBvcnQgKiBhcyBFZGl0b3JSdWxlcyBmcm9tICcuL2pzb25FZGl0b3IvcnVsZXMnO1xuZXhwb3J0IHtcbiAgICBDb21wb3NpdGVKc29uTWFwLFxuICAgIFByZWZpeGVkSnNvbk1hcCxcbiAgICBTaW1wbGVKc29uTWFwLFxufSBmcm9tICcuL2pzb25SZWZlcmVuY2VNYXAnO1xuZXhwb3J0IHtcbiAgICBKc29uUmVmZXJlbmNlTWFwLFxuICAgIEpzb25SZWZlcmVuY2VNYXBGYWlsdXJlUmVhc29uLFxuICAgIFRlbXBsYXRlVmFycyxcbiAgICBKc29uQ29udGV4dCxcbn0gZnJvbSAnLi9qc29uQ29udGV4dCc7XG5leHBvcnQgKiBhcyBDb252ZXJ0ZXJzIGZyb20gJy4vY29udmVydGVycyc7XG5leHBvcnQgKiBhcyBGaWxlIGZyb20gJy4vZmlsZSc7XG4iXX0=
|
package/jsonContext.d.ts
CHANGED
|
@@ -3,16 +3,16 @@ import { JsonObject, JsonValue } from './common';
|
|
|
3
3
|
/**
|
|
4
4
|
* Collection of variable used for template replacement in a JSON edit or conversion.
|
|
5
5
|
*/
|
|
6
|
-
export
|
|
6
|
+
export type TemplateVars = Record<string, unknown>;
|
|
7
7
|
/**
|
|
8
8
|
* Describes one value in a TemplateVars collection of variables
|
|
9
9
|
*/
|
|
10
|
-
export
|
|
10
|
+
export type VariableValue = [string, unknown];
|
|
11
11
|
/**
|
|
12
12
|
* Function used to create a new collection of template vars with one or more
|
|
13
13
|
* new or changed values.
|
|
14
14
|
*/
|
|
15
|
-
export
|
|
15
|
+
export type TemplateVarsExtendFunction = (base: TemplateVars | undefined, values: VariableValue[]) => Result<TemplateVars | undefined>;
|
|
16
16
|
/**
|
|
17
17
|
* This default implementation of a TemplateVarsExtendFunction creates a new collection
|
|
18
18
|
* via inheritance from the supplied collection
|
|
@@ -25,7 +25,7 @@ export declare function defaultExtendVars(base: TemplateVars | undefined, values
|
|
|
25
25
|
* that the object is not present in the map and 'error' means
|
|
26
26
|
* that an error occurred while retrieving or converting it.
|
|
27
27
|
*/
|
|
28
|
-
export
|
|
28
|
+
export type JsonReferenceMapFailureReason = 'unknown' | 'error';
|
|
29
29
|
/**
|
|
30
30
|
* Interface for a simple map that returns named @see JsonValue values with templating, conditional logic,
|
|
31
31
|
* and external reference lookups applied using an optionally supplied context.
|
package/jsonContext.js
CHANGED
|
@@ -34,7 +34,7 @@ function defaultExtendVars(base, values) {
|
|
|
34
34
|
for (const v of values) {
|
|
35
35
|
rtrn[v[0]] = v[1];
|
|
36
36
|
}
|
|
37
|
-
return ts_utils_1.succeed(rtrn);
|
|
37
|
+
return (0, ts_utils_1.succeed)(rtrn);
|
|
38
38
|
}
|
|
39
39
|
exports.defaultExtendVars = defaultExtendVars;
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoianNvbkNvbnRleHQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvanNvbkNvbnRleHQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9CRzs7O0FBRUgsNENBQWdFO0FBbUJoRTs7Ozs7R0FLRztBQUNILFNBQWdCLGlCQUFpQixDQUFDLElBQTRCLEVBQUUsTUFBdUI7SUFDbkYsTUFBTSxJQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQy9DLEtBQUssTUFBTSxDQUFDLElBQUksTUFBTSxFQUFFO1FBQ3BCLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7S0FDckI7SUFDRCxPQUFPLElBQUEsa0JBQU8sRUFBQyxJQUFJLENBQUMsQ0FBQztBQUN6QixDQUFDO0FBTkQsOENBTUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IChjKSAyMDIwIEVyaWsgRm9ydHVuZVxuICpcbiAqIFBlcm1pc3Npb24gaXMgaGVyZWJ5IGdyYW50ZWQsIGZyZWUgb2YgY2hhcmdlLCB0byBhbnkgcGVyc29uIG9idGFpbmluZyBhIGNvcHlcbiAqIG9mIHRoaXMgc29mdHdhcmUgYW5kIGFzc29jaWF0ZWQgZG9jdW1lbnRhdGlvbiBmaWxlcyAodGhlIFwiU29mdHdhcmVcIiksIHRvIGRlYWxcbiAqIGluIHRoZSBTb2Z0d2FyZSB3aXRob3V0IHJlc3RyaWN0aW9uLCBpbmNsdWRpbmcgd2l0aG91dCBsaW1pdGF0aW9uIHRoZSByaWdodHNcbiAqIHRvIHVzZSwgY29weSwgbW9kaWZ5LCBtZXJnZSwgcHVibGlzaCwgZGlzdHJpYnV0ZSwgc3VibGljZW5zZSwgYW5kL29yIHNlbGxcbiAqIGNvcGllcyBvZiB0aGUgU29mdHdhcmUsIGFuZCB0byBwZXJtaXQgcGVyc29ucyB0byB3aG9tIHRoZSBTb2Z0d2FyZSBpc1xuICogZnVybmlzaGVkIHRvIGRvIHNvLCBzdWJqZWN0IHRvIHRoZSBmb2xsb3dpbmcgY29uZGl0aW9uczpcbiAqXG4gKiBUaGUgYWJvdmUgY29weXJpZ2h0IG5vdGljZSBhbmQgdGhpcyBwZXJtaXNzaW9uIG5vdGljZSBzaGFsbCBiZSBpbmNsdWRlZCBpbiBhbGxcbiAqIGNvcGllcyBvciBzdWJzdGFudGlhbCBwb3J0aW9ucyBvZiB0aGUgU29mdHdhcmUuXG4gKlxuICogVEhFIFNPRlRXQVJFIElTIFBST1ZJREVEIFwiQVMgSVNcIiwgV0lUSE9VVCBXQVJSQU5UWSBPRiBBTlkgS0lORCwgRVhQUkVTUyBPUlxuICogSU1QTElFRCwgSU5DTFVESU5HIEJVVCBOT1QgTElNSVRFRCBUTyBUSEUgV0FSUkFOVElFUyBPRiBNRVJDSEFOVEFCSUxJVFksXG4gKiBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRSBBTkQgTk9OSU5GUklOR0VNRU5ULiBJTiBOTyBFVkVOVCBTSEFMTCBUSEVcbiAqIEFVVEhPUlMgT1IgQ09QWVJJR0hUIEhPTERFUlMgQkUgTElBQkxFIEZPUiBBTlkgQ0xBSU0sIERBTUFHRVMgT1IgT1RIRVJcbiAqIExJQUJJTElUWSwgV0hFVEhFUiBJTiBBTiBBQ1RJT04gT0YgQ09OVFJBQ1QsIFRPUlQgT1IgT1RIRVJXSVNFLCBBUklTSU5HIEZST00sXG4gKiBPVVQgT0YgT1IgSU4gQ09OTkVDVElPTiBXSVRIIFRIRSBTT0ZUV0FSRSBPUiBUSEUgVVNFIE9SIE9USEVSIERFQUxJTkdTIElOIFRIRVxuICogU09GVFdBUkUuXG4gKi9cblxuaW1wb3J0IHsgRGV0YWlsZWRSZXN1bHQsIFJlc3VsdCwgc3VjY2VlZCB9IGZyb20gJ0BmZ3YvdHMtdXRpbHMnO1xuaW1wb3J0IHsgSnNvbk9iamVjdCwgSnNvblZhbHVlIH0gZnJvbSAnLi9jb21tb24nO1xuXG4vKipcbiAqIENvbGxlY3Rpb24gb2YgdmFyaWFibGUgdXNlZCBmb3IgdGVtcGxhdGUgcmVwbGFjZW1lbnQgaW4gYSBKU09OIGVkaXQgb3IgY29udmVyc2lvbi5cbiAqL1xuZXhwb3J0IHR5cGUgVGVtcGxhdGVWYXJzID0gUmVjb3JkPHN0cmluZywgdW5rbm93bj47XG5cbi8qKlxuICogRGVzY3JpYmVzIG9uZSB2YWx1ZSBpbiBhIFRlbXBsYXRlVmFycyBjb2xsZWN0aW9uIG9mIHZhcmlhYmxlc1xuICovXG5leHBvcnQgdHlwZSBWYXJpYWJsZVZhbHVlID0gW3N0cmluZywgdW5rbm93bl07XG5cbi8qKlxuICogRnVuY3Rpb24gdXNlZCB0byBjcmVhdGUgYSBuZXcgY29sbGVjdGlvbiBvZiB0ZW1wbGF0ZSB2YXJzIHdpdGggb25lIG9yIG1vcmVcbiAqIG5ldyBvciBjaGFuZ2VkIHZhbHVlcy5cbiAqL1xuZXhwb3J0IHR5cGUgVGVtcGxhdGVWYXJzRXh0ZW5kRnVuY3Rpb24gPSAoYmFzZTogVGVtcGxhdGVWYXJzfHVuZGVmaW5lZCwgdmFsdWVzOiBWYXJpYWJsZVZhbHVlW10pID0+IFJlc3VsdDxUZW1wbGF0ZVZhcnN8dW5kZWZpbmVkPjtcblxuLyoqXG4gKiBUaGlzIGRlZmF1bHQgaW1wbGVtZW50YXRpb24gb2YgYSBUZW1wbGF0ZVZhcnNFeHRlbmRGdW5jdGlvbiBjcmVhdGVzIGEgbmV3IGNvbGxlY3Rpb25cbiAqIHZpYSBpbmhlcml0YW5jZSBmcm9tIHRoZSBzdXBwbGllZCBjb2xsZWN0aW9uXG4gKiBAcGFyYW0gYmFzZSBUaGUgYmFzZSB2YXJpYWJsZXMgdG8gYmUgZXh0ZW5kZW5kXG4gKiBAcGFyYW0gdmFsdWVzIFRoZSB2YWx1ZXMgdG8gYmUgYWRkZWQgb3Igb3ZlcnJpZGRlbiBpbiB0aGUgbmV3IHZhcmlhYmxlc1xuICovXG5leHBvcnQgZnVuY3Rpb24gZGVmYXVsdEV4dGVuZFZhcnMoYmFzZTogVGVtcGxhdGVWYXJzfHVuZGVmaW5lZCwgdmFsdWVzOiBWYXJpYWJsZVZhbHVlW10pOiBSZXN1bHQ8VGVtcGxhdGVWYXJzfHVuZGVmaW5lZD4ge1xuICAgIGNvbnN0IHJ0cm4gPSAoYmFzZSA/IE9iamVjdC5jcmVhdGUoYmFzZSkgOiB7fSk7XG4gICAgZm9yIChjb25zdCB2IG9mIHZhbHVlcykge1xuICAgICAgICBydHJuW3ZbMF1dID0gdlsxXTtcbiAgICB9XG4gICAgcmV0dXJuIHN1Y2NlZWQocnRybik7XG59XG5cbi8qKlxuICogRmFpbHVyZSByZWFzb24gZm9yIEBzZWUgSnNvblJlZmVyZW5jZU1hcCBsb29rdXAsIHdoZXJlICd1bmtub3duJyBtZWFuc1xuICogdGhhdCB0aGUgb2JqZWN0IGlzIG5vdCBwcmVzZW50IGluIHRoZSBtYXAgYW5kICdlcnJvcicgbWVhbnNcbiAqIHRoYXQgYW4gZXJyb3Igb2NjdXJyZWQgd2hpbGUgcmV0cmlldmluZyBvciBjb252ZXJ0aW5nIGl0LlxuICovXG5leHBvcnQgdHlwZSBKc29uUmVmZXJlbmNlTWFwRmFpbHVyZVJlYXNvbiA9ICd1bmtub3duJ3wnZXJyb3InO1xuXG4vKipcbiAqIEludGVyZmFjZSBmb3IgYSBzaW1wbGUgbWFwIHRoYXQgcmV0dXJucyBuYW1lZCBAc2VlIEpzb25WYWx1ZSB2YWx1ZXMgd2l0aCB0ZW1wbGF0aW5nLCBjb25kaXRpb25hbCBsb2dpYyxcbiAqIGFuZCBleHRlcm5hbCByZWZlcmVuY2UgbG9va3VwcyBhcHBsaWVkIHVzaW5nIGFuIG9wdGlvbmFsbHkgc3VwcGxpZWQgY29udGV4dC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBKc29uUmVmZXJlbmNlTWFwIHtcbiAgICAvKipcbiAgICAgKiBEZXRlcm1pbmUgaWYgYSBrZXkgbWlnaHQgYmUgdmFsaWQgZm9yIHRoaXMgbWFwIGJ1dCBkb2VzIG5vdCBkZXRlcm1pbmUgaWYga2V5IGFjdHVhbGx5XG4gICAgICogZXhpc3RzLiBBbGxvd3Mga2V5IHJhbmdlIHRvIGJlIGNvbnN0cmFpbmVkLlxuICAgICAqIEBwYXJhbSBrZXkga2V5IHRvIGJlIHRlc3RlZFxuICAgICAqIEByZXR1cm5zIHRydWUgaWYgdGhlIGtleSBpcyBpbiB0aGUgdmFsaWQgcmFuZ2UsIGZhbHNlIG90aGVyd2lzZS5cbiAgICAgKi9cbiAgICBrZXlJc0luUmFuZ2Uoa2V5OiBzdHJpbmcpOiBib29sZWFuO1xuXG4gICAgLyoqXG4gICAgICogRGV0ZXJtaW5lcyBpZiBhbiBvYmplY3Qgd2l0aCB0aGUgc3BlY2lmaWVkIGtleSBhY3R1YWxseSBleGlzdHMgaW4gdGhlIG1hcC5cbiAgICAgKiBAcGFyYW0ga2V5IGtleSB0byBiZSB0ZXN0ZWRcbiAgICAgKiBAcmV0dXJucyB0cnVlIGlmIGFuIG9iamVjdCB3aXRoIHRoZSBzcGVjaWZpZWQga2V5IGV4aXN0cywgZmFsc2Ugb3RoZXJ3aXNlLlxuICAgICAqL1xuICAgIGhhcyhrZXk6IHN0cmluZyk6IGJvb2xlYW47XG5cbiAgICAvKipcbiAgICAgKiBHZXRzIGEgSlNPTiBvYmplY3Qgc3BlY2lmaWVkIGJ5IGtleS5cbiAgICAgKiBAcGFyYW0ga2V5IGtleSBvZiB0aGUgb2JqZWN0IHRvIGJlIHJldHJpZXZlZFxuICAgICAqIEBwYXJhbSB2YXJzIG9wdGlvbmFsIHZhcmlhYmxlcyB1c2VkIHRvIGZvcm1hdCB0aGUgb2JqZWN0XG4gICAgICogQHBhcmFtIHJlZnMgb3B0aW9uYWwgb2JqZWN0IG1hcCB0byByZXNvbHZlIGV4dGVybmFsIHJlZmVyZW5jZXNcbiAgICAgKiBAcmV0dXJucyBTdWNjZXNzIHdpdGggdGhlIGZvcm1hdHRlZCBvYmplY3QgaWYgc3VjY2Vzc2Z1bC4gRmFpbHVyZSB3aXRoIGRldGFpbCAndW5rbm93bidcbiAgICAgKiBpZiBubyBzdWNoIG9iamVjdCBleGlzdHMsIG9yIGZhaWx1cmUgd2l0aCBkZXRhaWwgJ2Vycm9yJyBpZiB0aGUgb2JqZWN0IHdhcyBmb3VuZCBidXRcbiAgICAgKiBjb3VsZCBub3QgYmUgZm9ybWF0dGVkLlxuICAgICAqL1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby11c2UtYmVmb3JlLWRlZmluZVxuICAgIGdldEpzb25PYmplY3Qoa2V5OiBzdHJpbmcsIGNvbnRleHQ/OiBKc29uQ29udGV4dCk6IERldGFpbGVkUmVzdWx0PEpzb25PYmplY3QsIEpzb25SZWZlcmVuY2VNYXBGYWlsdXJlUmVhc29uPjtcblxuICAgIC8qKlxuICAgICAqIEdldHMgYSBKU09OIHZhbHVlIHNwZWNpZmllZCBieSBrZXkuXG4gICAgICogQHBhcmFtIGtleSBrZXkgb2YgdGhlIG9iamVjdCB0byBiZSByZXRyaWV2ZWRcbiAgICAgKiBAcGFyYW0gY29udGV4dCBPcHRpb25hbCBAc2VlIEpzb25Db250ZXh0IHVzZWQgdG8gZm9ybWF0IHRoZSB2YWx1ZVxuICAgICAqIEByZXR1cm5zIFN1Y2Nlc3Mgd2l0aCB0aGUgZm9ybWF0dGVkIG9iamVjdCBpZiBzdWNjZXNzZnVsLiBGYWlsdXJlIHdpdGggZGV0YWlsICd1bmtub3duJ1xuICAgICAqIGlmIG5vIHN1Y2ggb2JqZWN0IGV4aXN0cywgb3IgZmFpbHVyZSB3aXRoIGRldGFpbCAnZXJyb3InIGlmIHRoZSBvYmplY3Qgd2FzIGZvdW5kIGJ1dFxuICAgICAqIGNvdWxkIG5vdCBiZSBmb3JtYXR0ZWQuXG4gICAgICovXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXVzZS1iZWZvcmUtZGVmaW5lXG4gICAgZ2V0SnNvblZhbHVlKGtleTogc3RyaW5nLCBjb250ZXh0PzogSnNvbkNvbnRleHQpOiBEZXRhaWxlZFJlc3VsdDxKc29uVmFsdWUsIEpzb25SZWZlcmVuY2VNYXBGYWlsdXJlUmVhc29uPjtcbn1cblxuLyoqXG4gKiBDb250ZXh0IHVzZWQgdG8gY29udmVydCBvciBlZGl0IEpTT04gb2JqZWN0cy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBKc29uQ29udGV4dCB7XG4gICAgdmFycz86IFRlbXBsYXRlVmFycztcbiAgICByZWZzPzogSnNvblJlZmVyZW5jZU1hcDtcbiAgICBleHRlbmRWYXJzPzogVGVtcGxhdGVWYXJzRXh0ZW5kRnVuY3Rpb247XG59XG5cbiJdfQ==
|
package/jsonConverter.d.ts
CHANGED
|
@@ -164,7 +164,7 @@ export declare class JsonConverter extends JsonEditorConverter {
|
|
|
164
164
|
*/
|
|
165
165
|
static create(options?: Partial<JsonConverterOptions>): Result<JsonConverter>;
|
|
166
166
|
}
|
|
167
|
-
export
|
|
167
|
+
export type TemplatedJsonConverterOptions = Omit<JsonConverterOptions, 'useNameTemplates' | 'useValueTemplates' | 'useMultivalueTemplateNmes'>;
|
|
168
168
|
/**
|
|
169
169
|
* A ts-utils @see Converter from unknown to type-safe JSON with mustache
|
|
170
170
|
* template rendering and multi-value property name rules enabled regardless
|
|
@@ -185,7 +185,7 @@ export declare class TemplatedJsonConverter extends JsonEditorConverter {
|
|
|
185
185
|
*/
|
|
186
186
|
static create(options?: Partial<TemplatedJsonConverterOptions>): Result<JsonConverter>;
|
|
187
187
|
}
|
|
188
|
-
export
|
|
188
|
+
export type ConditionalJsonConverterOptions = Omit<TemplatedJsonConverterOptions, 'useConditionalNames'>;
|
|
189
189
|
/**
|
|
190
190
|
* A ts-utils @see Converter from unknown to type-safe JSON with mustache
|
|
191
191
|
* template rendering, multi-value property name and conditional property
|
|
@@ -206,7 +206,7 @@ export declare class ConditionalJsonConverter extends JsonEditorConverter {
|
|
|
206
206
|
*/
|
|
207
207
|
static create(options?: Partial<ConditionalJsonConverterOptions>): Result<JsonConverter>;
|
|
208
208
|
}
|
|
209
|
-
export
|
|
209
|
+
export type RichJsonConverterOptions = Omit<ConditionalJsonConverterOptions, 'useReferences'>;
|
|
210
210
|
/**
|
|
211
211
|
* A ts-utils @see Converter from unknown to type-safe JSON with mustache
|
|
212
212
|
* template rendering, multi-value property name, conditional property
|