@fgv/ts-json 1.0.1 → 1.8.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/jsonConverter.js CHANGED
@@ -140,7 +140,7 @@ class JsonEditorConverter extends ts_utils_1.BaseConverter {
140
140
  * @param editor
141
141
  */
142
142
  static createWithEditor(editor) {
143
- return ts_utils_1.captureResult(() => new JsonEditorConverter(editor));
143
+ return (0, ts_utils_1.captureResult)(() => new JsonEditorConverter(editor));
144
144
  }
145
145
  /**
146
146
  * Gets a derived converter which fails if the resulting converted
@@ -148,10 +148,10 @@ class JsonEditorConverter extends ts_utils_1.BaseConverter {
148
148
  */
149
149
  object() {
150
150
  return this.map((jv) => {
151
- if (!common_1.isJsonObject(jv)) {
152
- return ts_utils_1.fail(`Cannot convert "${JSON.stringify(jv)}" to JSON object.`);
151
+ if (!(0, common_1.isJsonObject)(jv)) {
152
+ return (0, ts_utils_1.fail)(`Cannot convert "${JSON.stringify(jv)}" to JSON object.`);
153
153
  }
154
- return ts_utils_1.succeed(jv);
154
+ return (0, ts_utils_1.succeed)(jv);
155
155
  });
156
156
  }
157
157
  /**
@@ -161,9 +161,9 @@ class JsonEditorConverter extends ts_utils_1.BaseConverter {
161
161
  array() {
162
162
  return this.map((jv) => {
163
163
  if ((!Array.isArray(jv)) || (typeof jv !== 'object')) {
164
- return ts_utils_1.fail(`Cannot convert "${JSON.stringify(jv)}" to JSON array.`);
164
+ return (0, ts_utils_1.fail)(`Cannot convert "${JSON.stringify(jv)}" to JSON array.`);
165
165
  }
166
- return ts_utils_1.succeed(jv);
166
+ return (0, ts_utils_1.succeed)(jv);
167
167
  });
168
168
  }
169
169
  _convert(from, context) {
@@ -181,17 +181,17 @@ class JsonConverter extends JsonEditorConverter {
181
181
  * @param options Optional options to configure the converter
182
182
  */
183
183
  constructor(options) {
184
- const editor = converterOptionsToEditor(options).getValueOrThrow();
184
+ const editor = converterOptionsToEditor(options).orThrow();
185
185
  super(editor);
186
186
  }
187
187
  /**
188
188
  * Creates a new converter.
189
- * @param options Optional options to conifgure the converter
189
+ * @param options Optional options to configure the converter
190
190
  * @returns Success with a new JsonConverter on success, or Failure with an
191
191
  * informative message if an error occurs.
192
192
  */
193
193
  static create(options) {
194
- return ts_utils_1.captureResult(() => new JsonConverter(options));
194
+ return (0, ts_utils_1.captureResult)(() => new JsonConverter(options));
195
195
  }
196
196
  }
197
197
  exports.JsonConverter = JsonConverter;
@@ -208,7 +208,7 @@ class TemplatedJsonConverter extends JsonEditorConverter {
208
208
  */
209
209
  constructor(options) {
210
210
  options = { ...options, ...TemplatedJsonConverter.templateOptions };
211
- const editor = converterOptionsToEditor(options).getValueOrThrow();
211
+ const editor = converterOptionsToEditor(options).orThrow();
212
212
  super(editor);
213
213
  }
214
214
  /**
@@ -217,7 +217,7 @@ class TemplatedJsonConverter extends JsonEditorConverter {
217
217
  * @param options Optional configuration or context for the converter
218
218
  */
219
219
  static create(options) {
220
- return ts_utils_1.captureResult(() => new TemplatedJsonConverter(options));
220
+ return (0, ts_utils_1.captureResult)(() => new TemplatedJsonConverter(options));
221
221
  }
222
222
  }
223
223
  exports.TemplatedJsonConverter = TemplatedJsonConverter;
@@ -241,7 +241,7 @@ class ConditionalJsonConverter extends JsonEditorConverter {
241
241
  */
242
242
  constructor(options) {
243
243
  options = { ...options, ...ConditionalJsonConverter.conditionalOptions };
244
- const editor = converterOptionsToEditor(options).getValueOrThrow();
244
+ const editor = converterOptionsToEditor(options).orThrow();
245
245
  super(editor);
246
246
  }
247
247
  /**
@@ -250,7 +250,7 @@ class ConditionalJsonConverter extends JsonEditorConverter {
250
250
  * @param options Optional configuration or context for the converter
251
251
  */
252
252
  static create(options) {
253
- return ts_utils_1.captureResult(() => new ConditionalJsonConverter(options));
253
+ return (0, ts_utils_1.captureResult)(() => new ConditionalJsonConverter(options));
254
254
  }
255
255
  }
256
256
  exports.ConditionalJsonConverter = ConditionalJsonConverter;
@@ -272,7 +272,7 @@ class RichJsonConverter extends JsonEditorConverter {
272
272
  */
273
273
  constructor(options) {
274
274
  options = { ...options, ...RichJsonConverter.richOptions };
275
- const editor = converterOptionsToEditor(options).getValueOrThrow();
275
+ const editor = converterOptionsToEditor(options).orThrow();
276
276
  super(editor);
277
277
  }
278
278
  /**
@@ -281,7 +281,7 @@ class RichJsonConverter extends JsonEditorConverter {
281
281
  * @param options Optional configuration or context for the converter
282
282
  */
283
283
  static create(options) {
284
- return ts_utils_1.captureResult(() => new RichJsonConverter(options));
284
+ return (0, ts_utils_1.captureResult)(() => new RichJsonConverter(options));
285
285
  }
286
286
  }
287
287
  exports.RichJsonConverter = RichJsonConverter;
@@ -289,4 +289,4 @@ RichJsonConverter.richOptions = {
289
289
  ...ConditionalJsonConverter.conditionalOptions,
290
290
  useReferences: true,
291
291
  };
292
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jsonConverter.js","sourceRoot":"","sources":["../src/jsonConverter.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2020 Erik Fortune\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\n\nimport {\n    BaseConverter,\n    Converter,\n    Result,\n    captureResult,\n    fail,\n    succeed,\n} from '@fgv/ts-utils';\nimport {\n    ConditionalJsonEditorRule,\n    MultiValueJsonEditorRule,\n    ReferenceJsonEditorRule,\n    TemplatedJsonEditorRule,\n} from './jsonEditor/rules';\nimport { JsonArray, JsonObject, JsonValue, isJsonObject } from './common';\nimport {\n    JsonContext,\n    JsonReferenceMap,\n    TemplateVars,\n    TemplateVarsExtendFunction,\n    defaultExtendVars,\n} from './jsonContext';\n\nimport { JsonEditor } from './jsonEditor/jsonEditor';\nimport { JsonEditorOptions } from './jsonEditor/jsonEditorState';\nimport { JsonEditorRule } from './jsonEditor/jsonEditorRule';\n\n/**\n * Conversion options for JsonConverter\n */\nexport interface JsonConverterOptions {\n    /**\n     * If true and if template variables are available,\n     * then string property values will be rendered using\n     * mustache and those variables. Otherwise string properties\n     * are copied without modification.\n     *\n     * Defaults to true if vars are supplied with options,\n     * false otherwise.\n     */\n    useValueTemplates: boolean;\n\n    /**\n     * If true and if template variables are available,\n     * then string property names will be rendered using\n     * mustache and those variables. Otherwise string properties\n     * are copied without modification.\n     *\n     * Defaults to true if vars are supplied with options,\n     * false otherwise.\n     */\n    useNameTemplates: boolean;\n\n    /**\n     * If true and if template variables are available,\n     * then string property names will be considered for\n     * conditionals.\n     *\n     * Default is to match useNameTemplates\n     */\n    useConditionalNames: boolean;\n\n    /**\n     * If true (default) then properties with unconditional names\n     * (which start with !) are flattened.\n     */\n    flattenUnconditionalValues: boolean;\n\n    /**\n     * If true and if both template variables and a\n     * context derivation function is available, then properties\n     * which match the multi-value name pattern will be expanded.\n     * Default matches useNameTemplates.\n     *\n     * Default is true unless extendVars is explicitly set to\n     * undefined.\n     */\n    useMultiValueTemplateNames: boolean;\n\n    /**\n     * The variables (mustache view) used to render templated string names\n     * and properties.  See the mustache documentation for details of mustache\n     * syntax and the template view.\n     */\n    vars?: TemplateVars;\n\n    /**\n     * Method used to extend variables for children of an array node during\n     * expansion. Default is to use a built-in extension function unless\n     * extendVars is explicitly set to undefined.\n     */\n    extendVars?: TemplateVarsExtendFunction;\n\n    /**\n     * If true and if a references map is supplied, then\n     * references in the source object will be replaced with\n     * the corresponding value from the map.\n     *\n     * Default is true if refs are present in options, false\n     * otherwise.\n     */\n    useReferences: boolean;\n\n    /**\n     * An optional object map used to insert any references in the\n     * converted JSON.\n     */\n    refs?: JsonReferenceMap;\n\n    /**\n     * If onInvalidPropertyName is 'error' (default) then any property name\n     * that is invalid after template rendering causes an error and stops\n     * conversion.  If onInvalidPropertyName is 'ignore', then names which\n     * are invalid after template rendering are passed through unchanged.\n     */\n    onInvalidPropertyName: 'error'|'ignore';\n\n    /**\n     * If onInvalidPropertyVaule is 'error' (default) then any illegal\n     * property value causes an error and stops conversion.  If\n     * onInvalidPropertyValue is 'ignore' then any invalid property\n     * values are silently ignored.\n     */\n    onInvalidPropertyValue: 'error'|'ignore';\n\n    /**\n     * If onUnknownPropertyValue is error, then any property with\n     * value undefined will cause an error and stop conversion.  If\n     * onUndefinedPropertyValue is 'ignore' (default) then any\n     * property with value undefined is silently ignored.\n     */\n    onUndefinedPropertyValue: 'error'|'ignore';\n}\n\n/**\n * Merges an optionally supplied partial set of options with the default\n * converter options, producing a fully-resolved set of ConverterOptions\n * and taking all dynamic rules into account (e.g. template usage enabled\n * if variables are supplied and disabled if not)\n * @param partial An optional partial @see JsonConverterOptions to be merged\n */\nexport function mergeDefaultJsonConverterOptions(partial?: Partial<JsonConverterOptions>): JsonConverterOptions {\n    const haveVars = (partial?.vars !== undefined);\n    const haveRefs = (partial?.refs !== undefined);\n    const extender = partial?.hasOwnProperty('extendVars') ? partial.extendVars : defaultExtendVars;\n    const haveExtender = (extender !== undefined);\n    const namesDefault = (partial?.useNameTemplates ?? haveVars);\n    const conditionsDefault = (partial?.useConditionalNames ?? namesDefault);\n\n    const options: JsonConverterOptions = {\n        useValueTemplates: partial?.useValueTemplates ?? haveVars,\n        useNameTemplates: namesDefault,\n        useConditionalNames: conditionsDefault,\n        flattenUnconditionalValues: partial?.flattenUnconditionalValues ?? conditionsDefault,\n        useMultiValueTemplateNames: partial?.useMultiValueTemplateNames ?? (haveExtender && namesDefault),\n        useReferences: partial?.useReferences ?? haveRefs,\n        onInvalidPropertyName: partial?.onInvalidPropertyName ?? 'error',\n        onInvalidPropertyValue: partial?.onInvalidPropertyValue ?? 'error',\n        onUndefinedPropertyValue: partial?.onUndefinedPropertyValue ?? 'ignore',\n        extendVars: extender,\n    };\n    if (partial?.vars) {\n        options.vars = partial.vars;\n    }\n    if (partial?.refs) {\n        options.refs = partial.refs;\n    }\n    return options;\n}\n\n/**\n * Creates a new @see JsonContext using values supplied in an optional partial\n * @see JsonConverterOptions\n * @param partial Optional partial @see JsonConverterOptions used to populate the context\n */\nexport function contextFromConverterOptions(partial?: Partial<JsonConverterOptions>): JsonContext|undefined {\n    const context: JsonContext = {};\n    if (partial?.vars) {\n        context.vars = partial.vars;\n    }\n    if (partial?.refs) {\n        context.refs = partial.refs;\n    }\n    if (partial?.hasOwnProperty('extendVars')) {\n        context.extendVars = partial.extendVars;\n    }\n    return (context.vars || context.refs || context.extendVars) ? context : undefined;\n}\n\n/**\n * Creates a new @see JsonEditor from an optionally supplied partial @see JsonConverterOptions.\n * Expands supplied options with default values and constructs an editor with\n * matching configuration and defined rules.\n * @param partial Optional partial @see JsonConverterOptions used to create the editor\n */\nexport function converterOptionsToEditor(partial?: Partial<JsonConverterOptions>): Result<JsonEditor> {\n    const converterOptions = mergeDefaultJsonConverterOptions(partial);\n    const context = contextFromConverterOptions(partial);\n    const validation = {\n        onInvalidPropertyName: converterOptions.onInvalidPropertyName,\n        onInvalidPropertyValue: converterOptions.onInvalidPropertyValue,\n        onUndefinedPropertyValue: converterOptions.onUndefinedPropertyValue,\n    };\n    const editorOptions: JsonEditorOptions = { context, validation };\n\n    const rules: JsonEditorRule[] = [];\n    if (converterOptions.useNameTemplates || converterOptions.useValueTemplates) {\n        const templateOptions = {\n            ...editorOptions,\n            useNameTemplates: converterOptions.useNameTemplates,\n            useValueTemplates: converterOptions.useValueTemplates,\n        };\n        rules.push(new TemplatedJsonEditorRule(templateOptions));\n    }\n    if (converterOptions.useConditionalNames || converterOptions.flattenUnconditionalValues) {\n        const conditionalOptions = {\n            ...editorOptions,\n            flattenUnconditionalValues: converterOptions.flattenUnconditionalValues,\n        };\n        rules.push(new ConditionalJsonEditorRule(conditionalOptions));\n    }\n    if (converterOptions.useMultiValueTemplateNames) {\n        rules.push(new MultiValueJsonEditorRule(editorOptions));\n    }\n    if (converterOptions.useReferences) {\n        rules.push(new ReferenceJsonEditorRule(editorOptions));\n    }\n\n    return JsonEditor.create(editorOptions, rules);\n}\n\n/**\n * A thin wrapper to allow an arbitrary @see JsonEditor to be used via the\n * ts-utils @see Converter pattern.\n */\nexport class JsonEditorConverter extends BaseConverter<JsonValue, JsonContext> {\n    public editor: JsonEditor;\n\n    /**\n     * Constructs a new @see JsonEditorConverter which uses the supplied editor\n     * @param editor\n     */\n    public constructor(editor: JsonEditor) {\n        super(\n            (from, _self, context) => this._convert(from, context),\n            editor.options.context,\n        );\n        this.editor = editor;\n    }\n\n    /**\n     * Constructs a new @see JsonEditorConverter which uses the supplied editor\n     * @param editor\n     */\n    public static createWithEditor(editor: JsonEditor): Result<JsonEditorConverter> {\n        return captureResult(() => new JsonEditorConverter(editor));\n    }\n\n    /**\n     * Gets a derived converter which fails if the resulting converted\n     * @see JsonValue is not a @see JsonObject\n     */\n    public object(): Converter<JsonObject, JsonContext> {\n        return this.map((jv) => {\n            if (!isJsonObject(jv)) {\n                return fail(`Cannot convert \"${JSON.stringify(jv)}\" to JSON object.`);\n            }\n            return succeed(jv);\n        });\n    }\n\n    /**\n     * Gets a derived converter which fails if the resulting converted\n     * @see JsonValue is not a @see JsonArray\n     */\n    public array(): Converter<JsonArray, JsonContext> {\n        return this.map((jv) => {\n            if ((!Array.isArray(jv)) || (typeof jv !== 'object')) {\n                return fail(`Cannot convert \"${JSON.stringify(jv)}\" to JSON array.`);\n            }\n            return succeed(jv);\n        });\n    }\n\n    protected _convert(from: unknown, context?: JsonContext): Result<JsonValue> {\n        return this.editor.clone(from as JsonValue, context);\n    }\n}\n\n/**\n * A ts-utils @see Converter from unknown to type-safe JSON, optionally rendering\n * any string property names or values using mustache with a supplied view.\n */\nexport class JsonConverter extends JsonEditorConverter {\n    /**\n     * Constructs a new JsonConverter with supplied or default options\n     * @param options Optional options to configure the converter\n     */\n    public constructor(options?: Partial<JsonConverterOptions>) {\n        const editor = converterOptionsToEditor(options).getValueOrThrow();\n        super(editor);\n    }\n\n    /**\n     * Creates a new converter.\n     * @param options Optional options to conifgure the converter\n     * @returns Success with a new JsonConverter on success, or Failure with an\n     * informative message if an error occurs.\n     */\n    public static create(options?: Partial<JsonConverterOptions>): Result<JsonConverter> {\n        return captureResult(() => new JsonConverter(options));\n    }\n}\n\nexport type TemplatedJsonConverterOptions = Omit<JsonConverterOptions, 'useNameTemplates'|'useValueTemplates'|'useMultivalueTemplateNmes'>;\n\n/**\n * A ts-utils @see Converter from unknown to type-safe JSON with mustache\n * template rendering and multi-value property name rules enabled regardless\n * of initial context.\n */\nexport class TemplatedJsonConverter extends JsonEditorConverter {\n    public static readonly templateOptions: Partial<JsonConverterOptions> = {\n        useNameTemplates: true,\n        useValueTemplates: true,\n        useMultiValueTemplateNames: true,\n        useConditionalNames: false,\n        flattenUnconditionalValues: false,\n    };\n\n    /**\n     * Constructs a new @see TemplatedJsonConverter with supplied or\n     * default options\n     * @param options Optional configuration or context for the converter\n     */\n    public constructor(options?: Partial<TemplatedJsonConverterOptions>) {\n        options = { ...options, ...TemplatedJsonConverter.templateOptions };\n        const editor = converterOptionsToEditor(options).getValueOrThrow();\n        super(editor);\n    }\n\n    /**\n     * Constructs a new @see TemplatedJsonConverter with supplied or\n     * default options\n     * @param options Optional configuration or context for the converter\n     */\n    public static create(options?: Partial<TemplatedJsonConverterOptions>): Result<JsonConverter> {\n        return captureResult(() => new TemplatedJsonConverter(options));\n    }\n}\n\nexport type ConditionalJsonConverterOptions = Omit<TemplatedJsonConverterOptions, 'useConditionalNames'>;\n\n/**\n * A ts-utils @see Converter from unknown to type-safe JSON with mustache\n * template rendering, multi-value property name and conditional property\n * name rules enabled regardless of initial context.\n */\nexport class ConditionalJsonConverter extends JsonEditorConverter {\n    public static readonly conditionalOptions: Partial<JsonConverterOptions> = {\n        ...TemplatedJsonConverter.templateOptions,\n        useConditionalNames: true,\n        flattenUnconditionalValues: true,\n    };\n\n    /**\n     * Constructs a new @see ConditionalJsonConverter with supplied or\n     * default options\n     * @param options Optional configuration or context for the converter\n     */\n    public constructor(options?: Partial<ConditionalJsonConverterOptions>) {\n        options = { ...options, ...ConditionalJsonConverter.conditionalOptions };\n        const editor = converterOptionsToEditor(options).getValueOrThrow();\n        super(editor);\n    }\n\n    /**\n     * Constructs a new @see ConditionalJsonConverter with supplied or\n     * default options\n     * @param options Optional configuration or context for the converter\n     */\n    public static create(options?: Partial<ConditionalJsonConverterOptions>): Result<JsonConverter> {\n        return captureResult(() => new ConditionalJsonConverter(options));\n    }\n}\n\nexport type RichJsonConverterOptions = Omit<ConditionalJsonConverterOptions, 'useReferences'>;\n\n/**\n * A ts-utils @see Converter from unknown to type-safe JSON with mustache\n * template rendering, multi-value property name, conditional property\n * name, and external reference rules enabled regardless of initial context.\n */\nexport class RichJsonConverter extends JsonEditorConverter {\n    public static readonly richOptions: Partial<JsonConverterOptions> = {\n        ...ConditionalJsonConverter.conditionalOptions,\n        useReferences: true,\n    };\n\n    /**\n     * Constructs a new @see RichJsonConverter with supplied or\n     * default options\n     * @param options Optional configuration or context for the converter\n     */\n    public constructor(options?: Partial<RichJsonConverterOptions>) {\n        options = { ...options, ...RichJsonConverter.richOptions };\n        const editor = converterOptionsToEditor(options).getValueOrThrow();\n        super(editor);\n    }\n\n    /**\n     * Constructs a new @see RichJsonConverter with supplied or\n     * default options\n     * @param options Optional configuration or context for the converter\n     */\n    public static create(options?: Partial<RichJsonConverterOptions>): Result<JsonConverter> {\n        return captureResult(() => new RichJsonConverter(options));\n    }\n}\n"]}
292
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jsonConverter.js","sourceRoot":"","sources":["../src/jsonConverter.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2020 Erik Fortune\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\n\nimport {\n    BaseConverter,\n    Converter,\n    Result,\n    captureResult,\n    fail,\n    succeed,\n} from '@fgv/ts-utils';\nimport {\n    ConditionalJsonEditorRule,\n    MultiValueJsonEditorRule,\n    ReferenceJsonEditorRule,\n    TemplatedJsonEditorRule,\n} from './jsonEditor/rules';\nimport { JsonArray, JsonObject, JsonValue, isJsonObject } from './common';\nimport {\n    JsonContext,\n    JsonReferenceMap,\n    TemplateVars,\n    TemplateVarsExtendFunction,\n    defaultExtendVars,\n} from './jsonContext';\n\nimport { JsonEditor } from './jsonEditor/jsonEditor';\nimport { JsonEditorOptions } from './jsonEditor/jsonEditorState';\nimport { JsonEditorRule } from './jsonEditor/jsonEditorRule';\n\n/**\n * Conversion options for JsonConverter\n */\nexport interface JsonConverterOptions {\n    /**\n     * If true and if template variables are available,\n     * then string property values will be rendered using\n     * mustache and those variables. Otherwise string properties\n     * are copied without modification.\n     *\n     * Defaults to true if vars are supplied with options,\n     * false otherwise.\n     */\n    useValueTemplates: boolean;\n\n    /**\n     * If true and if template variables are available,\n     * then string property names will be rendered using\n     * mustache and those variables. Otherwise string properties\n     * are copied without modification.\n     *\n     * Defaults to true if vars are supplied with options,\n     * false otherwise.\n     */\n    useNameTemplates: boolean;\n\n    /**\n     * If true and if template variables are available,\n     * then string property names will be considered for\n     * conditionals.\n     *\n     * Default is to match useNameTemplates\n     */\n    useConditionalNames: boolean;\n\n    /**\n     * If true (default) then properties with unconditional names\n     * (which start with !) are flattened.\n     */\n    flattenUnconditionalValues: boolean;\n\n    /**\n     * If true and if both template variables and a\n     * context derivation function is available, then properties\n     * which match the multi-value name pattern will be expanded.\n     * Default matches useNameTemplates.\n     *\n     * Default is true unless extendVars is explicitly set to\n     * undefined.\n     */\n    useMultiValueTemplateNames: boolean;\n\n    /**\n     * The variables (mustache view) used to render templated string names\n     * and properties.  See the mustache documentation for details of mustache\n     * syntax and the template view.\n     */\n    vars?: TemplateVars;\n\n    /**\n     * Method used to extend variables for children of an array node during\n     * expansion. Default is to use a built-in extension function unless\n     * extendVars is explicitly set to undefined.\n     */\n    extendVars?: TemplateVarsExtendFunction;\n\n    /**\n     * If true and if a references map is supplied, then\n     * references in the source object will be replaced with\n     * the corresponding value from the map.\n     *\n     * Default is true if refs are present in options, false\n     * otherwise.\n     */\n    useReferences: boolean;\n\n    /**\n     * An optional object map used to insert any references in the\n     * converted JSON.\n     */\n    refs?: JsonReferenceMap;\n\n    /**\n     * If onInvalidPropertyName is 'error' (default) then any property name\n     * that is invalid after template rendering causes an error and stops\n     * conversion.  If onInvalidPropertyName is 'ignore', then names which\n     * are invalid after template rendering are passed through unchanged.\n     */\n    onInvalidPropertyName: 'error'|'ignore';\n\n    /**\n     * If onInvalidPropertyValue is 'error' (default) then any illegal\n     * property value causes an error and stops conversion.  If\n     * onInvalidPropertyValue is 'ignore' then any invalid property\n     * values are silently ignored.\n     */\n    onInvalidPropertyValue: 'error'|'ignore';\n\n    /**\n     * If onUnknownPropertyValue is error, then any property with\n     * value undefined will cause an error and stop conversion.  If\n     * onUndefinedPropertyValue is 'ignore' (default) then any\n     * property with value undefined is silently ignored.\n     */\n    onUndefinedPropertyValue: 'error'|'ignore';\n}\n\n/**\n * Merges an optionally supplied partial set of options with the default\n * converter options, producing a fully-resolved set of ConverterOptions\n * and taking all dynamic rules into account (e.g. template usage enabled\n * if variables are supplied and disabled if not)\n * @param partial An optional partial @see JsonConverterOptions to be merged\n */\nexport function mergeDefaultJsonConverterOptions(partial?: Partial<JsonConverterOptions>): JsonConverterOptions {\n    const haveVars = (partial?.vars !== undefined);\n    const haveRefs = (partial?.refs !== undefined);\n    const extender = partial?.hasOwnProperty('extendVars') ? partial.extendVars : defaultExtendVars;\n    const haveExtender = (extender !== undefined);\n    const namesDefault = (partial?.useNameTemplates ?? haveVars);\n    const conditionsDefault = (partial?.useConditionalNames ?? namesDefault);\n\n    const options: JsonConverterOptions = {\n        useValueTemplates: partial?.useValueTemplates ?? haveVars,\n        useNameTemplates: namesDefault,\n        useConditionalNames: conditionsDefault,\n        flattenUnconditionalValues: partial?.flattenUnconditionalValues ?? conditionsDefault,\n        useMultiValueTemplateNames: partial?.useMultiValueTemplateNames ?? (haveExtender && namesDefault),\n        useReferences: partial?.useReferences ?? haveRefs,\n        onInvalidPropertyName: partial?.onInvalidPropertyName ?? 'error',\n        onInvalidPropertyValue: partial?.onInvalidPropertyValue ?? 'error',\n        onUndefinedPropertyValue: partial?.onUndefinedPropertyValue ?? 'ignore',\n        extendVars: extender,\n    };\n    if (partial?.vars) {\n        options.vars = partial.vars;\n    }\n    if (partial?.refs) {\n        options.refs = partial.refs;\n    }\n    return options;\n}\n\n/**\n * Creates a new @see JsonContext using values supplied in an optional partial\n * @see JsonConverterOptions\n * @param partial Optional partial @see JsonConverterOptions used to populate the context\n */\nexport function contextFromConverterOptions(partial?: Partial<JsonConverterOptions>): JsonContext|undefined {\n    const context: JsonContext = {};\n    if (partial?.vars) {\n        context.vars = partial.vars;\n    }\n    if (partial?.refs) {\n        context.refs = partial.refs;\n    }\n    if (partial?.hasOwnProperty('extendVars')) {\n        context.extendVars = partial.extendVars;\n    }\n    return (context.vars || context.refs || context.extendVars) ? context : undefined;\n}\n\n/**\n * Creates a new @see JsonEditor from an optionally supplied partial @see JsonConverterOptions.\n * Expands supplied options with default values and constructs an editor with\n * matching configuration and defined rules.\n * @param partial Optional partial @see JsonConverterOptions used to create the editor\n */\nexport function converterOptionsToEditor(partial?: Partial<JsonConverterOptions>): Result<JsonEditor> {\n    const converterOptions = mergeDefaultJsonConverterOptions(partial);\n    const context = contextFromConverterOptions(partial);\n    const validation = {\n        onInvalidPropertyName: converterOptions.onInvalidPropertyName,\n        onInvalidPropertyValue: converterOptions.onInvalidPropertyValue,\n        onUndefinedPropertyValue: converterOptions.onUndefinedPropertyValue,\n    };\n    const editorOptions: JsonEditorOptions = { context, validation };\n\n    const rules: JsonEditorRule[] = [];\n    if (converterOptions.useNameTemplates || converterOptions.useValueTemplates) {\n        const templateOptions = {\n            ...editorOptions,\n            useNameTemplates: converterOptions.useNameTemplates,\n            useValueTemplates: converterOptions.useValueTemplates,\n        };\n        rules.push(new TemplatedJsonEditorRule(templateOptions));\n    }\n    if (converterOptions.useConditionalNames || converterOptions.flattenUnconditionalValues) {\n        const conditionalOptions = {\n            ...editorOptions,\n            flattenUnconditionalValues: converterOptions.flattenUnconditionalValues,\n        };\n        rules.push(new ConditionalJsonEditorRule(conditionalOptions));\n    }\n    if (converterOptions.useMultiValueTemplateNames) {\n        rules.push(new MultiValueJsonEditorRule(editorOptions));\n    }\n    if (converterOptions.useReferences) {\n        rules.push(new ReferenceJsonEditorRule(editorOptions));\n    }\n\n    return JsonEditor.create(editorOptions, rules);\n}\n\n/**\n * A thin wrapper to allow an arbitrary @see JsonEditor to be used via the\n * ts-utils @see Converter pattern.\n */\nexport class JsonEditorConverter extends BaseConverter<JsonValue, JsonContext> {\n    public editor: JsonEditor;\n\n    /**\n     * Constructs a new @see JsonEditorConverter which uses the supplied editor\n     * @param editor\n     */\n    public constructor(editor: JsonEditor) {\n        super(\n            (from, _self, context) => this._convert(from, context),\n            editor.options.context,\n        );\n        this.editor = editor;\n    }\n\n    /**\n     * Constructs a new @see JsonEditorConverter which uses the supplied editor\n     * @param editor\n     */\n    public static createWithEditor(editor: JsonEditor): Result<JsonEditorConverter> {\n        return captureResult(() => new JsonEditorConverter(editor));\n    }\n\n    /**\n     * Gets a derived converter which fails if the resulting converted\n     * @see JsonValue is not a @see JsonObject\n     */\n    public object(): Converter<JsonObject, JsonContext> {\n        return this.map((jv) => {\n            if (!isJsonObject(jv)) {\n                return fail(`Cannot convert \"${JSON.stringify(jv)}\" to JSON object.`);\n            }\n            return succeed(jv);\n        });\n    }\n\n    /**\n     * Gets a derived converter which fails if the resulting converted\n     * @see JsonValue is not a @see JsonArray\n     */\n    public array(): Converter<JsonArray, JsonContext> {\n        return this.map((jv) => {\n            if ((!Array.isArray(jv)) || (typeof jv !== 'object')) {\n                return fail(`Cannot convert \"${JSON.stringify(jv)}\" to JSON array.`);\n            }\n            return succeed(jv);\n        });\n    }\n\n    protected _convert(from: unknown, context?: JsonContext): Result<JsonValue> {\n        return this.editor.clone(from as JsonValue, context);\n    }\n}\n\n/**\n * A ts-utils @see Converter from unknown to type-safe JSON, optionally rendering\n * any string property names or values using mustache with a supplied view.\n */\nexport class JsonConverter extends JsonEditorConverter {\n    /**\n     * Constructs a new JsonConverter with supplied or default options\n     * @param options Optional options to configure the converter\n     */\n    public constructor(options?: Partial<JsonConverterOptions>) {\n        const editor = converterOptionsToEditor(options).orThrow();\n        super(editor);\n    }\n\n    /**\n     * Creates a new converter.\n     * @param options Optional options to configure the converter\n     * @returns Success with a new JsonConverter on success, or Failure with an\n     * informative message if an error occurs.\n     */\n    public static create(options?: Partial<JsonConverterOptions>): Result<JsonConverter> {\n        return captureResult(() => new JsonConverter(options));\n    }\n}\n\nexport type TemplatedJsonConverterOptions = Omit<JsonConverterOptions, 'useNameTemplates'|'useValueTemplates'|'useMultiValueTemplateNames'>;\n\n/**\n * A ts-utils @see Converter from unknown to type-safe JSON with mustache\n * template rendering and multi-value property name rules enabled regardless\n * of initial context.\n */\nexport class TemplatedJsonConverter extends JsonEditorConverter {\n    public static readonly templateOptions: Partial<JsonConverterOptions> = {\n        useNameTemplates: true,\n        useValueTemplates: true,\n        useMultiValueTemplateNames: true,\n        useConditionalNames: false,\n        flattenUnconditionalValues: false,\n    };\n\n    /**\n     * Constructs a new @see TemplatedJsonConverter with supplied or\n     * default options\n     * @param options Optional configuration or context for the converter\n     */\n    public constructor(options?: Partial<TemplatedJsonConverterOptions>) {\n        options = { ...options, ...TemplatedJsonConverter.templateOptions };\n        const editor = converterOptionsToEditor(options).orThrow();\n        super(editor);\n    }\n\n    /**\n     * Constructs a new @see TemplatedJsonConverter with supplied or\n     * default options\n     * @param options Optional configuration or context for the converter\n     */\n    public static create(options?: Partial<TemplatedJsonConverterOptions>): Result<JsonConverter> {\n        return captureResult(() => new TemplatedJsonConverter(options));\n    }\n}\n\nexport type ConditionalJsonConverterOptions = Omit<TemplatedJsonConverterOptions, 'useConditionalNames'>;\n\n/**\n * A ts-utils @see Converter from unknown to type-safe JSON with mustache\n * template rendering, multi-value property name and conditional property\n * name rules enabled regardless of initial context.\n */\nexport class ConditionalJsonConverter extends JsonEditorConverter {\n    public static readonly conditionalOptions: Partial<JsonConverterOptions> = {\n        ...TemplatedJsonConverter.templateOptions,\n        useConditionalNames: true,\n        flattenUnconditionalValues: true,\n    };\n\n    /**\n     * Constructs a new @see ConditionalJsonConverter with supplied or\n     * default options\n     * @param options Optional configuration or context for the converter\n     */\n    public constructor(options?: Partial<ConditionalJsonConverterOptions>) {\n        options = { ...options, ...ConditionalJsonConverter.conditionalOptions };\n        const editor = converterOptionsToEditor(options).orThrow();\n        super(editor);\n    }\n\n    /**\n     * Constructs a new @see ConditionalJsonConverter with supplied or\n     * default options\n     * @param options Optional configuration or context for the converter\n     */\n    public static create(options?: Partial<ConditionalJsonConverterOptions>): Result<JsonConverter> {\n        return captureResult(() => new ConditionalJsonConverter(options));\n    }\n}\n\nexport type RichJsonConverterOptions = Omit<ConditionalJsonConverterOptions, 'useReferences'>;\n\n/**\n * A ts-utils @see Converter from unknown to type-safe JSON with mustache\n * template rendering, multi-value property name, conditional property\n * name, and external reference rules enabled regardless of initial context.\n */\nexport class RichJsonConverter extends JsonEditorConverter {\n    public static readonly richOptions: Partial<JsonConverterOptions> = {\n        ...ConditionalJsonConverter.conditionalOptions,\n        useReferences: true,\n    };\n\n    /**\n     * Constructs a new @see RichJsonConverter with supplied or\n     * default options\n     * @param options Optional configuration or context for the converter\n     */\n    public constructor(options?: Partial<RichJsonConverterOptions>) {\n        options = { ...options, ...RichJsonConverter.richOptions };\n        const editor = converterOptionsToEditor(options).orThrow();\n        super(editor);\n    }\n\n    /**\n     * Constructs a new @see RichJsonConverter with supplied or\n     * default options\n     * @param options Optional configuration or context for the converter\n     */\n    public static create(options?: Partial<RichJsonConverterOptions>): Result<JsonConverter> {\n        return captureResult(() => new RichJsonConverter(options));\n    }\n}\n"]}
File without changes
@@ -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.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
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];
@@ -48,4 +52,4 @@ __exportStar(require("./jsonEditorRule"), exports);
48
52
  __exportStar(require("./jsonEditor"), exports);
49
53
  __exportStar(require("./jsonEditorState"), exports);
50
54
  exports.Rules = __importStar(require("./rules"));
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvanNvbkVkaXRvci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBb0JHOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUgsbURBQWlDO0FBQ2pDLCtDQUE2QjtBQUM3QixvREFBa0M7QUFDbEMsaURBQWlDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAyMCBFcmlrIEZvcnR1bmVcbiAqXG4gKiBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBvYnRhaW5pbmcgYSBjb3B5XG4gKiBvZiB0aGlzIHNvZnR3YXJlIGFuZCBhc3NvY2lhdGVkIGRvY3VtZW50YXRpb24gZmlsZXMgKHRoZSBcIlNvZnR3YXJlXCIpLCB0byBkZWFsXG4gKiBpbiB0aGUgU29mdHdhcmUgd2l0aG91dCByZXN0cmljdGlvbiwgaW5jbHVkaW5nIHdpdGhvdXQgbGltaXRhdGlvbiB0aGUgcmlnaHRzXG4gKiB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsIGRpc3RyaWJ1dGUsIHN1YmxpY2Vuc2UsIGFuZC9vciBzZWxsXG4gKiBjb3BpZXMgb2YgdGhlIFNvZnR3YXJlLCBhbmQgdG8gcGVybWl0IHBlcnNvbnMgdG8gd2hvbSB0aGUgU29mdHdhcmUgaXNcbiAqIGZ1cm5pc2hlZCB0byBkbyBzbywgc3ViamVjdCB0byB0aGUgZm9sbG93aW5nIGNvbmRpdGlvbnM6XG4gKlxuICogVGhlIGFib3ZlIGNvcHlyaWdodCBub3RpY2UgYW5kIHRoaXMgcGVybWlzc2lvbiBub3RpY2Ugc2hhbGwgYmUgaW5jbHVkZWQgaW4gYWxsXG4gKiBjb3BpZXMgb3Igc3Vic3RhbnRpYWwgcG9ydGlvbnMgb2YgdGhlIFNvZnR3YXJlLlxuICpcbiAqIFRIRSBTT0ZUV0FSRSBJUyBQUk9WSURFRCBcIkFTIElTXCIsIFdJVEhPVVQgV0FSUkFOVFkgT0YgQU5ZIEtJTkQsIEVYUFJFU1MgT1JcbiAqIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE8gVEhFIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZLFxuICogRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQU5EIE5PTklORlJJTkdFTUVOVC4gSU4gTk8gRVZFTlQgU0hBTEwgVEhFXG4gKiBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFIExJQUJMRSBGT1IgQU5ZIENMQUlNLCBEQU1BR0VTIE9SIE9USEVSXG4gKiBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQU4gQUNUSU9OIE9GIENPTlRSQUNULCBUT1JUIE9SIE9USEVSV0lTRSwgQVJJU0lORyBGUk9NLFxuICogT1VUIE9GIE9SIElOIENPTk5FQ1RJT04gV0lUSCBUSEUgU09GVFdBUkUgT1IgVEhFIFVTRSBPUiBPVEhFUiBERUFMSU5HUyBJTiBUSEVcbiAqIFNPRlRXQVJFLlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vanNvbkVkaXRvclJ1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9qc29uRWRpdG9yJztcbmV4cG9ydCAqIGZyb20gJy4vanNvbkVkaXRvclN0YXRlJztcbmV4cG9ydCAqIGFzIFJ1bGVzIGZyb20gJy4vcnVsZXMnO1xuIl19
55
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvanNvbkVkaXRvci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBb0JHOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVILG1EQUFpQztBQUNqQywrQ0FBNkI7QUFDN0Isb0RBQWtDO0FBQ2xDLGlEQUFpQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjAgRXJpayBGb3J0dW5lXG4gKlxuICogUGVybWlzc2lvbiBpcyBoZXJlYnkgZ3JhbnRlZCwgZnJlZSBvZiBjaGFyZ2UsIHRvIGFueSBwZXJzb24gb2J0YWluaW5nIGEgY29weVxuICogb2YgdGhpcyBzb2Z0d2FyZSBhbmQgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIGZpbGVzICh0aGUgXCJTb2Z0d2FyZVwiKSwgdG8gZGVhbFxuICogaW4gdGhlIFNvZnR3YXJlIHdpdGhvdXQgcmVzdHJpY3Rpb24sIGluY2x1ZGluZyB3aXRob3V0IGxpbWl0YXRpb24gdGhlIHJpZ2h0c1xuICogdG8gdXNlLCBjb3B5LCBtb2RpZnksIG1lcmdlLCBwdWJsaXNoLCBkaXN0cmlidXRlLCBzdWJsaWNlbnNlLCBhbmQvb3Igc2VsbFxuICogY29waWVzIG9mIHRoZSBTb2Z0d2FyZSwgYW5kIHRvIHBlcm1pdCBwZXJzb25zIHRvIHdob20gdGhlIFNvZnR3YXJlIGlzXG4gKiBmdXJuaXNoZWQgdG8gZG8gc28sIHN1YmplY3QgdG8gdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOlxuICpcbiAqIFRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlIGFuZCB0aGlzIHBlcm1pc3Npb24gbm90aWNlIHNoYWxsIGJlIGluY2x1ZGVkIGluIGFsbFxuICogY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS5cbiAqXG4gKiBUSEUgU09GVFdBUkUgSVMgUFJPVklERUQgXCJBUyBJU1wiLCBXSVRIT1VUIFdBUlJBTlRZIE9GIEFOWSBLSU5ELCBFWFBSRVNTIE9SXG4gKiBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPIFRIRSBXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSxcbiAqIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFIEFORCBOT05JTkZSSU5HRU1FTlQuIElOIE5PIEVWRU5UIFNIQUxMIFRIRVxuICogQVVUSE9SUyBPUiBDT1BZUklHSFQgSE9MREVSUyBCRSBMSUFCTEUgRk9SIEFOWSBDTEFJTSwgREFNQUdFUyBPUiBPVEhFUlxuICogTElBQklMSVRZLCBXSEVUSEVSIElOIEFOIEFDVElPTiBPRiBDT05UUkFDVCwgVE9SVCBPUiBPVEhFUldJU0UsIEFSSVNJTkcgRlJPTSxcbiAqIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU4gVEhFXG4gKiBTT0ZUV0FSRS5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2pzb25FZGl0b3JSdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vanNvbkVkaXRvcic7XG5leHBvcnQgKiBmcm9tICcuL2pzb25FZGl0b3JTdGF0ZSc7XG5leHBvcnQgKiBhcyBSdWxlcyBmcm9tICcuL3J1bGVzJztcbiJdfQ==
@@ -16,6 +16,11 @@ export declare class JsonEditor {
16
16
  options: JsonEditorOptions;
17
17
  protected _rules: JsonEditorRule[];
18
18
  protected constructor(options?: Partial<JsonEditorOptions>, rules?: JsonEditorRule[]);
19
+ /**
20
+ * Default singleton @see JsonEditor for simple use. Applies all rules
21
+ * but with no default context.
22
+ */
23
+ static get default(): JsonEditor;
19
24
  /**
20
25
  * Constructs a new @see JsonEditor
21
26
  * @param options Optional configuration an context for this editor
@@ -29,11 +34,6 @@ export declare class JsonEditor {
29
34
  * @param options The options used to initialize all rules
30
35
  */
31
36
  static getDefaultRules(options?: JsonEditorOptions): Result<JsonEditorRule[]>;
32
- /**
33
- * Default singleton @see JsonEditor for simple use. Applies all rules
34
- * but with no default context.
35
- */
36
- static get default(): JsonEditor;
37
37
  protected static _getDefaultOptions(options?: Partial<JsonEditorOptions>): Result<JsonEditorOptions>;
38
38
  /**
39
39
  * Merges a supplied source object into a supplied target, updating the target object.
@@ -33,8 +33,19 @@ const jsonEditorState_1 = require("./jsonEditorState");
33
33
  */
34
34
  class JsonEditor {
35
35
  constructor(options, rules) {
36
- this.options = JsonEditor._getDefaultOptions(options).getValueOrThrow();
37
- this._rules = rules || JsonEditor.getDefaultRules(this.options).getValueOrThrow();
36
+ this.options = JsonEditor._getDefaultOptions(options).orThrow();
37
+ this._rules = rules || JsonEditor.getDefaultRules(this.options).orThrow();
38
+ }
39
+ /**
40
+ * Default singleton @see JsonEditor for simple use. Applies all rules
41
+ * but with no default context.
42
+ */
43
+ static get default() {
44
+ if (!JsonEditor._default) {
45
+ const rules = this.getDefaultRules().orDefault();
46
+ JsonEditor._default = new JsonEditor(undefined, rules);
47
+ }
48
+ return JsonEditor._default;
38
49
  }
39
50
  /**
40
51
  * Constructs a new @see JsonEditor
@@ -42,7 +53,7 @@ class JsonEditor {
42
53
  * @param rules Optional set of rules used by this editor
43
54
  */
44
55
  static create(options, rules) {
45
- return ts_utils_1.captureResult(() => new JsonEditor(options, rules));
56
+ return (0, ts_utils_1.captureResult)(() => new JsonEditor(options, rules));
46
57
  }
47
58
  /**
48
59
  * Gets the default set of rules to be applied for a given set of options.
@@ -51,24 +62,13 @@ class JsonEditor {
51
62
  * @param options The options used to initialize all rules
52
63
  */
53
64
  static getDefaultRules(options) {
54
- return ts_utils_1.mapResults([
65
+ return (0, ts_utils_1.mapResults)([
55
66
  rules_1.TemplatedJsonEditorRule.create(options),
56
67
  rules_1.ConditionalJsonEditorRule.create(options),
57
68
  rules_1.MultiValueJsonEditorRule.create(options),
58
69
  rules_1.ReferenceJsonEditorRule.create(options),
59
70
  ]);
60
71
  }
61
- /**
62
- * Default singleton @see JsonEditor for simple use. Applies all rules
63
- * but with no default context.
64
- */
65
- static get default() {
66
- if (!JsonEditor._default) {
67
- const rules = this.getDefaultRules().getValueOrDefault();
68
- JsonEditor._default = new JsonEditor(undefined, rules);
69
- }
70
- return JsonEditor._default;
71
- }
72
72
  static _getDefaultOptions(options) {
73
73
  const context = options === null || options === void 0 ? void 0 : options.context;
74
74
  let validation = options === null || options === void 0 ? void 0 : options.validation;
@@ -79,7 +79,7 @@ class JsonEditor {
79
79
  onUndefinedPropertyValue: 'ignore',
80
80
  };
81
81
  }
82
- return ts_utils_1.succeed({ context, validation });
82
+ return (0, ts_utils_1.succeed)({ context, validation });
83
83
  }
84
84
  /**
85
85
  * Merges a supplied source object into a supplied target, updating the target object.
@@ -116,7 +116,7 @@ class JsonEditor {
116
116
  return mergeResult.withFailureDetail('error');
117
117
  }
118
118
  }
119
- return ts_utils_1.succeedWithDetail(base);
119
+ return (0, ts_utils_1.succeedWithDetail)(base);
120
120
  }
121
121
  /**
122
122
  * Deep clones a supplied JSON value, applying all editor rules and a default
@@ -135,13 +135,13 @@ class JsonEditor {
135
135
  if ((valueResult.detail === 'error') || (valueResult.detail === 'ignore')) {
136
136
  return valueResult;
137
137
  }
138
- if (common_1.isJsonPrimitive(value) || (value === null)) {
139
- return ts_utils_1.succeedWithDetail(value, 'edited');
138
+ if ((0, common_1.isJsonPrimitive)(value) || (value === null)) {
139
+ return (0, ts_utils_1.succeedWithDetail)(value, 'edited');
140
140
  }
141
- else if (common_1.isJsonObject(value)) {
141
+ else if ((0, common_1.isJsonObject)(value)) {
142
142
  return this.mergeObjectInPlace({}, value, state.context).withFailureDetail('error');
143
143
  }
144
- else if (common_1.isJsonArray(value)) {
144
+ else if ((0, common_1.isJsonArray)(value)) {
145
145
  return this._cloneArray(value, state.context);
146
146
  }
147
147
  else if (value === undefined) {
@@ -169,25 +169,25 @@ class JsonEditor {
169
169
  return this._mergeClonedProperty(target, key, cloned, state);
170
170
  });
171
171
  if (valueResult.isFailure() && (valueResult.detail === 'error')) {
172
- return ts_utils_1.fail(`${key}: ${valueResult.message}`);
172
+ return (0, ts_utils_1.fail)(`${key}: ${valueResult.message}`);
173
173
  }
174
174
  }
175
175
  else if (propResult.detail !== 'ignore') {
176
- return ts_utils_1.fail(`${key}: ${propResult.message}`);
176
+ return (0, ts_utils_1.fail)(`${key}: ${propResult.message}`);
177
177
  }
178
178
  }
179
179
  else {
180
- return ts_utils_1.fail(`${key}: Cannot merge inherited properties`);
180
+ return (0, ts_utils_1.fail)(`${key}: Cannot merge inherited properties`);
181
181
  }
182
182
  }
183
- return ts_utils_1.succeed(target);
183
+ return (0, ts_utils_1.succeed)(target);
184
184
  }
185
185
  _cloneArray(src, context) {
186
186
  const results = src.map((v) => {
187
187
  return this.clone(v, context);
188
188
  });
189
- return ts_utils_1.mapDetailedResults(results, ['ignore']).onSuccess((converted) => {
190
- return ts_utils_1.succeed(converted);
189
+ return (0, ts_utils_1.mapDetailedResults)(results, ['ignore']).onSuccess((converted) => {
190
+ return (0, ts_utils_1.succeed)(converted);
191
191
  }).withFailureDetail('error');
192
192
  }
193
193
  _mergeClonedProperty(target, key, newValue, state) {
@@ -195,27 +195,27 @@ class JsonEditor {
195
195
  // merge is called right after clone so this should never happen
196
196
  // since clone itself will have failed
197
197
  // istanbul ignore else
198
- if (common_1.isJsonPrimitive(newValue)) {
198
+ if ((0, common_1.isJsonPrimitive)(newValue)) {
199
199
  target[key] = newValue;
200
- return ts_utils_1.succeedWithDetail(newValue, 'edited');
200
+ return (0, ts_utils_1.succeedWithDetail)(newValue, 'edited');
201
201
  }
202
- else if (common_1.isJsonObject(newValue)) {
203
- if (common_1.isJsonObject(existing)) {
202
+ else if ((0, common_1.isJsonObject)(newValue)) {
203
+ if ((0, common_1.isJsonObject)(existing)) {
204
204
  return this.mergeObjectInPlace(existing, newValue, state.context).withFailureDetail('error');
205
205
  }
206
206
  target[key] = newValue;
207
- return ts_utils_1.succeedWithDetail(newValue, 'edited');
207
+ return (0, ts_utils_1.succeedWithDetail)(newValue, 'edited');
208
208
  }
209
- else if (common_1.isJsonArray(newValue)) {
210
- if (common_1.isJsonArray(existing)) {
209
+ else if ((0, common_1.isJsonArray)(newValue)) {
210
+ if ((0, common_1.isJsonArray)(existing)) {
211
211
  target[key] = existing.concat(...newValue);
212
- return ts_utils_1.succeedWithDetail(target[key], 'edited');
212
+ return (0, ts_utils_1.succeedWithDetail)(target[key], 'edited');
213
213
  }
214
214
  target[key] = newValue;
215
- return ts_utils_1.succeedWithDetail(newValue, 'edited');
215
+ return (0, ts_utils_1.succeedWithDetail)(newValue, 'edited');
216
216
  }
217
217
  else {
218
- return ts_utils_1.failWithDetail(`Invalid JSON: ${JSON.stringify(newValue)}`, 'error');
218
+ return (0, ts_utils_1.failWithDetail)(`Invalid JSON: ${JSON.stringify(newValue)}`, 'error');
219
219
  }
220
220
  }
221
221
  _editProperty(key, value, state) {
@@ -225,7 +225,7 @@ class JsonEditor {
225
225
  return ruleResult;
226
226
  }
227
227
  }
228
- return ts_utils_1.failWithDetail('inapplicable', 'inapplicable');
228
+ return (0, ts_utils_1.failWithDetail)('inapplicable', 'inapplicable');
229
229
  }
230
230
  _editValue(value, state) {
231
231
  for (const rule of this._rules) {
@@ -234,7 +234,7 @@ class JsonEditor {
234
234
  return ruleResult;
235
235
  }
236
236
  }
237
- return ts_utils_1.failWithDetail('inapplicable', 'inapplicable');
237
+ return (0, ts_utils_1.failWithDetail)('inapplicable', 'inapplicable');
238
238
  }
239
239
  _finalizeAndMerge(target, state) {
240
240
  const deferred = state.deferred;
@@ -245,15 +245,15 @@ class JsonEditor {
245
245
  return this.mergeObjectsInPlaceWithContext(state.context, target, ruleResult.value).withFailureDetail('error');
246
246
  }
247
247
  else if (ruleResult.detail === 'ignore') {
248
- ts_utils_1.succeedWithDetail(target, 'edited');
248
+ (0, ts_utils_1.succeedWithDetail)(target, 'edited');
249
249
  }
250
250
  else if (ruleResult.detail !== 'inapplicable') {
251
- return ts_utils_1.failWithDetail(ruleResult.message, ruleResult.detail);
251
+ return (0, ts_utils_1.failWithDetail)(ruleResult.message, ruleResult.detail);
252
252
  }
253
253
  }
254
254
  }
255
- return ts_utils_1.succeedWithDetail(target, 'edited');
255
+ return (0, ts_utils_1.succeedWithDetail)(target, 'edited');
256
256
  }
257
257
  }
258
258
  exports.JsonEditor = JsonEditor;
259
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jsonEditor.js","sourceRoot":"","sources":["../../src/jsonEditor/jsonEditor.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2020 Erik Fortune\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\n\nimport {\n    ConditionalJsonEditorRule,\n    MultiValueJsonEditorRule,\n    ReferenceJsonEditorRule,\n    TemplatedJsonEditorRule,\n} from './rules';\nimport {\n    DetailedResult,\n    Result,\n    captureResult,\n    fail,\n    failWithDetail,\n    mapDetailedResults,\n    mapResults,\n    succeed,\n    succeedWithDetail,\n} from '@fgv/ts-utils';\n\nimport { JsonArray, JsonObject, JsonValue, isJsonArray, isJsonObject, isJsonPrimitive } from '../common';\nimport { JsonEditFailureReason, JsonEditorRule, JsonPropertyEditFailureReason } from './jsonEditorRule';\nimport { JsonEditorOptions, JsonEditorState, JsonEditorValidationOptions } from './jsonEditorState';\n\nimport { JsonContext } from '../jsonContext';\n\n/**\n * The JsonEditor can be used to edit JSON objects in place or to clone any JSON value,\n * applying a default context and optional set of editor rules that were supplied at\n * initialization.\n */\nexport class JsonEditor {\n    protected static _default?: JsonEditor;\n\n    /**\n     * Full set of @see JsonEditorOptions in effect for this rule.\n     */\n    public options: JsonEditorOptions;\n    protected _rules: JsonEditorRule[];\n\n    protected constructor(options?: Partial<JsonEditorOptions>, rules?: JsonEditorRule[]) {\n        this.options = JsonEditor._getDefaultOptions(options).getValueOrThrow();\n        this._rules = rules || JsonEditor.getDefaultRules(this.options).getValueOrThrow();\n    }\n\n    /**\n     * Constructs a new @see JsonEditor\n     * @param options Optional configuration an context for this editor\n     * @param rules Optional set of rules used by this editor\n     */\n    public static create(options?: Partial<JsonEditorOptions>, rules?: JsonEditorRule[]): Result<JsonEditor> {\n        return captureResult(() => new JsonEditor(options, rules));\n    }\n\n    /**\n     * Gets the default set of rules to be applied for a given set of options.\n     * By default, all available rules (templates, conditionals, multi-value and references)\n     * are applied.\n     * @param options The options used to initialize all rules\n     */\n    public static getDefaultRules(options?: JsonEditorOptions): Result<JsonEditorRule[]> {\n        return mapResults<JsonEditorRule>([\n            TemplatedJsonEditorRule.create(options),\n            ConditionalJsonEditorRule.create(options),\n            MultiValueJsonEditorRule.create(options),\n            ReferenceJsonEditorRule.create(options),\n        ]);\n    }\n\n    /**\n     * Default singleton @see JsonEditor for simple use. Applies all rules\n     * but with no default context.\n     */\n    public static get default(): JsonEditor {\n        if (!JsonEditor._default) {\n            const rules = this.getDefaultRules().getValueOrDefault();\n            JsonEditor._default = new JsonEditor(undefined, rules);\n        }\n        return JsonEditor._default;\n    }\n\n    protected static _getDefaultOptions(options?: Partial<JsonEditorOptions>): Result<JsonEditorOptions> {\n        const context: JsonContext|undefined = options?.context;\n        let validation: JsonEditorValidationOptions|undefined = options?.validation;\n        if (validation === undefined) {\n            validation = {\n                onInvalidPropertyName: 'error',\n                onInvalidPropertyValue: 'error',\n                onUndefinedPropertyValue: 'ignore',\n            };\n        }\n        return succeed({ context, validation });\n    }\n\n    /**\n     * Merges a supplied source object into a supplied target, updating the target object.\n     * @param target The target object to be updated\n     * @param src The source object to be merged\n     * @param runtimeContext An optional @see JsonContext supplying variables and references\n     */\n    public mergeObjectInPlace(target: JsonObject, src: JsonObject, runtimeContext?: JsonContext): Result<JsonObject> {\n        const state = new JsonEditorState(this, this.options, runtimeContext);\n        return this._mergeObjectInPlace(target, src, state).onSuccess((merged) => {\n            return this._finalizeAndMerge(merged, state);\n        });\n    }\n\n    /**\n     * Merges multiple supplied source objects into a supplied target, updating the target\n     * object and using the default context supplied at creation time.\n     * @param target The target object to be updated\n     * @param srcObjects Objects to be merged into the target object, in the order supplied.\n     */\n    public mergeObjectsInPlace(target: JsonObject, srcObjects: JsonObject[]): Result<JsonObject> {\n        return this.mergeObjectsInPlaceWithContext(this.options.context, target, srcObjects);\n    }\n\n    /**\n     * Merges multiple supplied source objects into a supplied target, updating the target\n     * object and using an optional context supplied in the call.\n     * @param context An optional @see JsonContext supplying variables and references\n     * @param target The target object to be updated\n     * @param srcObjects Objects to be merged into the target object, in the order supplied.\n     */\n    public mergeObjectsInPlaceWithContext(context: JsonContext|undefined, base: JsonObject, srcObjects: JsonObject[]): Result<JsonObject> {\n        for (const src of srcObjects) {\n            const mergeResult = this.mergeObjectInPlace(base, src, context);\n            if (mergeResult.isFailure()) {\n                return mergeResult.withFailureDetail('error');\n            }\n        }\n        return succeedWithDetail(base);\n    }\n\n    /**\n     * Deep clones a supplied JSON value, applying all editor rules and a default\n     * or optionally supplied context\n     * @param src The @see JsonValue to be cloned\n     * @param context An optional @see JsonContext supplying variables and references\n     */\n    public clone(src: JsonValue, context?: JsonContext): DetailedResult<JsonValue, JsonEditFailureReason> {\n        const state = new JsonEditorState(this, this.options, context);\n        let value = src;\n        let valueResult = this._editValue(src, state);\n\n        while (valueResult.isSuccess()) {\n            value = valueResult.value;\n            valueResult = this._editValue(value, state);\n        }\n\n        if ((valueResult.detail === 'error') || (valueResult.detail === 'ignore')) {\n            return valueResult;\n        }\n\n        if (isJsonPrimitive(value) || (value === null)) {\n            return succeedWithDetail(value, 'edited');\n        }\n        else if (isJsonObject(value)) {\n            return this.mergeObjectInPlace({}, value, state.context).withFailureDetail('error');\n        }\n        else if (isJsonArray(value)) {\n            return this._cloneArray(value, state.context);\n        }\n        else if (value === undefined) {\n            return state.failValidation('undefinedPropertyValue');\n        }\n        return state.failValidation('invalidPropertyValue', `Cannot convert invalid JSON: \"${JSON.stringify(value)}\"`);\n    }\n\n    protected _mergeObjectInPlace(target: JsonObject, src: JsonObject, state: JsonEditorState): Result<JsonObject> {\n        for (const key in src) {\n            if (src.hasOwnProperty(key)) {\n                const propResult = this._editProperty(key, src[key], state);\n                if (propResult.isSuccess()) {\n                    if (propResult.detail === 'deferred') {\n                        state.defer(propResult.value);\n                    }\n                    else {\n                        const mergeResult = this._mergeObjectInPlace(target, propResult.value, state);\n                        if (mergeResult.isFailure()) {\n                            return mergeResult;\n                        }\n                    }\n                }\n                else if (propResult.detail === 'inapplicable') {\n                    const valueResult = this.clone(src[key], state.context).onSuccess((cloned) => {\n                        return this._mergeClonedProperty(target, key, cloned, state);\n                    });\n\n                    if (valueResult.isFailure() && (valueResult.detail === 'error')) {\n                        return fail(`${key}: ${valueResult.message}`);\n                    }\n                }\n                else if (propResult.detail !== 'ignore') {\n                    return fail(`${key}: ${propResult.message}`);\n                }\n            }\n            else {\n                return fail(`${key}: Cannot merge inherited properties`);\n            }\n        }\n        return succeed(target);\n    }\n\n    protected _cloneArray(src: JsonArray, context?: JsonContext): DetailedResult<JsonArray, JsonEditFailureReason> {\n        const results = src.map((v) => {\n            return this.clone(v, context);\n        });\n\n        return mapDetailedResults<JsonValue, JsonEditFailureReason>(results, ['ignore']).onSuccess((converted) => {\n            return succeed(converted);\n        }).withFailureDetail('error');\n    }\n\n    protected _mergeClonedProperty(target: JsonObject, key: string, newValue: JsonValue, state: JsonEditorState): DetailedResult<JsonValue, JsonEditFailureReason> {\n        const existing = target[key];\n\n        // merge is called right after clone so this should never happen\n        // since clone itself will have failed\n        // istanbul ignore else\n        if (isJsonPrimitive(newValue)) {\n            target[key] = newValue;\n            return succeedWithDetail(newValue, 'edited');\n        }\n        else if (isJsonObject(newValue)) {\n            if (isJsonObject(existing)) {\n                return this.mergeObjectInPlace(existing, newValue, state.context).withFailureDetail('error');\n            }\n            target[key] = newValue;\n            return succeedWithDetail(newValue, 'edited');\n        }\n        else if (isJsonArray(newValue)) {\n            if (isJsonArray(existing)) {\n                target[key] = existing.concat(...newValue);\n                return succeedWithDetail(target[key], 'edited');\n            }\n            target[key] = newValue;\n            return succeedWithDetail(newValue, 'edited');\n        }\n        else {\n            return failWithDetail(`Invalid JSON: ${JSON.stringify(newValue)}`, 'error');\n        }\n    }\n\n    protected _editProperty(key: string, value: JsonValue, state: JsonEditorState): DetailedResult<JsonObject, JsonPropertyEditFailureReason> {\n        for (const rule of this._rules) {\n            const ruleResult = rule.editProperty(key, value, state);\n            if (ruleResult.isSuccess() || (ruleResult.detail !== 'inapplicable')) {\n                return ruleResult;\n            }\n        }\n        return failWithDetail('inapplicable', 'inapplicable');\n    }\n\n    protected _editValue(value: JsonValue, state: JsonEditorState): DetailedResult<JsonValue, JsonEditFailureReason> {\n        for (const rule of this._rules) {\n            const ruleResult = rule.editValue(value, state);\n            if (ruleResult.isSuccess() || (ruleResult.detail !== 'inapplicable')) {\n                return ruleResult;\n            }\n        }\n        return failWithDetail('inapplicable', 'inapplicable');\n    }\n\n    protected _finalizeAndMerge(target: JsonObject, state: JsonEditorState): DetailedResult<JsonObject, JsonEditFailureReason> {\n        const deferred = state.deferred;\n        if (deferred.length > 0) {\n            for (const rule of this._rules) {\n                const ruleResult = rule.finalizeProperties(deferred, state);\n                if (ruleResult.isSuccess()) {\n                    return this.mergeObjectsInPlaceWithContext(state.context, target, ruleResult.value).withFailureDetail('error');\n                }\n                else if (ruleResult.detail === 'ignore') {\n                    succeedWithDetail(target, 'edited');\n                }\n                else if (ruleResult.detail !== 'inapplicable') {\n                    return failWithDetail(ruleResult.message, ruleResult.detail);\n                }\n            }\n        }\n        return succeedWithDetail(target, 'edited');\n    }\n}\n\n"]}
259
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jsonEditor.js","sourceRoot":"","sources":["../../src/jsonEditor/jsonEditor.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2020 Erik Fortune\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\n\nimport {\n    ConditionalJsonEditorRule,\n    MultiValueJsonEditorRule,\n    ReferenceJsonEditorRule,\n    TemplatedJsonEditorRule,\n} from './rules';\nimport {\n    DetailedResult,\n    Result,\n    captureResult,\n    fail,\n    failWithDetail,\n    mapDetailedResults,\n    mapResults,\n    succeed,\n    succeedWithDetail,\n} from '@fgv/ts-utils';\n\nimport { JsonArray, JsonObject, JsonValue, isJsonArray, isJsonObject, isJsonPrimitive } from '../common';\nimport { JsonEditFailureReason, JsonEditorRule, JsonPropertyEditFailureReason } from './jsonEditorRule';\nimport { JsonEditorOptions, JsonEditorState, JsonEditorValidationOptions } from './jsonEditorState';\n\nimport { JsonContext } from '../jsonContext';\n\n/**\n * The JsonEditor can be used to edit JSON objects in place or to clone any JSON value,\n * applying a default context and optional set of editor rules that were supplied at\n * initialization.\n */\nexport class JsonEditor {\n    // eslint-disable-next-line no-use-before-define\n    protected static _default?: JsonEditor;\n\n    /**\n     * Full set of @see JsonEditorOptions in effect for this rule.\n     */\n    public options: JsonEditorOptions;\n    protected _rules: JsonEditorRule[];\n\n    protected constructor(options?: Partial<JsonEditorOptions>, rules?: JsonEditorRule[]) {\n        this.options = JsonEditor._getDefaultOptions(options).orThrow();\n        this._rules = rules || JsonEditor.getDefaultRules(this.options).orThrow();\n    }\n\n    /**\n     * Default singleton @see JsonEditor for simple use. Applies all rules\n     * but with no default context.\n     */\n    public static get default(): JsonEditor {\n        if (!JsonEditor._default) {\n            const rules = this.getDefaultRules().orDefault();\n            JsonEditor._default = new JsonEditor(undefined, rules);\n        }\n        return JsonEditor._default;\n    }\n\n    /**\n     * Constructs a new @see JsonEditor\n     * @param options Optional configuration an context for this editor\n     * @param rules Optional set of rules used by this editor\n     */\n    public static create(options?: Partial<JsonEditorOptions>, rules?: JsonEditorRule[]): Result<JsonEditor> {\n        return captureResult(() => new JsonEditor(options, rules));\n    }\n\n    /**\n     * Gets the default set of rules to be applied for a given set of options.\n     * By default, all available rules (templates, conditionals, multi-value and references)\n     * are applied.\n     * @param options The options used to initialize all rules\n     */\n    public static getDefaultRules(options?: JsonEditorOptions): Result<JsonEditorRule[]> {\n        return mapResults<JsonEditorRule>([\n            TemplatedJsonEditorRule.create(options),\n            ConditionalJsonEditorRule.create(options),\n            MultiValueJsonEditorRule.create(options),\n            ReferenceJsonEditorRule.create(options),\n        ]);\n    }\n\n    protected static _getDefaultOptions(options?: Partial<JsonEditorOptions>): Result<JsonEditorOptions> {\n        const context: JsonContext|undefined = options?.context;\n        let validation: JsonEditorValidationOptions|undefined = options?.validation;\n        if (validation === undefined) {\n            validation = {\n                onInvalidPropertyName: 'error',\n                onInvalidPropertyValue: 'error',\n                onUndefinedPropertyValue: 'ignore',\n            };\n        }\n        return succeed({ context, validation });\n    }\n\n    /**\n     * Merges a supplied source object into a supplied target, updating the target object.\n     * @param target The target object to be updated\n     * @param src The source object to be merged\n     * @param runtimeContext An optional @see JsonContext supplying variables and references\n     */\n    public mergeObjectInPlace(target: JsonObject, src: JsonObject, runtimeContext?: JsonContext): Result<JsonObject> {\n        const state = new JsonEditorState(this, this.options, runtimeContext);\n        return this._mergeObjectInPlace(target, src, state).onSuccess((merged) => {\n            return this._finalizeAndMerge(merged, state);\n        });\n    }\n\n    /**\n     * Merges multiple supplied source objects into a supplied target, updating the target\n     * object and using the default context supplied at creation time.\n     * @param target The target object to be updated\n     * @param srcObjects Objects to be merged into the target object, in the order supplied.\n     */\n    public mergeObjectsInPlace(target: JsonObject, srcObjects: JsonObject[]): Result<JsonObject> {\n        return this.mergeObjectsInPlaceWithContext(this.options.context, target, srcObjects);\n    }\n\n    /**\n     * Merges multiple supplied source objects into a supplied target, updating the target\n     * object and using an optional context supplied in the call.\n     * @param context An optional @see JsonContext supplying variables and references\n     * @param target The target object to be updated\n     * @param srcObjects Objects to be merged into the target object, in the order supplied.\n     */\n    public mergeObjectsInPlaceWithContext(context: JsonContext|undefined, base: JsonObject, srcObjects: JsonObject[]): Result<JsonObject> {\n        for (const src of srcObjects) {\n            const mergeResult = this.mergeObjectInPlace(base, src, context);\n            if (mergeResult.isFailure()) {\n                return mergeResult.withFailureDetail('error');\n            }\n        }\n        return succeedWithDetail(base);\n    }\n\n    /**\n     * Deep clones a supplied JSON value, applying all editor rules and a default\n     * or optionally supplied context\n     * @param src The @see JsonValue to be cloned\n     * @param context An optional @see JsonContext supplying variables and references\n     */\n    public clone(src: JsonValue, context?: JsonContext): DetailedResult<JsonValue, JsonEditFailureReason> {\n        const state = new JsonEditorState(this, this.options, context);\n        let value = src;\n        let valueResult = this._editValue(src, state);\n\n        while (valueResult.isSuccess()) {\n            value = valueResult.value;\n            valueResult = this._editValue(value, state);\n        }\n\n        if ((valueResult.detail === 'error') || (valueResult.detail === 'ignore')) {\n            return valueResult;\n        }\n\n        if (isJsonPrimitive(value) || (value === null)) {\n            return succeedWithDetail(value, 'edited');\n        }\n        else if (isJsonObject(value)) {\n            return this.mergeObjectInPlace({}, value, state.context).withFailureDetail('error');\n        }\n        else if (isJsonArray(value)) {\n            return this._cloneArray(value, state.context);\n        }\n        else if (value === undefined) {\n            return state.failValidation('undefinedPropertyValue');\n        }\n        return state.failValidation('invalidPropertyValue', `Cannot convert invalid JSON: \"${JSON.stringify(value)}\"`);\n    }\n\n    protected _mergeObjectInPlace(target: JsonObject, src: JsonObject, state: JsonEditorState): Result<JsonObject> {\n        for (const key in src) {\n            if (src.hasOwnProperty(key)) {\n                const propResult = this._editProperty(key, src[key], state);\n                if (propResult.isSuccess()) {\n                    if (propResult.detail === 'deferred') {\n                        state.defer(propResult.value);\n                    }\n                    else {\n                        const mergeResult = this._mergeObjectInPlace(target, propResult.value, state);\n                        if (mergeResult.isFailure()) {\n                            return mergeResult;\n                        }\n                    }\n                }\n                else if (propResult.detail === 'inapplicable') {\n                    const valueResult = this.clone(src[key], state.context).onSuccess((cloned) => {\n                        return this._mergeClonedProperty(target, key, cloned, state);\n                    });\n\n                    if (valueResult.isFailure() && (valueResult.detail === 'error')) {\n                        return fail(`${key}: ${valueResult.message}`);\n                    }\n                }\n                else if (propResult.detail !== 'ignore') {\n                    return fail(`${key}: ${propResult.message}`);\n                }\n            }\n            else {\n                return fail(`${key}: Cannot merge inherited properties`);\n            }\n        }\n        return succeed(target);\n    }\n\n    protected _cloneArray(src: JsonArray, context?: JsonContext): DetailedResult<JsonArray, JsonEditFailureReason> {\n        const results = src.map((v) => {\n            return this.clone(v, context);\n        });\n\n        return mapDetailedResults<JsonValue, JsonEditFailureReason>(results, ['ignore']).onSuccess((converted) => {\n            return succeed(converted);\n        }).withFailureDetail('error');\n    }\n\n    protected _mergeClonedProperty(target: JsonObject, key: string, newValue: JsonValue, state: JsonEditorState): DetailedResult<JsonValue, JsonEditFailureReason> {\n        const existing = target[key];\n\n        // merge is called right after clone so this should never happen\n        // since clone itself will have failed\n        // istanbul ignore else\n        if (isJsonPrimitive(newValue)) {\n            target[key] = newValue;\n            return succeedWithDetail(newValue, 'edited');\n        }\n        else if (isJsonObject(newValue)) {\n            if (isJsonObject(existing)) {\n                return this.mergeObjectInPlace(existing, newValue, state.context).withFailureDetail('error');\n            }\n            target[key] = newValue;\n            return succeedWithDetail(newValue, 'edited');\n        }\n        else if (isJsonArray(newValue)) {\n            if (isJsonArray(existing)) {\n                target[key] = existing.concat(...newValue);\n                return succeedWithDetail(target[key], 'edited');\n            }\n            target[key] = newValue;\n            return succeedWithDetail(newValue, 'edited');\n        }\n        else {\n            return failWithDetail(`Invalid JSON: ${JSON.stringify(newValue)}`, 'error');\n        }\n    }\n\n    protected _editProperty(key: string, value: JsonValue, state: JsonEditorState): DetailedResult<JsonObject, JsonPropertyEditFailureReason> {\n        for (const rule of this._rules) {\n            const ruleResult = rule.editProperty(key, value, state);\n            if (ruleResult.isSuccess() || (ruleResult.detail !== 'inapplicable')) {\n                return ruleResult;\n            }\n        }\n        return failWithDetail('inapplicable', 'inapplicable');\n    }\n\n    protected _editValue(value: JsonValue, state: JsonEditorState): DetailedResult<JsonValue, JsonEditFailureReason> {\n        for (const rule of this._rules) {\n            const ruleResult = rule.editValue(value, state);\n            if (ruleResult.isSuccess() || (ruleResult.detail !== 'inapplicable')) {\n                return ruleResult;\n            }\n        }\n        return failWithDetail('inapplicable', 'inapplicable');\n    }\n\n    protected _finalizeAndMerge(target: JsonObject, state: JsonEditorState): DetailedResult<JsonObject, JsonEditFailureReason> {\n        const deferred = state.deferred;\n        if (deferred.length > 0) {\n            for (const rule of this._rules) {\n                const ruleResult = rule.finalizeProperties(deferred, state);\n                if (ruleResult.isSuccess()) {\n                    return this.mergeObjectsInPlaceWithContext(state.context, target, ruleResult.value).withFailureDetail('error');\n                }\n                else if (ruleResult.detail === 'ignore') {\n                    succeedWithDetail(target, 'edited');\n                }\n                else if (ruleResult.detail !== 'inapplicable') {\n                    return failWithDetail(ruleResult.message, ruleResult.detail);\n                }\n            }\n        }\n        return succeedWithDetail(target, 'edited');\n    }\n}\n\n"]}