From 1c2778fbf8c36f332d50b7e6ac6aa355d22550ea Mon Sep 17 00:00:00 2001 From: barsdeveloper Date: Tue, 28 May 2024 16:44:39 +0200 Subject: [PATCH] Still WIP --- dist/ueblueprint.js | 2703 ++++++++--------- dist/ueblueprint.min.js | 12 +- js/Blueprint.js | 2 +- js/Utility.js | 35 - js/entity/AlternativesEntity.js | 29 + js/entity/ArrayEntity.js | 41 + js/entity/BooleanEntity.js | 20 + js/entity/ByteEntity.js | 22 +- js/entity/ColorChannelEntity.js | 25 +- js/entity/ComputedType.js | 14 - js/entity/ComputedTypeEntity.js | 22 + js/entity/EnumDisplayValueEntity.js | 8 +- js/entity/EnumEntity.js | 6 +- js/entity/FormatTextEntity.js | 59 +- js/entity/FunctionReferenceEntity.js | 14 +- js/entity/GuidEntity.js | 35 +- js/entity/IEntity.js | 349 ++- js/entity/IdentifierEntity.js | 25 +- js/entity/Integer64Entity.js | 39 +- js/entity/IntegerEntity.js | 45 +- js/entity/InvariantTextEntity.js | 45 +- js/entity/KeyBindingEntity.js | 39 +- js/entity/LinearColorEntity.js | 109 +- js/entity/LocalizedTextEntity.js | 75 +- js/entity/MacroGraphReferenceEntity.js | 22 +- js/entity/MirroredEntity.js | 48 +- js/entity/NaturalNumberEntity.js | 16 +- js/entity/NumberEntity.js | 36 + js/entity/ObjectEntity.js | 326 +- js/entity/ObjectReferenceEntity.js | 90 +- js/entity/PathSymbolEntity.js | 26 +- js/entity/PinEntity.js | 113 +- js/entity/PinReferenceEntity.js | 39 +- js/entity/PinTypeEntity.js | 60 +- js/entity/RBSerializationVector2DEntity.js | 28 +- js/entity/RotatorEntity.js | 29 +- js/entity/ScriptVariableEntity.js | 15 +- js/entity/SimpleSerializationRotatorEntity.js | 35 +- .../SimpleSerializationVector2DEntity.js | 29 +- .../SimpleSerializationVector4DEntity.js | 22 +- js/entity/SimpleSerializationVectorEntity.js | 37 +- js/entity/StringEntity.js | 22 + js/entity/SymbolEntity.js | 24 +- js/entity/TerminalTypeEntity.js | 13 +- js/entity/Union.js | 14 - js/entity/UnknownKeysEntity.js | 52 +- js/entity/UnknownPinEntity.js | 39 +- js/entity/VariableReferenceEntity.js | 17 +- js/entity/Vector2DEntity.js | 24 +- js/entity/Vector4DEntity.js | 38 +- js/entity/VectorEntity.js | 31 +- js/entity/objects/KnotEntity.js | 4 +- js/serialization/Grammar.js | 2 - js/serialization/Serializable.js | 8 +- .../initializeSerializerFactory.js | 22 +- tests/entities.spec.js | 25 +- tests/parsing.spec.js | 2 +- tests/resources/Entity1.js | 12 +- tests/resources/Entity2.js | 38 +- tests/resources/Entity3.js | 101 +- tests/resources/IssuesNodes1.js | 88 +- types.js | 13 +- 62 files changed, 2480 insertions(+), 2853 deletions(-) create mode 100644 js/entity/AlternativesEntity.js create mode 100644 js/entity/ArrayEntity.js create mode 100755 js/entity/BooleanEntity.js delete mode 100644 js/entity/ComputedType.js create mode 100644 js/entity/ComputedTypeEntity.js create mode 100755 js/entity/NumberEntity.js create mode 100755 js/entity/StringEntity.js delete mode 100644 js/entity/Union.js diff --git a/dist/ueblueprint.js b/dist/ueblueprint.js index 11b9c0e..d53052e 100755 --- a/dist/ueblueprint.js +++ b/dist/ueblueprint.js @@ -433,189 +433,6 @@ class Configuration { } } -class ComputedType { - - #f - - /** @param {Function} f */ - constructor(f) { - this.#f = f; - } - - /** @param {IEntity} entity */ - compute(entity) { - return this.#f(entity) - } -} - -/** - * @template T - * @typedef {{ - * type?: AttributeTypeDescription, - * default?: T, - * nullable?: Boolean, - * ignored?: Boolean, - * serialized?: Boolean, - * expected?: Boolean, - * inlined?: Boolean, - * quoted?: Boolean, - * silent?: Boolean, - * uninitialized?: Boolean, - * predicate?: (value: T) => Boolean, - * }} AttributeInfoSource - */ - -/** @template T */ -class AttributeInfo { - - /** @typedef {keyof AttributeInfo} AttributeKey */ - - static #default = { - nullable: false, - ignored: false, // Never serialize or deserialize - serialized: false, // Value is written and read as string - expected: false, // Must be there - inlined: false, // The key is a subobject or array and printed as inlined (A.B=123, A(0)=123) - quoted: false, // Key is serialized with quotes - silent: false, // Do not serialize if default - uninitialized: false, // Do not initialize with default - } - - /** @param {AttributeInfoSource} source */ - constructor(source) { - this.type = source.type ?? source.default?.constructor; - this.default = source.default; - this.nullable = source.nullable ?? source.default === null; - this.ignored = source.ignored; - this.serialized = source.serialized; - this.expected = source.expected; - this.inlined = source.inlined; - this.quoted = source.quoted; - this.silent = source.silent; - this.uninitialized = source.uninitialized; - this.predicate = source.predicate; - if (this.type === Array && this.default instanceof Array && this.default.length > 0) { - this.type = this.default - .map(v => v.constructor) - .reduce((acc, cur) => acc.includes(cur) ? acc : (acc.push(cur), acc), []); - } - } - - /** - * @template {AttributeTypeDescription} D - * @param {D} type - * @returns {AttributeInfo>} - */ - static createType(type) { - return new AttributeInfo({ type }) - } - - /** - * @template V - * @param {V} value - */ - static createValue(value) { - return new AttributeInfo({ default: value }) - } - - /** - * @param {IEntity | Object} source - * @param {String} attribute - * @param {AttributeKey} key - */ - static hasAttribute(source, attribute, key, type = /** @type {EntityConstructor} */(source.constructor)) { - const entity = /** @type {IEntity} */(source); - const result = entity.attributes[attribute]?.[key]; - return /** @type {result} */( - result - ?? type?.attributes?.[attribute]?.[key] - ?? AttributeInfo.#default[key] - ) - } - - /** - * @template {IEntity | Object} S - * @template {EntityConstructor} C - * @template {keyof C["attributes"]} A - * @template {keyof C["attributes"][attribute]} K - * @param {S} source - * @param {A} attribute - * @param {K} key - * @param {C} type - * @returns {C["attributes"][attribute][key]} - */ - static getAttribute(source, attribute, key, type = /** @type {C} */(source.constructor)) { - let result = source["attributes"]?.[attribute]?.[key]; - // Remember null is a valid asignment value for some attributes - if (result !== undefined) { - return result - } - result = /** @type {C["attributes"]} */(type?.attributes)?.[attribute]?.[key]; - if (result !== undefined) { - return result - } - result = /** @type {C["attributes"][attribute]} */(AttributeInfo.#default)[key]; - if (result !== undefined) { - return result - } - } - - /** @param {AttributeKey} key */ - get(key) { - return this[key] ?? AttributeInfo.#default[key] - } -} - -/** @template {Attribute} T */ -class MirroredEntity { - - static attributes = { - type: new AttributeInfo({ - ignored: true, - }), - getter: new AttributeInfo({ - ignored: true, - }), - } - - /** - * @param {ConstructorType} type - * @param {() => T} getter - */ - constructor(type, getter = null) { - this.type = type; - this.getter = getter; - } - - get() { - return this.getter() - } - - /** @returns {AttributeConstructor} */ - getTargetType() { - const result = this.type; - if (result instanceof MirroredEntity) { - return result.getTargetType() - } - return result - } -} - -/** @template {any[]} T */ -class Union { - - /** @type {T} */ - #values - get values() { - return this.#values - } - - /** @param {T} values */ - constructor(...values) { - this.#values = values; - } -} - class Utility { static booleanConverter = { @@ -855,38 +672,6 @@ class Utility { return (acceptNull && value === null) || value instanceof type || value?.constructor === type } - /** @param {Attribute} value */ - static sanitize(value, targetType = /** @type {AttributeTypeDescription } */(value?.constructor)) { - if (targetType instanceof Array) { - targetType = targetType[0]; - } - if (targetType instanceof ComputedType) { - return value // The type is computed, can't say anything about it - } - if (targetType instanceof Union) { - let type = targetType.values.find(t => Utility.isValueOfType(value, t, false)); - if (!type) { - type = targetType.values[0]; - } - targetType = type; - } - if (targetType instanceof MirroredEntity) { - if (value instanceof MirroredEntity) { - return value - } - return Utility.sanitize(value, targetType.getTargetType()) - } - if (targetType && !Utility.isValueOfType(value, targetType, true)) { - value = targetType === BigInt - ? BigInt(/** @type {Number} */(value)) - : new /** @type {EntityConstructor} */(targetType)(value); - } - if (value instanceof Boolean || value instanceof Number || value instanceof String) { - value = /** @type {TerminalAttribute} */(value.valueOf()); // Get the relative primitive value - } - return value - } - /** * @param {Number} x * @param {Number} y @@ -2575,196 +2360,283 @@ class Parsernostrum { } } -class Serializable { +/** + * @template T + * @typedef {{ + * type?: AttributeTypeDescription, + * default?: T, + * nullable?: Boolean, + * ignored?: Boolean, + * serialized?: Boolean, + * expected?: Boolean, + * inlined?: Boolean, + * quoted?: Boolean, + * silent?: Boolean, + * uninitialized?: Boolean, + * predicate?: (value: T) => Boolean, + * }} AttributeInfoSource + */ - static grammar = this.createGrammar() +/** @template T */ +class AttributeInfo { - /** @protected */ - static createGrammar() { - return /** @type {Parsernostrum} */(Parsernostrum.failure()) - } -} + /** @typedef {keyof AttributeInfo} AttributeKey */ -class SerializerFactory { - - static #serializers = new Map() - - /** - * @template {AttributeConstructor} T - * @param {T} type - * @param {Serializer} object - */ - static registerSerializer(type, object) { - SerializerFactory.#serializers.set(type, object); - } - - /** - * @template {AttributeConstructor} T - * @param {T} type - * @returns {Serializer} - */ - static getSerializer(type) { - return SerializerFactory.#serializers.get(type) - } -} - -/** @abstract */ -class IEntity extends Serializable { - - /** @type {{ [attribute: String]: AttributeInfo }} */ - static attributes = { - attributes: new AttributeInfo({ - ignored: true, - }), - lookbehind: new AttributeInfo({ - default: /** @type {String | Union} */(""), - ignored: true, - uninitialized: true, - }), + static #default = { + nullable: false, + ignored: false, // Never serialize or deserialize + serialized: false, // Value is written and read as string + expected: false, // Must be there + inlined: false, // The key is a subobject or array and printed as inlined (A.B=123, A(0)=123) + quoted: false, // Key is serialized with quotes + silent: false, // Do not serialize if default + uninitialized: false, // Do not initialize with default } - /** @type {String[]} */ - #_keys - get _keys() { - return this.#_keys - } - set _keys(keys) { - this.#_keys = keys; - } - - constructor(values = {}, suppressWarns = false) { - super(); - const Self = /** @type {typeof IEntity} */(this.constructor); - /** @type {AttributeDeclarations?} */ this.attributes; - /** @type {String} */ this.lookbehind; - const valuesKeys = Object.keys(values); - const attributesKeys = values.attributes - ? Utility.mergeArrays(Object.keys(values.attributes), Object.keys(Self.attributes)) - : Object.keys(Self.attributes); - const allAttributesKeys = Utility.mergeArrays(valuesKeys, attributesKeys); - for (const key of allAttributesKeys) { - let value = values[key]; - if (!suppressWarns && !(key in values)) { - if (!(key in Self.attributes) && !key.startsWith(Configuration.subObjectAttributeNamePrefix)) { - const typeName = value instanceof Array ? `[${value[0]?.constructor.name}]` : value.constructor.name; - console.warn( - `UEBlueprint: Attribute ${key} (of type ${typeName}) in the serialized data is not defined in ${Self.name}.attributes` - ); - } - } - if (!(key in Self.attributes)) { - // Remember attributeName can come from the values and be not defined in the attributes. - // In that case just assign it and skip the rest. - this[key] = value; - continue - } - Self.attributes.lookbehind; - const predicate = AttributeInfo.getAttribute(values, key, "predicate", Self); - const assignAttribute = !predicate - ? v => this[key] = v - : v => { - Object.defineProperties(this, { - ["#" + key]: { - writable: true, - enumerable: false, - }, - [key]: { - enumerable: true, - get() { - return this["#" + key] - }, - set(v) { - if (!predicate(v)) { - console.warn( - `UEBlueprint: Tried to assign attribute ${key} to ${Self.name} not satisfying the predicate` - ); - return - } - this["#" + key] = v; - } - }, - }); - this[key] = v; - }; - - let defaultValue = AttributeInfo.getAttribute(values, key, "default", Self); - if (defaultValue instanceof Function) { - defaultValue = defaultValue(this); - } - let defaultType = AttributeInfo.getAttribute(values, key, "type", Self); - if (defaultType instanceof ComputedType) { - defaultType = defaultType.compute(this); - } - if (defaultType instanceof Array) { - defaultType = Array; - } - if (defaultType === undefined) { - defaultType = Utility.getType(defaultValue); - } - - if (value !== undefined) { - // Remember value can still be null - if ( - value?.constructor === String - && AttributeInfo.getAttribute(values, key, "serialized", Self) - && defaultType !== String - ) { - try { - value = SerializerFactory - .getSerializer(defaultType) - .read(/** @type {String} */(value)); - } catch (e) { - assignAttribute(value); - continue - } - } - assignAttribute(Utility.sanitize(value, /** @type {AttributeConstructor} */(defaultType))); - continue // We have a value, need nothing more - } - if (defaultValue !== undefined && !AttributeInfo.getAttribute(values, key, "uninitialized", Self)) { - assignAttribute(defaultValue); - } - } - } - - /** @param {AttributeTypeDescription} attributeType */ - static defaultValueProviderFromType(attributeType) { - if (attributeType === Boolean) { - return false - } else if (attributeType === Number) { - return 0 - } else if (attributeType === BigInt) { - return 0n - } else if (attributeType === String) { - return "" - } else if (attributeType === Array || attributeType instanceof Array) { - return () => [] - } else if (attributeType instanceof Union) { - return this.defaultValueProviderFromType(attributeType.values[0]) - } else if (attributeType instanceof MirroredEntity) { - return () => new MirroredEntity(attributeType.type, attributeType.getter) - } else if (attributeType instanceof ComputedType) { - return undefined - } else { - return () => new /** @type {AnyConstructor} */(attributeType)() + /** @param {AttributeInfoSource} source */ + constructor(source) { + this.type = source.type ?? source.default?.constructor; + this.default = source.default; + this.nullable = source.nullable ?? source.default === null; + this.ignored = source.ignored; + this.serialized = source.serialized; + this.expected = source.expected; + this.inlined = source.inlined; + this.quoted = source.quoted; + this.silent = source.silent; + this.uninitialized = source.uninitialized; + this.predicate = source.predicate; + if (this.type === Array && this.default instanceof Array && this.default.length > 0) { + this.type = this.default + .map(v => v.constructor) + .reduce((acc, cur) => acc.includes(cur) ? acc : (acc.push(cur), acc), []); } } /** - * @template {new (...args: any) => any} C - * @param {C} type - * @returns {value is InstanceType} + * @template {AttributeTypeDescription} D + * @param {D} type + * @returns {AttributeInfo>} */ - static isValueOfType(value, type) { - return value != null && (value instanceof type || value.constructor === type) + static createType(type) { + return new AttributeInfo({ type }) } - static defineAttributes(object, attributes) { - Object.defineProperty(object, "attributes", { - writable: true, - configurable: false, - }); - object.attributes = attributes; + /** + * @template V + * @param {V} value + */ + static createValue(value) { + return new AttributeInfo({ default: value }) + } + + /** + * @param {IEntity | Object} source + * @param {String} attribute + * @param {AttributeKey} key + */ + static hasAttribute(source, attribute, key, type = /** @type {EntityConstructor} */(source.constructor)) { + const entity = /** @type {IEntity} */(source); + const result = entity.attributes[attribute]?.[key]; + return /** @type {result} */( + result + ?? type?.attributes?.[attribute]?.[key] + ?? AttributeInfo.#default[key] + ) + } + + /** + * @template {IEntity | Object} S + * @template {EntityConstructor} C + * @template {keyof C["attributes"]} A + * @template {keyof C["attributes"][attribute]} K + * @param {S} source + * @param {A} attribute + * @param {K} key + * @param {C} type + * @returns {C["attributes"][attribute][key]} + */ + static getAttribute(source, attribute, key, type = /** @type {C} */(source.constructor)) { + let result = source["attributes"]?.[attribute]?.[key]; + // Remember null is a valid asignment value for some attributes + if (result !== undefined) { + return result + } + result = /** @type {C["attributes"]} */(type?.attributes)?.[attribute]?.[key]; + if (result !== undefined) { + return result + } + result = /** @type {C["attributes"][attribute]} */(AttributeInfo.#default)[key]; + if (result !== undefined) { + return result + } + } + + /** @param {AttributeKey} key */ + get(key) { + return this[key] ?? AttributeInfo.#default[key] + } +} + +/** @abstract */ +class IEntity { + + /** @type {(v: String) => String} */ + static same = v => v + + /** @type {(entity: Attribute, serialized: String) => String} */ + static notWrapped = (entity, serialized) => serialized + + /** @type {(entity: Attribute, serialized: String) => String} */ + static bracketsWrapped = (entity, serialized) => `(${serialized})` + + static wrap = this.notWrapped + + static attributeSeparator = "," + + static trailingSeparator = false + + /** @type {(k: String) => String} */ + static printKey = k => k + + /** @type {P} */ + static grammar = Parsernostrum.failure() + + /** @type {{ [key: String]: typeof IEntity }} */ + static attributes = {} + + /** @type {String | String[]} */ + static lookbehind = "" + + /** @type {typeof IEntity.lookbehind} */ + #lookbehind = this.Self().lookbehind + get lookbehind() { + return this.#lookbehind + } + set lookbehind(value) { + throw this.#lookbehind = value + } + + /** @type {String[]} */ + #keys + get keys() { + return this.#keys ?? Object.keys(this.Self().attributes) + } + set keys(value) { + this.#keys = [... new Set(value)]; + } + + /** @type {(type: typeof IEntity) => InstanceType} */ + static default + static nullable = false + static ignored = false // Never serialize or deserialize + static serialized = false // Value is written and read as string + static expected = false // Must be there + static inlined = false // The key is a subobject or array and printed as inlined (A.B=123, A(0)=123) + static quoted = false // Key is serialized with quotes + static silent = false // Do not serialize if default + static uninitialized = false // Do not initialize with default + + constructor(values = {}) { + const keys = Utility.mergeArrays(Object.keys(values.attributes), Object.keys(this.Self().attributes)); + for (const key of keys) { + if (values[key] !== undefined) { + this[key] = values[key]; + continue + } + const attribute = this.Self().attributes[key]; + if (attribute.default !== undefined) { + this[key] = attribute.default(attribute); + continue + } + } + } + + /** @param {String} key */ + showProperty(key) { + /** @type {IEntity} */ + let value = this[key]; + const Self = value.Self(); + if (Self.silent && Self.default !== undefined) { + if (Self["#default"] === undefined) { + Self["#default"] = Self.default(Self); + } + const defaultValue = Self["#default"]; + return !value.equals(defaultValue) + } + return true + } + + /** + * @protected + * @template {typeof IEntity} T + * @this {T} + * @returns {T} + */ + static asUniqueClass() { + if (this.name.length) { + // @ts-expect-error + return class extends this { } + } + return this + } + + /** + * @template {typeof IEntity} T + * @this {T} + */ + static withDefault(value = /** @type {(type: T) => InstanceType} */(type => new type())) { + const result = this.asUniqueClass(); + result.default = value; + return result + } + + /** + * @template {typeof IEntity} T + * @this {T} + */ + static flagNullable(value = true) { + const result = this.asUniqueClass(); + result.nullable = value; + return result + } + + /** + * @template {typeof IEntity} T + * @this {T} + */ + static flagSerialized(value = true) { + const result = this.asUniqueClass(); + result.serialized = value; + return result + } + + /** + * @template {typeof IEntity} T + * @this {T} + */ + static flagInlined(value = true) { + const result = this.asUniqueClass(); + result.inlined = value; + return result + } + + /** + * @template {typeof IEntity} T + * @this {T} + */ + static flagSilent(value = true) { + const result = this.asUniqueClass(); + result.silent = value; + return result + } + + /** + * @template {typeof IEntity} T + * @this {InstanceType} + */ + Self() { + return /** @type {T} */(this.constructor) } /** @@ -2794,27 +2666,16 @@ class IEntity extends Serializable { return this["#" + attribute] }, set(v) { - if (v == this["#" + attribute]) { - return + if (v != this["#" + attribute]) { + callback(v); + this["#" + attribute] = v; } - callback(v); - this["#" + attribute] = v; - } + }, }, }); } } - getLookbehind() { - let lookbehind = this.lookbehind ?? AttributeInfo.getAttribute(this, "lookbehind", "default"); - lookbehind = lookbehind instanceof Union ? lookbehind.values[0] : lookbehind; - return lookbehind - } - - unexpectedKeys() { - return Object.keys(this).length - Object.keys(/** @type {typeof IEntity} */(this.constructor).attributes).length - } - /** @param {IEntity} other */ equals(other) { const thisKeys = Object.keys(this); @@ -2822,15 +2683,98 @@ class IEntity extends Serializable { if (thisKeys.length != otherKeys.length) { return false } - for (const key of thisKeys) { - if (this[key] instanceof IEntity && !this[key].equals(other[key])) { - return false - } else if (!Utility.equals(this[key], other[key])) { + for (let i = 0; i < thisKeys.length; ++i) { + if (!(this[thisKeys[i]] instanceof IEntity && this[thisKeys[i]].equals(other[otherKeys[i]]))) { return false } } return true } + + toString( + insideString = false, + indentation = "", + printKey = this.Self().printKey, + ) { + const Self = this.Self(); + let result = ""; + let first = true; + for (const key of this.keys) { + /** @type {IEntity} */ + const value = this[key]; + if (value === undefined || !this.showProperty(key)) { + continue + } + if (first) { + first = false; + } else { + result += Self.attributeSeparator; + } + if (Self.inlined) { + result += value.toString(insideString, indentation, k => printKey(`${key}.${k}`)); + continue + } + let keyValue = printKey(key); + if (keyValue.length) { + if (Self.quoted) { + keyValue = `"${keyValue}"`; + } + result += Self.attributeSeparator.includes("\n") ? indentation : ""; + } + let serialization = value.toString(insideString, indentation, printKey); + if (Self.serialized) { + serialization = `"${serialization.replaceAll(/(?<=(?:[^\\]|^)(?:\\\\)*?)"/, '\\"')}"`; + } + result += serialization; + } + if (Self.trailingSeparator && result.length) { + result += Self.attributeSeparator; + } + return Self.wrap(this, result) + } +} + +/** @template {typeof IEntity} T */ +class MirroredEntity$1 extends IEntity { + + /** @type {typeof IEntity} */ + static type + + /** @param {() => T} getter */ + constructor(getter = null) { + super(); + this.getter = getter; + } + + /** + * @template {typeof IEntity} T + * @param {T} type + */ + static of(type) { + const result = this.asUniqueClass(); + result.type = type; + result.grammar = result.getTargetType().grammar.map(v => new this()); + return result + } + + /** @returns {typeof IEntity} */ + static getTargetType() { + const result = this.type; + if (result.prototype instanceof MirroredEntity$1) { + return /** @type {typeof MirroredEntity} */(result).getTargetType() + } + return result + } + + toString() { + return this.getter().toString() + } +} + +class Serializable { + + /** @type {Parsernostrum} */ + static grammar = Parsernostrum.failure() } class Grammar { @@ -2862,7 +2806,6 @@ class Grammar { static null = Parsernostrum.reg(/\(\s*\)/).map(() => null) static true = Parsernostrum.reg(/true/i).map(() => true) static false = Parsernostrum.reg(/false/i).map(() => false) - static boolean = Parsernostrum.regArray(/(true)|false/i).map(v => v[1] ? true : false) static number = Parsernostrum.regArray( new RegExp(`(${Parsernostrum.number.getParser().parser.regexp.source})|(\\+?inf)|(-inf)`) ).map(([_0, n, plusInf, minusInf]) => n ? Number(n) : plusInf ? Number.POSITIVE_INFINITY : Number.NEGATIVE_INFINITY) @@ -2917,10 +2860,10 @@ class Grammar { ? this.unknownValue : Parsernostrum.alt(acc, cur) ); - } else if (type instanceof MirroredEntity) { + } else if (type instanceof MirroredEntity$1) { // @ts-expect-error return this.grammarFor(undefined, type.getTargetType()) - .map(v => new MirroredEntity(type.type, () => v)) + .map(v => new MirroredEntity$1(type.type, () => v)) } else if (attribute?.constructor === Object) { result = this.grammarFor(undefined, type); } else { @@ -3066,25 +3009,11 @@ class Grammar { class ColorChannelEntity extends IEntity { - static attributes = { - ...super.attributes, - value: AttributeInfo.createValue(0), - } - static grammar = this.createGrammar() + static grammar = Parsernostrum.number.map(v => new this(v)) - static createGrammar() { - return Parsernostrum.number.map(value => new this(value)) - } - - constructor(values = 0) { - if (values.constructor !== Object) { - // @ts-expect-error - values = { - value: values, - }; - } - super(values); - /** @type {Number} */ this.value; + constructor(value = 0) { + super(); + this.value = value; } valueOf() { @@ -3100,42 +3029,36 @@ class LinearColorEntity extends IEntity { static attributes = { ...super.attributes, - R: new AttributeInfo({ - type: ColorChannelEntity, - default: () => new ColorChannelEntity(), - expected: true, - }), - G: new AttributeInfo({ - type: ColorChannelEntity, - default: () => new ColorChannelEntity(), - expected: true, - }), - B: new AttributeInfo({ - type: ColorChannelEntity, - default: () => new ColorChannelEntity(), - expected: true, - }), - A: new AttributeInfo({ - type: ColorChannelEntity, - default: () => new ColorChannelEntity(1), - }), - H: new AttributeInfo({ - type: ColorChannelEntity, - default: () => new ColorChannelEntity(), - ignored: true, - }), - S: new AttributeInfo({ - type: ColorChannelEntity, - default: () => new ColorChannelEntity(), - ignored: true, - }), - V: new AttributeInfo({ - type: ColorChannelEntity, - default: () => new ColorChannelEntity(), - ignored: true, - }), + R: ColorChannelEntity.withDefault(), + G: ColorChannelEntity.withDefault(), + B: ColorChannelEntity.withDefault(), + A: ColorChannelEntity.withDefault(type => new type(1)), + } + static grammar = Grammar.createEntityGrammar(this, false) + + #H = new ColorChannelEntity() + get H() { + return this.#H + } + set H(value) { + this.#H = value; + } + + #S = new ColorChannelEntity() + get S() { + return this.#H + } + set S(value) { + this.#H = value; + } + + #V = new ColorChannelEntity() + get V() { + return this.#H + } + set V(value) { + this.#H = value; } - static grammar = this.createGrammar() /** @param {Number} x */ static linearToSRGB(x) { @@ -3171,16 +3094,13 @@ class LinearColorEntity extends IEntity { }) } - static createGrammar() { - return Grammar.createEntityGrammar(this, false) - } - static getLinearColorFromHexGrammar() { + const hexDigit = /[0-9a-fA-F]/; return Parsernostrum.regArray(new RegExp( - "#(" + Grammar.Regex.HexDigit.source + "{2})" - + "(" + Grammar.Regex.HexDigit.source + "{2})" - + "(" + Grammar.Regex.HexDigit.source + "{2})" - + "(" + Grammar.Regex.HexDigit.source + "{2})?" + "#(" + hexDigit.source + "{2})" + + "(" + hexDigit.source + "{2})" + + "(" + hexDigit.source + "{2})" + + "(" + hexDigit.source + "{2})?" )).map(([m, R, G, B, A]) => new this({ R: parseInt(R, 16) / 255, G: parseInt(G, 16) / 255, @@ -3230,6 +3150,7 @@ class LinearColorEntity extends IEntity { } constructor(values) { + super(values); if (values instanceof Array) { values = { R: values[0] ?? 0, @@ -3238,14 +3159,10 @@ class LinearColorEntity extends IEntity { A: values[3] ?? 1, }; } - super(values); /** @type {ColorChannelEntity} */ this.R; /** @type {ColorChannelEntity} */ this.G; /** @type {ColorChannelEntity} */ this.B; /** @type {ColorChannelEntity} */ this.A; - /** @type {ColorChannelEntity} */ this.H; - /** @type {ColorChannelEntity} */ this.S; - /** @type {ColorChannelEntity} */ this.V; this.#updateHSV(); } @@ -4399,39 +4316,21 @@ if (typeof window === "undefined") { class GuidEntity extends IEntity { - static attributes = { - ...super.attributes, - value: AttributeInfo.createValue(""), - } - static grammar = this.createGrammar() + static grammar = Parsernostrum.reg(/[0-9a-fA-F]{32}/).map(v => new this(v)) - static createGrammar() { - return Grammar.guid.map(v => new this(v)) - } - - static generateGuid(random = true) { + static generateGuid() { let values = new Uint32Array(4); - if (random === true) { - crypto.getRandomValues(values); - } + crypto.getRandomValues(values); let guid = ""; values.forEach(n => { guid += ("0".repeat(8) + n.toString(16).toUpperCase()).slice(-8); }); - return new GuidEntity({ value: guid }) + return guid } - constructor(values) { - if (!values) { - values = GuidEntity.generateGuid().value; - } - if (values.constructor !== Object) { - values = { - value: values, - }; - } - super(values); - /** @type {String} */ this.value; + constructor(value = GuidEntity.generateGuid()) { + super(); + this.value = value; } valueOf() { @@ -4443,213 +4342,6 @@ class GuidEntity extends IEntity { } } -class ObjectReferenceEntity extends IEntity { - - static attributes = { - ...super.attributes, - type: new AttributeInfo({ - default: "", - serialized: true, - }), - path: new AttributeInfo({ - default: "", - serialized: true, - }), - _full: new AttributeInfo({ - ignored: true, - }), - } - static quoted = Parsernostrum.regArray(new RegExp( - `'"(${Grammar.Regex.InsideString.source})"'` - + "|" - + `'(${Grammar.Regex.InsideSingleQuotedString.source})'` - )).map(([_0, a, b]) => a ?? b) - static path = this.quoted.getParser().parser.regexp.source + "|" + Grammar.Regex.Path.source - static typeReference = Parsernostrum.reg( - new RegExp(Grammar.Regex.Path.source + "|" + Grammar.symbol.getParser().regexp.source) - ) - static fullReferenceGrammar = Parsernostrum.regArray( - new RegExp( - "(" + this.typeReference.getParser().regexp.source + ")" - + "(?:" + this.quoted.getParser().parser.regexp.source + ")" - ) - ).map(([_full, type, ...path]) => new this({ type, path: path.find(v => v), _full })) - static fullReferenceSerializedGrammar = Parsernostrum.regArray( - new RegExp( - '"(' + Grammar.Regex.InsideString.source + "?)" - + "(?:'(" + Grammar.Regex.InsideSingleQuotedString.source + `?)')?"` - ) - ).map(([_full, type, path]) => new this({ type, path, _full })) - static typeReferenceGrammar = this.typeReference.map(v => new this({ type: v, path: "", _full: v })) - static grammar = this.createGrammar() - - constructor(values = {}) { - if (values.constructor === String) { - values = { - path: values - }; - } - super(values); - if (!values._full || values._full.length === 0) { - this._full = `"${this.type + (this.path ? (`'${this.path}'`) : "")}"`; - } - /** @type {String} */ this.type; - /** @type {String} */ this.path; - } - - static createGrammar() { - return Parsernostrum.alt( - this.fullReferenceSerializedGrammar, - this.fullReferenceGrammar, - this.typeReferenceGrammar, - ) - } - - static createNoneInstance() { - return new ObjectReferenceEntity({ type: "None", path: "" }) - } - - getName(dropCounter = false) { - return Utility.getNameFromPath(this.path.replace(/_C$/, ""), dropCounter) - } - - toString() { - return this._full - } -} - -class FunctionReferenceEntity extends IEntity { - - static attributes = { - ...super.attributes, - MemberParent: AttributeInfo.createType(ObjectReferenceEntity), - MemberName: AttributeInfo.createType(String), - MemberGuid: AttributeInfo.createType(GuidEntity), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.createEntityGrammar(this) - } - - constructor(values) { - super(values); - /** @type {ObjectReferenceEntity} */ this.MemberParent; - /** @type {String} */ this.MemberName; - /** @type {GuidEntity} */ this.MemberGuid; - } -} - -class IdentifierEntity extends IEntity { - - static attributes = { - ...super.attributes, - value: AttributeInfo.createValue(""), - } - static attributeConverter = { - fromAttribute: (value, type) => new IdentifierEntity(value), - toAttribute: (value, type) => value.toString() - } - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.symbol.map(v => new this(v)) - } - - constructor(values) { - if (values.constructor !== Object) { - values = { - value: values, - }; - } - super(values); - /** @type {String} */ this.value; - } - - valueOf() { - return this.value - } - - toString() { - return this.value - } -} - -class IntegerEntity extends IEntity { - - static attributes = { - ...super.attributes, - value: new AttributeInfo({ - default: 0, - predicate: v => v % 1 == 0 && v > 1 << 31 && v < -(1 << 31), - }), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Parsernostrum.numberInteger.map(v => new this(v)) - } - - /** @param {Number | Object} values */ - constructor(values = 0) { - if (values.constructor !== Object) { - values = { - value: values, - }; - } - values.value = Math.floor(values.value); - if (values.value === -0) { - values.value = 0; - } - super(values); - /** @type {Number} */ this.value; - } - - valueOf() { - return this.value - } - - toString() { - return this.value.toString() - } -} - -class MacroGraphReferenceEntity extends IEntity { - - static attributes = { - ...super.attributes, - MacroGraph: new AttributeInfo({ - type: ObjectReferenceEntity, - default: () => new ObjectReferenceEntity(), - }), - GraphBlueprint: new AttributeInfo({ - type: ObjectReferenceEntity, - default: () => new ObjectReferenceEntity(), - }), - GraphGuid: new AttributeInfo({ - type: GuidEntity, - default: () => new GuidEntity(), - }), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.createEntityGrammar(this) - } - - constructor(values) { - super(values); - /** @type {ObjectReferenceEntity} */ this.MacroGraph; - /** @type {ObjectReferenceEntity} */ this.GraphBlueprint; - /** @type {GuidEntity} */ this.GuidEntity; - } - - getMacroName() { - const colonIndex = this.MacroGraph.path.search(":"); - return this.MacroGraph.path.substring(colonIndex + 1) - } -} - const colors = { [Configuration.paths.niagaraBool]: i$3`146, 0, 0`, [Configuration.paths.niagaraDataInterfaceVolumeTexture]: i$3`0, 168, 242`, @@ -4734,47 +4426,175 @@ function pinTitle(entity) { return result } +class AlternativesEntity extends IEntity { + + /** @type {(typeof IEntity)[]} */ + static alternatives = [] + + static createGrammar() { + return this.alternatives + .map(entity => entity.grammar) + .reduce((acc, cur) => !cur || cur === Grammar.unknownValue || acc === Grammar.unknownValue + ? Grammar.unknownValue + : Parsernostrum.alt(acc, cur) + ) + } + + /** + * @template {(typeof IEntity)[]} Types + * @param {Types} types + */ + static accepting(...types) { + const result = /** @type {typeof AlternativesEntity & { alternatives: Types }} */(this.asUniqueClass()); + result.alternatives = types; + result.grammar = result.createGrammar(); + return result + } +} + +/** @template {typeof IEntity} T */ +class ArrayEntity extends IEntity { + + /** @type {typeof IEntity} */ + static type + + /** @param {InstanceType[]} values */ + constructor(values = []) { + super(); + this.values = values; + } + + static createGrammar(elementGrammar = this.type.grammar) { + return this.inlined + ? elementGrammar + : Parsernostrum.seq( + Parsernostrum.reg(/\(\s*/), + elementGrammar.sepBy(Grammar.commaSeparation).opt(), + Parsernostrum.reg(/\s*(?:,\s*)?\)/), + ).map(([_0, values, _3]) => new this(values instanceof Array ? values : [])) + } + + /** + * @template {typeof IEntity} T + * @param {NonNullable} type + */ + static of(type) { + const result = /** @type {(typeof ArrayEntity) & { type: T }} */(this.asUniqueClass()); + result.type = type; + this.grammar = result.createGrammar(); + return result + } + + valueOf() { + return this.values + } +} + +class BooleanEntity extends IEntity { + + static grammar = Parsernostrum.regArray(/(true)|false/i).map(v => v[1] ? new this(true) : new this(false)) + + constructor(value = false) { + super(); + this.value = value; + } + + valueOf() { + return this.value + } + + toString() { + return this.value.toString() + } +} + +class NumberEntity extends IEntity { + + static grammar = Parsernostrum.regArray( + new RegExp(`(${Parsernostrum.number.getParser().parser.regexp.source})|(\\+?inf)|(-inf)`) + ).map(([_0, n, plusInf, minusInf]) => new this( + n ? Number(n) : plusInf ? Number.POSITIVE_INFINITY : Number.NEGATIVE_INFINITY + )) + + /** @type {Number} */ + #value + get value() { + return this.#value + } + set value(value) { + if (value === -0) { + value = 0; + } + this.#value = value; + } + + constructor(value = 0) { + super(); + this.value = value; + } + + valueOf() { + return this.value + } + + toString() { + return this.value.toString() + } +} + +// @ts-expect-error +class IntegerEntity extends NumberEntity { + + static grammar = Parsernostrum.numberInteger.map(v => new this(v)) + + set value(value) { + if (value >= -(1 << 31) && value < 1 << 31) { + value = Math.floor(value); + super.value = value; + } + } +} + class ByteEntity extends IntegerEntity { - static attributes = { - ...super.attributes, - value: new AttributeInfo({ - ...super.attributes.value, - predicate: v => v % 1 == 0 && v >= 0 && v < 1 << 8, - }), - } - static grammar = this.createGrammar() + static grammar = Parsernostrum.numberByte.map(v => new this(v)) - static createGrammar() { - return Parsernostrum.numberByte.map(v => new this(v)) - } - - constructor(values = 0) { - super(values); + set value(value) { + if (value % 1 == 0 && value >= 0 && value < 1 << 8) { + super.value = value; + } } } +class ComputedTypeEntity extends IEntity { + + /** @type {(entity: IEntity) => typeof IEntity} */ + static f + + /** + * @template {typeof ComputedTypeEntity.f} T + * @param {T} producer + */ + static from(producer) { + const result = /** @type {(typeof ComputedTypeEntity) & { f: T }} */(this.asUniqueClass()); + result.f = producer; + return result + } + + /** @param {IEntity} entity */ + compute(entity) { + return /** @type {typeof ComputedTypeEntity} */(this.Self()).f(entity) + } +} + class SymbolEntity extends IEntity { - static attributes = { - ...super.attributes, - value: AttributeInfo.createValue(""), - } - static grammar = this.createGrammar() + static grammar = Grammar.symbol.map(v => new this(v)) - static createGrammar() { - return Grammar.symbol.map(v => new this(v)) - } - - /** @param {String | Object} values */ - constructor(values) { - if (values.constructor !== Object) { - values = { - value: values, - }; - } - super(values); - /** @type {String} */ this.value; + /** @param {String} value */ + constructor(value = "") { + super(); + this.value = value; } valueOf() { @@ -4788,55 +4608,30 @@ class SymbolEntity extends IEntity { class EnumEntity extends SymbolEntity { - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.symbol.map(v => new this(v)) - } + static grammar = Grammar.symbol.map(v => new this(v)) } class EnumDisplayValueEntity extends EnumEntity { - static grammar = this.createGrammar() - - static createGrammar() { - return Parsernostrum.reg(Grammar.Regex.InsideString).map(v => new this(v)) - } + static grammar = Parsernostrum.reg(Grammar.Regex.InsideString).map(v => new this(v)) } class InvariantTextEntity extends IEntity { - static attributes = { - ...super.attributes, - value: AttributeInfo.createValue(""), - lookbehind: new AttributeInfo({ - ...super.attributes.lookbehind, - default: "INVTEXT", - }), - } - static grammar = this.createGrammar() + static lookbehind = "INVTEXT" - static createGrammar() { - return Parsernostrum.alt( - Parsernostrum.seq( - Parsernostrum.reg(new RegExp(`${this.attributes.lookbehind.default}\\s*\\(`)), - Grammar.grammarFor(this.attributes.value), - Parsernostrum.reg(/\s*\)/) - ) - .map(([_0, value, _2]) => value), - Parsernostrum.reg(new RegExp(this.attributes.lookbehind.default)) // InvariantTextEntity can not have arguments - .map(() => "") - ).map(value => new this(value)) - } + static grammar = Parsernostrum.alt( + Parsernostrum.seq( + Parsernostrum.reg(new RegExp(`${this.lookbehind}\\s*\\(`)), + Parsernostrum.doubleQuotedString, + Parsernostrum.reg(/\s*\)/) + ).map(([_0, value, _2]) => new this(value)), + Parsernostrum.reg(new RegExp(this.lookbehind)).map(() => new this()) // InvariantTextEntity can not have arguments + ).map(value => new this(value)) - constructor(values) { - if (values.constructor !== Object) { - values = { - value: values, - }; - } - super(values); - /** @type {String} */ this.value; + constructor(value = "") { + super(); + this.value = value; } toString() { @@ -4846,39 +4641,51 @@ class InvariantTextEntity extends IEntity { class LocalizedTextEntity extends IEntity { - static attributes = { - ...super.attributes, - namespace: AttributeInfo.createValue(""), - key: AttributeInfo.createValue(""), - value: AttributeInfo.createValue(""), - lookbehind: new AttributeInfo({ - ...super.attributes.lookbehind, - default: "NSLOCTEXT", - }), - } - static grammar = this.createGrammar() + static lookbehind = "NSLOCTEXT" + static grammar = Parsernostrum.regArray(new RegExp( + String.raw`${this.attributes.lookbehind.default}\s*\(` + + String.raw`\s*"(${Grammar.Regex.InsideString.source})"\s*,` + + String.raw`\s*"(${Grammar.Regex.InsideString.source})"\s*,` + + String.raw`\s*"(${Grammar.Regex.InsideString.source})"\s*` + + String.raw`(?:,\s+)?` + + String.raw`\)`, + "m" + )).map(matchResult => new this( + Utility.unescapeString(matchResult[1]), + Utility.unescapeString(matchResult[2]), + Utility.unescapeString(matchResult[3]), + )) - static createGrammar() { - return Parsernostrum.regArray(new RegExp( - String.raw`${this.attributes.lookbehind.default}\s*\(` - + String.raw`\s*"(${Grammar.Regex.InsideString.source})"\s*,` - + String.raw`\s*"(${Grammar.Regex.InsideString.source})"\s*,` - + String.raw`\s*"(${Grammar.Regex.InsideString.source})"\s*` - + String.raw`(?:,\s+)?` - + String.raw`\)`, - "m" - )).map(matchResult => new this({ - namespace: Utility.unescapeString(matchResult[1]), - key: Utility.unescapeString(matchResult[2]), - value: Utility.unescapeString(matchResult[3]), - })) + #namespace + get namespace() { + return this.#namespace + } + set namespace(value) { + this.#namespace = value; } - constructor(values) { - super(values); - /** @type {String} */ this.namespace; - /** @type {String} */ this.key; - /** @type {String} */ this.value; + #key + get key() { + return this.#key + } + set key(value) { + this.#key = value; + } + + #value + get value() { + return this.#value + } + set value(value) { + this.#value = value; + } + + + constructor(namespace = "", key = "", value = "") { + super(); + this.namespace = namespace; + this.key = key; + this.value = value; } toString() { @@ -4886,50 +4693,54 @@ class LocalizedTextEntity extends IEntity { } } +class StringEntity extends IEntity { + + static grammar = Parsernostrum.doubleQuotedString.map(insideString => Utility.unescapeString(insideString)) + + /** @param {String} value */ + constructor(value = "") { + super(); + this.value = value; + } + + valueOf() { + return this.value + } + + toString() { + return this.value.toString() + } +} + class FormatTextEntity extends IEntity { - static attributes = { - ...super.attributes, - value: new AttributeInfo({ - type: [new Union(String, LocalizedTextEntity, InvariantTextEntity, FormatTextEntity)], - default: [], - }), - lookbehind: /** @type {AttributeInfo>} */(new AttributeInfo({ - ...super.attributes.lookbehind, - default: new Union("LOCGEN_FORMAT_NAMED", "LOCGEN_FORMAT_ORDERED"), - })), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Parsernostrum.seq( - Parsernostrum.reg( - // Resulting regex: /(LOCGEN_FORMAT_NAMED|LOCGEN_FORMAT_ORDERED)\s*/ - new RegExp(`(${this.attributes.lookbehind.default.values.reduce((acc, cur) => acc + "|" + cur)})\\s*`), - 1 - ), - Grammar.grammarFor(this.attributes.value) - ) - .map(([lookbehind, values]) => { - const result = new this({ - value: values, - lookbehind, - }); - return result - }) - } + static lookbehind = ["LOCGEN_FORMAT_NAMED", "LOCGEN_FORMAT_ORDERED"] + static grammar = Parsernostrum.seq( + // Resulting regex: /(LOCGEN_FORMAT_NAMED|LOCGEN_FORMAT_ORDERED)\s*/ + Parsernostrum.reg(new RegExp(String.raw`(${this.lookbehind.reduce((acc, cur) => acc + "|" + cur)})\s*\(\s*)`), 1), + Parsernostrum.alt( + ...[StringEntity, LocalizedTextEntity, InvariantTextEntity, FormatTextEntity].map(type => type.grammar) + ).sepBy(Parsernostrum.reg(/\s*\,\s*/)), + Parsernostrum.reg(/\s*\)/) + ) + .map(([lookbehind, values]) => { + const result = new this(values); + result.lookbehind = lookbehind; + return result + }) + /** @param {(StringEntity | LocalizedTextEntity | InvariantTextEntity | FormatTextEntity)[]} values */ constructor(values) { - super(values); - /** @type {(String | LocalizedTextEntity | InvariantTextEntity | FormatTextEntity)[]} */ this.value; + super(); + this.values = values; } toString() { - const pattern = this.value?.[0]?.toString(); // The pattern is always the first element of the array + const pattern = this.values?.[0]?.toString(); // The pattern is always the first element of the array if (!pattern) { return "" } - const values = this.value.slice(1).map(v => v.toString()); + const values = this.values.slice(1).map(v => v.toString()); return this.lookbehind == "LOCGEN_FORMAT_NAMED" ? pattern.replaceAll(/\{([a-zA-Z]\w*)\}/g, (substring, arg) => { const argLocation = values.indexOf(arg) + 1; @@ -4950,31 +4761,23 @@ class FormatTextEntity extends IEntity { class Integer64Entity extends IEntity { - static attributes = { - ...super.attributes, - value: new AttributeInfo({ - default: 0n, - predicate: v => v >= -(1n << 63n) && v < 1n << 63n, - }), - } - static grammar = this.createGrammar() + static grammar = Parsernostrum.numberBigInteger.map(v => new this(v)) - static createGrammar() { - return Parsernostrum.numberBigInteger.map(v => new this(v)) + /** @type {bigint} */ + #value + get value() { + return this.#value + } + set value(value) { + if (value >= -(1n << 63n) && value < 1n << 63n) { + this.#value = value; + } } - /** @param {BigInt | Number | Object} values */ - constructor(values = 0) { - if (values.constructor !== Object) { - values = { - value: values, - }; - } - if (values.value === -0) { - values.value = 0n; - } - super(values); - /** @type {BigInt} */ this.value; + /** @param {bigint | Number} value */ + constructor(value = 0n) { + super(); + this.value = BigInt(value); } valueOf() { @@ -4986,28 +4789,87 @@ class Integer64Entity extends IEntity { } } +class ObjectReferenceEntity extends IEntity { + + static #quotedParser = Parsernostrum.regArray(new RegExp( + `'"(${Grammar.Regex.InsideString.source})"'` + + "|" + + `'(${Grammar.Regex.InsideSingleQuotedString.source})'` + )).map(([_0, a, b]) => a ?? b) + static typeReference = Parsernostrum.reg( + new RegExp(Grammar.Regex.Path.source + "|" + Grammar.symbol.getParser().regexp.source) + ) + static fullReferenceGrammar = Parsernostrum.regArray( + new RegExp( + "(" + this.typeReference.getParser().regexp.source + ")" + + "(?:" + this.#quotedParser.getParser().parser.regexp.source + ")" + ) + ).map(([full, type, ...path]) => new this(type, path.find(v => v), full)) + static fullReferenceSerializedGrammar = Parsernostrum.regArray( + new RegExp( + '"(' + Grammar.Regex.InsideString.source + "?)" + + "(?:'(" + Grammar.Regex.InsideSingleQuotedString.source + `?)')?"` + ) + ).map(([full, type, path]) => new this(type, path, full)) + static typeReferenceGrammar = this.typeReference.map(v => new this(v, "", v)) + static grammar = Parsernostrum.alt( + this.fullReferenceSerializedGrammar, + this.fullReferenceGrammar, + this.typeReferenceGrammar, + ) + + #type + get type() { + return this.#type + } + set type(value) { + this.#type = value; + } + + #path + get path() { + return this.#path + } + set path(value) { + this.#path = value; + } + + #full + get full() { + return this.#full + } + set full(value) { + this.#full = value; + } + + + constructor(type = "None", path = "", full = null) { + super(); + this.#type = type; + this.#path = path; + this.#full = full ?? `"${this.type + (this.path ? (`'${this.path}'`) : "")}"`; + } + + static createNoneInstance() { + return new ObjectReferenceEntity("None") + } + + getName(dropCounter = false) { + return Utility.getNameFromPath(this.path.replace(/_C$/, ""), dropCounter) + } + + toString() { + return this.full + } +} + class PathSymbolEntity extends IEntity { - static attributes = { - ...super.attributes, - value: new AttributeInfo({ - default: "", - }), - } - static grammar = this.createGrammar() + static grammar = Grammar.symbol.map(v => new this(v)) - static createGrammar() { - return Grammar.symbol.map(v => new this(v)) - } - - constructor(values) { - if (values.constructor !== Object) { - values = { - value: values, - }; - } - super(values); - /** @type {String} */ this.value; + constructor(value = "") { + super(); + this.value = value; } valueOf() { @@ -5015,36 +4877,44 @@ class PathSymbolEntity extends IEntity { } toString() { - return this.value + return this.value.toString() } } class PinReferenceEntity extends IEntity { + static grammar = Parsernostrum.seq( + PathSymbolEntity.grammar, + Parsernostrum.whitespace, + GuidEntity.grammar + ).map(([objectName, _1, pinGuid]) => new this(objectName, pinGuid)) + + /** + * @param {PathSymbolEntity} objectName + * @param {GuidEntity} pinGuid + */ + constructor(objectName = null, pinGuid = null) { + super(); + this.objectName = objectName; + this.pinGuid = pinGuid; + } +} + +class FunctionReferenceEntity extends IEntity { + static attributes = { ...super.attributes, - objectName: AttributeInfo.createType(PathSymbolEntity), - pinGuid: AttributeInfo.createType(GuidEntity), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Parsernostrum.seq( - PathSymbolEntity.grammar, - Parsernostrum.whitespace, - GuidEntity.grammar - ).map( - ([objectName, _1, pinGuid]) => new this({ - objectName: objectName, - pinGuid: pinGuid, - }) - ) + MemberParent: ObjectReferenceEntity, + MemberName: StringEntity, + MemberGuid: GuidEntity, } + static grammar = Grammar.createEntityGrammar(this) constructor(values) { super(values); - /** @type {PathSymbolEntity} */ this.objectName; - /** @type {GuidEntity} */ this.pinGuid; + /** @type {ObjectReferenceEntity} */ this.MemberParent; + /** @type {String} */ this.MemberName; + /** @type {GuidEntity} */ this.MemberGuid; } } @@ -5052,35 +4922,22 @@ class PinTypeEntity extends IEntity { static attributes = { ...super.attributes, - PinCategory: AttributeInfo.createValue(""), - PinSubCategory: AttributeInfo.createValue(""), - PinSubCategoryObject: new AttributeInfo({ - type: ObjectReferenceEntity, - default: () => ObjectReferenceEntity.createNoneInstance(), - }), - PinSubCategoryMemberReference: new AttributeInfo({ - type: FunctionReferenceEntity, - default: null, - }), - PinValueType: new AttributeInfo({ - type: PinTypeEntity, - default: null, - }), - ContainerType: AttributeInfo.createType(PathSymbolEntity), - bIsReference: AttributeInfo.createValue(false), - bIsConst: AttributeInfo.createValue(false), - bIsWeakPointer: AttributeInfo.createValue(false), - bIsUObjectWrapper: AttributeInfo.createValue(false), - bSerializeAsSinglePrecisionFloat: AttributeInfo.createValue(false), + PinCategory: StringEntity.withDefault(), + PinSubCategory: StringEntity.withDefault(), + PinSubCategoryObject: ObjectReferenceEntity.withDefault(), + PinSubCategoryMemberReference: FunctionReferenceEntity.withDefault(type => null), + PinValueType: PinTypeEntity.withDefault(), + ContainerType: PathSymbolEntity, + bIsReference: BooleanEntity.withDefault(), + bIsConst: BooleanEntity.withDefault(), + bIsWeakPointer: BooleanEntity.withDefault(), + bIsUObjectWrapper: BooleanEntity.withDefault(), + bSerializeAsSinglePrecisionFloat: BooleanEntity.withDefault(), } - static grammar = this.createGrammar() + static grammar = Grammar.createEntityGrammar(this) - static createGrammar() { - return Grammar.createEntityGrammar(this) - } - - constructor(values = {}, suppressWarns = false) { - super(values, suppressWarns); + constructor(values = {}) { + super(values); /** @type {String} */ this.PinCategory; /** @type {String} */ this.PinSubCategory; /** @type {ObjectReferenceEntity} */ this.PinSubCategoryObject; @@ -5097,17 +4954,11 @@ class PinTypeEntity extends IEntity { /** @param {PinTypeEntity} other */ copyTypeFrom(other) { - this.PinCategory = other.PinCategory; - this.PinSubCategory = other.PinSubCategory; - this.PinSubCategoryObject = other.PinSubCategoryObject; - this.PinSubCategoryMemberReference = other.PinSubCategoryMemberReference; - this.PinValueType = other.PinValueType; - this.ContainerType = other.ContainerType; - this.bIsReference = other.bIsReference; - this.bIsConst = other.bIsConst; - this.bIsWeakPointer = other.bIsWeakPointer; - this.bIsUObjectWrapper = other.bIsUObjectWrapper; - this.bSerializeAsSinglePrecisionFloat = other.bSerializeAsSinglePrecisionFloat; + for (const key of this.keys) { + if (other[key] !== undefined) { + this[key] = other[key]; + } + } } } @@ -5115,80 +4966,53 @@ class Vector2DEntity extends IEntity { static attributes = { ...super.attributes, - X: new AttributeInfo({ - default: 0, - expected: true, - }), - Y: new AttributeInfo({ - default: 0, - expected: true, - }), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.createEntityGrammar(this, false) + X: NumberEntity.withDefault(), + Y: NumberEntity.withDefault(), } + static grammar = Grammar.createEntityGrammar(this, false) constructor(values) { super(values); - /** @type {Number} */ this.X; - /** @type {Number} */ this.Y; + /** @type {NumberEntity} */ this.X; + /** @type {NumberEntity} */ this.Y; } /** @returns {[Number, Number]} */ toArray() { - return [this.X, this.Y] + return [this.X.valueOf(), this.Y.valueOf()] } } class RBSerializationVector2DEntity extends Vector2DEntity { - static grammar = this.createGrammar() - - static createGrammar() { - return Parsernostrum.alt( - Parsernostrum.regArray(new RegExp( - /X\s*=\s*/.source + "(?" + Parsernostrum.number.getParser().parser.regexp.source + ")" - + "\\s+" - + /Y\s*=\s*/.source + "(?" + Parsernostrum.number.getParser().parser.regexp.source + ")" - )).map(({ groups: { x, y } }) => new this({ - X: Number(x), - Y: Number(y), - })), - Vector2DEntity.grammar - ) - } + static grammar = Parsernostrum.alt( + Parsernostrum.regArray(new RegExp( + /X\s*=\s*/.source + "(?" + Parsernostrum.number.getParser().parser.regexp.source + ")" + + "\\s+" + + /Y\s*=\s*/.source + "(?" + Parsernostrum.number.getParser().parser.regexp.source + ")" + )).map(({ groups: { x, y } }) => new this({ + X: Number(x), + Y: Number(y), + })), + Vector2DEntity.grammar + ) } class RotatorEntity extends IEntity { static attributes = { ...super.attributes, - R: new AttributeInfo({ - default: 0, - expected: true, - }), - P: new AttributeInfo({ - default: 0, - expected: true, - }), - Y: new AttributeInfo({ - default: 0, - expected: true, - }), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.createEntityGrammar(this, false) + R: NumberEntity.withDefault(), + P: NumberEntity.withDefault(), + Y: NumberEntity.withDefault(), } + static grammar = Grammar.createEntityGrammar(this, false) constructor(values) { super(values); - /** @type {Number} */ this.R; - /** @type {Number} */ this.P; - /** @type {Number} */ this.Y; + /** @type {NumberEntity} */ this.R; + /** @type {NumberEntity} */ this.P; + /** @type {NumberEntity} */ this.Y; } getRoll() { @@ -5206,85 +5030,59 @@ class RotatorEntity extends IEntity { class SimpleSerializationRotatorEntity extends RotatorEntity { - static grammar = this.createGrammar() - - static createGrammar() { - const number = Parsernostrum.number.getParser().parser.regexp.source; - return Parsernostrum.alt( - Parsernostrum.regArray(new RegExp( - "(" + number + ")" - + "\\s*,\\s*" - + "(" + number + ")" - + "\\s*,\\s*" - + "(" + number + ")" - )).map(([_, p, y, r]) => new this({ - R: Number(r), - P: Number(p), - Y: Number(y), - })), - RotatorEntity.grammar - ) - } + static grammar = Parsernostrum.alt( + Parsernostrum.regArray(new RegExp( + `(${Parsernostrum.number.getParser().parser.regexp.source})` + + String.raw`\s*,\s*` + + `(${Parsernostrum.number.getParser().parser.regexp.source})` + + String.raw`\s*,\s*` + + `(${Parsernostrum.number.getParser().parser.regexp.source})` + )).map(([_, p, y, r]) => new this({ + R: Number(r), + P: Number(p), + Y: Number(y), + })), + RotatorEntity.grammar + ) } class SimpleSerializationVector2DEntity extends Vector2DEntity { - static grammar = this.createGrammar() - - static createGrammar() { - const number = Parsernostrum.number.getParser().parser.regexp.source; - return Parsernostrum.alt( - Parsernostrum.regArray(new RegExp( - "(" + number + ")" - + "\\s*,\\s*" - + "(" + number + ")" - )).map(([_, x, y]) => new this({ - X: Number(x), - Y: Number(y), - })), - Vector2DEntity.grammar - ) - } + static grammar = Parsernostrum.alt( + Parsernostrum.regArray(new RegExp( + `(${Parsernostrum.number.getParser().parser.regexp.source})` + + String.raw`\s*,\s*` + + `(${Parsernostrum.number.getParser().parser.regexp.source})` + )).map(([_, x, y]) => new this({ + X: Number(x), + Y: Number(y), + })), + Vector2DEntity.grammar + ) } class Vector4DEntity extends IEntity { static attributes = { ...super.attributes, - X: new AttributeInfo({ - default: 0, - expected: true, - }), - Y: new AttributeInfo({ - default: 0, - expected: true, - }), - Z: new AttributeInfo({ - default: 0, - expected: true, - }), - W: new AttributeInfo({ - default: 0, - expected: true, - }), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.createEntityGrammar(Vector4DEntity, false) + X: NumberEntity.withDefault(), + Y: NumberEntity.withDefault(), + Z: NumberEntity.withDefault(), + W: NumberEntity.withDefault(), } + static grammar = Grammar.createEntityGrammar(Vector4DEntity, false) constructor(values) { super(values); - /** @type {Number} */ this.X; - /** @type {Number} */ this.Y; - /** @type {Number} */ this.Z; - /** @type {Number} */ this.W; + /** @type {NumberEntity} */ this.X; + /** @type {NumberEntity} */ this.Y; + /** @type {NumberEntity} */ this.Z; + /** @type {NumberEntity} */ this.W; } /** @returns {[Number, Number, Number, Number]} */ toArray() { - return [this.X, this.Y, this.Z, this.W] + return [this.X.valueOf(), this.Y.valueOf(), this.Z.valueOf(), this.W.valueOf()] } } @@ -5293,16 +5091,16 @@ class SimpleSerializationVector4DEntity extends Vector4DEntity { static grammar = this.createGrammar() static createGrammar() { - const number = Parsernostrum.number.getParser().parser.regexp.source; + Parsernostrum.number.getParser().parser.regexp.source; return Parsernostrum.alt( Parsernostrum.regArray(new RegExp( - "(" + number + ")" - + "\\s*,\\s*" - + "(" + number + ")" - + "\\s*,\\s*" - + "(" + number + ")" - + "\\s*,\\s*" - + "(" + number + ")" + `(${Parsernostrum.number.getParser().parser.regexp.source})` + + String.raw`\s*,\s*` + + `(${Parsernostrum.number.getParser().parser.regexp.source})` + + String.raw`\s*,\s*` + + `(${Parsernostrum.number.getParser().parser.regexp.source})` + + String.raw`\s*,\s*` + + `(${Parsernostrum.number.getParser().parser.regexp.source})` )) .map(([_0, x, y, z, w]) => new this({ X: Number(x), @@ -5319,80 +5117,63 @@ class VectorEntity extends IEntity { static attributes = { ...super.attributes, - X: new AttributeInfo({ - default: 0, - expected: true, - }), - Y: new AttributeInfo({ - default: 0, - expected: true, - }), - Z: new AttributeInfo({ - default: 0, - expected: true, - }), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.createEntityGrammar(VectorEntity, false) + X: NumberEntity.withDefault(), + Y: NumberEntity.withDefault(), + Z: NumberEntity.withDefault(), } + static grammar = Grammar.createEntityGrammar(VectorEntity, false) constructor(values) { super(values); - /** @type {Number} */ this.X; - /** @type {Number} */ this.Y; - /** @type {Number} */ this.Z; + /** @type {NumberEntity} */ this.X; + /** @type {NumberEntity} */ this.Y; + /** @type {NumberEntity} */ this.Z; } /** @returns {[Number, Number, Number]} */ toArray() { - return [this.X, this.Y, this.Z] + return [this.X.valueOf(), this.Y.valueOf(), this.Z.valueOf()] } } class SimpleSerializationVectorEntity extends VectorEntity { - static grammar = this.createGrammar() - - static createGrammar() { - const number = Parsernostrum.number.getParser().parser.regexp.source; - return Parsernostrum.alt( - Parsernostrum.regArray(new RegExp( - "(" + number + ")" - + "\\s*,\\s*" - + "(" + number + ")" - + "\\s*,\\s*" - + "(" + number + ")" - )) - .map(([_0, x, y, z]) => new this({ - X: Number(x), - Y: Number(y), - Z: Number(z), - })), - VectorEntity.grammar - ) - } + static grammar = Parsernostrum.alt( + Parsernostrum.regArray(new RegExp( + `(${Parsernostrum.number.getParser().parser.regexp.source})` + + String.raw`\s*,\s*` + + `(${Parsernostrum.number.getParser().parser.regexp.source})` + + String.raw`\s*,\s*` + + `(${Parsernostrum.number.getParser().parser.regexp.source})` + )) + .map(([_0, x, y, z]) => new this({ + X: Number(x), + Y: Number(y), + Z: Number(z), + })), + VectorEntity.grammar + ) } /** @template {TerminalAttribute} T */ class PinEntity extends IEntity { + static lookbehind = "INVTEXT" static #typeEntityMap = { [Configuration.paths.linearColor]: LinearColorEntity, [Configuration.paths.rotator]: RotatorEntity, [Configuration.paths.vector]: VectorEntity, [Configuration.paths.vector2D]: Vector2DEntity, [Configuration.paths.vector4f]: Vector4DEntity, - "bool": Boolean, + "bool": BooleanEntity, "byte": ByteEntity, "enum": EnumEntity, - "exec": String, + "exec": StringEntity, "int": IntegerEntity, "int64": Integer64Entity, - "name": String, - "real": Number, - "string": String, + "name": StringEntity, + "real": NumberEntity, + "string": StringEntity, } static #alternativeTypeEntityMap = { "enum": EnumDisplayValueEntity, @@ -5405,51 +5186,36 @@ class PinEntity extends IEntity { } static attributes = { ...super.attributes, - lookbehind: new AttributeInfo({ - default: "Pin", - ignored: true, - }), - objectEntity: new AttributeInfo({ - ignored: true, - }), - pinIndex: new AttributeInfo({ - type: Number, - ignored: true, - }), - PinId: new AttributeInfo({ - type: GuidEntity, - default: () => new GuidEntity() - }), - PinName: AttributeInfo.createValue(""), - PinFriendlyName: AttributeInfo.createType(new Union(LocalizedTextEntity, FormatTextEntity, InvariantTextEntity, String)), - PinToolTip: AttributeInfo.createType(String), - Direction: AttributeInfo.createType(String), - PinType: new AttributeInfo({ - type: PinTypeEntity, - default: () => new PinTypeEntity(), - inlined: true, - }), - LinkedTo: AttributeInfo.createType([PinReferenceEntity]), - SubPins: AttributeInfo.createType([PinReferenceEntity]), - ParentPin: AttributeInfo.createType(PinReferenceEntity), - DefaultValue: new AttributeInfo({ - type: new ComputedType( + PinId: GuidEntity.withDefault(), + PinName: StringEntity.withDefault(), + PinFriendlyName: AlternativesEntity.accepting( + LocalizedTextEntity, + FormatTextEntity, + InvariantTextEntity, + StringEntity + ), + PinToolTip: StringEntity, + Direction: StringEntity, + PinType: PinTypeEntity.withDefault().flagInlined(), + LinkedTo: ArrayEntity.of(PinReferenceEntity), + SubPins: ArrayEntity.of(PinReferenceEntity), + ParentPin: PinReferenceEntity, + DefaultValue: + ComputedTypeEntity.from( /** @param {PinEntity} pinEntity */ - pinEntity => pinEntity.getEntityType(true) ?? String - ), - serialized: true, - }), - AutogeneratedDefaultValue: AttributeInfo.createType(String), - DefaultObject: AttributeInfo.createType(ObjectReferenceEntity), - PersistentGuid: AttributeInfo.createType(GuidEntity), - bHidden: AttributeInfo.createValue(false), - bNotConnectable: AttributeInfo.createValue(false), - bDefaultValueIsReadOnly: AttributeInfo.createValue(false), - bDefaultValueIsIgnored: AttributeInfo.createValue(false), - bAdvancedView: AttributeInfo.createValue(false), - bOrphanedPin: AttributeInfo.createValue(false), + pinEntity => pinEntity.getEntityType(true) ?? StringEntity + ).flagSerialized(), + AutogeneratedDefaultValue: StringEntity, + DefaultObject: ObjectReferenceEntity, + PersistentGuid: GuidEntity, + bHidden: BooleanEntity.withDefault(), + bNotConnectable: BooleanEntity.withDefault(), + bDefaultValueIsReadOnly: BooleanEntity.withDefault(), + bDefaultValueIsIgnored: BooleanEntity.withDefault(), + bAdvancedView: BooleanEntity.withDefault(), + bOrphanedPin: BooleanEntity.withDefault(), } - static grammar = this.createGrammar() + static grammar = Grammar.createEntityGrammar(this) #recomputesNodeTitleOnChange = false set recomputesNodeTitleOnChange(value) { @@ -5459,12 +5225,24 @@ class PinEntity extends IEntity { return this.#recomputesNodeTitleOnChange } - static createGrammar() { - return Grammar.createEntityGrammar(this) + #objectEntity + get objectEntity() { + return this.#objectEntity + } + set objectEntity(value) { + this.#objectEntity = value; } - constructor(values = {}, suppressWarns = false) { - super(values, suppressWarns); + #pinIndex + get pinIndex() { + return this.#pinIndex + } + set pinIndex(value) { + this.#pinIndex = value; + } + + constructor(values = {}) { + super(values); /** @type {ObjectEntity} */ this.objectEntity; /** @type {Number} */ this.pinIndex; /** @type {GuidEntity} */ this.PinId; @@ -5488,7 +5266,7 @@ class PinEntity extends IEntity { /** @param {ObjectEntity} objectEntity */ static fromLegacyObject(objectEntity) { - return new PinEntity(objectEntity, true) + return new PinEntity(objectEntity) } getType() { @@ -5654,77 +5432,6 @@ class PinEntity extends IEntity { } } -class ScriptVariableEntity extends IEntity { - - static attributes = { - ...super.attributes, - ScriptVariable: AttributeInfo.createType(ObjectReferenceEntity), - OriginalChangeId: AttributeInfo.createType(GuidEntity), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.createEntityGrammar(this) - } - - constructor(values = {}, suppressWarns = false) { - super(values, suppressWarns); - /** @type {ObjectReferenceEntity} */ this.ScriptVariable; - /** @type {GuidEntity} */ this.OriginalChangeId; - } -} - -class UnknownPinEntity extends PinEntity { - - static grammar = this.createGrammar() - - static createGrammar() { - return Parsernostrum.seq( - Parsernostrum.reg( - new RegExp(`(${Grammar.Regex.Symbol.source})\\s*\\(\\s*`), - 1 - ), - Grammar.createAttributeGrammar(this).sepBy(Grammar.commaSeparation), - Parsernostrum.reg(/\s*(?:,\s*)?\)/) - ).map(([lookbehind, attributes, _2]) => { - lookbehind ??= ""; - let values = {}; - if (lookbehind.length) { - values.lookbehind = lookbehind; - } - attributes.forEach(attributeSetter => attributeSetter(values)); - return new this(values) - }) - } - - constructor(values = {}) { - super(values, true); - } -} - -class VariableReferenceEntity extends IEntity { - - static attributes = { - ...super.attributes, - MemberScope: AttributeInfo.createType(String), - MemberName: AttributeInfo.createValue(""), - MemberGuid: AttributeInfo.createType(GuidEntity), - bSelfContext: AttributeInfo.createType(Boolean), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.createEntityGrammar(this) - } - - constructor(values) { - super(values); - /** @type {String} */ this.MemberName; - /** @type {GuidEntity} */ this.GuidEntity; - /** @type {Boolean} */ this.bSelfContext; - } -} - /** @param {PinEntity} pinEntity */ const indexFromUpperCaseLetterName = pinEntity => pinEntity.PinName.match(/^\s*([A-Z])\s*$/)?.[1]?.charCodeAt(0) - "A".charCodeAt(0); @@ -5870,144 +5577,230 @@ function nodeVariadic(entity) { } } -class ObjectEntity extends IEntity { +class IdentifierEntity extends IEntity { + + static attributeConverter = { + fromAttribute: (value, type) => new IdentifierEntity(value), + toAttribute: (value, type) => value.toString() + } + static grammar = Grammar.symbol.map(v => new this(v)) + + /** @param {String} value */ + constructor(value) { + super(); + this.value = value; + } + + valueOf() { + return this.value + } + + toString() { + return this.value.toString() + } +} + +class MacroGraphReferenceEntity extends IEntity { static attributes = { ...super.attributes, - isExported: new AttributeInfo({ - type: Boolean, - ignored: true, - }), - Class: AttributeInfo.createType(ObjectReferenceEntity), - Name: AttributeInfo.createType(String), - Archetype: AttributeInfo.createType(ObjectReferenceEntity), - ExportPath: AttributeInfo.createType(ObjectReferenceEntity), - ObjectRef: AttributeInfo.createType(ObjectReferenceEntity), - BlueprintElementType: AttributeInfo.createType(ObjectReferenceEntity), - BlueprintElementInstance: AttributeInfo.createType(ObjectReferenceEntity), - PinTags: new AttributeInfo({ - type: [null], - inlined: true, - }), - PinNames: new AttributeInfo({ - type: [String], - inlined: true, - }), - AxisKey: AttributeInfo.createType(SymbolEntity), - InputAxisKey: AttributeInfo.createType(SymbolEntity), - InputName: AttributeInfo.createType(String), - InputType: AttributeInfo.createType(SymbolEntity), - NumAdditionalInputs: AttributeInfo.createType(Number), - bIsPureFunc: AttributeInfo.createType(Boolean), - bIsConstFunc: AttributeInfo.createType(Boolean), - bIsCaseSensitive: AttributeInfo.createType(Boolean), - VariableReference: AttributeInfo.createType(VariableReferenceEntity), - SelfContextInfo: AttributeInfo.createType(SymbolEntity), - DelegatePropertyName: AttributeInfo.createType(String), - DelegateOwnerClass: AttributeInfo.createType(ObjectReferenceEntity), - ComponentPropertyName: AttributeInfo.createType(String), - EventReference: AttributeInfo.createType(FunctionReferenceEntity), - FunctionReference: AttributeInfo.createType(FunctionReferenceEntity), - FunctionScript: AttributeInfo.createType(ObjectReferenceEntity), - CustomFunctionName: AttributeInfo.createType(String), - TargetType: AttributeInfo.createType(ObjectReferenceEntity), - MacroGraphReference: AttributeInfo.createType(MacroGraphReferenceEntity), - Enum: AttributeInfo.createType(ObjectReferenceEntity), - EnumEntries: new AttributeInfo({ - type: [String], - inlined: true, - }), - InputKey: AttributeInfo.createType(SymbolEntity), - OpName: AttributeInfo.createType(String), - CachedChangeId: AttributeInfo.createType(GuidEntity), - FunctionDisplayName: AttributeInfo.createType(String), - AddedPins: new AttributeInfo({ - type: [UnknownPinEntity], - default: () => [], - inlined: true, - silent: true, - }), - ChangeId: AttributeInfo.createType(GuidEntity), - MaterialFunction: AttributeInfo.createType(ObjectReferenceEntity), - bOverrideFunction: AttributeInfo.createType(Boolean), - bInternalEvent: AttributeInfo.createType(Boolean), - bConsumeInput: AttributeInfo.createType(Boolean), - bExecuteWhenPaused: AttributeInfo.createType(Boolean), - bOverrideParentBinding: AttributeInfo.createType(Boolean), - bControl: AttributeInfo.createType(Boolean), - bAlt: AttributeInfo.createType(Boolean), - bShift: AttributeInfo.createType(Boolean), - bCommand: AttributeInfo.createType(Boolean), - CommentColor: AttributeInfo.createType(LinearColorEntity), - bCommentBubbleVisible_InDetailsPanel: AttributeInfo.createType(Boolean), - bColorCommentBubble: AttributeInfo.createType(Boolean), - ProxyFactoryFunctionName: AttributeInfo.createType(String), - ProxyFactoryClass: AttributeInfo.createType(ObjectReferenceEntity), - ProxyClass: AttributeInfo.createType(ObjectReferenceEntity), - StructType: AttributeInfo.createType(ObjectReferenceEntity), - MaterialExpression: AttributeInfo.createType(ObjectReferenceEntity), - MaterialExpressionComment: AttributeInfo.createType(ObjectReferenceEntity), - MoveMode: AttributeInfo.createType(SymbolEntity), - TimelineName: AttributeInfo.createType(String), - TimelineGuid: AttributeInfo.createType(GuidEntity), - SizeX: AttributeInfo.createType(new MirroredEntity(IntegerEntity)), - SizeY: AttributeInfo.createType(new MirroredEntity(IntegerEntity)), - Text: AttributeInfo.createType(new MirroredEntity(String)), - MaterialExpressionEditorX: AttributeInfo.createType(new MirroredEntity(IntegerEntity)), - MaterialExpressionEditorY: AttributeInfo.createType(new MirroredEntity(IntegerEntity)), - NodeTitle: AttributeInfo.createType(String), - NodeTitleColor: AttributeInfo.createType(LinearColorEntity), - PositionX: AttributeInfo.createType(new MirroredEntity(IntegerEntity)), - PositionY: AttributeInfo.createType(new MirroredEntity(IntegerEntity)), - SettingsInterface: AttributeInfo.createType(ObjectReferenceEntity), - PCGNode: AttributeInfo.createType(ObjectReferenceEntity), - HiGenGridSize: AttributeInfo.createType(SymbolEntity), - Operation: AttributeInfo.createType(SymbolEntity), - NodePosX: AttributeInfo.createType(IntegerEntity), - NodePosY: AttributeInfo.createType(IntegerEntity), - NodeHeight: AttributeInfo.createType(IntegerEntity), - NodeWidth: AttributeInfo.createType(IntegerEntity), - Graph: AttributeInfo.createType(ObjectReferenceEntity), - SubgraphInstance: AttributeInfo.createType(String), - InputPins: new AttributeInfo({ - type: [ObjectReferenceEntity], - inlined: true, - }), - OutputPins: new AttributeInfo({ - type: [ObjectReferenceEntity], - inlined: true, - }), - bExposeToLibrary: AttributeInfo.createType(Boolean), - bCanRenameNode: AttributeInfo.createType(Boolean), - bCommentBubblePinned: AttributeInfo.createType(Boolean), - bCommentBubbleVisible: AttributeInfo.createType(Boolean), - NodeComment: AttributeInfo.createType(String), - AdvancedPinDisplay: AttributeInfo.createType(IdentifierEntity), - DelegateReference: AttributeInfo.createType(VariableReferenceEntity), - EnabledState: AttributeInfo.createType(IdentifierEntity), - NodeGuid: AttributeInfo.createType(GuidEntity), - ErrorType: AttributeInfo.createType(IntegerEntity), - ErrorMsg: AttributeInfo.createType(String), - ScriptVariables: new AttributeInfo({ - type: [ScriptVariableEntity], - inlined: true, - }), - Node: AttributeInfo.createType(new MirroredEntity(ObjectReferenceEntity)), - ExportedNodes: AttributeInfo.createType(String), - CustomProperties: AttributeInfo.createType([new Union(PinEntity, UnknownPinEntity)]), + MacroGraph: ObjectReferenceEntity, + GraphBlueprint: ObjectReferenceEntity, + GraphGuid: GuidEntity, } - static nameRegex = /^(\w+?)(?:_(\d+))?$/ + static grammar = Grammar.createEntityGrammar(this) + + constructor(values) { + super(values); + /** @type {ObjectReferenceEntity} */ this.MacroGraph; + /** @type {ObjectReferenceEntity} */ this.GraphBlueprint; + /** @type {GuidEntity} */ this.GuidEntity; + } + + getMacroName() { + const colonIndex = this.MacroGraph.path.search(":"); + return this.MacroGraph.path.substring(colonIndex + 1) + } +} + +class NaturalNumberEntity extends IntegerEntity { + + static grammar = Parsernostrum.numberNatural.map(v => new this(v)) + + set value(value) { + value = Math.round(Utility.clamp(this.value, 0)); + super.value = value; + } + + constructor(value = 0) { + super(value); + } +} + +class ScriptVariableEntity extends IEntity { + + static attributes = { + ...super.attributes, + ScriptVariable: ObjectReferenceEntity, + OriginalChangeId: GuidEntity, + } + static grammar = Grammar.createEntityGrammar(this) + + constructor(values = {}) { + super(values); + /** @type {ObjectReferenceEntity} */ this.ScriptVariable; + /** @type {GuidEntity} */ this.OriginalChangeId; + } +} + +class UnknownPinEntity extends PinEntity { + + static grammar = Parsernostrum.seq( + Parsernostrum.reg(new RegExp(`(${Grammar.Regex.Symbol.source})\\s*\\(\\s*`), 1), + Grammar.createAttributeGrammar(this).sepBy(Grammar.commaSeparation), + Parsernostrum.reg(/\s*(?:,\s*)?\)/) + ).map(([lookbehind, attributes, _2]) => { + lookbehind ??= ""; + let values = {}; + if (lookbehind.length) { + values.lookbehind = lookbehind; + } + attributes.forEach(attributeSetter => attributeSetter(values)); + return new this(values) + }) +} + +class VariableReferenceEntity extends IEntity { + + static attributes = { + ...super.attributes, + MemberScope: StringEntity, + MemberName: StringEntity.withDefault(), + MemberGuid: GuidEntity, + bSelfContext: BooleanEntity, + } + static grammar = Grammar.createEntityGrammar(this) + + constructor(values) { + super(values); + /** @type {String} */ this.MemberName; + /** @type {GuidEntity} */ this.GuidEntity; + /** @type {Boolean} */ this.bSelfContext; + } +} + +class ObjectEntity extends IEntity { + + #_exported = false + get _exported() { + return this.#_exported + } + set _exported(value) { + this.#_exported = value; + } + + static attributes = { + ...super.attributes, + Class: ObjectReferenceEntity, + Name: StringEntity, + Archetype: ObjectReferenceEntity, + ExportPath: ObjectReferenceEntity, + ObjectRef: ObjectReferenceEntity, + BlueprintElementType: ObjectReferenceEntity, + BlueprintElementInstance: ObjectReferenceEntity, + PinNames: ArrayEntity.of(StringEntity).flagInlined(), + AxisKey: SymbolEntity, + InputAxisKey: SymbolEntity, + InputName: StringEntity, + InputType: SymbolEntity, + NumAdditionalInputs: NaturalNumberEntity, + bIsPureFunc: BooleanEntity, + bIsConstFunc: BooleanEntity, + bIsCaseSensitive: BooleanEntity, + VariableReference: VariableReferenceEntity, + SelfContextInfo: SymbolEntity, + DelegatePropertyName: StringEntity, + DelegateOwnerClass: ObjectReferenceEntity, + ComponentPropertyName: StringEntity, + EventReference: FunctionReferenceEntity, + FunctionReference: FunctionReferenceEntity, + FunctionScript: ObjectReferenceEntity, + CustomFunctionName: StringEntity, + TargetType: ObjectReferenceEntity, + MacroGraphReference: MacroGraphReferenceEntity, + Enum: ObjectReferenceEntity, + EnumEntries: ArrayEntity.of(StringEntity).flagInlined(), + InputKey: SymbolEntity, + OpName: StringEntity, + CachedChangeId: GuidEntity, + FunctionDisplayName: StringEntity, + AddedPins: ArrayEntity.of(UnknownPinEntity).withDefault().flagInlined().flagSilent(), + ChangeId: GuidEntity, + MaterialFunction: ObjectReferenceEntity, + bOverrideFunction: BooleanEntity, + bInternalEvent: BooleanEntity, + bConsumeInput: BooleanEntity, + bExecuteWhenPaused: BooleanEntity, + bOverrideParentBinding: BooleanEntity, + bControl: BooleanEntity, + bAlt: BooleanEntity, + bShift: BooleanEntity, + bCommand: BooleanEntity, + CommentColor: LinearColorEntity, + bCommentBubbleVisible_InDetailsPanel: BooleanEntity, + bColorCommentBubble: BooleanEntity, + ProxyFactoryFunctionName: StringEntity, + ProxyFactoryClass: ObjectReferenceEntity, + ProxyClass: ObjectReferenceEntity, + StructType: ObjectReferenceEntity, + MaterialExpression: ObjectReferenceEntity, + MaterialExpressionComment: ObjectReferenceEntity, + MoveMode: SymbolEntity, + TimelineName: StringEntity, + TimelineGuid: GuidEntity, + SizeX: MirroredEntity$1.of(IntegerEntity), + SizeY: MirroredEntity$1.of(IntegerEntity), + Text: MirroredEntity$1.of(StringEntity), + MaterialExpressionEditorX: MirroredEntity$1.of(IntegerEntity), + MaterialExpressionEditorY: MirroredEntity$1.of(IntegerEntity), + NodeTitle: StringEntity, + NodeTitleColor: LinearColorEntity, + PositionX: MirroredEntity$1.of(IntegerEntity), + PositionY: MirroredEntity$1.of(IntegerEntity), + SettingsInterface: ObjectReferenceEntity, + PCGNode: ObjectReferenceEntity, + HiGenGridSize: SymbolEntity, + Operation: SymbolEntity, + NodePosX: IntegerEntity, + NodePosY: IntegerEntity, + NodeHeight: IntegerEntity, + NodeWidth: IntegerEntity, + Graph: ObjectReferenceEntity, + SubgraphInstance: StringEntity, + InputPins: ArrayEntity.of(ObjectReferenceEntity).flagInlined(), + OutputPins: ArrayEntity.of(ObjectReferenceEntity).flagInlined(), + bExposeToLibrary: BooleanEntity, + bCanRenameNode: BooleanEntity, + bCommentBubblePinned: BooleanEntity, + bCommentBubbleVisible: BooleanEntity, + NodeComment: StringEntity, + AdvancedPinDisplay: IdentifierEntity, + DelegateReference: VariableReferenceEntity, + EnabledState: IdentifierEntity, + NodeGuid: GuidEntity, + ErrorType: IntegerEntity, + ErrorMsg: StringEntity, + ScriptVariables: ArrayEntity.of(ScriptVariableEntity), + Node: MirroredEntity$1.of(ObjectReferenceEntity), + ExportedNodes: StringEntity, + CustomProperties: ArrayEntity.of(AlternativesEntity.accepting(PinEntity, UnknownPinEntity)), + } + static #nameRegex = /^(\w+?)(?:_(\d+))?$/ static customPropertyGrammar = Parsernostrum.seq( Parsernostrum.reg(/CustomProperties\s+/), - Grammar.grammarFor( - undefined, - this.attributes.CustomProperties.type[0] - ), + this.attributes.CustomProperties.type.grammar, ).map(([_0, pin]) => values => { - if (!values.CustomProperties) { - values.CustomProperties = []; - } - values.CustomProperties.push(pin); + (values.CustomProperties ??= []).push(pin); }) static inlinedArrayEntryGrammar = Parsernostrum.seq( Parsernostrum.alt( @@ -6090,7 +5883,7 @@ class ObjectEntity extends IEntity { /** @type {String} */ #class - constructor(values = {}, suppressWarns = false) { + constructor(values = {}) { if ("NodePosX" in values !== "NodePosY" in values) { const entries = Object.entries(values); const [key, position] = "NodePosX" in values @@ -6100,13 +5893,7 @@ class ObjectEntity extends IEntity { entries.splice(position, 0, entry); values = Object.fromEntries(entries); } - super(values, suppressWarns); - - // Attributes not assigned a strong type in attributes because the names are too generic - /** @type {Number | MirroredEntity} */ this.R; - /** @type {Number | MirroredEntity} */ this.G; - /** @type {Number | MirroredEntity} */ this.B; - /** @type {Number | MirroredEntity} */ this.A; + super(values); // Attributes /** @type {(PinEntity | UnknownPinEntity)[]} */ this.CustomProperties; @@ -6206,19 +5993,19 @@ class ObjectEntity extends IEntity { const rgbaPins = Configuration.rgba.map(pinName => this.getPinEntities().find(pin => pin.PinName === pinName && (pin.recomputesNodeTitleOnChange = true)) ); - obj.R = new MirroredEntity(Boolean, () => rgbaPins[0].DefaultValue); - obj.G = new MirroredEntity(Boolean, () => rgbaPins[1].DefaultValue); - obj.B = new MirroredEntity(Boolean, () => rgbaPins[2].DefaultValue); - obj.A = new MirroredEntity(Boolean, () => rgbaPins[3].DefaultValue); - Utility.objectSet(obj, ["attributes", "R", "default"], false); - Utility.objectSet(obj, ["attributes", "R", "silent"], true); - Utility.objectSet(obj, ["attributes", "G", "default"], false); - Utility.objectSet(obj, ["attributes", "G", "silent"], true); - Utility.objectSet(obj, ["attributes", "B", "default"], false); - Utility.objectSet(obj, ["attributes", "B", "silent"], true); - Utility.objectSet(obj, ["attributes", "A", "default"], false); - Utility.objectSet(obj, ["attributes", "A", "silent"], true); - obj._keys = [...Configuration.rgba, ...Object.keys(obj).filter(k => !Configuration.rgba.includes(k))]; + obj.R = new ( + MirroredEntity$1.of(BooleanEntity).withDefault().flagSilent() + )(() => rgbaPins[0].DefaultValue); + obj.G = new ( + MirroredEntity$1.of(BooleanEntity).withDefault().flagSilent() + )(() => rgbaPins[1].DefaultValue); + obj.B = new ( + MirroredEntity$1.of(BooleanEntity).withDefault().flagSilent() + )(() => rgbaPins[2].DefaultValue); + obj.A = new ( + MirroredEntity$1.of(BooleanEntity).withDefault().flagSilent() + )(() => rgbaPins[3].DefaultValue); + obj.keys = [...Configuration.rgba, ...super.keys.filter(k => !Configuration.rgba.includes(k))]; } } /** @type {ObjectEntity} */ @@ -6235,10 +6022,10 @@ class ObjectEntity extends IEntity { nodeRef.type === this.PCGNode.type && nodeRef.path === `${this.Name}.${this.PCGNode.path}` ) { - obj.Node.getter = () => new ObjectReferenceEntity({ - type: this.PCGNode.type, - path: `${this.Name}.${this.PCGNode.path}`, - }); + obj.Node.getter = () => new ObjectReferenceEntity( + this.PCGNode.type, + `${this.Name}.${this.PCGNode.path}`, + ); } } } @@ -6293,7 +6080,7 @@ class ObjectEntity extends IEntity { /** @returns {[String, Number]} */ getNameAndCounter() { - const result = this.getObjectName().match(ObjectEntity.nameRegex); + const result = this.getObjectName().match(ObjectEntity.#nameRegex); return result ? [result[1] ?? "", parseInt(result[2] ?? "0")] : ["", 0] @@ -6501,21 +6288,19 @@ class KnotEntity extends ObjectEntity { values.Name = "K2Node_Knot"; const inputPinEntity = new PinEntity( { PinName: "InputPin" }, - true ); const outputPinEntity = new PinEntity( { PinName: "OutputPin", Direction: "EGPD_Output", }, - true ); if (pinReferenceForType) { inputPinEntity.copyTypeFrom(pinReferenceForType); outputPinEntity.copyTypeFrom(pinReferenceForType); } values["CustomProperties"] = [inputPinEntity, outputPinEntity]; - super(values, true); + super(values); } } @@ -6600,26 +6385,24 @@ class KeyBindingEntity extends IEntity { static attributes = { ...super.attributes, - ActionName: AttributeInfo.createValue(""), - bShift: AttributeInfo.createValue(false), - bCtrl: AttributeInfo.createValue(false), - bAlt: AttributeInfo.createValue(false), - bCmd: AttributeInfo.createValue(false), - Key: AttributeInfo.createType(IdentifierEntity), + ActionName: StringEntity, + bShift: BooleanEntity, + bCtrl: BooleanEntity, + bAlt: BooleanEntity, + bCmd: BooleanEntity, + Key: IdentifierEntity, } - static grammar = this.createGrammar() + static grammar = Parsernostrum.alt( + IdentifierEntity.grammar.map(identifier => { + const result = new this(); + result.Key = identifier; + return result + }), + Grammar.createEntityGrammar(this) + ) - static createGrammar() { - return Parsernostrum.alt( - IdentifierEntity.grammar.map(identifier => new this({ - Key: identifier - })), - Grammar.createEntityGrammar(this) - ) - } - - constructor(values = {}) { - super(values, true); + constructor() { + super(); /** @type {String} */ this.ActionName; /** @type {Boolean} */ this.bShift; /** @type {Boolean} */ this.bCtrl; @@ -9308,6 +9091,29 @@ function nodeTemplateClass(nodeEntity) { return NodeTemplate } +class SerializerFactory { + + static #serializers = new Map() + + /** + * @template {AttributeConstructor} T + * @param {T} type + * @param {Serializer} object + */ + static registerSerializer(type, object) { + SerializerFactory.#serializers.set(type, object); + } + + /** + * @template {AttributeConstructor} T + * @param {T} type + * @returns {Serializer} + */ + static getSerializer(type) { + return SerializerFactory.#serializers.get(type) + } +} + /** * @template {IEntity} EntityT * @template {ISelectableDraggableTemplate} TemplateT @@ -11075,7 +10881,7 @@ class Blueprint extends IElement { this.entity = this.entity.mergeWith(element.entity); const additionalSerialization = atob(element.entity.ExportedNodes); this.template.getPasteInputObject().pasted(additionalSerialization) - .forEach(node => node.entity.isExported = true); + .forEach(node => node.entity._exported = true); continue } const name = element.entity.getObjectName(); @@ -13222,11 +13028,11 @@ class TerminalTypeEntity extends IEntity { static attributes = { ...super.attributes, - TerminalCategory: AttributeInfo.createType(String), - TerminalSubCategory: AttributeInfo.createType(String), - bTerminalIsConst: AttributeInfo.createType(Boolean), - bTerminalIsWeakPointer: AttributeInfo.createType(Boolean), - bTerminalIsUObjectWrapper: AttributeInfo.createType(Boolean), + TerminalCategory: StringEntity, + TerminalSubCategory: StringEntity, + bTerminalIsConst: BooleanEntity, + bTerminalIsWeakPointer: BooleanEntity, + bTerminalIsUObjectWrapper: BooleanEntity, } constructor(values) { @@ -13242,36 +13048,29 @@ class TerminalTypeEntity extends IEntity { class UnknownKeysEntity extends IEntity { - static grammar = this.createGrammar() - - static createGrammar() { - return Parsernostrum.seq( - // Lookbehind - Parsernostrum.reg( - new RegExp(`(${Grammar.Regex.Path.source}|${Grammar.Regex.Symbol.source}\\s*)?\\(\\s*`), - 1 - ), - Parsernostrum.seq(Grammar.attributeName, Grammar.equalSeparation).map(([attribute, equal]) => attribute) - .chain(attributeName => - Grammar.unknownValue.map(attributeValue => - values => values[attributeName] = attributeValue - ) + static grammar = Parsernostrum.seq( + // Lookbehind + Parsernostrum.reg(new RegExp(`(${Grammar.Regex.Path.source}|${Grammar.Regex.Symbol.source}\\s*)?\\(\\s*`), 1), + Parsernostrum.seq(Grammar.attributeName, Grammar.equalSeparation).map(([attribute, equal]) => attribute) + .chain(attributeName => + Grammar.unknownValue.map(attributeValue => + values => values[attributeName] = attributeValue ) - .sepBy(Grammar.commaSeparation), - Parsernostrum.reg(/\s*(?:,\s*)?\)/), - ).map(([lookbehind, attributes, _2]) => { - lookbehind ??= ""; - let values = {}; - if (lookbehind.length) { - values.lookbehind = lookbehind; - } - attributes.forEach(attributeSetter => attributeSetter(values)); - return new this(values) - }) - } + ) + .sepBy(Grammar.commaSeparation), + Parsernostrum.reg(/\s*(?:,\s*)?\)/), + ).map(([lookbehind, attributes, _2]) => { + lookbehind ??= ""; + let values = {}; + if (lookbehind.length) { + values.lookbehind = lookbehind; + } + attributes.forEach(attributeSetter => attributeSetter(values)); + return new this(values) + }) - constructor(values) { - super(values, true); + constructor(values = {}) { + super(values); } } @@ -13332,13 +13131,13 @@ class ToStringSerializer extends Serializer { Grammar.unknownValue = Parsernostrum.alt( // Remember to keep the order, otherwise parsing might fail - Grammar.boolean, + BooleanEntity.grammar, GuidEntity.grammar, - Parsernostrum.str("None").map(() => new ObjectReferenceEntity({ type: "None" })), + Parsernostrum.str("None").map(() => ObjectReferenceEntity.createNoneInstance()), Grammar.null, - Grammar.number, + NumberEntity.grammar, ObjectReferenceEntity.fullReferenceGrammar, - Grammar.string, + StringEntity.grammar, LocalizedTextEntity.grammar, InvariantTextEntity.grammar, FormatTextEntity.grammar, @@ -13350,9 +13149,9 @@ Grammar.unknownValue = Vector2DEntity.grammar, UnknownKeysEntity.grammar, SymbolEntity.grammar, - Grammar.grammarFor(undefined, [PinReferenceEntity]), - Grammar.grammarFor(undefined, [new Union(Number, String, SymbolEntity)]), - Parsernostrum.lazy(() => Grammar.grammarFor(undefined, [undefined])), + ArrayEntity.of(PinReferenceEntity).grammar, + ArrayEntity.of(AlternativesEntity.accepting(NumberEntity, StringEntity, SymbolEntity)).grammar, + Parsernostrum.lazy(() => ArrayEntity.createGrammar(Grammar.unknownValue)), ); function initializeSerializerFactory() { @@ -13486,11 +13285,11 @@ function initializeSerializerFactory() { new Serializer(MacroGraphReferenceEntity, Serializer.bracketsWrapped) ); - SerializerFactory.registerSerializer( - MirroredEntity, + SerializerFactory.registeOrSerializer( + MirroredEntity$1, new CustomSerializer( (v, insideString) => SerializerFactory.getSerializer(v.getTargetType()).write(v.get(), insideString), - MirroredEntity + MirroredEntity$1 ) ); diff --git a/dist/ueblueprint.min.js b/dist/ueblueprint.min.js index 52e40bf..1cdd969 100644 --- a/dist/ueblueprint.min.js +++ b/dist/ueblueprint.min.js @@ -3,31 +3,31 @@ * Copyright 2019 Google LLC * SPDX-License-Identifier: BSD-3-Clause */ -const e=window,t=e.ShadowRoot&&(void 0===e.ShadyCSS||e.ShadyCSS.nativeShadow)&&"adoptedStyleSheets"in Document.prototype&&"replace"in CSSStyleSheet.prototype,i=Symbol(),r=new WeakMap;class s{constructor(e,t,r){if(this._$cssResult$=!0,r!==i)throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");this.cssText=e,this.t=t}get styleSheet(){let e=this.o;const i=this.t;if(t&&void 0===e){const t=void 0!==i&&1===i.length;t&&(e=r.get(i)),void 0===e&&((this.o=e=new CSSStyleSheet).replaceSync(this.cssText),t&&r.set(i,e))}return e}toString(){return this.cssText}}const n=(e,...t)=>{const r=1===e.length?e[0]:t.reduce(((t,i,r)=>t+(e=>{if(!0===e._$cssResult$)return e.cssText;if("number"==typeof e)return e;throw Error("Value passed to 'css' function must be a 'css' function result: "+e+". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.")})(i)+e[r+1]),e[0]);return new s(r,e,i)},a=t?e=>e:e=>e instanceof CSSStyleSheet?(e=>{let t="";for(const i of e.cssRules)t+=i.cssText;return(e=>new s("string"==typeof e?e:e+"",void 0,i))(t)})(e):e +const e=window,t=e.ShadowRoot&&(void 0===e.ShadyCSS||e.ShadyCSS.nativeShadow)&&"adoptedStyleSheets"in Document.prototype&&"replace"in CSSStyleSheet.prototype,i=Symbol(),s=new WeakMap;class n{constructor(e,t,s){if(this._$cssResult$=!0,s!==i)throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");this.cssText=e,this.t=t}get styleSheet(){let e=this.o;const i=this.t;if(t&&void 0===e){const t=void 0!==i&&1===i.length;t&&(e=s.get(i)),void 0===e&&((this.o=e=new CSSStyleSheet).replaceSync(this.cssText),t&&s.set(i,e))}return e}toString(){return this.cssText}}const r=(e,...t)=>{const s=1===e.length?e[0]:t.reduce(((t,i,s)=>t+(e=>{if(!0===e._$cssResult$)return e.cssText;if("number"==typeof e)return e;throw Error("Value passed to 'css' function must be a 'css' function result: "+e+". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.")})(i)+e[s+1]),e[0]);return new n(s,e,i)},a=t?e=>e:e=>e instanceof CSSStyleSheet?(e=>{let t="";for(const i of e.cssRules)t+=i.cssText;return(e=>new n("string"==typeof e?e:e+"",void 0,i))(t)})(e):e /** * @license * Copyright 2017 Google LLC * SPDX-License-Identifier: BSD-3-Clause - */;var o;const l=window,c=l.trustedTypes,u=c?c.emptyScript:"",h=l.reactiveElementPolyfillSupport,p={toAttribute(e,t){switch(t){case Boolean:e=e?u:null;break;case Object:case Array:e=null==e?e:JSON.stringify(e)}return e},fromAttribute(e,t){let i=e;switch(t){case Boolean:i=null!==e;break;case Number:i=null===e?null:Number(e);break;case Object:case Array:try{i=JSON.parse(e)}catch(e){i=null}}return i}},d=(e,t)=>t!==e&&(t==t||e==e),m={attribute:!0,type:String,converter:p,reflect:!1,hasChanged:d},g="finalized";class b extends HTMLElement{constructor(){super(),this._$Ei=new Map,this.isUpdatePending=!1,this.hasUpdated=!1,this._$El=null,this._$Eu()}static addInitializer(e){var t;this.finalize(),(null!==(t=this.h)&&void 0!==t?t:this.h=[]).push(e)}static get observedAttributes(){this.finalize();const e=[];return this.elementProperties.forEach(((t,i)=>{const r=this._$Ep(i,t);void 0!==r&&(this._$Ev.set(r,i),e.push(r))})),e}static createProperty(e,t=m){if(t.state&&(t.attribute=!1),this.finalize(),this.elementProperties.set(e,t),!t.noAccessor&&!this.prototype.hasOwnProperty(e)){const i="symbol"==typeof e?Symbol():"__"+e,r=this.getPropertyDescriptor(e,i,t);void 0!==r&&Object.defineProperty(this.prototype,e,r)}}static getPropertyDescriptor(e,t,i){return{get(){return this[t]},set(r){const s=this[e];this[t]=r,this.requestUpdate(e,s,i)},configurable:!0,enumerable:!0}}static getPropertyOptions(e){return this.elementProperties.get(e)||m}static finalize(){if(this.hasOwnProperty(g))return!1;this[g]=!0;const e=Object.getPrototypeOf(this);if(e.finalize(),void 0!==e.h&&(this.h=[...e.h]),this.elementProperties=new Map(e.elementProperties),this._$Ev=new Map,this.hasOwnProperty("properties")){const e=this.properties,t=[...Object.getOwnPropertyNames(e),...Object.getOwnPropertySymbols(e)];for(const i of t)this.createProperty(i,e[i])}return this.elementStyles=this.finalizeStyles(this.styles),!0}static finalizeStyles(e){const t=[];if(Array.isArray(e)){const i=new Set(e.flat(1/0).reverse());for(const e of i)t.unshift(a(e))}else void 0!==e&&t.push(a(e));return t}static _$Ep(e,t){const i=t.attribute;return!1===i?void 0:"string"==typeof i?i:"string"==typeof e?e.toLowerCase():void 0}_$Eu(){var e;this._$E_=new Promise((e=>this.enableUpdating=e)),this._$AL=new Map,this._$Eg(),this.requestUpdate(),null===(e=this.constructor.h)||void 0===e||e.forEach((e=>e(this)))}addController(e){var t,i;(null!==(t=this._$ES)&&void 0!==t?t:this._$ES=[]).push(e),void 0!==this.renderRoot&&this.isConnected&&(null===(i=e.hostConnected)||void 0===i||i.call(e))}removeController(e){var t;null===(t=this._$ES)||void 0===t||t.splice(this._$ES.indexOf(e)>>>0,1)}_$Eg(){this.constructor.elementProperties.forEach(((e,t)=>{this.hasOwnProperty(t)&&(this._$Ei.set(t,this[t]),delete this[t])}))}createRenderRoot(){var i;const r=null!==(i=this.shadowRoot)&&void 0!==i?i:this.attachShadow(this.constructor.shadowRootOptions);return((i,r)=>{t?i.adoptedStyleSheets=r.map((e=>e instanceof CSSStyleSheet?e:e.styleSheet)):r.forEach((t=>{const r=document.createElement("style"),s=e.litNonce;void 0!==s&&r.setAttribute("nonce",s),r.textContent=t.cssText,i.appendChild(r)}))})(r,this.constructor.elementStyles),r}connectedCallback(){var e;void 0===this.renderRoot&&(this.renderRoot=this.createRenderRoot()),this.enableUpdating(!0),null===(e=this._$ES)||void 0===e||e.forEach((e=>{var t;return null===(t=e.hostConnected)||void 0===t?void 0:t.call(e)}))}enableUpdating(e){}disconnectedCallback(){var e;null===(e=this._$ES)||void 0===e||e.forEach((e=>{var t;return null===(t=e.hostDisconnected)||void 0===t?void 0:t.call(e)}))}attributeChangedCallback(e,t,i){this._$AK(e,i)}_$EO(e,t,i=m){var r;const s=this.constructor._$Ep(e,i);if(void 0!==s&&!0===i.reflect){const n=(void 0!==(null===(r=i.converter)||void 0===r?void 0:r.toAttribute)?i.converter:p).toAttribute(t,i.type);this._$El=e,null==n?this.removeAttribute(s):this.setAttribute(s,n),this._$El=null}}_$AK(e,t){var i;const r=this.constructor,s=r._$Ev.get(e);if(void 0!==s&&this._$El!==s){const e=r.getPropertyOptions(s),n="function"==typeof e.converter?{fromAttribute:e.converter}:void 0!==(null===(i=e.converter)||void 0===i?void 0:i.fromAttribute)?e.converter:p;this._$El=s,this[s]=n.fromAttribute(t,e.type),this._$El=null}}requestUpdate(e,t,i){let r=!0;void 0!==e&&(((i=i||this.constructor.getPropertyOptions(e)).hasChanged||d)(this[e],t)?(this._$AL.has(e)||this._$AL.set(e,t),!0===i.reflect&&this._$El!==e&&(void 0===this._$EC&&(this._$EC=new Map),this._$EC.set(e,i))):r=!1),!this.isUpdatePending&&r&&(this._$E_=this._$Ej())}async _$Ej(){this.isUpdatePending=!0;try{await this._$E_}catch(e){Promise.reject(e)}const e=this.scheduleUpdate();return null!=e&&await e,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){var e;if(!this.isUpdatePending)return;this.hasUpdated,this._$Ei&&(this._$Ei.forEach(((e,t)=>this[t]=e)),this._$Ei=void 0);let t=!1;const i=this._$AL;try{t=this.shouldUpdate(i),t?(this.willUpdate(i),null===(e=this._$ES)||void 0===e||e.forEach((e=>{var t;return null===(t=e.hostUpdate)||void 0===t?void 0:t.call(e)})),this.update(i)):this._$Ek()}catch(e){throw t=!1,this._$Ek(),e}t&&this._$AE(i)}willUpdate(e){}_$AE(e){var t;null===(t=this._$ES)||void 0===t||t.forEach((e=>{var t;return null===(t=e.hostUpdated)||void 0===t?void 0:t.call(e)})),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(e)),this.updated(e)}_$Ek(){this._$AL=new Map,this.isUpdatePending=!1}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$E_}shouldUpdate(e){return!0}update(e){void 0!==this._$EC&&(this._$EC.forEach(((e,t)=>this._$EO(t,this[t],e))),this._$EC=void 0),this._$Ek()}updated(e){}firstUpdated(e){}} + */;var o;const l=window,u=l.trustedTypes,c=u?u.emptyScript:"",h=l.reactiveElementPolyfillSupport,p={toAttribute(e,t){switch(t){case Boolean:e=e?c:null;break;case Object:case Array:e=null==e?e:JSON.stringify(e)}return e},fromAttribute(e,t){let i=e;switch(t){case Boolean:i=null!==e;break;case Number:i=null===e?null:Number(e);break;case Object:case Array:try{i=JSON.parse(e)}catch(e){i=null}}return i}},d=(e,t)=>t!==e&&(t==t||e==e),m={attribute:!0,type:String,converter:p,reflect:!1,hasChanged:d},g="finalized";class b extends HTMLElement{constructor(){super(),this._$Ei=new Map,this.isUpdatePending=!1,this.hasUpdated=!1,this._$El=null,this._$Eu()}static addInitializer(e){var t;this.finalize(),(null!==(t=this.h)&&void 0!==t?t:this.h=[]).push(e)}static get observedAttributes(){this.finalize();const e=[];return this.elementProperties.forEach(((t,i)=>{const s=this._$Ep(i,t);void 0!==s&&(this._$Ev.set(s,i),e.push(s))})),e}static createProperty(e,t=m){if(t.state&&(t.attribute=!1),this.finalize(),this.elementProperties.set(e,t),!t.noAccessor&&!this.prototype.hasOwnProperty(e)){const i="symbol"==typeof e?Symbol():"__"+e,s=this.getPropertyDescriptor(e,i,t);void 0!==s&&Object.defineProperty(this.prototype,e,s)}}static getPropertyDescriptor(e,t,i){return{get(){return this[t]},set(s){const n=this[e];this[t]=s,this.requestUpdate(e,n,i)},configurable:!0,enumerable:!0}}static getPropertyOptions(e){return this.elementProperties.get(e)||m}static finalize(){if(this.hasOwnProperty(g))return!1;this[g]=!0;const e=Object.getPrototypeOf(this);if(e.finalize(),void 0!==e.h&&(this.h=[...e.h]),this.elementProperties=new Map(e.elementProperties),this._$Ev=new Map,this.hasOwnProperty("properties")){const e=this.properties,t=[...Object.getOwnPropertyNames(e),...Object.getOwnPropertySymbols(e)];for(const i of t)this.createProperty(i,e[i])}return this.elementStyles=this.finalizeStyles(this.styles),!0}static finalizeStyles(e){const t=[];if(Array.isArray(e)){const i=new Set(e.flat(1/0).reverse());for(const e of i)t.unshift(a(e))}else void 0!==e&&t.push(a(e));return t}static _$Ep(e,t){const i=t.attribute;return!1===i?void 0:"string"==typeof i?i:"string"==typeof e?e.toLowerCase():void 0}_$Eu(){var e;this._$E_=new Promise((e=>this.enableUpdating=e)),this._$AL=new Map,this._$Eg(),this.requestUpdate(),null===(e=this.constructor.h)||void 0===e||e.forEach((e=>e(this)))}addController(e){var t,i;(null!==(t=this._$ES)&&void 0!==t?t:this._$ES=[]).push(e),void 0!==this.renderRoot&&this.isConnected&&(null===(i=e.hostConnected)||void 0===i||i.call(e))}removeController(e){var t;null===(t=this._$ES)||void 0===t||t.splice(this._$ES.indexOf(e)>>>0,1)}_$Eg(){this.constructor.elementProperties.forEach(((e,t)=>{this.hasOwnProperty(t)&&(this._$Ei.set(t,this[t]),delete this[t])}))}createRenderRoot(){var i;const s=null!==(i=this.shadowRoot)&&void 0!==i?i:this.attachShadow(this.constructor.shadowRootOptions);return((i,s)=>{t?i.adoptedStyleSheets=s.map((e=>e instanceof CSSStyleSheet?e:e.styleSheet)):s.forEach((t=>{const s=document.createElement("style"),n=e.litNonce;void 0!==n&&s.setAttribute("nonce",n),s.textContent=t.cssText,i.appendChild(s)}))})(s,this.constructor.elementStyles),s}connectedCallback(){var e;void 0===this.renderRoot&&(this.renderRoot=this.createRenderRoot()),this.enableUpdating(!0),null===(e=this._$ES)||void 0===e||e.forEach((e=>{var t;return null===(t=e.hostConnected)||void 0===t?void 0:t.call(e)}))}enableUpdating(e){}disconnectedCallback(){var e;null===(e=this._$ES)||void 0===e||e.forEach((e=>{var t;return null===(t=e.hostDisconnected)||void 0===t?void 0:t.call(e)}))}attributeChangedCallback(e,t,i){this._$AK(e,i)}_$EO(e,t,i=m){var s;const n=this.constructor._$Ep(e,i);if(void 0!==n&&!0===i.reflect){const r=(void 0!==(null===(s=i.converter)||void 0===s?void 0:s.toAttribute)?i.converter:p).toAttribute(t,i.type);this._$El=e,null==r?this.removeAttribute(n):this.setAttribute(n,r),this._$El=null}}_$AK(e,t){var i;const s=this.constructor,n=s._$Ev.get(e);if(void 0!==n&&this._$El!==n){const e=s.getPropertyOptions(n),r="function"==typeof e.converter?{fromAttribute:e.converter}:void 0!==(null===(i=e.converter)||void 0===i?void 0:i.fromAttribute)?e.converter:p;this._$El=n,this[n]=r.fromAttribute(t,e.type),this._$El=null}}requestUpdate(e,t,i){let s=!0;void 0!==e&&(((i=i||this.constructor.getPropertyOptions(e)).hasChanged||d)(this[e],t)?(this._$AL.has(e)||this._$AL.set(e,t),!0===i.reflect&&this._$El!==e&&(void 0===this._$EC&&(this._$EC=new Map),this._$EC.set(e,i))):s=!1),!this.isUpdatePending&&s&&(this._$E_=this._$Ej())}async _$Ej(){this.isUpdatePending=!0;try{await this._$E_}catch(e){Promise.reject(e)}const e=this.scheduleUpdate();return null!=e&&await e,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){var e;if(!this.isUpdatePending)return;this.hasUpdated,this._$Ei&&(this._$Ei.forEach(((e,t)=>this[t]=e)),this._$Ei=void 0);let t=!1;const i=this._$AL;try{t=this.shouldUpdate(i),t?(this.willUpdate(i),null===(e=this._$ES)||void 0===e||e.forEach((e=>{var t;return null===(t=e.hostUpdate)||void 0===t?void 0:t.call(e)})),this.update(i)):this._$Ek()}catch(e){throw t=!1,this._$Ek(),e}t&&this._$AE(i)}willUpdate(e){}_$AE(e){var t;null===(t=this._$ES)||void 0===t||t.forEach((e=>{var t;return null===(t=e.hostUpdated)||void 0===t?void 0:t.call(e)})),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(e)),this.updated(e)}_$Ek(){this._$AL=new Map,this.isUpdatePending=!1}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$E_}shouldUpdate(e){return!0}update(e){void 0!==this._$EC&&(this._$EC.forEach(((e,t)=>this._$EO(t,this[t],e))),this._$EC=void 0),this._$Ek()}updated(e){}firstUpdated(e){}} /** * @license * Copyright 2017 Google LLC * SPDX-License-Identifier: BSD-3-Clause */ -var v;b[g]=!0,b.elementProperties=new Map,b.elementStyles=[],b.shadowRootOptions={mode:"open"},null==h||h({ReactiveElement:b}),(null!==(o=l.reactiveElementVersions)&&void 0!==o?o:l.reactiveElementVersions=[]).push("1.6.3");const y=window,f=y.trustedTypes,w=f?f.createPolicy("lit-html",{createHTML:e=>e}):void 0,S="$lit$",E=`lit$${(Math.random()+"").slice(9)}$`,C="?"+E,N=`<${C}>`,x=document,P=()=>x.createComment(""),k=e=>null===e||"object"!=typeof e&&"function"!=typeof e,T=Array.isArray,A="[ \t\n\f\r]",L=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,M=/-->/g,I=/>/g,B=RegExp(`>|${A}(?:([^\\s"'>=/]+)(${A}*=${A}*(?:[^ \t\n\f\r"'\`<>=]|("|')|))|$)`,"g"),V=/'/g,$=/"/g,O=/^(?:script|style|textarea|title)$/i,H=(e=>(t,...i)=>({_$litType$:e,strings:t,values:i}))(1),D=Symbol.for("lit-noChange"),G=Symbol.for("lit-nothing"),R=new WeakMap,z=x.createTreeWalker(x,129,null,!1);function _(e,t){if(!Array.isArray(e)||!e.hasOwnProperty("raw"))throw Error("invalid template strings array");return void 0!==w?w.createHTML(t):t}const F=(e,t)=>{const i=e.length-1,r=[];let s,n=2===t?"":"",a=L;for(let t=0;t"===l[0]?(a=null!=s?s:L,c=-1):void 0===l[1]?c=-2:(c=a.lastIndex-l[2].length,o=l[1],a=void 0===l[3]?B:'"'===l[3]?$:V):a===$||a===V?a=B:a===M||a===I?a=L:(a=B,s=void 0);const h=a===B&&e[t+1].startsWith("/>")?" ":"";n+=a===L?i+N:c>=0?(r.push(o),i.slice(0,c)+S+i.slice(c)+E+h):i+E+(-2===c?(r.push(void 0),t):h)}return[_(e,n+(e[i]||"")+(2===t?"":"")),r]};class j{constructor({strings:e,_$litType$:t},i){let r;this.parts=[];let s=0,n=0;const a=e.length-1,o=this.parts,[l,c]=F(e,t);if(this.el=j.createElement(l,i),z.currentNode=this.el.content,2===t){const e=this.el.content,t=e.firstChild;t.remove(),e.append(...t.childNodes)}for(;null!==(r=z.nextNode())&&o.length0){r.textContent=f?f.emptyScript:"";for(let i=0;iT(e)||"function"==typeof(null==e?void 0:e[Symbol.iterator]))(e)?this.T(e):this._(e)}k(e){return this._$AA.parentNode.insertBefore(e,this._$AB)}$(e){this._$AH!==e&&(this._$AR(),this._$AH=this.k(e))}_(e){this._$AH!==G&&k(this._$AH)?this._$AA.nextSibling.data=e:this.$(x.createTextNode(e)),this._$AH=e}g(e){var t;const{values:i,_$litType$:r}=e,s="number"==typeof r?this._$AC(e):(void 0===r.el&&(r.el=j.createElement(_(r.h,r.h[0]),this.options)),r);if((null===(t=this._$AH)||void 0===t?void 0:t._$AD)===s)this._$AH.v(i);else{const e=new U(s,this),t=e.u(this.options);e.v(i),this.$(t),this._$AH=e}}_$AC(e){let t=R.get(e.strings);return void 0===t&&R.set(e.strings,t=new j(e)),t}T(e){T(this._$AH)||(this._$AH=[],this._$AR());const t=this._$AH;let i,r=0;for(const s of e)r===t.length?t.push(i=new K(this.k(P()),this.k(P()),this,this.options)):i=t[r],i._$AI(s),r++;r2||""!==i[0]||""!==i[1]?(this._$AH=Array(i.length-1).fill(new String),this.strings=i):this._$AH=G}get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}_$AI(e,t=this,i,r){const s=this.strings;let n=!1;if(void 0===s)e=W(this,e,t,0),n=!k(e)||e!==this._$AH&&e!==D,n&&(this._$AH=e);else{const r=e;let a,o;for(e=s[0],a=0;ae}):void 0,S="$lit$",E=`lit$${(Math.random()+"").slice(9)}$`,C="?"+E,N=`<${C}>`,x=document,P=()=>x.createComment(""),k=e=>null===e||"object"!=typeof e&&"function"!=typeof e,A=Array.isArray,L="[ \t\n\f\r]",M=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,T=/-->/g,I=/>/g,$=RegExp(`>|${L}(?:([^\\s"'>=/]+)(${L}*=${L}*(?:[^ \t\n\f\r"'\`<>=]|("|')|))|$)`,"g"),D=/'/g,B=/"/g,V=/^(?:script|style|textarea|title)$/i,H=(e=>(t,...i)=>({_$litType$:e,strings:t,values:i}))(1),O=Symbol.for("lit-noChange"),R=Symbol.for("lit-nothing"),G=new WeakMap,z=x.createTreeWalker(x,129,null,!1);function _(e,t){if(!Array.isArray(e)||!e.hasOwnProperty("raw"))throw Error("invalid template strings array");return void 0!==w?w.createHTML(t):t}const F=(e,t)=>{const i=e.length-1,s=[];let n,r=2===t?"":"",a=M;for(let t=0;t"===l[0]?(a=null!=n?n:M,u=-1):void 0===l[1]?u=-2:(u=a.lastIndex-l[2].length,o=l[1],a=void 0===l[3]?$:'"'===l[3]?B:D):a===B||a===D?a=$:a===T||a===I?a=M:(a=$,n=void 0);const h=a===$&&e[t+1].startsWith("/>")?" ":"";r+=a===M?i+N:u>=0?(s.push(o),i.slice(0,u)+S+i.slice(u)+E+h):i+E+(-2===u?(s.push(void 0),t):h)}return[_(e,r+(e[i]||"")+(2===t?"":"")),s]};class j{constructor({strings:e,_$litType$:t},i){let s;this.parts=[];let n=0,r=0;const a=e.length-1,o=this.parts,[l,u]=F(e,t);if(this.el=j.createElement(l,i),z.currentNode=this.el.content,2===t){const e=this.el.content,t=e.firstChild;t.remove(),e.append(...t.childNodes)}for(;null!==(s=z.nextNode())&&o.length0){s.textContent=y?y.emptyScript:"";for(let i=0;iA(e)||"function"==typeof(null==e?void 0:e[Symbol.iterator]))(e)?this.T(e):this._(e)}k(e){return this._$AA.parentNode.insertBefore(e,this._$AB)}$(e){this._$AH!==e&&(this._$AR(),this._$AH=this.k(e))}_(e){this._$AH!==R&&k(this._$AH)?this._$AA.nextSibling.data=e:this.$(x.createTextNode(e)),this._$AH=e}g(e){var t;const{values:i,_$litType$:s}=e,n="number"==typeof s?this._$AC(e):(void 0===s.el&&(s.el=j.createElement(_(s.h,s.h[0]),this.options)),s);if((null===(t=this._$AH)||void 0===t?void 0:t._$AD)===n)this._$AH.v(i);else{const e=new W(n,this),t=e.u(this.options);e.v(i),this.$(t),this._$AH=e}}_$AC(e){let t=G.get(e.strings);return void 0===t&&G.set(e.strings,t=new j(e)),t}T(e){A(this._$AH)||(this._$AH=[],this._$AR());const t=this._$AH;let i,s=0;for(const n of e)s===t.length?t.push(i=new K(this.k(P()),this.k(P()),this,this.options)):i=t[s],i._$AI(n),s++;s2||""!==i[0]||""!==i[1]?(this._$AH=Array(i.length-1).fill(new String),this.strings=i):this._$AH=R}get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}_$AI(e,t=this,i,s){const n=this.strings;let r=!1;if(void 0===n)e=U(this,e,t,0),r=!k(e)||e!==this._$AH&&e!==O,r&&(this._$AH=e);else{const s=e;let a,o;for(e=n[0],a=0;a{var r,s;const n=null!==(r=null==i?void 0:i.renderBefore)&&void 0!==r?r:t;let a=n._$litPart$;if(void 0===a){const e=null!==(s=null==i?void 0:i.renderBefore)&&void 0!==s?s:null;n._$litPart$=a=new K(t.insertBefore(P(),e),e,void 0,null!=i?i:{})}return a._$AI(e),a})(t,this.renderRoot,this.renderOptions)}connectedCallback(){var e;super.connectedCallback(),null===(e=this._$Do)||void 0===e||e.setConnected(!0)}disconnectedCallback(){var e;super.disconnectedCallback(),null===(e=this._$Do)||void 0===e||e.setConnected(!1)}render(){return D}}re.finalized=!0,re._$litElement$=!0,null===(te=globalThis.litElementHydrateSupport)||void 0===te||te.call(globalThis,{LitElement:re});const se=globalThis.litElementPolyfillSupport;null==se||se({LitElement:re}),(null!==(ie=globalThis.litElementVersions)&&void 0!==ie?ie:globalThis.litElementVersions=[]).push("3.3.3");class ne{static nodeColors={black:n``,blue:n``,darkBlue:n``,darkerBlue:n``,darkTurquoise:n``,gray:n``,green:n``,intenseGreen:n``,lime:n``,red:n``,turquoise:n``,violet:n``,yellow:n``};static alphaPattern="repeating-conic-gradient(#7c8184 0% 25%, #c2c3c4 0% 50%) 50% / 10px 10px";static colorDragEventName="ueb-color-drag";static colorPickEventName="ueb-color-pick";static colorWindowEventName="ueb-color-window";static colorWindowName="Color Picker";static defaultCommentHeight=96;static defaultCommentWidth=400;static distanceThreshold=5;static dragEventName="ueb-drag";static dragGeneralEventName="ueb-drag-general";static edgeScrollThreshold=50;static editTextEventName={begin:"ueb-edit-text-begin",end:"ueb-edit-text-end"};static expandGridSize=400;static focusEventName={begin:"blueprint-focus",end:"blueprint-unfocus"};static fontSize=n``;static gridAxisLineColor=n``;static gridExpandThreshold=.25;static gridLineColor=n``;static gridLineWidth=1;static gridSet=8;static gridSetLineColor=n``;static gridShrinkThreshold=4;static gridSize=16;static hexColorRegex=/^\s*#(?[0-9a-fA-F]{2})(?[0-9a-fA-F]{2})(?[0-9a-fA-F]{2})([0-9a-fA-F]{2})?|#(?[0-9a-fA-F])(?[0-9a-fA-F])(?[0-9a-fA-F])\s*$/;static indentation=" ";static keysSeparator=/[\.\(\)]/;static knotOffset=[-ne.gridSize,-.5*ne.gridSize];static lineTracePattern=/LineTrace(Single|Multi)(\w*)/;static linkCurveHeight=15;static linkCurveWidth=80;static linkMinWidth=100;static nameRegexSpaceReplacement=new RegExp("^K2(?:[Nn]ode)?_|(?<=[a-z])(?=[A-Z0-9])|(?<=[A-Z])(?{let r=100-e;return`M ${e} 0 C ${t.toFixed(3)} 0, ${i.toFixed(3)} 0, 50 50 S ${(r-t+e).toFixed(3)} 100, ${r.toFixed(3)} 100`};static maxZoom=7;static minZoom=-12;static mouseClickButton=0;static mouseRightClickButton=2;static mouseWheelZoomThreshold=80;static nodeDragEventName="ueb-node-drag";static nodeDragGeneralEventName="ueb-node-drag-general";static nodeTitle=(e,t)=>`${e}_${t}`;static nodeRadius=8;static nodeReflowEventName="ueb-node-reflow";static paths={actorBoundEvent:"/Script/BlueprintGraph.K2Node_ActorBoundEvent",addDelegate:"/Script/BlueprintGraph.K2Node_AddDelegate",ambientSound:"/Script/Engine.AmbientSound",asyncAction:"/Script/BlueprintGraph.K2Node_AsyncAction",blueprint:"/Script/Engine.Blueprint",blueprintGameplayTagLibrary:"/Script/GameplayTags.BlueprintGameplayTagLibrary",blueprintMapLibrary:"/Script/Engine.BlueprintMapLibrary",blueprintSetLibrary:"/Script/Engine.BlueprintSetLibrary",callArrayFunction:"/Script/BlueprintGraph.K2Node_CallArrayFunction",callDelegate:"/Script/BlueprintGraph.K2Node_CallDelegate",callFunction:"/Script/BlueprintGraph.K2Node_CallFunction",comment:"/Script/UnrealEd.EdGraphNode_Comment",commutativeAssociativeBinaryOperator:"/Script/BlueprintGraph.K2Node_CommutativeAssociativeBinaryOperator",componentBoundEvent:"/Script/BlueprintGraph.K2Node_ComponentBoundEvent",createDelegate:"/Script/BlueprintGraph.K2Node_CreateDelegate",customEvent:"/Script/BlueprintGraph.K2Node_CustomEvent",doN:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:Do N",doOnce:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:DoOnce",dynamicCast:"/Script/BlueprintGraph.K2Node_DynamicCast",eAttachmentRule:"/Script/Engine.EAttachmentRule",edGraph:"/Script/Engine.EdGraph",eDrawDebugTrace:"/Script/Engine.EDrawDebugTrace",eMaterialSamplerType:"/Script/Engine.EMaterialSamplerType",eNiagara_Float4Channel:"/Niagara/Enums/ENiagara_Float4Channel.ENiagara_Float4Channel",enum:"/Script/CoreUObject.Enum",enumLiteral:"/Script/BlueprintGraph.K2Node_EnumLiteral",eSamplerSourceMode:"/Script/Engine.ESamplerSourceMode",eSearchCase:"/Script/CoreUObject.ESearchCase",eSearchDir:"/Script/CoreUObject.ESearchDir",eSpawnActorCollisionHandlingMethod:"/Script/Engine.ESpawnActorCollisionHandlingMethod",eTextureMipValueMode:"/Script/Engine.ETextureMipValueMode",eTraceTypeQuery:"/Script/Engine.ETraceTypeQuery",event:"/Script/BlueprintGraph.K2Node_Event",executionSequence:"/Script/BlueprintGraph.K2Node_ExecutionSequence",flipflop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:FlipFlop",forEachElementInEnum:"/Script/BlueprintGraph.K2Node_ForEachElementInEnum",forEachLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ForEachLoop",forEachLoopWithBreak:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ForEachLoopWithBreak",forLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ForLoop",forLoopWithBreak:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ForLoopWithBreak",functionEntry:"/Script/BlueprintGraph.K2Node_FunctionEntry",functionResult:"/Script/BlueprintGraph.K2Node_FunctionResult",gameplayTag:"/Script/GameplayTags.GameplayTag",getInputAxisKeyValue:"/Script/BlueprintGraph.K2Node_GetInputAxisKeyValue",ifThenElse:"/Script/BlueprintGraph.K2Node_IfThenElse",inputAxisKeyEvent:"/Script/BlueprintGraph.K2Node_InputAxisKeyEvent",inputDebugKey:"/Script/InputBlueprintNodes.K2Node_InputDebugKey",inputKey:"/Script/BlueprintGraph.K2Node_InputKey",inputVectorAxisEvent:"/Script/BlueprintGraph.K2Node_InputVectorAxisEvent",isValid:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:IsValid",kismetArrayLibrary:"/Script/Engine.KismetArrayLibrary",kismetMathLibrary:"/Script/Engine.KismetMathLibrary",knot:"/Script/BlueprintGraph.K2Node_Knot",linearColor:"/Script/CoreUObject.LinearColor",literal:"/Script/BlueprintGraph.K2Node_Literal",macro:"/Script/BlueprintGraph.K2Node_MacroInstance",makeArray:"/Script/BlueprintGraph.K2Node_MakeArray",makeMap:"/Script/BlueprintGraph.K2Node_MakeMap",makeSet:"/Script/BlueprintGraph.K2Node_MakeSet",makeStruct:"/Script/BlueprintGraph.K2Node_MakeStruct",materialExpressionComponentMask:"/Script/Engine.MaterialExpressionComponentMask",materialExpressionConstant:"/Script/Engine.MaterialExpressionConstant",materialExpressionConstant2Vector:"/Script/Engine.MaterialExpressionConstant2Vector",materialExpressionConstant3Vector:"/Script/Engine.MaterialExpressionConstant3Vector",materialExpressionConstant4Vector:"/Script/Engine.MaterialExpressionConstant4Vector",materialExpressionFunctionInput:"/Script/Engine.MaterialExpressionFunctionInput",materialExpressionLogarithm:"/Script/InterchangeImport.MaterialExpressionLogarithm",materialExpressionLogarithm10:"/Script/Engine.MaterialExpressionLogarithm10",materialExpressionLogarithm2:"/Script/Engine.MaterialExpressionLogarithm2",materialExpressionMaterialFunctionCall:"/Script/Engine.MaterialExpressionMaterialFunctionCall",materialExpressionSquareRoot:"/Script/Engine.MaterialExpressionSquareRoot",materialExpressionTextureCoordinate:"/Script/Engine.MaterialExpressionTextureCoordinate",materialExpressionTextureSample:"/Script/Engine.MaterialExpressionTextureSample",materialGraphNode:"/Script/UnrealEd.MaterialGraphNode",materialGraphNodeComment:"/Script/UnrealEd.MaterialGraphNode_Comment",metasoundEditorGraphExternalNode:"/Script/MetasoundEditor.MetasoundEditorGraphExternalNode",multiGate:"/Script/BlueprintGraph.K2Node_MultiGate",niagaraBool:"/Script/Niagara.NiagaraBool",niagaraClipboardContent:"/Script/NiagaraEditor.NiagaraClipboardContent",niagaraDataInterfaceVolumeTexture:"/Script/Niagara.NiagaraDataInterfaceVolumeTexture",niagaraFloat:"/Script/Niagara.NiagaraFloat",niagaraMatrix:"/Script/Niagara.NiagaraMatrix",niagaraNodeFunctionCall:"/Script/NiagaraEditor.NiagaraNodeFunctionCall",niagaraNodeOp:"/Script/NiagaraEditor.NiagaraNodeOp",niagaraNumeric:"/Script/Niagara.NiagaraNumeric",niagaraPosition:"/Script/Niagara.NiagaraPosition",pawn:"/Script/Engine.Pawn",pcgEditorGraphNode:"/Script/PCGEditor.PCGEditorGraphNode",pcgEditorGraphNodeInput:"/Script/PCGEditor.PCGEditorGraphNodeInput",pcgEditorGraphNodeOutput:"/Script/PCGEditor.PCGEditorGraphNodeOutput",pcgHiGenGridSizeSettings:"/Script/PCG.PCGHiGenGridSizeSettings",pcgSubgraphSettings:"/Script/PCG.PCGSubgraphSettings",promotableOperator:"/Script/BlueprintGraph.K2Node_PromotableOperator",quat4f:"/Script/CoreUObject.Quat4f",reverseForEachLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ReverseForEachLoop",rotator:"/Script/CoreUObject.Rotator",select:"/Script/BlueprintGraph.K2Node_Select",self:"/Script/BlueprintGraph.K2Node_Self",slateBlueprintLibrary:"/Script/UMG.SlateBlueprintLibrary",spawnActorFromClass:"/Script/BlueprintGraph.K2Node_SpawnActorFromClass",switchEnum:"/Script/BlueprintGraph.K2Node_SwitchEnum",switchGameplayTag:"/Script/GameplayTagsEditor.GameplayTagsK2Node_SwitchGameplayTag",switchInteger:"/Script/BlueprintGraph.K2Node_SwitchInteger",switchName:"/Script/BlueprintGraph.K2Node_SwitchName",switchString:"/Script/BlueprintGraph.K2Node_SwitchString",timeline:"/Script/BlueprintGraph.K2Node_Timeline",timeManagementBlueprintLibrary:"/Script/TimeManagement.TimeManagementBlueprintLibrary",transform:"/Script/CoreUObject.Transform",userDefinedEnum:"/Script/Engine.UserDefinedEnum",variableGet:"/Script/BlueprintGraph.K2Node_VariableGet",variableSet:"/Script/BlueprintGraph.K2Node_VariableSet",vector:"/Script/CoreUObject.Vector",vector2D:"/Script/CoreUObject.Vector2D",vector3f:"/Script/CoreUObject.Vector3f",vector4f:"/Script/CoreUObject.Vector4f",whileLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:WhileLoop"};static pinInputWrapWidth=143;static removeEventName="ueb-element-delete";static scale={[-12]:.133333,[-11]:.166666,[-10]:.2,[-9]:.233333,[-8]:.266666,[-7]:.3,[-6]:.333333,[-5]:.375,[-4]:.5,[-3]:.675,[-2]:.75,[-1]:.875,0:1,1:1.25,2:1.375,3:1.5,4:1.675,5:1.75,6:1.875,7:2};static smoothScrollTime=1e3;static stringEscapedCharacters=/["\\]/g;static subObjectAttributeNamePrefix="#SubObject";static subObjectAttributeNameFromEntity=(e,t=!1)=>this.subObjectAttributeNamePrefix+(!t&&e.Class?`_${e.Class.type}`:"")+"_"+e.Name;static subObjectAttributeNameFromReference=(e,t=!1)=>this.subObjectAttributeNamePrefix+(t?"":"_"+e.type)+"_"+e.path;static subObjectAttributeNameFromName=e=>this.subObjectAttributeNamePrefix+"_"+e;static switchTargetPattern=/\/Script\/[\w\.\/\:]+K2Node_Switch([A-Z]\w+)+/;static trackingMouseEventName={begin:"ueb-tracking-mouse-begin",end:"ueb-tracking-mouse-end"};static unescapedBackslash=/(?<=(?:[^\\]|^)(?:\\\\)*)\\(?!\\)/;static windowApplyEventName="ueb-window-apply";static windowApplyButtonText="OK";static windowCancelEventName="ueb-window-cancel";static windowCancelButtonText="Cancel";static windowCloseEventName="ueb-window-close";static CommonEnums={[this.paths.eAttachmentRule]:["KeepRelative","KeepWorld","SnapToTarget"],[this.paths.eMaterialSamplerType]:["Color","Grayscale","Alpha","Normal","Masks","Distance Field Font","Linear Color","Linear Grayscale","Data","External","Virtual Color","Virtual Grayscale","Virtual Alpha","Virtual Normal","Virtual Mask","Virtual Linear Color","Virtual Linear Grayscal"],[this.paths.eNiagara_Float4Channel]:[["NewEnumerator0","R"],["NewEnumerator1","G"],["NewEnumerator2","B"],["NewEnumerator3","A"]],[this.paths.eSamplerSourceMode]:["From texture asset","Shared: Wrap","Shared: Clamp","Hidden"],[this.paths.eSpawnActorCollisionHandlingMethod]:[["Undefined","Default"],["AlwaysSpawn","Always Spawn, Ignore Collisions"],["AdjustIfPossibleButAlwaysSpawn","Try To Adjust Location, But Always Spawn"],["AdjustIfPossibleButDontSpawnIfColliding","Try To Adjust Location, Don't Spawn If Still Colliding"],["DontSpawnIfColliding","Do Not Spawn"]],[this.paths.eSearchCase]:["CaseSensitive","IgnoreCase"],[this.paths.eSearchDir]:["FromStart","FromEnd"],[this.paths.eDrawDebugTrace]:["None","ForOneFrame","ForDuration","Persistent"],[this.paths.eTextureMipValueMode]:["None (use computed mip level)","MipLevel (absolute, 0 is full resolution)","MipBias (relative to the computed mip level)","Derivative (explicit derivative to compute mip level)"],[this.paths.eTraceTypeQuery]:[["TraceTypeQuery1","Visibility"],["TraceTypeQuery2","Camera"]]};static ModifierKeys=["Ctrl","Shift","Alt","Meta"];static rgba=["R","G","B","A"];static Keys={Backspace:"Backspace",Tab:"Tab",LeftControl:"ControlLeft",RightControl:"ControlRight",LeftShift:"ShiftLeft",RightShift:"ShiftRight",LeftAlt:"AltLeft",RightAlt:"AltRight",Enter:"Enter",Pause:"Pause",CapsLock:"CapsLock",Escape:"Escape",Space:"Space",PageUp:"PageUp",PageDown:"PageDown",End:"End",Home:"Home",ArrowLeft:"ArrowLeft",ArrowUp:"ArrowUp",ArrowRight:"ArrowRight",ArrowDown:"ArrowDown",PrintScreen:"PrintScreen",Insert:"Insert",Delete:"Delete",Zero:"Digit0",One:"Digit1",Two:"Digit2",Three:"Digit3",Four:"Digit4",Five:"Digit5",Six:"Digit6",Seven:"Digit7",Eight:"Digit8",Nine:"Digit9",A:"KeyA",B:"KeyB",C:"KeyC",D:"KeyD",E:"KeyE",F:"KeyF",G:"KeyG",H:"KeyH",I:"KeyI",K:"KeyK",L:"KeyL",M:"KeyM",N:"KeyN",O:"KeyO",P:"KeyP",Q:"KeyQ",R:"KeyR",S:"KeyS",T:"KeyT",U:"KeyU",V:"KeyV",W:"KeyW",X:"KeyX",Y:"KeyY",Z:"KeyZ",NumPadZero:"Numpad0",NumPadOne:"Numpad1",NumPadTwo:"Numpad2",NumPadThree:"Numpad3",NumPadFour:"Numpad4",NumPadFive:"Numpad5",NumPadSix:"Numpad6",NumPadSeven:"Numpad7",NumPadEight:"Numpad8",NumPadNine:"Numpad9",Multiply:"NumpadMultiply",Add:"NumpadAdd",Subtract:"NumpadSubtract",Decimal:"NumpadDecimal",Divide:"NumpadDivide",F1:"F1",F2:"F2",F3:"F3",F4:"F4",F5:"F5",F6:"F6",F7:"F7",F8:"F8",F9:"F9",F10:"F10",F11:"F11",F12:"F12",NumLock:"NumLock",ScrollLock:"ScrollLock"}}class ae{#e;constructor(e){this.#e=e}compute(e){return this.#e(e)}}class oe{static#t={nullable:!1,ignored:!1,serialized:!1,expected:!1,inlined:!1,quoted:!1,silent:!1,uninitialized:!1};constructor(e){this.type=e.type??e.default?.constructor,this.default=e.default,this.nullable=e.nullable??null===e.default,this.ignored=e.ignored,this.serialized=e.serialized,this.expected=e.expected,this.inlined=e.inlined,this.quoted=e.quoted,this.silent=e.silent,this.uninitialized=e.uninitialized,this.predicate=e.predicate,this.type===Array&&this.default instanceof Array&&this.default.length>0&&(this.type=this.default.map((e=>e.constructor)).reduce(((e,t)=>(e.includes(t)||e.push(t),e)),[]))}static createType(e){return new oe({type:e})}static createValue(e){return new oe({default:e})}static hasAttribute(e,t,i,r=e.constructor){const s=e,n=s.attributes[t]?.[i];return n??r?.attributes?.[t]?.[i]??oe.#t[i]}static getAttribute(e,t,i,r=e.constructor){let s=e.attributes?.[t]?.[i];return void 0!==s?s:(s=(r?.attributes)?.[t]?.[i],void 0!==s?s:(s=oe.#t[i],void 0!==s?s:void 0))}get(e){return this[e]??oe.#t[e]}}class le{static attributes={type:new oe({ignored:!0}),getter:new oe({ignored:!0})};constructor(e,t=null){this.type=e,this.getter=t}get(){return this.getter()}getTargetType(){const e=this.type;return e instanceof le?e.getTargetType():e}}class ce{#i;get values(){return this.#i}constructor(...e){this.#i=e}}class ue{static booleanConverter={fromAttribute:(e,t)=>{},toAttribute:(e,t)=>!0===e?"true":!1===e?"false":""};static sigmoid(e,t=1.7){return 1/(1+e/(1-e)**-t)}static sigmoidPositive(e,t=3.7,i=1.1){return 1-Math.exp(-((e/i)**t))}static clamp(e,t=-1/0,i=1/0){return Math.min(Math.max(e,t),i)}static getScale(e){const t=e.blueprint?.getScale()??getComputedStyle(e).getPropertyValue("--ueb-scale");return""!=t?parseFloat(t):1}static minDecimals(e,t=1,i=1e-8){const r=e*10**t;return Math.abs(r%1)>i?e.toString():e.toFixed(t)}static numberFromText(e=""){switch(e=e.toLowerCase()){case"zero":return 0;case"one":return 1;case"two":return 2;case"three":return 3;case"four":return 4;case"five":return 5;case"six":return 6;case"seven":return 7;case"eight":return 8;case"nine":return 9}}static roundDecimals(e,t=1){const i=10**t;return Math.round(e*i)/i}static printNumber(e){return e==Number.POSITIVE_INFINITY?"inf":e==Number.NEGATIVE_INFINITY?"-inf":ue.minDecimals(e)}static printExponential(e){if(e==Number.POSITIVE_INFINITY)return"inf";if(e==Number.NEGATIVE_INFINITY)return"-inf";const t=Math.round(e);if(t>=1e3){const i=Math.floor(Math.log10(t));return`${Math.round(e/10**(i-2))/100}e+${i<10?"0":""}${i}`}return 0==Math.floor(e)?e.toString():this.roundDecimals(e,Math.max(0,3-Math.floor(e).toString().length)).toString()}static approximatelyEqual(e,t,i=1e-8){return!(Math.abs(e-t)>i)}static convertLocation(e,t,i=!1){const r=i?1:1/ue.getScale(t),s=t.getBoundingClientRect();return[Math.round((e[0]-s.x)*r),Math.round((e[1]-s.y)*r)]}static isSerialized(e,t){return e.attributes?.[t]?.serialized??e.constructor.attributes?.[t]?.serialized??!1}static objectGet(e,t,i=void 0){if(void 0!==e){if(!(t instanceof Array))throw new TypeError("UEBlueprint: Expected keys to be an array");return 0!=t.length&&t[0]in e&&void 0!==e[t[0]]?1==t.length?e[t[0]]:ue.objectGet(e[t[0]],t.slice(1),i):i}}static objectSet(e,t,i,r=Object){if(!(t instanceof Array))throw new TypeError("Expected keys to be an array.");if(1==t.length){if(t[0]in e||void 0===e[t[0]])return e[t[0]]=i,!0}else if(t.length>0)return e[t[0]]instanceof Object||(e[t[0]]=new r),ue.objectSet(e[t[0]],t.slice(1),i,r);return!1}static equals(e,t){for(;e instanceof le;)e=e.get();for(;t instanceof le;)t=t.get();return e?.equals&&t?.equals?e.equals(t):(e=ue.sanitize(e),t=ue.sanitize(t),e?.constructor===BigInt&&t?.constructor===Number?t=BigInt(t):e?.constructor===Number&&t?.constructor===BigInt&&(e=BigInt(e)),e===t||e instanceof Array&&t instanceof Array&&(e.length===t.length&&e.every(((e,i)=>ue.equals(e,t[i])))))}static getType(e){return null===e?null:e?.constructor===Object&&e?.type instanceof Function?e.type:e?.constructor}static isValueOfType(e,t,i=!1){return t instanceof le&&(t=t.getTargetType()),i&&null===e||e instanceof t||e?.constructor===t}static sanitize(e,t=e?.constructor){if(t instanceof Array&&(t=t[0]),t instanceof ae)return e;if(t instanceof ce){let i=t.values.find((t=>ue.isValueOfType(e,t,!1)));i||(i=t.values[0]),t=i}return t instanceof le?e instanceof le?e:ue.sanitize(e,t.getTargetType()):(t&&!ue.isValueOfType(e,t,!0)&&(e=t===BigInt?BigInt(e):new t(e)),(e instanceof Boolean||e instanceof Number||e instanceof String)&&(e=e.valueOf()),e)}static snapToGrid(e,t,i){return 1===i?[e,t]:[i*Math.floor(e/i),i*Math.floor(t/i)]}static mergeArrays(e=[],t=[],i=((e,t)=>e==t)){let r=[];e=[...e],t=[...t];e:for(;;){for(let s=0;s|
/g,"\n").replaceAll(/(\)/g,"")}static encodeHTMLWhitespace(e){return e.replaceAll(" "," ")}static capitalFirstLetter(e){return 0===e.length?e:e.charAt(0).toUpperCase()+e.slice(1)}static formatStringName(e=""){return e.replace(/^\s*b(?=[A-Z])/,"").replaceAll(ne.nameRegexSpaceReplacement," ").trim().split(" ").map((e=>ue.capitalFirstLetter(e))).join(" ")}static getIdFromReference(e){return e.replace(/(?:.+\.)?([^\.]+)$/,"$1").replaceAll(/(?<=[a-z\d])(?=[A-Z])|(?<=[a-zA-Z])(?=\d)|(?<=[A-Z]{2})(?=[A-Z][a-z])/g,"-").toLowerCase()}static getNameFromPath(e,t=!1){const i=t?/([^\.\/]+?)(?:_\d+)$/:/([^\.\/]+)$/;return e.match(i)?.[1]??""}static printLinearColor(e){return`${Math.round(255*e.R.valueOf())}, ${Math.round(255*e.G.valueOf())}, ${Math.round(255*e.B.valueOf())}`}static getPolarCoordinates(e,t,i=!1){let r=Math.atan2(t,e);return i&&r<0&&(r=2*Math.PI+r),[Math.sqrt(e*e+t*t),r]}static getCartesianCoordinates(e,t){return[e*Math.cos(t),e*Math.sin(t)]}static range(e=0,t=0,i=(t>=e?1:-1)){return Array.from({length:Math.ceil((t-e)/i)},((t,r)=>e+r*i))}static getFirstWordOrder(e){return new RegExp(/\s*/.source+e.join(/[^\n]+\n\s*/.source)+/\s*/.source)}static paste(e,t){const i=new ClipboardEvent("paste",{bubbles:!0,cancelable:!0,clipboardData:new DataTransfer});i.clipboardData.setData("text",t),e.dispatchEvent(i)}static async copy(e){const t=new ClipboardEvent("copy",{bubbles:!0,cancelable:!0,clipboardData:new DataTransfer});e.dispatchEvent(t)}static animate(e,t,i,r,s=(e=>{}),n=(e=>{const t=e**3.5;return t/(t+(1-e)**3.5)})){let a;const o=l=>{void 0===a&&(a=l);let c=(l-a)/i;ue.approximatelyEqual(c,1)||c>1?c=1:s(requestAnimationFrame(o));const u=e+(t-e)*n(c);r(u)};s(requestAnimationFrame(o))}}class he extends re{#r;get blueprint(){return this.#r}set blueprint(e){this.#r=e}#s;get entity(){return this.#s}set entity(e){this.#s=e}#n;get template(){return this.#n}isInitialized=!1;isSetup=!1;inputObjects=[];initialize(e,t){this.requestUpdate(),this.#s=e,this.#n=t,this.#n.initialize(this),this.isConnected&&this.updateComplete.then((()=>this.setup())),this.isInitialized=!0}connectedCallback(){super.connectedCallback(),this.blueprint=this.closest("ueb-blueprint"),this.isInitialized&&(this.requestUpdate(),this.updateComplete.then((()=>this.setup())))}disconnectedCallback(){super.disconnectedCallback(),this.isSetup&&this.updateComplete.then((()=>this.cleanup())),this.acknowledgeDelete()}createRenderRoot(){return this}setup(){this.template.setup(),this.isSetup=!0}cleanup(){this.template.cleanup(),this.isSetup=!1}willUpdate(e){super.willUpdate(e),this.template.willUpdate(e)}update(e){super.update(e),this.template.update(e)}render(){return this.template.render()}firstUpdated(e){super.firstUpdated(e),this.template.firstUpdated(e),this.template.inputSetup()}updated(e){super.updated(e),this.template.updated(e)}acknowledgeDelete(){let e=new CustomEvent(ne.removeEventName);this.dispatchEvent(e)}isSameGraph(e){return this.blueprint&&this.blueprint==e?.blueprint}}class pe extends he{static properties={...super.properties,fromX:{type:Number,attribute:!1},fromY:{type:Number,attribute:!1},toX:{type:Number,attribute:!1},toY:{type:Number,attribute:!1}};constructor(){super(),this.fromX=0,this.fromY=0,this.toX=0,this.toY=0}setBothLocations([e,t]){this.fromX=e,this.fromY=t,this.toX=e,this.toY=t}addSourceLocation(e,t){this.fromX+=e,this.fromY+=t}addDestinationLocation(e,t){this.toX+=e,this.toY+=t}}class de{static deleteNodes="Delete";static duplicateNodes="(bCtrl=True,Key=D)";static enableLinkDelete="LeftAlt";static enableZoomIn=["LeftControl","RightControl"];static selectAllNodes="(bCtrl=True,Key=A)"}class me{static#a=new Map;static registerElement(e,t){me.#a.set(e,t)}static getConstructor(e){return me.#a.get(e)}}class ge{static makeSuccess(e,t,i=null,r=0){return{status:!0,value:t,position:e,bestParser:i,bestPosition:r}}static makeFailure(e=0,t=null,i=0){return{status:!1,value:null,position:e,bestParser:t,bestPosition:i}}static makeContext(e=null,t=""){return{parsernostrum:e,input:t,highlighted:null}}static makePathNode(e,t=0,i=null){return{parent:i,current:e,index:t}}}class be{static indentation=" ";static highlight="Last valid parser";Self;static frame(e,t="",i=""){t=e?"[ "+t+" ]":"";let r=e.split("\n");const s=Math.max(...r.map((e=>e.length))),n=s";const s=this.isVisited(i),n=this.isHighlighted(e,i);let a=s?"<...>":this.doToString(e,n?"":t,i,r);return n&&(a=be.frame(a,be.highlight,t)),a}doToString(e,t,i,r){return`${this.constructor.name} does not implement toString()`}}class ve extends be{#o;get value(){return this.#o}constructor(e){super(),this.#o=e}parse(e,t,i,r){i=this.makePath(i,r);const s=t+this.#o.length,n=e.input.substring(t,s);return this.#o===n?ge.makeSuccess(s,this.#o,i,s):ge.makeFailure()}doToString(e,t,i,r){return`"${this.value.replaceAll("\n","\\n").replaceAll('"','\\"')}"`}}class ye extends be{static instance=new ye;parse(e,t,i,r){return i=this.makePath(i,r),ge.makeSuccess(t,"",i,0)}doToString(e,t,i,r){return""}}class fe extends be{#l;get parsers(){return this.#l}constructor(...e){super(),this.#l=e}parse(e,t,i,r){i=this.makePath(i,r);const s=ge.makeSuccess(0,"");for(let r=0;rs.bestPosition&&(s.bestParser=n.bestParser,s.bestPosition=n.bestPosition),n.status)return s.value=n.value,s.position=n.position,s}return s.status=!1,s.value=null,s}doToString(e,t,i,r){if(2===this.#l.length&&this.#l[1]instanceof ye){let r=this.#l[0].toString(e,t,i,0);return this.#l[0]instanceof ve||(r="<"+r+">"),r+="?",r}const s=t+be.indentation;let n="ALT<\n"+s+this.#l.map(((t,r)=>t.toString(e,s+" ".repeat(0===r?0:be.indentation.length-2),i,r))).join("\n"+s+"| ")+"\n"+t+">";return n}}class we extends be{#c;get parser(){return this.#c}#u;constructor(e,t){super(),this.#c=e,this.#u=t}parse(e,t,i,r){i=this.makePath(i,r);const s=this.#c.parse(e,t,i,0);if(!s.status)return s;const n=this.#u(s.value,e.input,s.position).getParser().parse(e,s.position);return s.bestPosition>n.bestPosition&&(n.bestParser=s.bestParser,n.bestPosition=s.bestPosition),n}doToString(e,t,i,r){return this.#c.toString(e,t,i,0)+" => chained"}}class Se extends be{static instance=new Se;parse(e,t,i,r){return ge.makeFailure()}doToString(e,t,i,r){return""}}class Ee extends be{#c;get parser(){return this.#c}#h="";constructor(e,t){super(),this.#c=e,this.#h=t}makePath(e,t){return e}parse(e,t,i,r){return this.parse=this.#c.parse.bind(this.#c),this.parse(e,t,i,r)}doToString(e,t,i,r){let s=this.#c.toString(e,"",i,r);return s=be.frame(s,this.#h,t),s}}class Ce extends be{#c;#p;constructor(e){super(),this.#c=e}makePath(e,t){return e}isHighlighted(e,t){if(super.isHighlighted(e,t)){const i={parent:t,parser:this.#p,index:0};e.highlighted=e.highlighted instanceof be?this.#p:i}return!1}resolve(){return this.#p||(this.#p=this.#c().getParser()),this.#p}parse(e,t,i,r){return this.resolve(),this.parse=this.#p.parse.bind(this.#p),this.parse(e,t,i,r)}doToString(e,t,i,r){return this.resolve(),this.doToString=this.#p.toString.bind(this.#p),this.doToString(e,t,i,r)}}class Ne extends be{#c;get parser(){return this.#c}#d;get type(){return this.#d}static Type={NEGATIVE_AHEAD:"?!",NEGATIVE_BEHIND:"?String.raw`[^${e}\\]*(?:\\.[^${e}\\]*)*`;static#y=/[-\+]?(?:\d*\.)?\d+/;static common={number:new RegExp(this.#y.source+String.raw`(?!\.)`),numberInteger:/[\-\+]?\d+(?!\.\d)/,numberNatural:/\d+/,numberExponential:new RegExp(this.#y.source+String.raw`(?:[eE][\+\-]?\d+)?(?!\.)`),numberUnit:/\+?(?:0(?:\.\d+)?|1(?:\.0+)?)(?![\.\d])/,numberByte:/0*(?:25[0-5]|2[0-4]\d|1?\d?\d)(?!\d|\.)/,whitespace:/\s+/,whitespaceOpt:/\s*/,whitespaceInline:/[^\S\n]+/,whitespaceInlineOpt:/[^\S\n]*/,whitespaceMultiline:/\s*?\n\s*/,doubleQuotedString:new RegExp(`"(${this.#v('"')})"`),singleQuotedString:new RegExp(`'(${this.#v("'")})'`),backtickQuotedString:new RegExp("`("+this.#v("`")+")`")};constructor(e,t){super(),this.#m=e,this.#g=new RegExp(`^(?:${e.source})`,e.flags),this.#b=t}parse(e,t,i,r){i=this.makePath(i,r);const s=this.#g.exec(e.input.substring(t));s&&(t+=s[0].length);return s?ge.makeSuccess(t,this.#b(s),i,t):ge.makeFailure()}doToString(e,t,i,r){let s="/"+this.#m.source+"/";const n=Object.entries(xe.common).find((([e,t])=>t.source===this.#m.source))?.[0];return n&&(s="P."+n),s}}class Pe extends be{#c;get parser(){return this.#c}#f;get mapper(){return this.#f}constructor(e,t){super(),this.#c=e,this.#f=t}isHighlighted(e,t){if(super.isHighlighted(e,t)){const i={parent:t,parser:this.#c,index:0};e.highlighted=e.highlighted instanceof be?this.#c:i}return!1}parse(e,t,i,r){i=this.makePath(i,r);const s=this.#c.parse(e,t,i,0);return s.status&&(s.value=this.#f(s.value)),s}doToString(e,t,i,r){let s=this.#c.toString(e,t,i,0);if(this.#c instanceof xe&&Object.values(xe.common).includes(this.#c.regexp))return this.#c.regexp===xe.common.numberInteger&&this.#f===BigInt?"P.numberBigInteger":s;let n=this.#f.toString();return(n.length>60||n.includes("\n"))&&(n="(...) => { ... }"),s+=` -> map<${n}>`,s}}class ke extends xe{static#f=e=>e;constructor(e){super(e,ke.#f)}}class Te extends xe{constructor(e,t=0){super(e,(e=>e[t]))}}class Ae extends be{#l;get parsers(){return this.#l}constructor(...e){super(),this.#l=e}parse(e,t,i,r){i=this.makePath(i,r);const s=new Array(this.#l.length),n=ge.makeSuccess(t,s);for(let t=0;tn.bestPosition&&(n.bestParser=r.bestParser,n.bestPosition=r.bestPosition),!r.status){n.status=!1,n.value=null;break}n.value[t]=r.value,n.position=r.position}return n}doToString(e,t,i,r){const s=t+be.indentation,n="SEQ<\n"+s+this.#l.map(((t,r)=>t.toString(e,s,i,r))).join("\n"+s)+"\n"+t+">";return n}}class Le extends be{#c;get parser(){return this.#c}#w;get min(){return this.#w}#S;get max(){return this.#S}constructor(e,t=0,i=Number.POSITIVE_INFINITY){if(super(),t>i)throw new Error("Min is greater than max");this.#c=e,this.#w=t,this.#S=i}parse(e,t,i,r){i=this.makePath(i,r);const s=ge.makeSuccess(t,[],i);for(let t=0;ts.bestPosition&&(s.bestParser=r.bestParser,s.bestPosition=r.bestPosition),!r.status){te;static#C=([e,t])=>t;static#N=([e,t])=>[e,...t];static#x=e=>e instanceof Array?e.join(""):e;static#v=e=>String.raw`[^${e}\\]*(?:\\.[^${e}\\]*)*`;static number=this.reg(xe.common.number).map(Number);static numberInteger=this.reg(xe.common.numberInteger).map(Number);static numberBigInteger=this.reg(this.numberInteger.getParser().parser.regexp).map(BigInt);static numberNatural=this.reg(xe.common.numberNatural).map(Number);static numberExponential=this.reg(xe.common.numberExponential).map(Number);static numberUnit=this.reg(xe.common.numberUnit).map(Number);static numberByte=this.reg(xe.common.numberByte).map(Number);static whitespace=this.reg(xe.common.whitespace);static whitespaceOpt=this.reg(xe.common.whitespaceOpt);static whitespaceInline=this.reg(xe.common.whitespaceInline);static whitespaceInlineOpt=this.reg(xe.common.whitespaceInlineOpt);static whitespaceMultiline=this.reg(xe.common.whitespaceMultiline);static doubleQuotedString=this.reg(xe.common.doubleQuotedString,1);static singleQuotedString=this.reg(xe.common.singleQuotedString,1);static backtickQuotedString=this.reg(xe.common.backtickQuotedString,1);constructor(e,t=!1){this.#c=e}static#P(e){const t=[];for(;e;)t.push(e),e=e.parent;t.reverse();let i=new Map;for(let e=1;ei<=r||i>e))),i.set(t[e].current,r),t.splice(r+1,e-r),e=r):i.set(t[e].current,e)}return t[t.length-1]}getParser(){return this.#c}run(e){const t=this.#c.parse(ge.makeContext(this,e),0,ge.makePathNode(),0);return t.position!==e.length&&(t.status=!1),t}parse(e,t=!0){const i=this.run(e);if(i.status)return i.value;const r=[Math.ceil(30),Math.floor(30)],s=Me.lineColumnFromOffset(e,i.bestPosition);let n=i.bestPosition;const a=e.replaceAll(/^(\s)+|\s{6,}|\s*?\n\s*/g,((e,t,r)=>{let s=t?"...":" ... ";return r<=i.bestPosition&&(i.bestPosition0&&(u="..."+u,c+=3),r[1]e.getParser()))));return t}static alt(...e){return new this(new fe(...e.map((e=>e.getParser()))))}static lookahead(e){return new this(new Ne(e.getParser(),Ne.Type.POSITIVE_AHEAD))}static lazy(e){return new this(new Ce(e))}times(e,t=e){return new Me(new Le(this.#c,e,t))}many(){return this.times(0,Number.POSITIVE_INFINITY)}atLeast(e){return this.times(e,Number.POSITIVE_INFINITY)}atMost(e){return this.times(0,e)}opt(){return Me.alt(this,Me.success())}sepBy(e,t=!1){return Me.seq(this,Me.seq(e,this).map(Me.#C).many()).map(Me.#N)}skipSpace(){return Me.seq(this,Me.whitespaceOpt).map(Me.#E)}map(e){return new Me(new Pe(this.#c,e))}chain(e){return new Me(new we(this.#c,e))}assert(e){return this.chain(((t,i,r)=>e(t,i,r)?Me.success().map((()=>t)):Me.failure()))}join(e=""){return this.map(Me.#x)}label(e=""){return new Me(new Ee(this.#c,e))}toString(e="",t=!1,i=null){i instanceof Me&&(i=i.getParser());const r=ge.makeContext(this,"");r.highlighted=i;const s=ge.makePathNode();return(t?"\n"+e:"")+this.#c.toString(r,e,s)}}class Ie{static grammar=this.createGrammar();static createGrammar(){return Me.failure()}}class Be{static#k=new Map;static registerSerializer(e,t){Be.#k.set(e,t)}static getSerializer(e){return Be.#k.get(e)}}class Ve extends Ie{static attributes={attributes:new oe({ignored:!0}),lookbehind:new oe({default:"",ignored:!0,uninitialized:!0})};#T;get _keys(){return this.#T}set _keys(e){this.#T=e}constructor(e={},t=!1){super();const i=this.constructor;this.attributes,this.lookbehind;const r=Object.keys(e),s=e.attributes?ue.mergeArrays(Object.keys(e.attributes),Object.keys(i.attributes)):Object.keys(i.attributes),n=ue.mergeArrays(r,s);for(const r of n){let s=e[r];if(!(t||r in e||r in i.attributes||r.startsWith(ne.subObjectAttributeNamePrefix))){const e=s instanceof Array?`[${s[0]?.constructor.name}]`:s.constructor.name;console.warn(`UEBlueprint: Attribute ${r} (of type ${e}) in the serialized data is not defined in ${i.name}.attributes`)}if(!(r in i.attributes)){this[r]=s;continue}i.attributes.lookbehind;const n=oe.getAttribute(e,r,"predicate",i),a=n?e=>{Object.defineProperties(this,{["#"+r]:{writable:!0,enumerable:!1},[r]:{enumerable:!0,get(){return this["#"+r]},set(e){n(e)?this["#"+r]=e:console.warn(`UEBlueprint: Tried to assign attribute ${r} to ${i.name} not satisfying the predicate`)}}}),this[r]=e}:e=>this[r]=e;let o=oe.getAttribute(e,r,"default",i);o instanceof Function&&(o=o(this));let l=oe.getAttribute(e,r,"type",i);if(l instanceof ae&&(l=l.compute(this)),l instanceof Array&&(l=Array),void 0===l&&(l=ue.getType(o)),void 0===s)void 0===o||oe.getAttribute(e,r,"uninitialized",i)||a(o);else{if(s?.constructor===String&&oe.getAttribute(e,r,"serialized",i)&&l!==String)try{s=Be.getSerializer(l).read(s)}catch(e){a(s);continue}a(ue.sanitize(s,l))}}}static defaultValueProviderFromType(e){return e!==Boolean&&(e===Number?0:e===BigInt?0n:e===String?"":e===Array||e instanceof Array?()=>[]:e instanceof ce?this.defaultValueProviderFromType(e.values[0]):e instanceof le?()=>new le(e.type,e.getter):e instanceof ae?void 0:()=>new e)}static isValueOfType(e,t){return null!=e&&(e instanceof t||e.constructor===t)}static defineAttributes(e,t){Object.defineProperty(e,"attributes",{writable:!0,configurable:!1}),e.attributes=t}listenAttribute(e,t){const i=Object.getOwnPropertyDescriptor(this,e),r=i.set;r?(i.set=e=>{r(e),t(e)},Object.defineProperties(this,{[e]:i})):i.value&&Object.defineProperties(this,{["#"+e]:{value:i.value,writable:!0,enumerable:!1},[e]:{enumerable:!0,get(){return this["#"+e]},set(i){i!=this["#"+e]&&(t(i),this["#"+e]=i)}}})}getLookbehind(){let e=this.lookbehind??oe.getAttribute(this,"lookbehind","default");return e=e instanceof ce?e.values[0]:e,e}unexpectedKeys(){return Object.keys(this).length-Object.keys(this.constructor.attributes).length}equals(e){const t=Object.keys(this),i=Object.keys(e);if(t.length!=i.length)return!1;for(const i of t){if(this[i]instanceof Ve&&!this[i].equals(e[i]))return!1;if(!ue.equals(this[i],e[i]))return!1}return!0}}class $e{static separatedBy=(e,t,i=1)=>new RegExp(e+"(?:"+t+e+")"+(1===i?"*":2===i?"+":`{${i},}`));static Regex=class{static HexDigit=/[0-9a-fA-F]/;static InsideString=/(?:[^"\\]|\\.)*/;static InsideSingleQuotedString=/(?:[^'\\]|\\.)*/;static Integer=/[\-\+]?\d+(?!\d|\.)/;static Number=/[-\+]?(?:\d*\.)?\d+(?!\d|\.)/;static RealUnit=/\+?(?:0(?:\.\d+)?|1(?:\.0+)?)(?![\.\d])/;static Word=$e.separatedBy("[a-zA-Z]","_");static Symbol=/[a-zA-Z_]\w*/;static DotSeparatedSymbols=$e.separatedBy(this.Symbol.source,"\\.");static MultipleWordsSymbols=$e.separatedBy(this.Symbol.source,"(?:\\.|\\ +)");static PathFragment=$e.separatedBy(this.Symbol.source,"[\\.:]");static PathSpaceFragment=$e.separatedBy(this.Symbol.source,"[\\.:\\ ]");static Path=new RegExp(`(?:\\/${this.PathFragment.source}){2,}`)};static null=Me.reg(/\(\s*\)/).map((()=>null));static true=Me.reg(/true/i).map((()=>!0));static false=Me.reg(/false/i).map((()=>!1));static boolean=Me.regArray(/(true)|false/i).map((e=>!!e[1]));static number=Me.regArray(new RegExp(`(${Me.number.getParser().parser.regexp.source})|(\\+?inf)|(-inf)`)).map((([e,t,i,r])=>t?Number(t):i?Number.POSITIVE_INFINITY:Number.NEGATIVE_INFINITY));static bigInt=Me.reg(new RegExp(Me.number.getParser().parser.regexp.source)).map(BigInt).map((e=>void 0!==e[2]?Number.POSITIVE_INFINITY:void 0!==e[3]?Number.NEGATIVE_INFINITY:Number(e[1])));static naturalNumber=Me.lazy((()=>Me.reg(/\d+/).map(Number)));static string=Me.doubleQuotedString.map((e=>ue.unescapeString(e)));static colorValue=Me.numberByte;static word=Me.reg($e.Regex.Word);static symbol=Me.reg($e.Regex.Symbol);static symbolQuoted=Me.reg(new RegExp('"('+$e.Regex.Symbol.source+')"'),1);static attributeName=Me.reg($e.Regex.DotSeparatedSymbols);static attributeNameQuoted=Me.reg(new RegExp('"('+$e.Regex.InsideString.source+')"'),1);static guid=Me.reg(new RegExp(`${$e.Regex.HexDigit.source}{32}`));static commaSeparation=Me.reg(/\s*,\s*(?!\))/);static commaOrSpaceSeparation=Me.reg(/\s*,\s*(?!\))|\s+/);static equalSeparation=Me.reg(/\s*=\s*/);static hexColorChannel=Me.reg(new RegExp($e.Regex.HexDigit.source+"{2}"));static grammarFor(e,t=e?.type,i=this.unknownValue){let r=i;if(t===Array||t instanceof Array){if(e?.inlined)return this.grammarFor(void 0,t[0]);r=Me.seq(Me.reg(/\(\s*/),this.grammarFor(void 0,t[0]).sepBy(this.commaSeparation).opt(),Me.reg(/\s*(?:,\s*)?\)/)).map((([e,t,i])=>t instanceof Array?t:[]))}else if(t instanceof ce)r=t.values.map((e=>this.grammarFor(void 0,e))).reduce(((e,t)=>t&&t!==this.unknownValue&&e!==this.unknownValue?Me.alt(e,t):this.unknownValue));else{if(t instanceof le)return this.grammarFor(void 0,t.getTargetType()).map((e=>new le(t.type,(()=>e))));if(e?.constructor===Object)r=this.grammarFor(void 0,t);else switch(t){case Boolean:r=this.boolean;break;case null:r=this.null;break;case Number:r=this.number;break;case BigInt:r=this.bigInt;break;case String:r=this.string;break;default:t?.prototype instanceof Ie&&(r=t.grammar)}}return e&&(e.serialized&&t.constructor!==String&&(r=r==this.unknownValue?this.string:Me.seq(Me.str('"'),r,Me.str('"')).map((([e,t,i])=>t))),e.nullable&&(r=Me.alt(r,this.null))),r}static getAttribute(e,t){let i,r;if(e instanceof ce)for(let r of e.values)if(i=this.getAttribute(r,t))return i;return e instanceof Ve.constructor?(i=e.attributes[t[0]],r=i?.type):e instanceof Array&&(i=e[t[0]],r=i),t.length>1?this.getAttribute(r,t.slice(1)):i}static createAttributeGrammar(e,t=this.attributeName,i=this.equalSeparation,r=((e,t,i)=>{})){return Me.seq(t,i).chain((([t,i])=>{const s=t.split(ne.keysSeparator),n=this.getAttribute(e,s);return this.grammarFor(n).map((e=>t=>{r(t,s,e),ue.objectSet(t,s,e)}))}))}static createEntityGrammar(e,t=!0,i=this.commaSeparation){const r=e.attributes.lookbehind.default;return Me.seq(Me.reg(r instanceof ce?new RegExp(`(${r.values.reduce(((e,t)=>e+"|"+t))})\\s*\\(\\s*`):r.constructor==String&&r.length>0?new RegExp(`(${r})\\s*\\(\\s*`):/()\(\s*/,1),this.createAttributeGrammar(e).sepBy(i),Me.reg(/\s*(?:,\s*)?\)/)).map((([e,t,i])=>{let r={};return t.forEach((e=>e(r))),e.length&&(r.lookbehind=e),r})).chain((i=>{let r=Object.keys(i);if(Object.keys(e.attributes).filter((t=>e.attributes[t].expected)).find((e=>!r.includes(e)&&e)))return Me.failure();const s=Object.keys(i).filter((t=>!(t in e.attributes))).length;return!t&&s>0?Me.failure():Me.success().map((()=>new e(i)))}))}static unknownValue}class Oe extends Ve{static attributes={...super.attributes,value:oe.createValue(0)};static grammar=this.createGrammar();static createGrammar(){return Me.number.map((e=>new this(e)))}constructor(e=0){e.constructor!==Object&&(e={value:e}),super(e),this.value}valueOf(){return this.value}toString(){return this.value.toFixed(6)}}class He extends Ve{static attributes={...super.attributes,R:new oe({type:Oe,default:()=>new Oe,expected:!0}),G:new oe({type:Oe,default:()=>new Oe,expected:!0}),B:new oe({type:Oe,default:()=>new Oe,expected:!0}),A:new oe({type:Oe,default:()=>new Oe(1)}),H:new oe({type:Oe,default:()=>new Oe,ignored:!0}),S:new oe({type:Oe,default:()=>new Oe,ignored:!0}),V:new oe({type:Oe,default:()=>new Oe,ignored:!0})};static grammar=this.createGrammar();static linearToSRGB(e){return e<=0?0:e>=1?1:e<.0031308?12.92*e:1.055*Math.pow(e,1/2.4)-.055}static sRGBtoLinear(e){return e<=0?0:e>=1?1:e<.04045?e/12.92:Math.pow((e+.055)/1.055,2.4)}static getWhite(){return new He({R:1,G:1,B:1})}static createGrammar(){return $e.createEntityGrammar(this,!1)}static getLinearColorFromHexGrammar(){return Me.regArray(new RegExp("#("+$e.Regex.HexDigit.source+"{2})("+$e.Regex.HexDigit.source+"{2})("+$e.Regex.HexDigit.source+"{2})("+$e.Regex.HexDigit.source+"{2})?")).map((([e,t,i,r,s])=>new this({R:parseInt(t,16)/255,G:parseInt(i,16)/255,B:parseInt(r,16)/255,A:parseInt(s??"FF",16)/255})))}static getLinearColorRGBListGrammar(){return Me.seq(Me.numberByte,$e.commaSeparation,Me.numberByte,$e.commaSeparation,Me.numberByte).map((([e,t,i,r,s])=>new this({R:e/255,G:i/255,B:s/255,A:1})))}static getLinearColorRGBGrammar(){return Me.seq(Me.reg(/rgb\s*\(\s*/),this.getLinearColorRGBListGrammar(),Me.reg(/\s*\)/)).map((([e,t,i])=>t))}static getLinearColorRGBAGrammar(){return Me.seq(Me.reg(/rgba\s*\(\s*/),this.getLinearColorRGBListGrammar(),Me.reg(/\s*\)/)).map((([e,t,i])=>t))}static getLinearColorFromAnyFormat(){return Me.alt(this.getLinearColorFromHexGrammar(),this.getLinearColorRGBAGrammar(),this.getLinearColorRGBGrammar(),this.getLinearColorRGBListGrammar())}constructor(e){e instanceof Array&&(e={R:e[0]??0,G:e[1]??0,B:e[2]??0,A:e[3]??1}),super(e),this.R,this.G,this.B,this.A,this.H,this.S,this.V,this.#A()}#A(){const e=this.R.value,t=this.G.value,i=this.B.value;if(ue.approximatelyEqual(e,t)&&ue.approximatelyEqual(e,i)&&ue.approximatelyEqual(t,i))return this.S.value=0,void(this.V.value=e);const r=Math.max(e,t,i),s=Math.min(e,t,i),n=r-s;let a;switch(r){case s:a=0;break;case e:a=(t-i)/n+(te.toString(16).toUpperCase().padStart(2,"0"))).join("")}toSRGBAString(){return this.toSRGBA().map((e=>e.toString(16).toUpperCase().padStart(2,"0"))).join("")}toHSVA(){return[this.H.value,this.S.value,this.V.value,this.A.value]}toNumber(){return(Math.round(255*this.R.value)<<24)+(Math.round(255*this.G.value)<<16)+(Math.round(255*this.B.value)<<8)+Math.round(255*this.A.value)}setFromRGBANumber(e){this.A.value=(255&e)/255,this.B.value=(e>>8&255)/255,this.G.value=(e>>16&255)/255,this.R.value=(e>>24&255)/255,this.#A()}setFromSRGBANumber(e){this.A.value=(255&e)/255,this.B.value=He.sRGBtoLinear((e>>8&255)/255),this.G.value=He.sRGBtoLinear((e>>16&255)/255),this.R.value=He.sRGBtoLinear((e>>24&255)/255),this.#A()}toArray(){return[this.R.value,this.G.value,this.B.value,this.A.value]}toString(){return ue.printLinearColor(this)}}class De{static arrayPin=H``;static branchNode=H``;static breakStruct=H``;static cast=H``;static close=H``;static convert=H``;static correct=H``;static delegate=H``;static doN=H``;static doOnce=H``;static enum=H``;static event=H``;static execPin=H``;static expandIcon=H``;static flipflop=H``;static forEachLoop=H``;static functionSymbol=H``;static gamepad=H``;static genericPin=H``;static keyboard=H``;static loop=H``;static macro=H``;static mapPin=H``;static makeArray=H``;static makeMap=H``;static makeSet=H``;static makeStruct=H``;static metasoundFunction=H``;static mouse=H``;static node=H``;static operationPin=H``;static pcgStackPin=H``;static pcgPin=H``;static pcgParamPin=H``;static pcgSpatialPin=H``;static plusCircle=H``;static questionMark=H``;static referencePin=H``;static reject=H``;static setPin=H``;static select=H``;static sequence=H``;static sound=H``;static spawnActor=H``;static switch=H``;static timer=H``;static touchpad=H``}const Ge=/\/Script\/SequencerScripting\.MovieSceneScripting(.+)Channel/,Re={A_AccentGrave:"à",Add:"Num +",C_Cedille:"ç",Decimal:"Num .",Divide:"Num /",E_AccentAigu:"é",E_AccentGrave:"è",F1:"F1",F10:"F10",F11:"F11",F12:"F12",F2:"F2",F3:"F3",F4:"F4",F5:"F5",F6:"F6",F7:"F7",F8:"F8",F9:"F9",Gamepad_Special_Left_X:"Touchpad Button X Axis",Gamepad_Special_Left_Y:"Touchpad Button Y Axis",Mouse2D:"Mouse XY 2D-Axis",Multiply:"Num *",Section:"§",Subtract:"Num -",Tilde:"`"};function ze(e){let t;switch(e.getType()){case ne.paths.asyncAction:if(e.ProxyFactoryFunctionName)return ue.formatStringName(e.ProxyFactoryFunctionName);case ne.paths.actorBoundEvent:case ne.paths.componentBoundEvent:return`${ue.formatStringName(e.DelegatePropertyName)} (${e.ComponentPropertyName??"Unknown"})`;case ne.paths.callDelegate:return`Call ${e.DelegateReference?.MemberName??"None"}`;case ne.paths.createDelegate:return"Create Event";case ne.paths.customEvent:if(e.CustomFunctionName)return e.CustomFunctionName;case ne.paths.dynamicCast:return e.TargetType?`Cast To ${e.TargetType?.getName()}`:"Bad cast node";case ne.paths.enumLiteral:return`Literal enum ${e.Enum?.getName()}`;case ne.paths.event:return`Event ${(e.EventReference?.MemberName??"").replace(/^Receive/,"")}`;case ne.paths.executionSequence:return"Sequence";case ne.paths.forEachElementInEnum:return`For Each ${e.Enum?.getName()}`;case ne.paths.forEachLoopWithBreak:return"For Each Loop with Break";case ne.paths.functionEntry:return"UserConstructionScript"===e.FunctionReference?.MemberName?"Construction Script":e.FunctionReference?.MemberName;case ne.paths.functionResult:return"Return Node";case ne.paths.ifThenElse:return"Branch";case ne.paths.makeStruct:if(e.StructType)return`Make ${e.StructType.getName()}`;case ne.paths.materialExpressionComponentMask:{const t=e.getMaterialSubobject();return`Mask ( ${ne.rgba.filter((e=>!0===t[e].get())).map((e=>e+" ")).join("")})`}case ne.paths.materialExpressionConstant:t??=[e.getCustomproperties().find((e=>"Value"==e.PinName))?.DefaultValue];case ne.paths.materialExpressionConstant2Vector:t??=[e.getCustomproperties().find((e=>"X"==e.PinName))?.DefaultValue,e.getCustomproperties().find((e=>"Y"==e.PinName))?.DefaultValue];case ne.paths.materialExpressionConstant3Vector:if(!t){const i=e.getCustomproperties().find((e=>"Constant"==e.PinName))?.DefaultValue;t=[i.X,i.Y,i.Z]}case ne.paths.materialExpressionConstant4Vector:if(!t){const i=e.getCustomproperties().find((e=>"Constant"==e.PinName))?.DefaultValue;t=[i.R,i.G,i.B,i.A].map((e=>e.valueOf()))}if(t.length>0)return t.map((e=>ue.printExponential(e))).reduce(((e,t)=>e+","+t));break;case ne.paths.materialExpressionFunctionInput:{const t=e.getMaterialSubobject();return`Input ${t?.InputName??"In"} (${t?.InputType?.value.match(/^.+?_(\w+)$/)?.[1]??"Vector3"})`}case ne.paths.materialExpressionLogarithm:return"Ln";case ne.paths.materialExpressionLogarithm10:return"Log10";case ne.paths.materialExpressionLogarithm2:return"Log2";case ne.paths.materialExpressionMaterialFunctionCall:const i=e.getMaterialSubobject()?.MaterialFunction;if(i)return i.getName();break;case ne.paths.materialExpressionSquareRoot:return"Sqrt";case ne.paths.metasoundEditorGraphExternalNode:{const t=e.ClassName?.Name;if(t)return"Add"===t?"+":t}case ne.paths.pcgEditorGraphNodeInput:return"Input";case ne.paths.pcgEditorGraphNodeOutput:return"Output";case ne.paths.spawnActorFromClass:let r=e.getCustomproperties().find((e=>"ReturnValue"==e.PinName))?.PinType?.PinSubCategoryObject?.getName();return"Actor"===r&&(r=null),`SpawnActor ${ue.formatStringName(r??"NONE")}`;case ne.paths.switchEnum:return`Switch on ${e.Enum?.getName()??"Enum"}`;case ne.paths.switchInteger:return"Switch on Int";case ne.paths.variableGet:return"";case ne.paths.variableSet:return"SET"}let i=e.switchTarget();if(i)return"E"!==i[0]&&(i=ue.formatStringName(i)),`Switch on ${i}`;if(e.isComment())return e.NodeComment;const r=e.getHIDAttribute();if(r){const t=r.toString();let i=function(e){let t=Re[e];if(t)return t;if(t=ue.numberFromText(e)?.toString(),t)return t;const i=e.match(/NumPad([a-zA-Z]+)/);return i&&(t=ue.numberFromText(i[1]).toString(),t)?"Num "+t:void 0}(t)??ue.formatStringName(t);return e.getClass()===ne.paths.inputDebugKey?i="Debug Key "+i:e.getClass()===ne.paths.getInputAxisKeyValue&&(i="Get "+i),i}if(e.getClass()===ne.paths.macro)return ue.formatStringName(e.MacroGraphReference?.getMacroName());if(e.isMaterial()&&e.getMaterialSubobject()){let t=ze(e.getMaterialSubobject());return t=t.match(/Material Expression (.+)/)?.[1]??t,t}if(e.isPcg()&&e.getPcgSubobject()){let t=e.getPcgSubobject();return t.NodeTitle?t.NodeTitle:ze(t)}const s=e.getSubgraphObject();if(s)return s.Graph.getName();const n=e.getSettingsObject();if(n){if(n.ExportPath.type===ne.paths.pcgHiGenGridSizeSettings)return`Grid Size: ${n.HiGenGridSize?.toString().match(/\d+/)?.[0]?.concat("00")??n.HiGenGridSize?.toString().match(/^\w+$/)?.[0]??"256"}`;if(n.BlueprintElementInstance)return ue.formatStringName(n.BlueprintElementType.getName());if(n.Operation){const e=n.Name.match(/PCGMetadata(\w+)Settings_\d+/);if(e)return ue.formatStringName(e[1]+": "+n.Operation)}const e=n.getSubgraphObject();if(e&&e.Graph)return e.Graph.getName()}let a=e.FunctionReference?.MemberName;if(a){const t=e.FunctionReference.MemberParent?.path??"";switch(a){case"AddKey":let e=t.match(Ge);if(e)return`Add Key (${ue.formatStringName(e[1])})`;case"Concat_StrStr":return"Append"}const i=a.match(ne.lineTracePattern);if(i)return"Line Trace"+("Multi"===i[1]?" Multi ":" ")+(""===i[2]?"By Channel":ue.formatStringName(i[2]));switch(t){case ne.paths.blueprintGameplayTagLibrary:case ne.paths.kismetMathLibrary:case ne.paths.slateBlueprintLibrary:case ne.paths.timeManagementBlueprintLibrary:const e=a.match(/[BF]([A-Z]\w+)/);switch(e&&(a=e[1]),a){case"Abs":return"ABS";case"BooleanAND":return"AND";case"BooleanNAND":return"NAND";case"BooleanOR":return"OR";case"Exp":return"e";case"LineTraceSingle":return"Line Trace By Channel";case"Max":case"MaxInt64":return"MAX";case"Min":case"MinInt64":return"MIN";case"Not_PreBool":return"NOT";case"Sin":return"SIN";case"Sqrt":return"SQRT";case"Square":return"^2";case"CrossProduct2D":return"cross";case"Vector4_CrossProduct3":return"cross3";case"DotProduct2D":case"Vector4_DotProduct":return"dot";case"Vector4_DotProduct3":return"dot3"}if(a.startsWith("Add_"))return"+";if(a.startsWith("And_"))return"&";if(a.startsWith("Conv_"))return"";if(a.startsWith("Cross_"))return"cross";if(a.startsWith("Divide_"))return String.fromCharCode(247);if(a.startsWith("Dot_"))return"dot";if(a.startsWith("EqualEqual_"))return"==";if(a.startsWith("Greater_"))return">";if(a.startsWith("GreaterEqual_"))return">=";if(a.startsWith("Less_"))return"<";if(a.startsWith("LessEqual_"))return"<=";if(a.startsWith("Multiply_"))return String.fromCharCode(10799);if(a.startsWith("Not_"))return"~";if(a.startsWith("NotEqual_"))return"!=";if(a.startsWith("Or_"))return"|";if(a.startsWith("Percent_"))return"%";if(a.startsWith("Subtract_"))return"-";if(a.startsWith("Xor_"))return"^";break;case ne.paths.blueprintSetLibrary:{const e=a.match(/Set_(\w+)/);if(e)return ue.formatStringName(e[1]).toUpperCase()}break;case ne.paths.blueprintMapLibrary:{const e=a.match(/Map_(\w+)/);if(e)return ue.formatStringName(e[1]).toUpperCase()}break;case ne.paths.kismetArrayLibrary:{const e=a.match(/Array_(\w+)/);if(e)return e[1].toUpperCase()}}return ue.formatStringName(a)}if(e.OpName){switch(e.OpName){case"Boolean::LogicAnd":return"Logic AND";case"Boolean::LogicEq":return"==";case"Boolean::LogicNEq":return"!=";case"Boolean::LogicNot":return"Logic NOT";case"Boolean::LogicOr":return"Logic OR";case"Matrix::MatrixMultiply":return"Multiply (Matrix * Matrix)";case"Matrix::MatrixVectorMultiply":return"Multiply (Matrix * Vector4)";case"Numeric::Abs":return"Abs";case"Numeric::Add":return"+";case"Numeric::DistancePos":return"Distance";case"Numeric::Mul":return String.fromCharCode(10799)}return ue.formatStringName(e.OpName).replaceAll("::"," ")}return e.FunctionDisplayName?ue.formatStringName(e.FunctionDisplayName):e.ObjectRef?e.ObjectRef.getName():ue.formatStringName(e.getNameAndCounter()[0])}var _e;"undefined"==typeof window?import("crypto").then((e=>_e=e.default)).catch():_e=window.crypto;class Fe extends Ve{static attributes={...super.attributes,value:oe.createValue("")};static grammar=this.createGrammar();static createGrammar(){return $e.guid.map((e=>new this(e)))}static generateGuid(e=!0){let t=new Uint32Array(4);!0===e&&_e.getRandomValues(t);let i="";return t.forEach((e=>{i+=("0".repeat(8)+e.toString(16).toUpperCase()).slice(-8)})),new Fe({value:i})}constructor(e){e||(e=Fe.generateGuid().value),e.constructor!==Object&&(e={value:e}),super(e),this.value}valueOf(){return this.value}toString(){return this.value}}class je extends Ve{static attributes={...super.attributes,type:new oe({default:"",serialized:!0}),path:new oe({default:"",serialized:!0}),_full:new oe({ignored:!0})};static quoted=Me.regArray(new RegExp(`'"(${$e.Regex.InsideString.source})"'|'(${$e.Regex.InsideSingleQuotedString.source})'`)).map((([e,t,i])=>t??i));static path=this.quoted.getParser().parser.regexp.source+"|"+$e.Regex.Path.source;static typeReference=Me.reg(new RegExp($e.Regex.Path.source+"|"+$e.symbol.getParser().regexp.source));static fullReferenceGrammar=Me.regArray(new RegExp("("+this.typeReference.getParser().regexp.source+")(?:"+this.quoted.getParser().parser.regexp.source+")")).map((([e,t,...i])=>new this({type:t,path:i.find((e=>e)),_full:e})));static fullReferenceSerializedGrammar=Me.regArray(new RegExp('"('+$e.Regex.InsideString.source+"?)(?:'("+$e.Regex.InsideSingleQuotedString.source+"?)')?\"")).map((([e,t,i])=>new this({type:t,path:i,_full:e})));static typeReferenceGrammar=this.typeReference.map((e=>new this({type:e,path:"",_full:e})));static grammar=this.createGrammar();constructor(e={}){e.constructor===String&&(e={path:e}),super(e),e._full&&0!==e._full.length||(this._full=`"${this.type+(this.path?`'${this.path}'`:"")}"`),this.type,this.path}static createGrammar(){return Me.alt(this.fullReferenceSerializedGrammar,this.fullReferenceGrammar,this.typeReferenceGrammar)}static createNoneInstance(){return new je({type:"None",path:""})}getName(e=!1){return ue.getNameFromPath(this.path.replace(/_C$/,""),e)}toString(){return this._full}}class We extends Ve{static attributes={...super.attributes,MemberParent:oe.createType(je),MemberName:oe.createType(String),MemberGuid:oe.createType(Fe)};static grammar=this.createGrammar();static createGrammar(){return $e.createEntityGrammar(this)}constructor(e){super(e),this.MemberParent,this.MemberName,this.MemberGuid}}class Ue extends Ve{static attributes={...super.attributes,value:oe.createValue("")};static attributeConverter={fromAttribute:(e,t)=>new Ue(e),toAttribute:(e,t)=>e.toString()};static grammar=this.createGrammar();static createGrammar(){return $e.symbol.map((e=>new this(e)))}constructor(e){e.constructor!==Object&&(e={value:e}),super(e),this.value}valueOf(){return this.value}toString(){return this.value}}class Ke extends Ve{static attributes={...super.attributes,value:new oe({default:0,predicate:e=>e%1==0&&e>1<<31&&e<-(1<<31)})};static grammar=this.createGrammar();static createGrammar(){return Me.numberInteger.map((e=>new this(e)))}constructor(e=0){e.constructor!==Object&&(e={value:e}),e.value=Math.floor(e.value),-0===e.value&&(e.value=0),super(e),this.value}valueOf(){return this.value}toString(){return this.value.toString()}}class Ye extends Ve{static attributes={...super.attributes,MacroGraph:new oe({type:je,default:()=>new je}),GraphBlueprint:new oe({type:je,default:()=>new je}),GraphGuid:new oe({type:Fe,default:()=>new Fe})};static grammar=this.createGrammar();static createGrammar(){return $e.createEntityGrammar(this)}constructor(e){super(e),this.MacroGraph,this.GraphBlueprint,this.GuidEntity}getMacroName(){const e=this.MacroGraph.path.search(":");return this.MacroGraph.path.substring(e+1)}}const Xe={[ne.paths.niagaraBool]:n``,[ne.paths.niagaraDataInterfaceVolumeTexture]:n``,[ne.paths.niagaraFloat]:n``,[ne.paths.niagaraMatrix]:n``,[ne.paths.niagaraNumeric]:n``,[ne.paths.niagaraPosition]:n``,[ne.paths.quat4f]:n``,[ne.paths.rotator]:n``,[ne.paths.transform]:n``,[ne.paths.vector]:n``,[ne.paths.vector3f]:n``,[ne.paths.vector4f]:n``,Any:n``,"Any[]":n``,audio:n``,blue:n``,bool:n``,byte:n``,class:n``,default:n``,delegate:n``,enum:n``,exec:n``,float:n``,green:n``,int:n``,int32:n``,int64:n``,interface:n``,name:n``,object:n``,Param:n``,"Param[]":n``,Point:n``,"Point[]":n``,real:n``,red:n``,string:n``,struct:n``,Surface:n``,"Surface[]":n``,text:n``,time:n``,Volume:n``,"Volume[]":n``,wildcard:n``},Ze=n``;class qe extends Ke{static attributes={...super.attributes,value:new oe({...super.attributes.value,predicate:e=>e%1==0&&e>=0&&e<256})};static grammar=this.createGrammar();static createGrammar(){return Me.numberByte.map((e=>new this(e)))}constructor(e=0){super(e)}}class Qe extends Ve{static attributes={...super.attributes,value:oe.createValue("")};static grammar=this.createGrammar();static createGrammar(){return $e.symbol.map((e=>new this(e)))}constructor(e){e.constructor!==Object&&(e={value:e}),super(e),this.value}valueOf(){return this.value}toString(){return this.value}}class Je extends Qe{static grammar=this.createGrammar();static createGrammar(){return $e.symbol.map((e=>new this(e)))}}class et extends Je{static grammar=this.createGrammar();static createGrammar(){return Me.reg($e.Regex.InsideString).map((e=>new this(e)))}}class tt extends Ve{static attributes={...super.attributes,value:oe.createValue(""),lookbehind:new oe({...super.attributes.lookbehind,default:"INVTEXT"})};static grammar=this.createGrammar();static createGrammar(){return Me.alt(Me.seq(Me.reg(new RegExp(`${this.attributes.lookbehind.default}\\s*\\(`)),$e.grammarFor(this.attributes.value),Me.reg(/\s*\)/)).map((([e,t,i])=>t)),Me.reg(new RegExp(this.attributes.lookbehind.default)).map((()=>""))).map((e=>new this(e)))}constructor(e){e.constructor!==Object&&(e={value:e}),super(e),this.value}toString(){return this.value}}class it extends Ve{static attributes={...super.attributes,namespace:oe.createValue(""),key:oe.createValue(""),value:oe.createValue(""),lookbehind:new oe({...super.attributes.lookbehind,default:"NSLOCTEXT"})};static grammar=this.createGrammar();static createGrammar(){return Me.regArray(new RegExp(String.raw`${this.attributes.lookbehind.default}\s*\(`+String.raw`\s*"(${$e.Regex.InsideString.source})"\s*,`+String.raw`\s*"(${$e.Regex.InsideString.source})"\s*,`+String.raw`\s*"(${$e.Regex.InsideString.source})"\s*`+String.raw`(?:,\s+)?`+String.raw`\)`,"m")).map((e=>new this({namespace:ue.unescapeString(e[1]),key:ue.unescapeString(e[2]),value:ue.unescapeString(e[3])})))}constructor(e){super(e),this.namespace,this.key,this.value}toString(){return ue.capitalFirstLetter(this.value)}}class rt extends Ve{static attributes={...super.attributes,value:new oe({type:[new ce(String,it,tt,rt)],default:[]}),lookbehind:new oe({...super.attributes.lookbehind,default:new ce("LOCGEN_FORMAT_NAMED","LOCGEN_FORMAT_ORDERED")})};static grammar=this.createGrammar();static createGrammar(){return Me.seq(Me.reg(new RegExp(`(${this.attributes.lookbehind.default.values.reduce(((e,t)=>e+"|"+t))})\\s*`),1),$e.grammarFor(this.attributes.value)).map((([e,t])=>new this({value:t,lookbehind:e})))}constructor(e){super(e),this.value}toString(){const e=this.value?.[0]?.toString();if(!e)return"";const t=this.value.slice(1).map((e=>e.toString()));return"LOCGEN_FORMAT_NAMED"==this.lookbehind?e.replaceAll(/\{([a-zA-Z]\w*)\}/g,((e,i)=>{const r=t.indexOf(i)+1;return r>0&&r{const r=Number(i);return re>=-(1n<<63n)&&e<1n<<63n})};static grammar=this.createGrammar();static createGrammar(){return Me.numberBigInteger.map((e=>new this(e)))}constructor(e=0){e.constructor!==Object&&(e={value:e}),-0===e.value&&(e.value=0n),super(e),this.value}valueOf(){return this.value}toString(){return this.value.toString()}}class nt extends Ve{static attributes={...super.attributes,value:new oe({default:""})};static grammar=this.createGrammar();static createGrammar(){return $e.symbol.map((e=>new this(e)))}constructor(e){e.constructor!==Object&&(e={value:e}),super(e),this.value}valueOf(){return this.value}toString(){return this.value}}class at extends Ve{static attributes={...super.attributes,objectName:oe.createType(nt),pinGuid:oe.createType(Fe)};static grammar=this.createGrammar();static createGrammar(){return Me.seq(nt.grammar,Me.whitespace,Fe.grammar).map((([e,t,i])=>new this({objectName:e,pinGuid:i})))}constructor(e){super(e),this.objectName,this.pinGuid}}class ot extends Ve{static attributes={...super.attributes,PinCategory:oe.createValue(""),PinSubCategory:oe.createValue(""),PinSubCategoryObject:new oe({type:je,default:()=>je.createNoneInstance()}),PinSubCategoryMemberReference:new oe({type:We,default:null}),PinValueType:new oe({type:ot,default:null}),ContainerType:oe.createType(nt),bIsReference:oe.createValue(!1),bIsConst:oe.createValue(!1),bIsWeakPointer:oe.createValue(!1),bIsUObjectWrapper:oe.createValue(!1),bSerializeAsSinglePrecisionFloat:oe.createValue(!1)};static grammar=this.createGrammar();static createGrammar(){return $e.createEntityGrammar(this)}constructor(e={},t=!1){super(e,t),this.PinCategory,this.PinSubCategory,this.PinSubCategoryObject,this.PinSubCategoryMemberReference,this.PinValueType,this.ContainerType,this.bIsReference,this.bIsConst,this.bIsWeakPointer,this.bIsUObjectWrapper,this.bIsUObjectWrapper,this.bSerializeAsSinglePrecisionFloat}copyTypeFrom(e){this.PinCategory=e.PinCategory,this.PinSubCategory=e.PinSubCategory,this.PinSubCategoryObject=e.PinSubCategoryObject,this.PinSubCategoryMemberReference=e.PinSubCategoryMemberReference,this.PinValueType=e.PinValueType,this.ContainerType=e.ContainerType,this.bIsReference=e.bIsReference,this.bIsConst=e.bIsConst,this.bIsWeakPointer=e.bIsWeakPointer,this.bIsUObjectWrapper=e.bIsUObjectWrapper,this.bSerializeAsSinglePrecisionFloat=e.bSerializeAsSinglePrecisionFloat}}class lt extends Ve{static attributes={...super.attributes,X:new oe({default:0,expected:!0}),Y:new oe({default:0,expected:!0})};static grammar=this.createGrammar();static createGrammar(){return $e.createEntityGrammar(this,!1)}constructor(e){super(e),this.X,this.Y}toArray(){return[this.X,this.Y]}}class ct extends lt{static grammar=this.createGrammar();static createGrammar(){return Me.alt(Me.regArray(new RegExp(/X\s*=\s*/.source+"(?"+Me.number.getParser().parser.regexp.source+")\\s+"+/Y\s*=\s*/.source+"(?"+Me.number.getParser().parser.regexp.source+")")).map((({groups:{x:e,y:t}})=>new this({X:Number(e),Y:Number(t)}))),lt.grammar)}}class ut extends Ve{static attributes={...super.attributes,R:new oe({default:0,expected:!0}),P:new oe({default:0,expected:!0}),Y:new oe({default:0,expected:!0})};static grammar=this.createGrammar();static createGrammar(){return $e.createEntityGrammar(this,!1)}constructor(e){super(e),this.R,this.P,this.Y}getRoll(){return this.R}getPitch(){return this.P}getYaw(){return this.Y}}class ht extends ut{static grammar=this.createGrammar();static createGrammar(){const e=Me.number.getParser().parser.regexp.source;return Me.alt(Me.regArray(new RegExp("("+e+")\\s*,\\s*("+e+")\\s*,\\s*("+e+")")).map((([e,t,i,r])=>new this({R:Number(r),P:Number(t),Y:Number(i)}))),ut.grammar)}}class pt extends lt{static grammar=this.createGrammar();static createGrammar(){const e=Me.number.getParser().parser.regexp.source;return Me.alt(Me.regArray(new RegExp("("+e+")\\s*,\\s*("+e+")")).map((([e,t,i])=>new this({X:Number(t),Y:Number(i)}))),lt.grammar)}}class dt extends Ve{static attributes={...super.attributes,X:new oe({default:0,expected:!0}),Y:new oe({default:0,expected:!0}),Z:new oe({default:0,expected:!0}),W:new oe({default:0,expected:!0})};static grammar=this.createGrammar();static createGrammar(){return $e.createEntityGrammar(dt,!1)}constructor(e){super(e),this.X,this.Y,this.Z,this.W}toArray(){return[this.X,this.Y,this.Z,this.W]}}class mt extends dt{static grammar=this.createGrammar();static createGrammar(){const e=Me.number.getParser().parser.regexp.source;return Me.alt(Me.regArray(new RegExp("("+e+")\\s*,\\s*("+e+")\\s*,\\s*("+e+")\\s*,\\s*("+e+")")).map((([e,t,i,r,s])=>new this({X:Number(t),Y:Number(i),Z:Number(r),W:Number(s)}))),dt.grammar)}}class gt extends Ve{static attributes={...super.attributes,X:new oe({default:0,expected:!0}),Y:new oe({default:0,expected:!0}),Z:new oe({default:0,expected:!0})};static grammar=this.createGrammar();static createGrammar(){return $e.createEntityGrammar(gt,!1)}constructor(e){super(e),this.X,this.Y,this.Z}toArray(){return[this.X,this.Y,this.Z]}}class bt extends gt{static grammar=this.createGrammar();static createGrammar(){const e=Me.number.getParser().parser.regexp.source;return Me.alt(Me.regArray(new RegExp("("+e+")\\s*,\\s*("+e+")\\s*,\\s*("+e+")")).map((([e,t,i,r])=>new this({X:Number(t),Y:Number(i),Z:Number(r)}))),gt.grammar)}}class vt extends Ve{static#L={[ne.paths.linearColor]:He,[ne.paths.rotator]:ut,[ne.paths.vector]:gt,[ne.paths.vector2D]:lt,[ne.paths.vector4f]:dt,bool:Boolean,byte:qe,enum:Je,exec:String,int:Ke,int64:st,name:String,real:Number,string:String};static#M={enum:et,rg:ct,[ne.paths.rotator]:ht,[ne.paths.vector]:bt,[ne.paths.vector2D]:pt,[ne.paths.vector3f]:bt,[ne.paths.vector4f]:mt};static attributes={...super.attributes,lookbehind:new oe({default:"Pin",ignored:!0}),objectEntity:new oe({ignored:!0}),pinIndex:new oe({type:Number,ignored:!0}),PinId:new oe({type:Fe,default:()=>new Fe}),PinName:oe.createValue(""),PinFriendlyName:oe.createType(new ce(it,rt,tt,String)),PinToolTip:oe.createType(String),Direction:oe.createType(String),PinType:new oe({type:ot,default:()=>new ot,inlined:!0}),LinkedTo:oe.createType([at]),SubPins:oe.createType([at]),ParentPin:oe.createType(at),DefaultValue:new oe({type:new ae((e=>e.getEntityType(!0)??String)),serialized:!0}),AutogeneratedDefaultValue:oe.createType(String),DefaultObject:oe.createType(je),PersistentGuid:oe.createType(Fe),bHidden:oe.createValue(!1),bNotConnectable:oe.createValue(!1),bDefaultValueIsReadOnly:oe.createValue(!1),bDefaultValueIsIgnored:oe.createValue(!1),bAdvancedView:oe.createValue(!1),bOrphanedPin:oe.createValue(!1)};static grammar=this.createGrammar();#I=!1;set recomputesNodeTitleOnChange(e){this.#I=e}get recomputesNodeTitleOnChange(){return this.#I}static createGrammar(){return $e.createEntityGrammar(this)}constructor(e={},t=!1){super(e,t),this.objectEntity,this.pinIndex,this.PinId,this.PinName,this.PinFriendlyName,this.PinToolTip,this.Direction,this.PinType,this.LinkedTo,this.DefaultValue,this.AutogeneratedDefaultValue,this.DefaultObject,this.PersistentGuid,this.bHidden,this.bNotConnectable,this.bDefaultValueIsReadOnly,this.bDefaultValueIsIgnored,this.bAdvancedView,this.bOrphanedPin}static fromLegacyObject(e){return new vt(e,!0)}getType(){const e=this.PinType.PinCategory.toLocaleLowerCase();if("struct"===e||"class"===e||"object"===e||"type"===e)return this.PinType.PinSubCategoryObject.path;if(this.isEnum())return"enum";if(this.objectEntity?.isPcg()){const e=this.objectEntity.getPcgSubobject(),t=this.isInput()?e.InputPins?.[this.pinIndex]:e.OutputPins?.[this.pinIndex];if(t){const i=e[ne.subObjectAttributeNameFromReference(t,!0)];let r=i.Properties?.AllowedTypes?.toString()??"";if(""==r&&(r=this.PinType.PinCategory??"",""==r&&(r="Any")),r)return!1!==i.Properties.bAllowMultipleData&&!1!==i.Properties.bAllowMultipleConnections&&(r+="[]"),r}}if("optional"===e)switch(this.PinType.PinSubCategory){case"red":return"real";case"rg":return"rg";case"rgb":return ne.paths.vector;case"rgba":return ne.paths.linearColor;default:return this.PinType.PinSubCategory}return e}getEntityType(e=!1){const t=this.getType(),i=vt.#L[t],r=vt.#M[t];return e&&void 0!==r?r:i}pinTitle(){return function(e){let t,i=e.PinFriendlyName?e.PinFriendlyName.toString():ue.formatStringName(e.PinName??"");return e.PinToolTip&&(t=e.PinToolTip.match(/\s*(.+?(?=\n)|.+\S)\s*/))&&t[1].toLowerCase()===i.toLowerCase()?t[1]:i}(this)}copyTypeFrom(e){this.PinType.PinCategory=e.PinType.PinCategory,this.PinType.PinSubCategory=e.PinType.PinSubCategory,this.PinType.PinSubCategoryObject=e.PinType.PinSubCategoryObject,this.PinType.PinSubCategoryMemberReference=e.PinType.PinSubCategoryMemberReference,this.PinType.PinValueType=e.PinType.PinValueType,this.PinType.ContainerType=e.PinType.ContainerType,this.PinType.bIsReference=e.PinType.bIsReference,this.PinType.bIsConst=e.PinType.bIsConst,this.PinType.bIsWeakPointer=e.PinType.bIsWeakPointer,this.PinType.bIsUObjectWrapper=e.PinType.bIsUObjectWrapper,this.PinType.bSerializeAsSinglePrecisionFloat=e.PinType.bSerializeAsSinglePrecisionFloat}getDefaultValue(e=!1){return void 0===this.DefaultValue&&e&&(this.DefaultValue=new(this.getEntityType(!0))),this.DefaultValue}isEnum(){const e=this.PinType.PinSubCategoryObject.type;return e===ne.paths.enum||e===ne.paths.userDefinedEnum||"enum"===e.toLowerCase()}isExecution(){return"exec"===this.PinType.PinCategory}isHidden(){return this.bHidden}isInput(){return!this.bHidden&&"EGPD_Output"!=this.Direction}isOutput(){return!this.bHidden&&"EGPD_Output"==this.Direction}isLinked(){return this.LinkedTo?.length>0??!1}linkTo(e,t){const i=this.LinkedTo?.some((i=>i.objectName.toString()==e&&i.pinGuid.valueOf()==t.PinId.valueOf()));return!i&&((this.LinkedTo??=[]).push(new at({objectName:e,pinGuid:t.PinId})),!0)}unlinkFrom(e,t){const i=this.LinkedTo?.findIndex((i=>i.objectName.toString()==e&&i.pinGuid.valueOf()==t.PinId.valueOf()));return i>=0&&(this.LinkedTo.splice(i,1),0===this.LinkedTo.length&&void 0===vt.attributes.LinkedTo.default&&(this.LinkedTo=void 0),!0)}getSubCategory(){return this.PinType.PinSubCategoryObject.path}pinColor(){return function(e){if("mask"==e.PinType.PinCategory){const t=Xe[e.PinType.PinSubCategory];if(t)return t}else if("optional"==e.PinType.PinCategory)return Ze;return Xe[e.getType()]??Xe[e.PinType.PinCategory.toLowerCase()]??Xe.default}(this)}}class yt extends Ve{static attributes={...super.attributes,ScriptVariable:oe.createType(je),OriginalChangeId:oe.createType(Fe)};static grammar=this.createGrammar();static createGrammar(){return $e.createEntityGrammar(this)}constructor(e={},t=!1){super(e,t),this.ScriptVariable,this.OriginalChangeId}}class ft extends vt{static grammar=this.createGrammar();static createGrammar(){return Me.seq(Me.reg(new RegExp(`(${$e.Regex.Symbol.source})\\s*\\(\\s*`),1),$e.createAttributeGrammar(this).sepBy($e.commaSeparation),Me.reg(/\s*(?:,\s*)?\)/)).map((([e,t,i])=>{e??="";let r={};return e.length&&(r.lookbehind=e),t.forEach((e=>e(r))),new this(r)}))}constructor(e={}){super(e,!0)}}class wt extends Ve{static attributes={...super.attributes,MemberScope:oe.createType(String),MemberName:oe.createValue(""),MemberGuid:oe.createType(Fe),bSelfContext:oe.createType(Boolean)};static grammar=this.createGrammar();static createGrammar(){return $e.createEntityGrammar(this)}constructor(e){super(e),this.MemberName,this.GuidEntity,this.bSelfContext}}const St=e=>e.PinName.match(/^\s*([A-Z])\s*$/)?.[1]?.charCodeAt(0)-"A".charCodeAt(0);class Et extends Ve{static attributes={...super.attributes,isExported:new oe({type:Boolean,ignored:!0}),Class:oe.createType(je),Name:oe.createType(String),Archetype:oe.createType(je),ExportPath:oe.createType(je),ObjectRef:oe.createType(je),BlueprintElementType:oe.createType(je),BlueprintElementInstance:oe.createType(je),PinTags:new oe({type:[null],inlined:!0}),PinNames:new oe({type:[String],inlined:!0}),AxisKey:oe.createType(Qe),InputAxisKey:oe.createType(Qe),InputName:oe.createType(String),InputType:oe.createType(Qe),NumAdditionalInputs:oe.createType(Number),bIsPureFunc:oe.createType(Boolean),bIsConstFunc:oe.createType(Boolean),bIsCaseSensitive:oe.createType(Boolean),VariableReference:oe.createType(wt),SelfContextInfo:oe.createType(Qe),DelegatePropertyName:oe.createType(String),DelegateOwnerClass:oe.createType(je),ComponentPropertyName:oe.createType(String),EventReference:oe.createType(We),FunctionReference:oe.createType(We),FunctionScript:oe.createType(je),CustomFunctionName:oe.createType(String),TargetType:oe.createType(je),MacroGraphReference:oe.createType(Ye),Enum:oe.createType(je),EnumEntries:new oe({type:[String],inlined:!0}),InputKey:oe.createType(Qe),OpName:oe.createType(String),CachedChangeId:oe.createType(Fe),FunctionDisplayName:oe.createType(String),AddedPins:new oe({type:[ft],default:()=>[],inlined:!0,silent:!0}),ChangeId:oe.createType(Fe),MaterialFunction:oe.createType(je),bOverrideFunction:oe.createType(Boolean),bInternalEvent:oe.createType(Boolean),bConsumeInput:oe.createType(Boolean),bExecuteWhenPaused:oe.createType(Boolean),bOverrideParentBinding:oe.createType(Boolean),bControl:oe.createType(Boolean),bAlt:oe.createType(Boolean),bShift:oe.createType(Boolean),bCommand:oe.createType(Boolean),CommentColor:oe.createType(He),bCommentBubbleVisible_InDetailsPanel:oe.createType(Boolean),bColorCommentBubble:oe.createType(Boolean),ProxyFactoryFunctionName:oe.createType(String),ProxyFactoryClass:oe.createType(je),ProxyClass:oe.createType(je),StructType:oe.createType(je),MaterialExpression:oe.createType(je),MaterialExpressionComment:oe.createType(je),MoveMode:oe.createType(Qe),TimelineName:oe.createType(String),TimelineGuid:oe.createType(Fe),SizeX:oe.createType(new le(Ke)),SizeY:oe.createType(new le(Ke)),Text:oe.createType(new le(String)),MaterialExpressionEditorX:oe.createType(new le(Ke)),MaterialExpressionEditorY:oe.createType(new le(Ke)),NodeTitle:oe.createType(String),NodeTitleColor:oe.createType(He),PositionX:oe.createType(new le(Ke)),PositionY:oe.createType(new le(Ke)),SettingsInterface:oe.createType(je),PCGNode:oe.createType(je),HiGenGridSize:oe.createType(Qe),Operation:oe.createType(Qe),NodePosX:oe.createType(Ke),NodePosY:oe.createType(Ke),NodeHeight:oe.createType(Ke),NodeWidth:oe.createType(Ke),Graph:oe.createType(je),SubgraphInstance:oe.createType(String),InputPins:new oe({type:[je],inlined:!0}),OutputPins:new oe({type:[je],inlined:!0}),bExposeToLibrary:oe.createType(Boolean),bCanRenameNode:oe.createType(Boolean),bCommentBubblePinned:oe.createType(Boolean),bCommentBubbleVisible:oe.createType(Boolean),NodeComment:oe.createType(String),AdvancedPinDisplay:oe.createType(Ue),DelegateReference:oe.createType(wt),EnabledState:oe.createType(Ue),NodeGuid:oe.createType(Fe),ErrorType:oe.createType(Ke),ErrorMsg:oe.createType(String),ScriptVariables:new oe({type:[yt],inlined:!0}),Node:oe.createType(new le(je)),ExportedNodes:oe.createType(String),CustomProperties:oe.createType([new ce(vt,ft)])};static nameRegex=/^(\w+?)(?:_(\d+))?$/;static customPropertyGrammar=Me.seq(Me.reg(/CustomProperties\s+/),$e.grammarFor(void 0,this.attributes.CustomProperties.type[0])).map((([e,t])=>e=>{e.CustomProperties||(e.CustomProperties=[]),e.CustomProperties.push(t)}));static inlinedArrayEntryGrammar=Me.seq(Me.alt($e.symbolQuoted.map((e=>[e,!0])),$e.symbol.map((e=>[e,!1]))),Me.reg(new RegExp("\\s*\\(\\s*(\\d+)\\s*\\)\\s*\\=\\s*"),1).map(Number)).chain((([[e,t],i])=>$e.grammarFor(this.attributes[e]).map((r=>s=>{(s[e]??=[])[i]=r,ue.objectSet(s,["attributes",e,"quoted"],t),this.attributes[e]?.inlined||(s.attributes||Ve.defineAttributes(s,{}),ue.objectSet(s,["attributes",e,"type"],[r.constructor]),ue.objectSet(s,["attributes",e,"inlined"],!0))}))));static grammar=this.createGrammar();static createSubObjectGrammar(){return Me.lazy((()=>this.grammar)).map((e=>t=>t[ne.subObjectAttributeNameFromEntity(e)]=e))}static createGrammar(){return Me.seq(Me.reg(/Begin +Object/),Me.seq(Me.whitespace,Me.alt(this.createSubObjectGrammar(),this.customPropertyGrammar,$e.createAttributeGrammar(this,Me.reg($e.Regex.MultipleWordsSymbols)),$e.createAttributeGrammar(this,$e.attributeNameQuoted,void 0,((e,t,i)=>ue.objectSet(e,["attributes",...t,"quoted"],!0))),this.inlinedArrayEntryGrammar)).map((([e,t])=>t)).many(),Me.reg(/\s+End +Object/)).map((([e,t,i])=>{const r={};return t.forEach((e=>e(r))),new this(r)}))}static getMultipleObjectsGrammar(){return Me.seq(Me.whitespaceOpt,this.grammar,Me.seq(Me.whitespace,this.grammar).map((([e,t])=>t)).many(),Me.whitespaceOpt).map((([e,t,i,r])=>[t,...i]))}#B;constructor(e={},t=!1){if("NodePosX"in e!="NodePosY"in e){const t=Object.entries(e),[i,r]="NodePosX"in e?["NodePosY",Object.keys(e).indexOf("NodePosX")+1]:["NodePosX",Object.keys(e).indexOf("NodePosY")],s=[i,new(oe.getAttribute(e,i,"type",Et))];t.splice(r,0,s),e=Object.fromEntries(t)}super(e,t),this.R,this.G,this.B,this.A,this.CustomProperties,this.bIsPureFunc,this.isExported,this.ComponentPropertyName,this.EventReference,this.FunctionReference,this.AdvancedPinDisplay,this.EnabledState,this.NodeHeight,this.NodePosX,this.NodePosY,this.NodeWidth,this.CommentColor,this.NodeTitleColor,this.MacroGraphReference,this.MaterialExpressionEditorX,this.MaterialExpressionEditorY,this.SizeX,this.SizeY,this.Text,this.PositionX,this.PositionY,this.Node,this.PinTags,this.NumAdditionalInputs,this.InputPins,this.OutputPins,this.Archetype,this.BlueprintElementInstance,this.BlueprintElementType,this.Class,this.Enum,this.ExportPath,this.FunctionScript,this.Graph,this.MaterialExpression,this.MaterialExpressionComment,this.MaterialFunction,this.ObjectRef,this.PCGNode,this.SettingsInterface,this.StructType,this.TargetType,this.ScriptVariables,this.EnumEntries,this.PinNames,this.CustomFunctionName,this.DelegatePropertyName,this.ExportedNodes,this.FunctionDisplayName,this.InputName,this.Name,this.NodeComment,this.NodeTitle,this.Operation,this.OpName,this.ProxyFactoryFunctionName,this.SubgraphInstance,this.Text,this.AxisKey,this.HiGenGridSize,this.InputAxisKey,this.InputKey,this.InputType,this.AddedPins,this.DelegateReference,this.VariableReference,this.Pins instanceof Array&&this.Pins.forEach((e=>{const t=this[ne.subObjectAttributeNameFromReference(e,!0)];if(t){const e=vt.fromLegacyObject(t);e.LinkedTo=[],this.getCustomproperties(!0).push(e),ue.objectSet(this,["attributes","CustomProperties","ignored"],!0)}}));const i=this.getMaterialSubobject();if(i){const e=i;if(void 0!==e.SizeX&&(e.SizeX.getter=()=>this.NodeWidth),e.SizeY&&(e.SizeY.getter=()=>this.NodeHeight),e.Text&&(e.Text.getter=()=>this.NodeComment),e.MaterialExpressionEditorX&&(e.MaterialExpressionEditorX.getter=()=>this.NodePosX),e.MaterialExpressionEditorY&&(e.MaterialExpressionEditorY.getter=()=>this.NodePosY),this.getType()===ne.paths.materialExpressionComponentMask){const t=ne.rgba.map((e=>this.getPinEntities().find((t=>t.PinName===e&&(t.recomputesNodeTitleOnChange=!0)))));e.R=new le(Boolean,(()=>t[0].DefaultValue)),e.G=new le(Boolean,(()=>t[1].DefaultValue)),e.B=new le(Boolean,(()=>t[2].DefaultValue)),e.A=new le(Boolean,(()=>t[3].DefaultValue)),ue.objectSet(e,["attributes","R","default"],!1),ue.objectSet(e,["attributes","R","silent"],!0),ue.objectSet(e,["attributes","G","default"],!1),ue.objectSet(e,["attributes","G","silent"],!0),ue.objectSet(e,["attributes","B","default"],!1),ue.objectSet(e,["attributes","B","silent"],!0),ue.objectSet(e,["attributes","A","default"],!1),ue.objectSet(e,["attributes","A","silent"],!0),e._keys=[...ne.rgba,...Object.keys(e).filter((e=>!ne.rgba.includes(e)))]}}const r=this.getPcgSubobject();r&&(r.PositionX&&(r.PositionX.getter=()=>this.NodePosX),r.PositionY&&(r.PositionY.getter=()=>this.NodePosY),r.getSubobjects().forEach((e=>{if(void 0!==e.Node){const t=e.Node.get();t.type===this.PCGNode.type&&t.path===`${this.Name}.${this.PCGNode.path}`&&(e.Node.getter=()=>new je({type:this.PCGNode.type,path:`${this.Name}.${this.PCGNode.path}`}))}})));let s=0,n=0;this.CustomProperties?.forEach(((e,t)=>{e.objectEntity=this,e.pinIndex=e.isInput()?s++:e.isOutput()?n++:t}))}getClass(){if(!this.#B&&(this.#B=(this.Class?.path?this.Class.path:this.Class?.type)??(this.ExportPath?.path?this.ExportPath.path:this.ExportPath?.type)??"",this.#B&&!this.#B.startsWith("/"))){let e=Object.values(ne.paths).find((e=>e.endsWith("."+this.#B)));e&&(this.#B=e)}return this.#B}getType(){let e=this.getClass();return this.MacroGraphReference?.MacroGraph?.path?this.MacroGraphReference.MacroGraph.path:this.MaterialExpression?this.MaterialExpression.type:e}getObjectName(e=!1){return e?this.getNameAndCounter()[0]:this.Name}getNameAndCounter(){const e=this.getObjectName().match(Et.nameRegex);return e?[e[1]??"",parseInt(e[2]??"0")]:["",0]}getCounter(){return this.getNameAndCounter()[1]}getNodeWidth(){return this.NodeWidth??this.isComment()?ne.defaultCommentWidth:void 0}setNodeWidth(e){this.NodeWidth||(this.NodeWidth=new Ke),this.NodeWidth.value=e}getNodeHeight(){return this.NodeHeight??this.isComment()?ne.defaultCommentHeight:void 0}setNodeHeight(e){this.NodeHeight||(this.NodeHeight=new Ke),this.NodeHeight.value=e}getNodePosX(){return this.NodePosX?.value??0}setNodePosX(e){this.NodePosX||(this.NodePosX=new Ke),this.NodePosX.value=Math.round(e)}getNodePosY(){return this.NodePosY?.value??0}setNodePosY(e){this.NodePosY||(this.NodePosY=new Ke),this.NodePosY.value=Math.round(e)}getCustomproperties(e=!1){return e&&!this.CustomProperties&&(this.CustomProperties=[]),this.CustomProperties??[]}getPinEntities(){return this.getCustomproperties().filter((e=>e.constructor===vt))}getSubobjects(){return Object.keys(this).filter((e=>e.startsWith(ne.subObjectAttributeNamePrefix))).flatMap((e=>[this[e],...this[e].getSubobjects()]))}switchTarget(){const e=this.getClass().match(ne.switchTargetPattern);if(e)return e[1]}isEvent(){switch(this.getClass()){case ne.paths.actorBoundEvent:case ne.paths.componentBoundEvent:case ne.paths.customEvent:case ne.paths.event:case ne.paths.inputAxisKeyEvent:case ne.paths.inputVectorAxisEvent:return!0}return!1}isComment(){switch(this.getClass()){case ne.paths.comment:case ne.paths.materialGraphNodeComment:return!0}return!1}isMaterial(){return this.getClass()===ne.paths.materialGraphNode}getMaterialSubobject(){const e=this.MaterialExpression??this.MaterialExpressionComment;return e?this[ne.subObjectAttributeNameFromReference(e,!0)]:null}isPcg(){return this.getClass()===ne.paths.pcgEditorGraphNode||this.getPcgSubobject()}isNiagara(){return this.Class&&(this.Class.type?this.Class.type:this.Class.path)?.startsWith("/Script/NiagaraEditor.")}getPcgSubobject(){const e=this.PCGNode;return e?this[ne.subObjectAttributeNameFromReference(e,!0)]:null}getSettingsObject(){const e=this.SettingsInterface;return e?this[ne.subObjectAttributeNameFromReference(e,!0)]:null}getSubgraphObject(){const e=this.SubgraphInstance;return e?this[ne.subObjectAttributeNameFromName(e)]:null}isDevelopmentOnly(){const e=this.getClass();return"DevelopmentOnly"===this.EnabledState?.toString()||e.includes("Debug",Math.max(0,e.lastIndexOf(".")))}getHIDAttribute(){return this.InputKey??this.AxisKey??this.InputAxisKey}getDelegatePin(){return this.getCustomproperties().find((e=>"delegate"===e.PinType.PinCategory))}nodeColor(){return function(e){switch(e.getType()){case ne.paths.materialExpressionConstant2Vector:case ne.paths.materialExpressionConstant3Vector:case ne.paths.materialExpressionConstant4Vector:return ne.nodeColors.yellow;case ne.paths.makeStruct:return ne.nodeColors.darkBlue;case ne.paths.materialExpressionMaterialFunctionCall:return ne.nodeColors.blue;case ne.paths.materialExpressionFunctionInput:return ne.nodeColors.red;case ne.paths.materialExpressionTextureSample:return ne.nodeColors.darkTurquoise;case ne.paths.materialExpressionTextureCoordinate:case ne.paths.pcgEditorGraphNodeInput:case ne.paths.pcgEditorGraphNodeOutput:return ne.nodeColors.red}switch(e.getClass()){case ne.paths.callFunction:return e.bIsPureFunc?ne.nodeColors.green:ne.nodeColors.blue;case ne.paths.niagaraNodeFunctionCall:return ne.nodeColors.darkerBlue;case ne.paths.dynamicCast:return ne.nodeColors.turquoise;case ne.paths.inputDebugKey:case ne.paths.inputKey:return ne.nodeColors.red;case ne.paths.createDelegate:case ne.paths.enumLiteral:case ne.paths.makeArray:case ne.paths.makeMap:case ne.paths.materialGraphNode:case ne.paths.select:return ne.nodeColors.green;case ne.paths.executionSequence:case ne.paths.ifThenElse:case ne.paths.macro:case ne.paths.multiGate:return ne.nodeColors.gray;case ne.paths.functionEntry:case ne.paths.functionResult:return ne.nodeColors.violet;case ne.paths.timeline:return ne.nodeColors.yellow}if(e.switchTarget())return ne.nodeColors.lime;if(e.isEvent())return ne.nodeColors.red;if(e.isComment())return(e.CommentColor?e.CommentColor:He.getWhite()).toDimmedColor().toCSSRGBValues();const t=e.getPcgSubobject();if(t){if(t.NodeTitleColor)return t.NodeTitleColor.toDimmedColor(.1).toCSSRGBValues();switch(e.PCGNode?.getName(!0)){case"Branch":case"Select":return ne.nodeColors.intenseGreen}}return e.bIsPureFunc?ne.nodeColors.green:ne.nodeColors.blue}(this)}nodeIcon(){return function(e){if(e.isMaterial()||e.isPcg()||e.isNiagara())return null;switch(e.getType()){case ne.paths.addDelegate:case ne.paths.asyncAction:case ne.paths.callDelegate:case ne.paths.createDelegate:case ne.paths.functionEntry:case ne.paths.functionResult:return De.node;case ne.paths.customEvent:return De.event;case ne.paths.doN:return De.doN;case ne.paths.doOnce:return De.doOnce;case ne.paths.dynamicCast:return De.cast;case ne.paths.enumLiteral:return De.enum;case ne.paths.event:return De.event;case ne.paths.executionSequence:case ne.paths.multiGate:return De.sequence;case ne.paths.flipflop:return De.flipflop;case ne.paths.forEachElementInEnum:case ne.paths.forLoop:case ne.paths.forLoopWithBreak:case ne.paths.whileLoop:return De.loop;case ne.paths.forEachLoop:case ne.paths.forEachLoopWithBreak:return De.forEachLoop;case ne.paths.ifThenElse:return De.branchNode;case ne.paths.isValid:return De.questionMark;case ne.paths.makeArray:return De.makeArray;case ne.paths.makeMap:return De.makeMap;case ne.paths.makeSet:return De.makeSet;case ne.paths.makeStruct:return De.makeStruct;case ne.paths.metasoundEditorGraphExternalNode:return De.metasoundFunction;case ne.paths.select:return De.select;case ne.paths.spawnActorFromClass:return De.spawnActor;case ne.paths.timeline:return De.timer}if(e.switchTarget())return De.switch;if(ze(e).startsWith("Break"))return De.breakStruct;if(e.getClass()===ne.paths.macro)return De.macro;const t=e.getHIDAttribute()?.toString();return t?t.includes("Mouse")?De.mouse:t.includes("Gamepad_Special")?De.keyboard:t.includes("Gamepad")||t.includes("Steam")?De.gamepad:t.includes("Touch")?De.touchpad:De.keyboard:e.getDelegatePin()?De.event:e.ObjectRef?.type===ne.paths.ambientSound?De.sound:De.functionSymbol}(this)}additionalPinInserter(){return function(e){let t,i,r,s;switch(e.getType()){case ne.paths.commutativeAssociativeBinaryOperator:case ne.paths.promotableOperator:switch(s=e.FunctionReference?.MemberName,s){default:if(!(s?.startsWith("Add_")||s?.startsWith("Subtract_")||s?.startsWith("Multiply_")||s?.startsWith("Divide_")))break;case"And_Int64Int64":case"And_IntInt":case"BMax":case"BMin":case"BooleanAND":case"BooleanNAND":case"BooleanOR":case"Concat_StrStr":case"FMax":case"FMin":case"Max":case"MaxInt64":case"Min":case"MinInt64":case"Or_Int64Int64":case"Or_IntInt":t??=()=>e.getPinEntities().filter((e=>e.isInput())),i??=St,r??=(i,r=-1,s=-1)=>{const n=String.fromCharCode(i>=0?i:s+"A".charCodeAt(0)+1);return e.NumAdditionalInputs=t().length-1,n}}break;case ne.paths.multiGate:t??=()=>e.getPinEntities().filter((e=>e.isOutput())),i??=e=>Number(e.PinName.match(/^\s*Out[_\s]+(\d+)\s*$/i)?.[1]),r??=(e,t=-1,i=-1,r)=>`Out ${e>=0?e:t>0?"Out 0":i+1}`;break;case ne.paths.switchInteger:t??=()=>e.getPinEntities().filter((e=>e.isOutput())),i??=e=>Number(e.PinName.match(/^\s*(\d+)\s*$/)?.[1]),r??=(e,t=-1,i=-1,r)=>(e<0?i+1:e).toString();break;case ne.paths.switchGameplayTag:r??=(t,i=-1,r=-1,s)=>{const n=`Case_${t>=0?t:i>0?"0":r+1}`;return e.PinNames??=[],e.PinNames.push(n),delete e.PinTags[e.PinTags.length-1],e.PinTags[e.PinTags.length]=null,n};case ne.paths.switchName:case ne.paths.switchString:t??=()=>e.getPinEntities().filter((e=>e.isOutput())),i??=e=>Number(e.PinName.match(/^\s*Case[_\s]+(\d+)\s*$/i)?.[1]),r??=(t,i=-1,r=-1,s)=>{const n=`Case_${t>=0?t:i>0?"0":r+1}`;return e.PinNames??=[],e.PinNames.push(n),n}}if(t)return()=>{let s=Number.MAX_SAFE_INTEGER,n=Number.MIN_SAFE_INTEGER,a=[];const o=t().reduce(((e,t)=>{const r=i(t);if(isNaN(r)){if(void 0===e)return t}else if(a.push(r),s=Math.min(r,s),r>n)return n=r,t;return e}),void 0);if(s!==Number.MAX_SAFE_INTEGER&&n!==Number.MIN_SAFE_INTEGER||(s=void 0,n=void 0),!o)return null;a.sort(((e,t)=>e{const t=e-l>1;return l=e,t}));const u=new vt(o);return u.PinId=Fe.generateGuid(),u.PinName=r(c,s,n,u),u.PinToolTip=void 0,e.getCustomproperties(!0).push(u),u}}(this)}}class Ct extends Et{constructor(e={},t=void 0){e.Class=new je(ne.paths.knot),e.Name="K2Node_Knot";const i=new vt({PinName:"InputPin"},!0),r=new vt({PinName:"OutputPin",Direction:"EGPD_Output"},!0);t&&(i.copyTypeFrom(t),r.copyTypeFrom(t)),e.CustomProperties=[i,r],super(e,!0)}}class Nt{#V;get target(){return this.#V}#r;get blueprint(){return this.#r}consumeEvent;options;listenHandler=()=>this.listenEvents();unlistenHandler=()=>this.unlistenEvents();constructor(e,t,i={}){i.consumeEvent??=!1,i.listenOnFocus??=!1,i.unlistenOnTextEdit??=!1,this.#V=e,this.#r=t,this.consumeEvent=i.consumeEvent,this.options=i}setup(){this.options.listenOnFocus&&(this.blueprint.addEventListener(ne.focusEventName.begin,this.listenHandler),this.blueprint.addEventListener(ne.focusEventName.end,this.unlistenHandler)),this.options.unlistenOnTextEdit&&(this.blueprint.addEventListener(ne.editTextEventName.begin,this.unlistenHandler),this.blueprint.addEventListener(ne.editTextEventName.end,this.listenHandler)),this.blueprint.focused&&this.listenEvents()}cleanup(){this.unlistenEvents(),this.blueprint.removeEventListener(ne.focusEventName.begin,this.listenHandler),this.blueprint.removeEventListener(ne.focusEventName.end,this.unlistenHandler),this.blueprint.removeEventListener(ne.editTextEventName.begin,this.unlistenHandler),this.blueprint.removeEventListener(ne.editTextEventName.end,this.listenHandler)}listenEvents(){}unlistenEvents(){}}class xt extends Ve{static attributes={...super.attributes,ActionName:oe.createValue(""),bShift:oe.createValue(!1),bCtrl:oe.createValue(!1),bAlt:oe.createValue(!1),bCmd:oe.createValue(!1),Key:oe.createType(Ue)};static grammar=this.createGrammar();static createGrammar(){return Me.alt(Ue.grammar.map((e=>new this({Key:e}))),$e.createEntityGrammar(this))}constructor(e={}){super(e,!0),this.ActionName,this.bShift,this.bCtrl,this.bAlt,this.bCmd,this.Key}}class Pt extends Nt{static#$=e=>{};#O;pressedKey="";constructor(e,t,i={},r=Pt.#$,s=Pt.#$){i.activationKeys??=[],i.consumeEvent??=!0,i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,i.activationKeys instanceof Array||(i.activationKeys=[i.activationKeys]),i.activationKeys=i.activationKeys.map((e=>{if(e instanceof xt)return e;if(e.constructor===String){const t=xt.grammar.run(e);if(t.status)return t.value}throw new Error("Unexpected key value")})),super(e,t,i),this.onKeyDown=r,this.onKeyUp=s,this.#O=this.options.activationKeys??[];let n=this;this.keyDownHandler=e=>{n.#O.some((t=>(e=>e.bShift||"LeftShift"==e.Key||"RightShift"==e.Key)(t)==e.shiftKey&&(e=>e.bCtrl||"LeftControl"==e.Key||"RightControl"==e.Key)(t)==e.ctrlKey&&(e=>e.bAlt||"LeftAlt"==e.Key||"RightAlt"==e.Key)(t)==e.altKey&&ne.Keys[t.Key.value]==e.code))&&(this.consumeEvent&&(e.preventDefault(),e.stopImmediatePropagation()),this.pressedKey=e.code,n.fire(),document.removeEventListener("keydown",n.keyDownHandler),document.addEventListener("keyup",n.keyUpHandler))},this.keyUpHandler=e=>{n.#O.some((t=>t.bShift&&"Shift"==e.key||t.bCtrl&&"Control"==e.key||t.bAlt&&"Alt"==e.key||t.bCmd&&"Meta"==e.key||ne.Keys[t.Key.value]==e.code))&&(this.consumeEvent&&e.stopImmediatePropagation(),n.unfire(),this.pressedKey="",document.removeEventListener("keyup",this.keyUpHandler),document.addEventListener("keydown",this.keyDownHandler))}}listenEvents(){document.addEventListener("keydown",this.keyDownHandler)}unlistenEvents(){document.removeEventListener("keydown",this.keyDownHandler)}fire(){this.onKeyDown(this)}unfire(){this.onKeyUp(this)}}class kt extends Nt{#H=[0,0];get location(){return this.#H}#D;get enablerKey(){return this.#D}#G=!0;get enablerActivated(){return this.#G}constructor(e,t,i={}){i.ignoreTranslateCompensate??=!1,i.ignoreScale??=!1,i.movementSpace??=t.getGridDOMElement()??document.documentElement,super(e,t,i),this.movementSpace=i.movementSpace,i.enablerKey&&(this.#D=i.enablerKey,this.#D.onKeyDown=()=>this.#G=!0,this.#D.onKeyUp=()=>this.#G=!1,this.#D.consumeEvent=!1,this.#D.listenEvents(),this.#G=!1)}setLocationFromEvent(e){let t=ue.convertLocation([e.clientX,e.clientY],this.movementSpace,this.options.ignoreScale);return t=this.options.ignoreTranslateCompensate?t:this.blueprint.compensateTranslation(t[0],t[1]),this.#H=[...t],this.#H}}class Tt extends kt{static#$=e=>{};#R=e=>{if(this.blueprint.setFocused(!0),!this.enablerKey||this.enablerActivated)if(e.button===this.options.clickButton)this.options.strictTarget&&e.target!==e.currentTarget||(this.consumeEvent&&e.stopImmediatePropagation(),document.addEventListener("mouseup",this.#z),this.setLocationFromEvent(e),this.clickedPosition[0]=this.location[0],this.clickedPosition[1]=this.location[1],this.blueprint.mousePosition[0]=this.location[0],this.blueprint.mousePosition[1]=this.location[1],this.clicked(this.clickedPosition));else this.options.exitAnyButton||this.#z(e)};#z=e=>{this.options.exitAnyButton&&e.button!=this.options.clickButton||(this.consumeEvent&&e.stopImmediatePropagation(),document.removeEventListener("mouseup",this.#z),this.unclicked())};clickedPosition=[0,0];constructor(e,t,i={},r=Tt.#$,s=Tt.#$){i.clickButton??=ne.mouseClickButton,i.consumeEvent??=!0,i.exitAnyButton??=!0,i.strictTarget??=!1,super(e,t,i),this.onClick=r,this.onUnclick=s,this.listenEvents()}listenEvents(){this.target.addEventListener("mousedown",this.#R),this.options.clickButton===ne.mouseRightClickButton&&this.target.addEventListener("contextmenu",(e=>e.preventDefault()))}unlistenEvents(){this.target.removeEventListener("mousedown",this.#R)}clicked(e){this.onClick(this)}unclicked(e){this.onUnclick(this)}}class At extends kt{static ignoreDbClick=e=>{};#_=e=>{this.options.strictTarget&&e.target!==e.currentTarget||(this.consumeEvent&&e.stopImmediatePropagation(),this.clickedPosition=this.setLocationFromEvent(e),this.blueprint.mousePosition=[...this.clickedPosition],this.dbclicked(this.clickedPosition))};#F;get onDbClick(){return this.#F}set onDbClick(e){this.#F=e}clickedPosition=[0,0];constructor(e,t,i={},r=At.ignoreDbClick){i.consumeEvent??=!0,i.strictTarget??=!1,super(e,t,i),this.#F=r,this.listenEvents()}listenEvents(){this.target.addEventListener("dblclick",this.#_)}unlistenEvents(){this.target.removeEventListener("dblclick",this.#_)}dbclicked(e){this.onDbClick(e)}}class Lt{element;get blueprint(){return this.element.blueprint}#j=[];get inputObjects(){return this.#j}initialize(e){this.element=e}createInputObjects(){return[]}setup(){this.#j.forEach((e=>e.setup()))}cleanup(){this.#j.forEach((e=>e.cleanup()))}willUpdate(e){}update(e){}render(){return H``}firstUpdated(e){}updated(e){}inputSetup(){this.#j=this.createInputObjects()}}class Mt extends Lt{update(e){super.update(e);const[t,i,r,s]=[Math.round(this.element.fromX),Math.round(this.element.fromY),Math.round(this.element.toX),Math.round(this.element.toY)],[n,a,o,l]=[Math.min(t,r),Math.min(i,s),Math.abs(t-r),Math.abs(i-s)];(e.has("fromX")||e.has("toX"))&&(this.element.style.left=`${n}px`,this.element.style.width=`${o}px`),(e.has("fromY")||e.has("toY"))&&(this.element.style.top=`${a}px`,this.element.style.height=`${l}px`)}}class It extends Mt{static decreasingValue(e,t){const i=-e*t[0]**2,r=t[1]-i/t[0];return e=>i/e+r}static clampedLine(e,t){if(e[0]>t[0]){const i=e;e=t,t=i}const i=(t[1]-e[1])/(t[0]-e[0]),r=e[1]-i*e[0];return s=>st[0]?t[1]:i*s+r}static c1DecreasingValue=It.decreasingValue(-.15,[100,15]);static c2DecreasingValue=It.decreasingValue(-.05,[500,130]);static c2Clamped=It.clampedLine([0,80],[200,40]);#W=`ueb-id-${Math.floor(1e12*Math.random())}`;#U=e=>{const t=new Ct({},this.element.source.entity),i=me.getConstructor("ueb-node").newObject(t);i.setLocation(...this.blueprint.snapToGrid(...e));const r=i.template;this.blueprint.addGraphElement(i);const s=this.element.getInputPin(),n=this.element.getOutputPin();this.element.source=null,this.element.destination=null;const a=me.getConstructor("ueb-link").newObject(n,r.inputPin);this.blueprint.addGraphElement(a),this.element.source=r.outputPin,this.element.destination=s};createInputObjects(){const e=this.element.querySelector(".ueb-link-area");return[...super.createInputObjects(),new At(e,this.blueprint,void 0,(e=>{e[0]+=ne.knotOffset[0],e[1]+=ne.knotOffset[1],e=ue.snapToGrid(e[0],e[1],ne.gridSize),this.#U(e)})),new Tt(e,this.blueprint,{enablerKey:new Pt(this.blueprint,this.blueprint,{activationKeys:de.enableLinkDelete})},(()=>this.blueprint.removeGraphElement(this.element)))]}willUpdate(e){super.willUpdate(e);const t=this.element.source,i=this.element.destination;if(e.has("fromX")||e.has("toX")){const e=this.element.fromX,r=this.element.toX,s=t?.nodeElement.getType()==ne.paths.knot,n=i?.nodeElement.getType()==ne.paths.knot;!s||i&&!n||(t?.isInput()&&r>e+ne.distanceThreshold?this.element.source=t.nodeElement.template.outputPin:t?.isOutput()&&re+ne.distanceThreshold&&(this.element.destination=i.nodeElement.template.inputPin))}const r=Math.max(Math.abs(this.element.fromX-this.element.toX),1),s=Math.max(Math.abs(this.element.fromY-this.element.toY),1),n=Math.max(r,ne.linkMinWidth),a=r/n,o=this.element.originatesFromInput?this.element.fromXthis.element.toY?1:0)),this.element.style.setProperty("--ueb-start-percentage",`${Math.round(this.element.startPercentage)}%`),this.element.style.setProperty("--ueb-link-start",`${Math.round(this.element.startPixels)}`)}render(){return H` ${this.element.linkMessageIcon||this.element.linkMessageText?H``:G}`}}class Bt extends pe{static properties={...super.properties,dragging:{type:Boolean,attribute:"data-dragging",converter:ue.booleanConverter,reflect:!0},originatesFromInput:{type:Boolean,attribute:!1},svgPathD:{type:String,attribute:!1},linkMessageIcon:{type:String,attribute:!1},linkMessageText:{type:String,attribute:!1}};#K;get source(){return this.#K}set source(e){this.#Y(e,!1)}#X;get destination(){return this.#X}set destination(e){this.#Y(e,!0)}#Z=()=>this.remove();#q=e=>this.addSourceLocation(...e.detail.value);#Q=e=>this.addDestinationLocation(...e.detail.value);#J=e=>this.setSourceLocation();#ee=e=>this.setDestinationLocation();linkMessageIcon=G;linkMessageText=G;pathElement;constructor(){super(),this.dragging=!1,this.originatesFromInput=!1,this.startPercentage=0,this.svgPathD="",this.startPixels=0}static newObject(e,t){const i=new Bt;return i.initialize(e,t),i}initialize(e,t){super.initialize({},new It),e&&(this.source=e,t||(this.toX=this.fromX,this.toY=this.fromY)),t&&(this.destination=t,e||(this.fromX=this.toX,this.fromY=this.toY))}#Y(e,t){const i=()=>t?this.destination:this.source;if(i()!=e){if(i()){const e=i().getNodeElement();e.removeEventListener(ne.removeEventName,this.#Z),e.removeEventListener(ne.nodeDragEventName,t?this.#Q:this.#q),e.removeEventListener(ne.nodeReflowEventName,t?this.#ee:this.#J),this.#te()}if(t?this.#X=e:this.#K=e,i()){const e=i().getNodeElement();e.addEventListener(ne.removeEventName,this.#Z),e.addEventListener(ne.nodeDragEventName,t?this.#Q:this.#q),e.addEventListener(ne.nodeReflowEventName,t?this.#ee:this.#J),t?this.setDestinationLocation():(this.setSourceLocation(),this.originatesFromInput=this.source.isInput()),this.#ie()}}}#ie(){this.source&&this.destination&&(this.source.linkTo(this.destination),this.destination.linkTo(this.source))}#te(){this.source&&this.destination&&(this.source.unlinkFrom(this.destination,!1),this.destination.unlinkFrom(this.source,!1))}cleanup(){super.cleanup(),this.#te(),this.source=null,this.destination=null}setSourceLocation(e=null,t=!0){if(null==e){const i=this;if(t&&(!this.hasUpdated||!this.source.hasUpdated))return void Promise.all([this.updateComplete,this.source.updateComplete]).then((()=>i.setSourceLocation(null,!1)));e=this.source.template.getLinkLocation()}const[i,r]=e;this.fromX=i,this.fromY=r}setDestinationLocation(e=null,t=!0){if(null==e){const i=this;if(t&&(!this.hasUpdated||!this.destination.hasUpdated))return void Promise.all([this.updateComplete,this.destination.updateComplete]).then((()=>i.setDestinationLocation(null,!1)));e=this.destination.template.getLinkLocation()}this.toX=e[0],this.toY=e[1]}getInputPin(){return this.source?.isInput()?this.source:this.destination}setInputPin(e){this.source?.isInput()&&(this.source=e),this.destination=e}getOutputPin(){return this.destination?.isOutput()?this.destination:this.source}setOutputPin(e){this.destination?.isOutput()&&(this.destination=e),this.source=e}startDragging(){this.dragging=!0}finishDragging(){this.dragging=!1}removeMessage(){this.linkMessageIcon=G,this.linkMessageText=G}setMessageConvertType(){this.linkMessageIcon=De.convert,this.linkMessageText=H`Convert ${this.source.pinType} to ${this.destination.pinType}.`}setMessageCorrect(){this.linkMessageIcon=De.correct,this.linkMessageText=G}setMessageReplace(){this.linkMessageIcon=De.correct,this.linkMessageText=G}setMessageDirectionsIncompatible(){this.linkMessageIcon=De.reject,this.linkMessageText=H`Directions are not compatbile.`}setMessagePlaceNode(){this.linkMessageIcon=G,this.linkMessageText=H`Place a new node.`}setMessageReplaceLink(){this.linkMessageIcon=De.correct,this.linkMessageText=H`Replace existing input connections.`}setMessageReplaceOutputLink(){this.linkMessageIcon=De.correct,this.linkMessageText=H`Replace existing output connections.`}setMessageSameNode(){this.linkMessageIcon=De.reject,this.linkMessageText=H`Both are on the same node.`}setMessageTypesIncompatible(e,t){this.linkMessageIcon=De.reject,this.linkMessageText=H`${ue.capitalFirstLetter(e.pinType)} is not compatible with ${ue.capitalFirstLetter(t.pinType)}.`}}class Vt extends he{static properties={...super.properties,locationX:{type:Number,attribute:!1},locationY:{type:Number,attribute:!1},sizeX:{type:Number,attribute:!1},sizeY:{type:Number,attribute:!1}};static dragEventName=ne.dragEventName;static dragGeneralEventName=ne.dragGeneralEventName;constructor(){super(),this.locationX=0,this.locationY=0,this.sizeX=0,this.sizeY=0}computeSizes(){const e=this.getBoundingClientRect();this.sizeX=this.blueprint.scaleCorrect(e.width),this.sizeY=this.blueprint.scaleCorrect(e.height)}firstUpdated(e){super.firstUpdated(e),this.computeSizes()}setLocation(e,t,i=!0){const r=e-this.locationX,s=t-this.locationY;if(this.locationX=e,this.locationY=t,this.blueprint&&i){const e=new CustomEvent(this.constructor.dragEventName,{detail:{value:[r,s]},bubbles:!1,cancelable:!0});this.dispatchEvent(e)}}addLocation(e,t,i=!0){this.setLocation(this.locationX+e,this.locationY+t,i)}acknowledgeDrag(e){const t=new CustomEvent(this.constructor.dragGeneralEventName,{detail:{value:e},bubbles:!0,cancelable:!0});this.dispatchEvent(t)}snapToGrid(){const e=ue.snapToGrid(this.locationX,this.locationY,ne.gridSize);this.locationX==e[0]&&this.locationY==e[1]||this.setLocation(e[0],e[1])}topBoundary(e=!1){return this.template.topBoundary(e)}rightBoundary(e=!1){return this.template.rightBoundary(e)}bottomBoundary(e=!1){return this.template.bottomBoundary(e)}leftBoundary(e=!1){return this.template.leftBoundary(e)}}class $t extends kt{#R=e=>{if(this.blueprint.setFocused(!0),e.button===this.options.clickButton)this.options.strictTarget&&e.target!=e.currentTarget||(this.consumeEvent&&e.stopImmediatePropagation(),this.#re.addEventListener("mousemove",this.#se),document.addEventListener("mouseup",this.#z),this.setLocationFromEvent(e),this.clickedPosition[0]=this.location[0],this.clickedPosition[1]=this.location[1],this.blueprint.mousePosition[0]=this.location[0],this.blueprint.mousePosition[1]=this.location[1],this.target instanceof Vt&&(this.clickedOffset=[this.clickedPosition[0]-this.target.locationX,this.clickedPosition[1]-this.target.locationY]),this.clicked(this.clickedPosition));else this.options.exitAnyButton||this.#z(e)};#se=e=>{this.consumeEvent&&e.stopImmediatePropagation(),this.#re.removeEventListener("mousemove",this.#se),this.#re.addEventListener("mousemove",this.#ne);const t=this.getEvent(ne.trackingMouseEventName.begin);this.#ae=0==this.target.dispatchEvent(t),this.setLocationFromEvent(e),this.lastLocation=ue.snapToGrid(this.clickedPosition[0],this.clickedPosition[1],this.stepSize),this.startDrag(this.location),this.started=!0,this.#ne(e)};#ne=e=>{this.consumeEvent&&e.stopImmediatePropagation();const t=this.setLocationFromEvent(e),i=[e.movementX,e.movementY];if(this.dragTo(t,i),this.#ae&&(this.blueprint.mousePosition=t),this.options.scrollGraphEdge){const e=Math.sqrt(i[0]*i[0]+i[1]*i[1]),r=this.blueprint.scaleCorrect(ne.edgeScrollThreshold),s=this.blueprint.template.gridLeftVisibilityBoundary()+r,n=this.blueprint.template.gridRightVisibilityBoundary()-r;let a=0;t[0]n&&(a=t[0]-n);const o=this.blueprint.template.gridTopVisibilityBoundary()+r,l=this.blueprint.template.gridBottomVisibilityBoundary()-r;let c=0;t[1]l&&(c=t[1]-l),a=ue.clamp(this.blueprint.scaleCorrectReverse(a)**3*e*.6,-20,20),c=ue.clamp(this.blueprint.scaleCorrectReverse(c)**3*e*.6,-20,20),this.blueprint.scrollDelta(a,c)}};#z=e=>{if(!this.options.exitAnyButton||e.button==this.options.clickButton){if(this.consumeEvent&&e.stopImmediatePropagation(),this.#re.removeEventListener("mousemove",this.#se),this.#re.removeEventListener("mousemove",this.#ne),document.removeEventListener("mouseup",this.#z),this.started&&this.endDrag(),this.unclicked(),this.#ae){const e=this.getEvent(ne.trackingMouseEventName.end);this.target.dispatchEvent(e),this.#ae=!1}this.started=!1}};#ae=!1;#re;#oe;get draggableElement(){return this.#oe}clickedOffset=[0,0];clickedPosition=[0,0];lastLocation=[0,0];started=!1;stepSize=1;constructor(e,t,i={}){i.clickButton??=ne.mouseClickButton,i.consumeEvent??=!0,i.draggableElement??=e,i.exitAnyButton??=!0,i.moveEverywhere??=!1,i.movementSpace??=t?.getGridDOMElement(),i.repositionOnClick??=!1,i.scrollGraphEdge??=!1,i.strictTarget??=!1,super(e,t,i),this.stepSize=Number(i.stepSize??ne.gridSize),this.#re=this.options.moveEverywhere?document.documentElement:this.movementSpace,this.#oe=this.options.draggableElement,this.listenEvents()}listenEvents(){super.listenEvents(),this.#oe.addEventListener("mousedown",this.#R),this.options.clickButton===ne.mouseRightClickButton&&this.#oe.addEventListener("contextmenu",(e=>e.preventDefault()))}unlistenEvents(){super.unlistenEvents(),this.#oe.removeEventListener("mousedown",this.#R)}getEvent(e){return new CustomEvent(e,{detail:{tracker:this},bubbles:!0,cancelable:!0})}clicked(e){}startDrag(e){}dragTo(e,t){}endDrag(){}unclicked(e){}}class Ot extends $t{clicked(e){this.options.repositionOnClick&&(this.target.setLocation(...this.stepSize>1?ue.snapToGrid(e[0],e[1],this.stepSize):e),this.clickedOffset=[0,0])}dragTo(e,t){const i=[this.target.locationX??this.lastLocation[0],this.target.locationY??this.lastLocation[1]],[r,s]=this.stepSize>1?[ue.snapToGrid(e[0],e[1],this.stepSize),ue.snapToGrid(i[0],i[1],this.stepSize)]:[e,i];0==(t=[r[0]-this.lastLocation[0],r[1]-this.lastLocation[1]])[0]&&0==t[1]||(t[0]+=s[0]-i[0],t[1]+=s[1]-i[1],this.dragAction(r,t),this.lastLocation=r)}dragAction(e,t){this.target.setLocation(e[0]-this.clickedOffset[0],e[1]-this.clickedOffset[1])}}class Ht extends Ot{#le;#ce;#ue;#he;constructor(e,t,i={}){super(e,t,i),i.onClicked&&(this.#le=i.onClicked),i.onStartDrag&&(this.#ce=i.onStartDrag),i.onDrag&&(this.#ue=i.onDrag),i.onEndDrag&&(this.#he=i.onEndDrag)}clicked(e){super.clicked(e),this.#le?.()}startDrag(){super.startDrag(),this.#ce?.()}dragAction(e,t){this.#ue?.(e,t)}endDrag(){super.endDrag(),this.#he?.()}}class Dt extends Ot{constructor(e,t,i={}){super(e,t,i),this.draggableElement.classList.add("ueb-draggable")}startDrag(){this.target.selected||(this.blueprint.unselectAll(),this.target.setSelected(!0))}dragAction(e,t){this.target.acknowledgeDrag(t)}unclicked(){this.started?(this.blueprint.getNodes(!0).forEach((e=>e.boundComments.filter((t=>!e.isInsideComment(t))).forEach((t=>e.unbindFromComment(t))))),this.blueprint.getCommentNodes().forEach((e=>e.template.manageNodesBind()))):(this.blueprint.unselectAll(),this.target.setSelected(!0))}}class Gt extends Lt{getDraggableElement(){return this.element}createDraggableObject(){const e=this.getDraggableElement();return new Ot(this.element,this.blueprint,{draggableElement:e})}createInputObjects(){return[...super.createInputObjects(),this.createDraggableObject(),new Pt(this.element,this.blueprint,{activationKeys:[ne.Keys.ArrowUp,ne.Keys.ArrowRight,ne.Keys.ArrowDown,ne.Keys.ArrowLeft]},(e=>e.target.acknowledgeDrag([e.pressedKey===ne.Keys.ArrowLeft?-ne.gridSize:e.pressedKey===ne.Keys.ArrowRight?ne.gridSize:0,e.pressedKey===ne.Keys.ArrowUp?-ne.gridSize:e.pressedKey===ne.Keys.ArrowDown?ne.gridSize:0])))]}topBoundary(e=!1){return this.element.locationY}rightBoundary(e=!1){return this.element.locationX+this.element.sizeX}bottomBoundary(e=!1){return this.element.locationY+this.element.sizeY}leftBoundary(e=!1){return this.element.locationX}centerInViewport(){const e=Math.min(this.blueprint.template.viewportSize[0]/10,this.blueprint.template.viewportSize[1]/10),t=this.leftBoundary()-this.blueprint.template.gridLeftVisibilityBoundary(),i=this.blueprint.template.gridRightVisibilityBoundary()-this.rightBoundary();let r=Math.max((t+i)/2,e);const s=this.topBoundary()-this.blueprint.template.gridTopVisibilityBoundary(),n=this.blueprint.template.gridBottomVisibilityBoundary()-this.bottomBoundary();let a=Math.max((s+n)/2,e);this.blueprint.scrollDelta(t-r,s-a,!0)}}class Rt extends Gt{update(e){super.update(e),e.has("locationX")&&(this.element.style.left=`${this.element.locationX}px`),e.has("locationY")&&(this.element.style.top=`${this.element.locationY}px`)}}class zt extends Rt{getDraggableElement(){return this.element}createDraggableObject(){return new Dt(this.element,this.blueprint,{draggableElement:this.getDraggableElement(),scrollGraphEdge:!0})}firstUpdated(e){super.firstUpdated(e),this.element.selected&&!this.element.listeningDrag&&this.element.setSelected(!0)}}class _t extends zt{static nodeStyleClasses=["ueb-node-style-default"];#pe=!1;pinInserter;inputContainer;outputContainer;pinElement;addPinHandler=()=>{const e=this.pinInserter?.();e&&(this.defaultPin&&this.defaultPin.isInput()===e.isInput()?this.defaultPin.before(this.createPinElement(e)):(e.isInput()?this.inputContainer:this.outputContainer).appendChild(this.createPinElement(e)),this.element.acknowledgeReflow())};toggleAdvancedDisplayHandler=()=>{this.element.toggleShowAdvancedPinDisplay(),this.element.requestUpdate(),this.element.updateComplete.then((()=>this.element.acknowledgeReflow()))};createPinElement(e){const t=me.getConstructor("ueb-pin").newObject(e,void 0,this.element);return this.pinInserter&&!this.defaultPin&&"Default"===t.getPinName()&&(this.defaultPin=t,this.defaultPin.classList.add("ueb-node-variadic-default")),t}initialize(e){super.initialize(e),this.element.classList.add(...this.constructor.nodeStyleClasses),this.element.style.setProperty("--ueb-node-color",this.getColor().cssText),this.pinInserter=this.element.entity.additionalPinInserter(),this.pinInserter&&this.element.classList.add("ueb-node-is-variadic")}getColor(){return this.element.entity.nodeColor()}render(){return H`
${this.renderTop()}
${this.pinInserter?H`
Add pin ${De.plusCircle}
`:G} ${this.element.entity.isDevelopmentOnly()?H`
Development Only
`:G} ${this.element.advancedPinDisplay?H`
${De.expandIcon}
`:G}
`}renderNodeIcon(){return this.element.entity.nodeIcon()}renderNodeName(){return this.element.nodeDisplayName}renderTop(){const e=this.renderNodeIcon(),t=this.renderNodeName();return H`
${e?H`
${e}
`:G} ${t?H`
${t} ${this.#pe&&this.getTargetType().length>0?H`
Target is ${ue.formatStringName(this.getTargetType())}
`:G}
`:G}
`}firstUpdated(e){super.firstUpdated(e),this.inputContainer=this.element.querySelector(".ueb-node-inputs"),this.outputContainer=this.element.querySelector(".ueb-node-outputs"),this.setupPins(),this.element.updateComplete.then((()=>this.element.acknowledgeReflow()))}setupPins(){this.element.nodeNameElement=this.element.querySelector(".ueb-node-name-text");let e=!1,t=!1;for(const i of this.element.getPinElements())i!==this.defaultPin&&(i.isInput()?(this.inputContainer.appendChild(i),e=!0):i.isOutput()&&(this.outputContainer.appendChild(i),t=!0));this.defaultPin&&(this.defaultPin.isInput()?this.inputContainer:this.outputContainer).appendChild(this.defaultPin),e&&this.element.classList.add("ueb-node-has-inputs"),t&&this.element.classList.add("ueb-node-has-outputs")}createPinElements(){return this.element.getPinEntities().filter((e=>!e.isHidden())).map((e=>(this.#pe=this.#pe||"self"===e.PinName&&"Target"===e.pinTitle(),this.createPinElement(e))))}getTargetType(){return this.element.entity.FunctionReference?.MemberParent?.getName()??"Untitled"}getPinElements(e){return e.querySelectorAll("ueb-pin")}linksChanged(){}}class Ft extends _t{#de=document.createElement("div");#me=document.createElement("div");#ge=document.createElement("div");#be=document.createElement("div");#ve=document.createElement("div");#ye=document.createElement("div");#fe=document.createElement("div");#we=document.createElement("div");initialize(e){super.initialize(e),this.element.classList.add("ueb-resizeable"),this.#de.classList.add("ueb-resizeable-top"),this.#me.classList.add("ueb-resizeable-right"),this.#ge.classList.add("ueb-resizeable-bottom"),this.#be.classList.add("ueb-resizeable-left"),this.#ve.classList.add("ueb-resizeable-top-right"),this.#ye.classList.add("ueb-resizeable-bottom-right"),this.#fe.classList.add("ueb-resizeable-bottom-left"),this.#we.classList.add("ueb-resizeable-top-left")}update(e){super.update(e),this.element.sizeX>=0&&e.has("sizeX")&&(this.element.style.width=`${this.element.sizeX}px`),this.element.sizeY>=0&&e.has("sizeY")&&(this.element.style.height=`${this.element.sizeY}px`)}firstUpdated(e){super.firstUpdated(e),this.element.append(this.#de,this.#me,this.#ge,this.#be,this.#ve,this.#ye,this.#fe,this.#we)}createInputObjects(){return[...super.createInputObjects(),new Ht(this.#de,this.blueprint,{onDrag:(e,t)=>{t[1]=e[1]-this.element.topBoundary(),this.setSizeY(this.element.sizeY-t[1])&&this.element.addLocation(0,t[1],!1)},onEndDrag:()=>this.endResize()}),new Ht(this.#me,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.rightBoundary(),this.setSizeX(this.element.sizeX+t[0])},onEndDrag:()=>this.endResize()}),new Ht(this.#ge,this.blueprint,{onDrag:(e,t)=>{t[1]=e[1]-this.element.bottomBoundary(),this.setSizeY(this.element.sizeY+t[1])},onEndDrag:()=>this.endResize()}),new Ht(this.#be,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.leftBoundary(),this.setSizeX(this.element.sizeX-t[0])&&this.element.addLocation(t[0],0,!1)},onEndDrag:()=>this.endResize()}),new Ht(this.#ve,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.rightBoundary(),t[1]=e[1]-this.element.topBoundary(),this.setSizeX(this.element.sizeX+t[0]),this.setSizeY(this.element.sizeY-t[1])&&this.element.addLocation(0,t[1],!1)},onEndDrag:()=>this.endResize()}),new Ht(this.#ye,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.rightBoundary(),t[1]=e[1]-this.element.bottomBoundary(),this.setSizeX(this.element.sizeX+t[0]),this.setSizeY(this.element.sizeY+t[1])},onEndDrag:()=>this.endResize()}),new Ht(this.#fe,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.leftBoundary(),t[1]=e[1]-this.element.bottomBoundary(),this.setSizeX(this.element.sizeX-t[0])&&this.element.addLocation(t[0],0,!1),this.setSizeY(this.element.sizeY+t[1])},onEndDrag:()=>this.endResize()}),new Ht(this.#we,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.leftBoundary(),t[1]=e[1]-this.element.topBoundary(),this.setSizeX(this.element.sizeX-t[0])&&this.element.addLocation(t[0],0,!1),this.setSizeY(this.element.sizeY-t[1])&&this.element.addLocation(0,t[1],!1)},onEndDrag:()=>this.endResize()})]}setSizeX(e){return this.element.setNodeWidth(e),!0}setSizeY(e){return this.element.setNodeHeight(e),!0}endResize(){}}class jt extends Ft{#Se=0;initialize(e){super.initialize(e),e.classList.add("ueb-node-style-comment","ueb-node-resizeable"),e.sizeX=25*ne.gridSize,e.sizeY=6*ne.gridSize,super.initialize(e)}getDraggableElement(){return this.element.querySelector(".ueb-node-top")}render(){return H`
`}firstUpdated(e){super.firstUpdated(e);const t=this.getDraggableElement().getBoundingClientRect();this.#Se=t.height}manageNodesBind(){let e=this.blueprint.getNodes();for(let t of e)t.topBoundary()>=this.element.topBoundary()&&t.rightBoundary()<=this.element.rightBoundary()&&t.bottomBoundary()<=this.element.bottomBoundary()&&t.leftBoundary()>=this.element.leftBoundary()?t.bindToComment(this.element):t.unbindFromComment(this.element)}setSizeX(e){return(e=Math.round(e))>=2*ne.gridSize&&(this.element.setNodeWidth(e),!0)}setSizeY(e){return(e=Math.round(e))>=2*ne.gridSize&&(this.element.setNodeHeight(e),!0)}endResize(){this.manageNodesBind()}topBoundary(e=!1){return this.element.locationY}rightBoundary(e=!1){return this.element.locationX+this.element.sizeX}bottomBoundary(e=!1){return e?this.element.locationY+this.#Se:super.bottomBoundary()}leftBoundary(e=!1){return this.element.locationX}}class Wt extends $t{#Ee;#Ce=null;#Ne=e=>{if(!this.enteredPin){this.linkValid=!1,this.enteredPin=e.target;const t=this.link.source??this.target,i=this.enteredPin,r=t.isOutput()?t:i;t.nodeElement.getType()===ne.paths.knot||i.nodeElement.getType()===ne.paths.knot?(this.link.setMessageCorrect(),this.linkValid=!0):t.getNodeElement()===i.getNodeElement()?this.link.setMessageSameNode():t.isOutput()===i.isOutput()?this.link.setMessageDirectionsIncompatible():this.blueprint.getLinks(t,i).length?(this.link.setMessageReplaceLink(),this.linkValid=!0):"exec"===r.entity.getType()&&r.isLinked?(this.link.setMessageReplaceOutputLink(),this.linkValid=!0):"object"==t.entity.PinType.PinCategory&&"object"==i.entity.PinType.PinCategory||t.pinType==i.pinType?(this.link.setMessageCorrect(),this.linkValid=!0):(this.link.setMessageTypesIncompatible(t,i),this.linkValid=!1)}};#xe=e=>{this.enteredPin==e.target&&(this.enteredPin=null,this.linkValid=!1,this.link?.setMessagePlaceNode())};link;enteredPin;linkValid=!1;constructor(e,t,i={}){i.scrollGraphEdge??=!0,super(e,t,i)}startDrag(e){this.target.nodeElement.getType()==ne.paths.knot&&(this.#Ce=this.target),this.link=me.getConstructor("ueb-link").newObject(this.target,null),this.blueprint.template.linksContainerElement.prepend(this.link),this.link.setMessagePlaceNode(),this.#Ee=this.blueprint.querySelectorAll("ueb-pin"),this.#Ee.forEach((e=>{e!=this.target&&(e.addEventListener("mouseenter",this.#Ne),e.addEventListener("mouseleave",this.#xe))})),this.link.startDragging(),this.link.setDestinationLocation(e)}dragTo(e,t){this.link.setDestinationLocation(e)}endDrag(){if(this.#Ee.forEach((e=>{e.removeEventListener("mouseenter",this.#Ne),e.removeEventListener("mouseleave",this.#xe)})),this.#Ee=null,this.enteredPin&&this.linkValid){if(this.#Ce){const e=this.#Ce!==this.link.source?this.link.source:this.enteredPin;if(this.#Ce.isInput()&&e.isInput()||this.#Ce.isOutput()&&e.isOutput()){const e=this.#Ce.template.getOppositePin();this.#Ce===this.link.source?this.link.source=e:this.enteredPin=e}}else this.enteredPin.nodeElement.getType()===ne.paths.knot&&(this.enteredPin=this.enteredPin.template.getOppositePin());this.link.source.getLinks().find((e=>e.equals(this.enteredPin.createPinReference())))?this.link.remove():(this.blueprint.addGraphElement(this.link),this.link.destination=this.enteredPin)}else this.link.remove();this.enteredPin=null,this.link.removeMessage(),this.link.finishDragging(),this.link=null}}class Ut extends _t{#Pe=!1;#ke=!1;displayName="";static nodeStyleClasses=["ueb-node-style-glass"];initialize(e){super.initialize(e),this.displayName=this.element.nodeDisplayName}render(){return H`
${this.displayName?H`
${this.displayName}
`:G} ${this.#Pe?H`
`:G} ${this.#ke?H`
`:G} ${this.pinInserter?H`
Add pin ${De.plusCircle}
`:G}
`}createPinElements(){return this.element.getPinEntities().filter((e=>!e.isHidden())).map((e=>{this.#Pe||=e.isInput(),this.#ke||=e.isOutput();return me.getConstructor("ueb-pin").newObject(e,void 0,this.element)}))}}class Kt extends Ut{static nodeStyleClasses=["ueb-node-style-metasound","ueb-node-style-operation"]}class Yt extends Ut{static nodeStyleClasses=[...super.nodeStyleClasses,"ueb-node-style-conversion"]}class Xt extends Ut{static nodeStyleClasses=[...super.nodeStyleClasses,"ueb-node-style-operation"]}class Zt extends Lt{static canWrapInput=!0;#Te;get iconElement(){return this.#Te}#Ae;get wrapperElement(){return this.#Ae}isNameRendered=!0;initialize(e){if(super.initialize(e),this.element.nodeElement){const e=this.element.nodeElement.template;this.isNameRendered=!(e instanceof Yt||e instanceof Xt||e instanceof Kt)}}setup(){super.setup(),this.element.nodeElement=this.element.closest("ueb-node");const e=this.element.nodeElement.template;(e instanceof Yt||e instanceof Xt)&&(this.isNameRendered=!1,this.element.requestUpdate())}createInputObjects(){return[new Wt(this.element,this.blueprint,{moveEverywhere:!0,draggableElement:this.getClickableElement()})]}render(){const e=H`
${this.renderIcon()}
`,t=H`
${this.isNameRendered?this.renderName():G} ${this.isInputRendered()?this.renderInput():H``}
`;return H`
${this.element.isInput()?H`${e}${t}`:H`${t}${e}`}
`}renderIcon(){if(this.element.nodeElement.entity.isPcg())switch(this.element.entity.getType()){case"Any":return De.pcgPin;case"Param":case"Param[]":return De.pcgParamPin;case"Spatial":case"Spatial[]":return De.pcgSpatialPin;case"Any[]":case"Point[]":case"Surface[]":case"Volume[]":if(this.element.isOutput())return De.pcgPin;case"Point":case"Surface":case"Volume":return De.pcgStackPin}switch(this.element.entity.PinType?.ContainerType?.toString()){case"Array":return De.arrayPin;case"Set":return De.setPin;case"Map":return De.mapPin}return"delegate"===this.element.entity.PinType?.PinCategory?.toLocaleLowerCase()?De.delegate:this.element.nodeElement?.template instanceof Xt?De.operationPin:De.genericPin}renderName(){let e=this.element.getPinDisplayName();const t=this.element.nodeElement,i=this.element.getPinName();return t.getType()==ne.paths.makeStruct&&i==t.entity.StructType.getName()&&(e=i),H`${e}`}isInputRendered(){return this.element.isInput()&&!this.element.entity.bDefaultValueIsIgnored&&!this.element.entity.PinType.bIsReference}renderInput(){return H``}updated(e){if(super.updated(e),this.element.isInput()&&e.has("isLinked")){const e=this.element.nodeElement;this.element.requestUpdate(),this.element.updateComplete.then((()=>e.acknowledgeReflow()))}}firstUpdated(e){super.firstUpdated(e),this.element.style.setProperty("--ueb-pin-color-rgb",this.element.entity.pinColor().cssText),this.#Te=this.element.querySelector(".ueb-pin-icon svg")??this.element,this.#Ae=this.element.querySelector(".ueb-pin-wrapper")}getLinkLocation(){const e=this.iconElement.getBoundingClientRect(),t=[this.element.isInput()?e.left:e.right+1,(e.top+e.bottom)/2],i=ue.convertLocation(t,this.blueprint.template.gridElement);return this.blueprint.compensateTranslation(i[0],i[1])}getClickableElement(){return this.#Ae??this.element}}class qt extends Zt{render(){return H`
${this.renderIcon()}
`}}class Qt extends _t{static nodeStyleClasses=[...super.nodeStyleClasses,"ueb-node-style-event"];firstUpdated(e){super.firstUpdated(e),this.element.querySelector(".ueb-node-top").appendChild(this.createDelegatePinElement())}renderTop(){const e=this.renderNodeIcon(),t=this.renderNodeName(),i=this.element.getType()===ne.paths.customEvent&&(this.element.entity.CustomFunctionName||this.element.entity.FunctionReference.MemberParent);return H`
${e?H`
${e}
`:G} ${t?H`
${t} ${i?H`
Custom Event
`:G}
`:G}
`}createDelegatePinElement(){const e=me.getConstructor("ueb-pin").newObject(this.element.getPinEntities().find((e=>!e.isHidden()&&"delegate"===e.PinType.PinCategory)),new qt,this.element);return e.template.isNameRendered=!1,e}createPinElements(){return this.element.getPinEntities().filter((e=>!e.isHidden()&&"delegate"!==e.PinType.PinCategory)).map((e=>me.getConstructor("ueb-pin").newObject(e,void 0,this.element)))}}class Jt extends qt{render(){return this.element.isOutput()?super.render():H``}getOppositePin(){const e=this.element.nodeElement.template;return this.element.isOutput()?e.inputPin:e.outputPin}getLinkLocation(){const e=(this.element.isInput()?this.element.nodeElement.template.outputPin.template:this).iconElement.getBoundingClientRect(),t=[this.element.isInput()?e.left:e.right+1,(e.top+e.bottom)/2],i=ue.convertLocation(t,this.blueprint.template.gridElement);return this.blueprint.compensateTranslation(i[0],i[1])}}class ei extends _t{static#Le=new Set;#Me=null;#Ie;get inputPin(){return this.#Ie}#Be;get outputPin(){return this.#Be}initialize(e){super.initialize(e),this.element.classList.add("ueb-node-style-minimal")}findDirectionaPin(e){if(e.nodeElement.getType()!==ne.paths.knot||ei.#Le.has(e))return ei.#Le.clear(),!0;ei.#Le.add(e);for(let t of e.getLinks().map((e=>this.blueprint.getPin(e))))if(this.findDirectionaPin(t))return!0;return!1}render(){return H`
`}setupPins(){this.element.getPinElements().forEach((e=>this.element.querySelector(".ueb-node-border").appendChild(e)))}getPinElements(e){return e.querySelectorAll("ueb-pin")}createPinElements(){const e=this.element.getPinEntities().filter((e=>!e.isHidden())),t=e[e[0].isInput()?0:1],i=e[e[0].isOutput()?0:1],r=me.getConstructor("ueb-pin");return[this.#Ie=r.newObject(t,new Jt,this.element),this.#Be=r.newObject(i,new Jt,this.element)]}linksChanged(){}}class ti extends _t{static nodeStyleClasses=["ueb-node-style-metasound"]}class ii extends Ut{initialize(e){super.initialize(e);const t=e.getType();t===ne.paths.variableGet||t===ne.paths.self?(this.element.classList.add("ueb-node-style-getter"),this.displayName=""):t===ne.paths.variableSet&&this.element.classList.add("ueb-node-style-setter")}setupPins(){super.setupPins();let e=this.element.getPinElements().find((e=>!e.entity.isHidden()&&!e.entity.isExecution()));this.element.style.setProperty("--ueb-node-color",e.getColor().cssText)}}function ri(e){if(e.getClass()===ne.paths.callFunction||e.getClass()===ne.paths.commutativeAssociativeBinaryOperator||e.getClass()===ne.paths.callArrayFunction){const t=e.FunctionReference?.MemberParent?.path??"",i=e.FunctionReference?.MemberName;if(i&&(t===ne.paths.kismetMathLibrary||t===ne.paths.kismetArrayLibrary)){if(i.startsWith("Conv_"))return Yt;if(i.startsWith("Add_")||i.startsWith("And_")||i.startsWith("Boolean")||i.startsWith("Cross_")||i.startsWith("Dot_")||i.startsWith("Not_")||i.startsWith("Or_")||i.startsWith("Percent_")||i.startsWith("Xor_"))return Xt;switch(i){case"Abs":case"Array_Add":case"Array_AddUnique":case"Array_Identical":case"BMax":case"BMin":case"CrossProduct2D":case"DotProduct2D":case"Exp":case"FMax":case"FMin":case"GetPI":case"Max":case"MaxInt64":case"Min":case"MinInt64":case"Sqrt":case"Square":case"Vector4_CrossProduct3":case"Vector4_DotProduct":case"Vector4_DotProduct3":case"Acos":case"Asin":case"Cos":case"DegAcos":case"DegCos":case"DegSin":case"DegTan":case"Sin":case"Tan":return Xt}}if(t===ne.paths.blueprintSetLibrary)return Xt;if(t===ne.paths.blueprintMapLibrary)return Xt}switch(e.getClass()){case ne.paths.comment:case ne.paths.materialGraphNodeComment:return jt;case ne.paths.createDelegate:return _t;case ne.paths.metasoundEditorGraphExternalNode:return"Add"==e.ClassName?.Name?Kt:ti;case ne.paths.niagaraNodeOp:if(["Boolean::LogicEq","Boolean::LogicNEq","Numeric::Abs","Numeric::Add","Numeric::Mul"].includes(e.OpName))return Xt;break;case ne.paths.promotableOperator:return Xt;case ne.paths.knot:return ei;case ne.paths.literal:case ne.paths.self:case ne.paths.variableGet:case ne.paths.variableSet:return ii}return e.isEvent()?Qt:_t}class si extends Vt{static properties={...super.properties,selected:{type:Boolean,attribute:"data-selected",reflect:!0,converter:ue.booleanConverter}};dragHandler=e=>this.addLocation(...e.detail.value);constructor(){super(),this.selected=!1,this.listeningDrag=!1}setup(){super.setup(),this.setSelected(this.selected)}cleanup(){super.cleanup(),this.blueprint.removeEventListener(ne.nodeDragGeneralEventName,this.dragHandler)}setSelected(e=!0){this.selected=e,this.blueprint&&(this.selected?(this.listeningDrag=!0,this.blueprint.addEventListener(ne.nodeDragGeneralEventName,this.dragHandler)):(this.blueprint.removeEventListener(ne.nodeDragGeneralEventName,this.dragHandler),this.listeningDrag=!1))}}class ni extends si{static properties={...si.properties,typePath:{type:String,attribute:"data-type",reflect:!0},nodeTitle:{type:String,attribute:"data-title",reflect:!0},advancedPinDisplay:{type:String,attribute:"data-advanced-display",converter:Ue.attributeConverter,reflect:!0},enabledState:{type:String,attribute:"data-enabled-state",reflect:!0},nodeDisplayName:{type:String,attribute:!1},pureFunction:{type:Boolean,converter:ue.booleanConverter,attribute:"data-pure-function",reflect:!0}};static dragEventName=ne.nodeDragEventName;static dragGeneralEventName=ne.nodeDragGeneralEventName;get blueprint(){return super.blueprint}set blueprint(e){super.blueprint=e,this.#Ve.forEach((t=>t.blueprint=e))}#$e;get nodeNameElement(){return this.#$e}set nodeNameElement(e){this.#$e=e}#Ve=[];boundComments=[];#Oe=!1;#He=e=>{this.selected||this.#Oe||(this.#Oe=!0,this.requestUpdate(),this.updateComplete.then((()=>this.#Oe=!1)),this.addLocation(...e.detail.value))};static fromSerializedObject(e){e=e.trim();let t=Be.getSerializer(Et).read(e);return ni.newObject(t)}static newObject(e=new Et,t=new(ri(e))){const i=new ni;return i.initialize(e,t),i}#De(e){for(let t of this.getPinElements())for(let i of t.getLinks())this.blueprint.getPin(i).redirectLink(t,new at({objectName:e,pinGuid:t.entity.PinId}))}initialize(e=new Et,t=new(ri(e))){this.typePath=e.getType(),this.nodeTitle=e.getObjectName(),this.advancedPinDisplay=e.AdvancedPinDisplay?.toString(),this.enabledState=e.EnabledState,this.nodeDisplayName=ze(e),this.pureFunction=e.bIsPureFunc,this.dragLinkObjects=[],super.initialize(e,t),this.#Ve=this.template.createPinElements(),super.setLocation(this.entity.getNodePosX(),this.entity.getNodePosY()),this.entity.NodeWidth&&this.entity.NodeHeight?(this.sizeX=this.entity.NodeWidth.value,this.sizeY=this.entity.NodeHeight.value):this.updateComplete.then((()=>this.computeSizes())),e.listenAttribute("Name",(t=>{this.nodeTitle=e.Name,this.nodeDisplayName=ze(e),this.#De(t)}))}async getUpdateComplete(){let e=await super.getUpdateComplete();for(const t of this.getPinElements())e&&=await t.updateComplete;return e}bindToComment(e){e==this||this.boundComments.includes(e)||(e.addEventListener(ne.nodeDragEventName,this.#He),this.boundComments.push(e))}unbindFromComment(e){const t=this.boundComments.indexOf(e);t>=0&&(e.removeEventListener(ne.nodeDragEventName,this.#He),this.boundComments[t]=this.boundComments[this.boundComments.length-1],this.boundComments.pop())}isInsideComment(e){return this.topBoundary()>=e.topBoundary()&&this.rightBoundary()<=e.rightBoundary()&&this.bottomBoundary()<=e.bottomBoundary()&&this.leftBoundary()>=e.leftBoundary()}getType(){return this.entity.getType()}getNodeName(){return this.entity.getObjectName()}computeNodeDisplayName(){this.nodeDisplayName=ze(this.entity)}setNodeWidth(e){this.entity.setNodeWidth(e),this.sizeX=e,this.acknowledgeReflow()}setNodeHeight(e){this.entity.setNodeHeight(e),this.sizeY=e,this.acknowledgeReflow()}sanitizeLinks(e=[]){this.getPinElements().forEach((t=>t.sanitizeLinks(e)))}getPinElements(){return this.#Ve}getPinEntities(){return this.entity.getPinEntities()}setLocation(e=0,t=0,i=!0){this.entity.setNodePosX(e),this.entity.setNodePosY(t),super.setLocation(e,t,i)}acknowledgeReflow(){this.requestUpdate(),this.updateComplete.then((()=>this.computeSizes()));let e=new CustomEvent(ne.nodeReflowEventName);this.dispatchEvent(e)}setShowAdvancedPinDisplay(e){this.entity.AdvancedPinDisplay=new Ue(e?"Shown":"Hidden"),this.advancedPinDisplay=this.entity.AdvancedPinDisplay}toggleShowAdvancedPinDisplay(){this.setShowAdvancedPinDisplay("Shown"!=this.entity.AdvancedPinDisplay?.toString())}}class ai extends Et{#Ge=new Map;#Re=[];get objectEntities(){return this.#Re}getHomonymObjectEntity(e){const t=e.getObjectName(!1);return this.#Re.find((e=>e.getObjectName()==t))}takeFreeName(e){e=e.replace(/_\d+$/,"");const t=(this.#Ge.get(e)??-1)+1;return this.#Ge.set(e,t),ne.nodeTitle(e,t)}addObjectEntity(e){if(!this.#Re.includes(e)){this.#Re.push(e);const[t,i]=e.getNameAndCounter();return this.#Ge.set(t,Math.max(this.#Ge.get(t)??0,i)),!0}return!1}removeObjectEntity(e){const t=this.#Re.indexOf(e);if(t>=0){const e=this.#Re.pop();return te.OriginalChangeId.value==t.OriginalChangeId.value));if(t.length===this.ScriptVariables.length)return this;const i=t.concat(t).map(((i,r)=>{const s=ne.subObjectAttributeNameFromReference(i.ScriptVariable,r>=t.length);return[s,this[s]??e[s]]}));return i.push(...Object.entries(this).filter((([e,t])=>!e.startsWith(ne.subObjectAttributeNamePrefix)&&"ExportedNodes"!==e))),new ai(Object.fromEntries(i))}}class oi{static same=e=>e;static notWrapped=(e,t)=>t;static bracketsWrapped=(e,t)=>`(${t})`;constructor(e,t=((e,t)=>t),i=",",r=!1,s="=",n=oi.same){this.entityType=e,this.wrap=t,this.attributeSeparator=i,this.trailingSeparator=r,this.attributeValueConjunctionSign=s,this.attributeKeyPrinter=n}read(e){return this.doRead(e.trim())}write(e,t=!1){return this.doWrite(e,t)}doRead(e){const t=$e.grammarFor(void 0,this.entityType).run(e);if(!t.status)throw new Error(this.entityType?`Error when trying to parse the entity ${this.entityType.prototype.constructor.name}`:"Error when trying to parse null");return t.value}doWrite(e,t=!1,i="",r=this.wrap,s=this.attributeSeparator,n=this.trailingSeparator,a=this.attributeValueConjunctionSign,o=this.attributeKeyPrinter){let l="";const c=e._keys??Object.keys(e);let u=!0;for(const r of c){const n=e[r];if(void 0!==n&&this.showProperty(e,r)){let c=e instanceof Array?`(${r})`:r;oe.getAttribute(e,r,"quoted")&&(c=`"${c}"`);const h=oe.getAttribute(e,r,"serialized");if(u?u=!1:l+=s,oe.getAttribute(e,r,"inlined")){l+=this.doWrite(n,t,i,oi.notWrapped,s,!1,a,oe.getAttribute(e,r,"type")instanceof Array?e=>o(`${c}${e}`):e=>o(`${c}.${e}`));continue}const p=o(c),d=s.includes("\n")?i:"";l+=(p.length?d+p+this.attributeValueConjunctionSign:"")+(h?`"${this.doWriteValue(n,!0,i)}"`:this.doWriteValue(n,t,i))}}return n&&l.length&&(l+=s),r(e,l)}doWriteValue(e,t,i=""){const r=ue.getType(e),s=Be.getSerializer(r);if(!s)throw new Error(`Unknown value type "${r.name}", a serializer must be registered in the SerializerFactory class, check initializeSerializerFactory.js`);return s.doWrite(e,t,i)}showProperty(e,t){if(e instanceof Ve){if(oe.getAttribute(e,t,"ignored"))return!1;if(oe.getAttribute(e,t,"silent")){let i=oe.getAttribute(e,t,"default");if(i instanceof Function&&(i=i(e)),ue.equals(e[t],i))return!1}}return!0}}class li extends oi{constructor(e=Et){super(e,void 0,"\n",!0,void 0,oi.same)}showProperty(e,t){switch(t){case"Class":case"Name":case"Archetype":case"ExportPath":case"CustomProperties":return!1}return super.showProperty(e,t)}write(e,t=!1){return this.doWrite(e,t)+"\n"}doRead(e){return $e.grammarFor(void 0,this.entityType).parse(e)}readMultiple(e){return Et.getMultipleObjectsGrammar().parse(e)}doWrite(e,t,i="",r=this.wrap,s=this.attributeSeparator,n=this.trailingSeparator,a=this.attributeValueConjunctionSign,o=this.attributeKeyPrinter){const l=i+ne.indentation;if(!(e instanceof Et))return super.doWrite(e,t,i,r,s,n,a,(t=>e[t]instanceof Et?"":o(t)));return i+"Begin Object"+(e.Class?.type||e.Class?.path?` Class=${this.doWriteValue(e.Class,t)}`:"")+(e.Name?` Name=${this.doWriteValue(e.Name,t)}`:"")+(e.Archetype?` Archetype=${this.doWriteValue(e.Archetype,t)}`:"")+(e.ExportPath?.type||e.ExportPath?.path?` ExportPath=${this.doWriteValue(e.ExportPath,t)}`:"")+"\n"+super.doWrite(e,t,l,r,s,!0,a,(t=>e[t]instanceof Et?"":o(t)))+(oe.getAttribute(e,"CustomProperties","ignored")?"":e.getCustomproperties().map((e=>l+o("CustomProperties ")+Be.getSerializer(vt).doWrite(e,t)+this.attributeSeparator)).join(""))+i+"End Object"}}class ci extends Nt{static#ze=new li;#_e;constructor(e,t,i={}){i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,super(e,t,i);let r=this;this.#_e=()=>r.copied()}listenEvents(){window.addEventListener("copy",this.#_e)}unlistenEvents(){window.removeEventListener("copy",this.#_e)}getSerializedText(){const e=this.blueprint.getNodes(!0).map((e=>e.entity)),t=e.filter((e=>e.isExported)).map((e=>ci.#ze.write(e,!1))),i=e.filter((e=>!e.isExported)).map((e=>ci.#ze.write(e,!1)));return t.length&&(this.blueprint.entity.ExportedNodes=btoa(t.join("")),i.splice(0,0,ci.#ze.write(this.blueprint.entity,!1)),delete this.blueprint.entity.ExportedNodes),i.join("")}copied(){const e=this.getSerializedText();return navigator.clipboard.writeText(e),e}}class ui extends Nt{static#ze=new li;#Fe;constructor(e,t,i={}){i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,super(e,t,i);let r=this;this.#Fe=()=>r.cut()}listenEvents(){window.addEventListener("cut",this.#Fe)}unlistenEvents(){window.removeEventListener("cut",this.#Fe)}getSerializedText(){return this.blueprint.getNodes(!0).map((e=>ui.#ze.write(e.entity,!1))).join("")}cut(){this.blueprint.template.getCopyInputObject().copied(),this.blueprint.removeGraphElement(...this.blueprint.getNodes(!0))}}class hi extends Nt{static#ze=new li;#je;constructor(e,t,i={}){i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,super(e,t,i);let r=this;this.#je=e=>r.pasted(e.clipboardData.getData("Text"))}listenEvents(){window.addEventListener("paste",this.#je)}unlistenEvents(){window.removeEventListener("paste",this.#je)}pasted(e){let t=0,i=0,r=0,s=hi.#ze.readMultiple(e).map((e=>{let s=me.getConstructor("ueb-node").newObject(e);return t+=s.locationY,i+=s.locationX,++r,s}));t/=r,i/=r,s.length>0&&this.blueprint.unselectAll();let n=this.blueprint.mousePosition;return s.forEach((e=>{e.addLocation(n[0]-i,n[1]-t),e.snapToGrid(),e.setSelected(!0)})),this.blueprint.addGraphElement(...s),s}}class pi extends kt{static#$=e=>{};#We=0;get variation(){return this.#We}#Ue=e=>{this.enablerKey&&!this.enablerActivated||(e.preventDefault(),this.#We=e.deltaY,this.setLocationFromEvent(e),this.wheel())};#Ke=e=>e.preventDefault();constructor(e,t,i={},r=pi.#$){i.listenOnFocus=!0,i.strictTarget??=!1,super(e,t,i),this.strictTarget=i.strictTarget,this.onWheel=r}listenEvents(){this.movementSpace.addEventListener("wheel",this.#Ue,!1),this.movementSpace.parentElement?.addEventListener("wheel",this.#Ke)}unlistenEvents(){this.movementSpace.removeEventListener("wheel",this.#Ue,!1),this.movementSpace.parentElement?.removeEventListener("wheel",this.#Ke)}wheel(){this.onWheel(this)}}class di extends pi{#Ye=0;#Xe=!1;get enableZoonIn(){return this.#Xe}set enableZoonIn(e){e!=this.#Xe&&(this.#Xe=e)}wheel(){if(this.#Ye+=-this.variation,Math.abs(this.#Ye)0||(e+=Math.sign(this.#Ye),this.blueprint.setZoom(e,this.location),this.#Ye=0)}}class mi extends Pt{#Ze;constructor(e,t,i={}){i.activationKeys=de.enableZoomIn,super(e,t,i)}fire(){this.#Ze=this.blueprint.template.getZoomInputObject(),this.#Ze.enableZoonIn=!0}unfire(){this.#Ze.enableZoonIn=!1}}class gi extends $t{startDrag(){this.blueprint.scrolling=!0}dragTo(e,t){this.blueprint.scrollDelta(-t[0],-t[1])}endDrag(){this.blueprint.scrolling=!1}}class bi extends kt{#qe=null;#Qe=e=>{e.preventDefault(),this.setLocationFromEvent(e),this.blueprint.mousePosition=[...this.location]};#Je=e=>{this.#qe||(e.preventDefault(),this.#qe=e.detail.tracker,this.unlistenMouseMove())};#et=e=>{this.#qe==e.detail.tracker&&(e.preventDefault(),this.#qe=null,this.listenMouseMove())};constructor(e,t,i={}){i.listenOnFocus=!0,super(e,t,i)}listenMouseMove(){this.target.addEventListener("mousemove",this.#Qe)}unlistenMouseMove(){this.target.removeEventListener("mousemove",this.#Qe)}listenEvents(){this.listenMouseMove(),this.blueprint.addEventListener(ne.trackingMouseEventName.begin,this.#Je),this.blueprint.addEventListener(ne.trackingMouseEventName.end,this.#et)}unlistenEvents(){this.unlistenMouseMove(),this.blueprint.removeEventListener(ne.trackingMouseEventName.begin,this.#Je),this.blueprint.removeEventListener(ne.trackingMouseEventName.end,this.#et)}}class vi extends $t{constructor(e,t,i={}){i.scrollGraphEdge??=!0,super(e,t,i),this.selectorElement=this.blueprint.template.selectorElement}startDrag(){this.selectorElement.beginSelect(this.clickedPosition)}dragTo(e,t){this.selectorElement.selectTo(e)}endDrag(){this.started&&this.selectorElement.endSelect()}unclicked(){this.started||this.blueprint.unselectAll()}}class yi extends Nt{#tt=e=>this.clickedSomewhere(e.target);constructor(e,t,i={}){i.listenOnFocus=!0,super(e,t,i),this.blueprint.focus&&document.addEventListener("click",this.#tt)}clickedSomewhere(e){e.closest("ueb-blueprint")||this.blueprint.setFocused(!1)}listenEvents(){document.addEventListener("click",this.#tt)}unlistenEvents(){document.removeEventListener("click",this.#tt)}}class fi extends Lt{static styleVariables={"--ueb-font-size":`${ne.fontSize}`,"--ueb-grid-axis-line-color":`${ne.gridAxisLineColor}`,"--ueb-grid-expand":`${ne.expandGridSize}px`,"--ueb-grid-line-color":`${ne.gridLineColor}`,"--ueb-grid-line-width":`${ne.gridLineWidth}px`,"--ueb-grid-set-line-color":`${ne.gridSetLineColor}`,"--ueb-grid-set":`${ne.gridSet}`,"--ueb-grid-size":`${ne.gridSize}px`,"--ueb-link-min-width":`${ne.linkMinWidth}`,"--ueb-node-radius":`${ne.nodeRadius}px`};#it=new ResizeObserver((e=>{const t=e.find((e=>e.target===this.viewportElement))?.devicePixelContentBoxSize?.[0];t&&(this.viewportSize[0]=t.inlineSize,this.viewportSize[1]=t.blockSize)}));#rt;#st;#Ze;headerElement;overlayElement;viewportElement;selectorElement;gridElement;linksContainerElement;nodesContainerElement;viewportSize=[0,0];initialize(e){super.initialize(e),this.element.style.cssText=Object.entries(fi.styleVariables).map((([e,t])=>`${e}:${t};`)).join("");const t=this.element.querySelector(":scope > template")?.content.textContent;t&&(this.element.requestUpdate(),this.element.updateComplete.then((()=>{this.blueprint.mousePosition=[Math.round(this.viewportSize[0]/2),Math.round(this.viewportSize[1]/2)],this.getPasteInputObject().pasted(t),this.blueprint.unselectAll()})))}setup(){super.setup(),this.#it.observe(this.viewportElement,{box:"device-pixel-content-box"});const e=this.viewportElement.getBoundingClientRect();this.viewportSize[0]=e.width,this.viewportSize[1]=e.height,this.blueprint.nodes.length>0&&(this.blueprint.requestUpdate(),this.blueprint.updateComplete.then((()=>this.centerContentInViewport())))}cleanup(){super.cleanup(),this.#it.unobserve(this.viewportElement)}createInputObjects(){const e=this.element.getGridDOMElement();return this.#rt=new ci(e,this.blueprint),this.#st=new hi(e,this.blueprint),this.#Ze=new di(e,this.blueprint),[...super.createInputObjects(),this.#rt,this.#st,this.#Ze,new ui(e,this.blueprint),new Pt(e,this.blueprint,{activationKeys:de.duplicateNodes},(()=>this.blueprint.template.getPasteInputObject().pasted(this.blueprint.template.getCopyInputObject().copied()))),new Pt(e,this.blueprint,{activationKeys:de.deleteNodes},(()=>this.blueprint.removeGraphElement(...this.blueprint.getNodes(!0)))),new Pt(e,this.blueprint,{activationKeys:de.selectAllNodes},(()=>this.blueprint.selectAll())),new vi(e,this.blueprint,{clickButton:ne.mouseClickButton,exitAnyButton:!0,moveEverywhere:!0}),new gi(e,this.blueprint,{clickButton:ne.mouseRightClickButton,exitAnyButton:!1,moveEverywhere:!0}),new yi(e,this.blueprint),new bi(e,this.blueprint),new mi(e,this.blueprint)]}render(){return H`
Zoom ${0==this.blueprint.zoom?"1:1":(this.blueprint.zoom>0?"+":"")+this.blueprint.zoom}
`}firstUpdated(e){super.firstUpdated(e),this.headerElement=this.blueprint.querySelector(".ueb-viewport-header"),this.overlayElement=this.blueprint.querySelector(".ueb-viewport-overlay"),this.viewportElement=this.blueprint.querySelector(".ueb-viewport-body"),this.selectorElement=this.blueprint.querySelector("ueb-selector"),this.gridElement=this.viewportElement.querySelector(".ueb-grid"),this.linksContainerElement=this.blueprint.querySelector("[data-links]"),this.linksContainerElement.append(...this.blueprint.getLinks()),this.nodesContainerElement=this.blueprint.querySelector("[data-nodes]"),this.nodesContainerElement.append(...this.blueprint.getNodes()),this.viewportElement.scroll(ne.expandGridSize,ne.expandGridSize)}willUpdate(e){super.willUpdate(e),this.headerElement&&e.has("zoom")&&(this.headerElement.classList.add("ueb-zoom-changed"),this.headerElement.addEventListener("animationend",(()=>this.headerElement.classList.remove("ueb-zoom-changed"))))}updated(e){if(super.updated(e),(e.has("scrollX")||e.has("scrollY"))&&this.viewportElement.scroll(this.blueprint.scrollX,this.blueprint.scrollY),e.has("zoom")){this.blueprint.style.setProperty("--ueb-scale",this.blueprint.getScale());const t=e.get("zoom"),i=Math.min(t,this.blueprint.zoom),r=Math.max(t,this.blueprint.zoom),s=ue.range(i,r),n=e=>`ueb-zoom-${e}`;te<0)).map(n)),this.blueprint.classList.add(...s.filter((e=>e>0)).map(n))):(this.blueprint.classList.remove(...s.filter((e=>e>0)).map(n)),this.blueprint.classList.add(...s.filter((e=>e<0)).map(n)))}}getCommentNodes(e=!1){return this.blueprint.querySelectorAll(`ueb-node[data-type="${ne.paths.comment}"]${e?'[data-selected="true"]':""}, ueb-node[data-type="${ne.paths.materialGraphNodeComment}"]${e?'[data-selected="true"]':""}`)}getPin(e){return this.blueprint.querySelector(`ueb-node[data-title="${e.objectName}"] ueb-pin[data-id="${e.pinGuid}"]`)}getCopyInputObject(){return this.#rt}getPasteInputObject(){return this.#st}getZoomInputObject(){return this.#Ze}isPointVisible(e,t){return!1}gridTopVisibilityBoundary(){return this.blueprint.scaleCorrect(this.blueprint.scrollY)-this.blueprint.translateY}gridRightVisibilityBoundary(){return this.gridLeftVisibilityBoundary()+this.blueprint.scaleCorrect(this.viewportSize[0])}gridBottomVisibilityBoundary(){return this.gridTopVisibilityBoundary()+this.blueprint.scaleCorrect(this.viewportSize[1])}gridLeftVisibilityBoundary(){return this.blueprint.scaleCorrect(this.blueprint.scrollX)-this.blueprint.translateX}centerViewport(e=0,t=0,i=!0){const r=this.gridLeftVisibilityBoundary()+this.blueprint.scaleCorrect(this.viewportSize[0]/2),s=this.gridTopVisibilityBoundary()+this.blueprint.scaleCorrect(this.viewportSize[1]/2);this.blueprint.scrollDelta(this.blueprint.scaleCorrectReverse(e-r),this.blueprint.scaleCorrectReverse(t-s),i)}centerContentInViewport(e=!0){let t=0,i=0,r=Number.MAX_SAFE_INTEGER,s=Number.MIN_SAFE_INTEGER,n=Number.MAX_SAFE_INTEGER,a=Number.MIN_SAFE_INTEGER;const o=this.blueprint.getNodes();for(const e of o)t+=e.leftBoundary()+e.rightBoundary(),i+=e.topBoundary()+e.bottomBoundary(),r=Math.min(r,e.leftBoundary()),s=Math.max(s,e.rightBoundary()),n=Math.min(n,e.topBoundary()),a=Math.max(a,e.bottomBoundary());t=Math.round(s-r<=this.viewportSize[0]?(s+r)/2:t/(2*o.length)),i=Math.round(a-n<=this.viewportSize[1]?(a+n)/2:i/(2*o.length)),this.centerViewport(t,i,e)}}class wi extends he{static properties={selecting:{type:Boolean,attribute:"data-selecting",reflect:!0,converter:ue.booleanConverter},scrolling:{type:Boolean,attribute:"data-scrolling",reflect:!0,converter:ue.booleanConverter},focused:{type:Boolean,attribute:"data-focused",reflect:!0,converter:ue.booleanConverter},zoom:{type:Number,attribute:"data-zoom",reflect:!0},scrollX:{type:Number,attribute:!1},scrollY:{type:Number,attribute:!1},additionalX:{type:Number,attribute:!1},additionalY:{type:Number,attribute:!1},translateX:{type:Number,attribute:!1},translateY:{type:Number,attribute:!1}};static nodeBoundariesSupplier=e=>({primaryInf:e.leftBoundary(!0),primarySup:e.rightBoundary(!0),secondaryInf:e.topBoundary(!0),secondarySup:e.bottomBoundary(!0)});static nodeSelectToggleFunction=(e,t)=>{e.setSelected(t)};#nt=0;#at=0;nodes=[];links=[];nodesNames=new Map;mousePosition=[0,0];waitingExpandUpdate=!1;constructor(){super(),this.selecting=!1,this.scrolling=!1,this.focused=!1,this.zoom=0,this.scrollX=ne.expandGridSize,this.scrollY=ne.expandGridSize,this.translateX=ne.expandGridSize,this.translateY=ne.expandGridSize,super.initialize(new ai,new fi)}initialize(){}getGridDOMElement(){return this.template.gridElement}getScroll(){return[this.scrollX,this.scrollY]}setScroll(e,t){this.scrollX=e,this.scrollY=t}scrollDelta(e=0,t=0,i=!1,r=ne.smoothScrollTime){if(i){let i=[0,0];this.#nt&&cancelAnimationFrame(this.#nt),this.#at&&cancelAnimationFrame(this.#at),ue.animate(0,e,r,(e=>{this.scrollDelta(e-i[0],0,!1),i[0]=e}),(e=>this.#nt=e)),ue.animate(0,t,r,(e=>{this.scrollDelta(0,e-i[1],!1),i[1]=e}),(e=>this.#at=e))}else{const i=[2*ne.expandGridSize,2*ne.expandGridSize];let r=this.getScroll(),s=[r[0]+e,r[1]+t],n=[0,0];for(let e=0;e<2;++e)s[e]i[e]-ne.gridExpandThreshold*ne.expandGridSize&&(n[e]=1);0==n[0]&&0==n[1]||this.seamlessExpand(n[0],n[1]),r=this.getScroll(),s=[r[0]+e,r[1]+t],this.setScroll(s[0],s[1])}}scrollCenter(e=!1){const t=this.getScroll(),i=[this.translateX-t[0],this.translateY-t[1]],r=this.getViewportSize().map((e=>e/2)),s=[i[0]-r[0],i[1]-r[1]];this.scrollDelta(s[0],s[1],e)}getViewportSize(){return[this.template.viewportElement.clientWidth,this.template.viewportElement.clientHeight]}getScrollMax(){return[this.template.viewportElement.scrollWidth-this.template.viewportElement.clientWidth,this.template.viewportElement.scrollHeight-this.template.viewportElement.clientHeight]}snapToGrid(e,t){return ue.snapToGrid(e,t,ne.gridSize)}seamlessExpand(e,t){e=Math.round(e),t=Math.round(t);let i=this.getScale();[e,t]=[-e*ne.expandGridSize,-t*ne.expandGridSize],0!=e&&(this.scrollX+=e,e/=i),0!=t&&(this.scrollY+=t,t/=i),this.translateX+=e,this.translateY+=t}progressiveSnapToGrid(e){return ne.expandGridSize*Math.round(e/ne.expandGridSize+.5*Math.sign(e))}getZoom(){return this.zoom}setZoom(e,t){if((e=ue.clamp(e,ne.minZoom,ne.maxZoom))==this.zoom)return;let i=this.getScale();if(this.zoom=e,t){t[0]+=this.translateX,t[1]+=this.translateY;let e=this.getScale()/i,r=[e*t[0],e*t[1]];this.scrollDelta((r[0]-t[0])*i,(r[1]-t[1])*i)}}getScale(){return ne.scale[this.getZoom()]}scaleCorrect(e){return e/this.getScale()}scaleCorrectReverse(e){return e*this.getScale()}compensateTranslation(e,t){return[e-=this.translateX,t-=this.translateY]}getNodes(e=!1,[t,i,r,s]=[Number.MIN_SAFE_INTEGER,Number.MAX_SAFE_INTEGER,Number.MAX_SAFE_INTEGER,Number.MIN_SAFE_INTEGER]){let n=this.nodes;return e&&(n=n.filter((e=>e.selected))),(t>Number.MIN_SAFE_INTEGER||iNumber.MIN_SAFE_INTEGER)&&(n=n.filter((e=>e.topBoundary()>=t&&e.rightBoundary()<=i&&e.bottomBoundary()<=r&&e.leftBoundary()>=s))),n}getCommentNodes(e=!1){let t=[...this.template.getCommentNodes(e)];return 0===t.length&&(t=this.nodes.filter((t=>t.getType()===ne.paths.comment&&(!e||t.selected)))),t}getPin(e){let t=this.template.getPin(e);return t&&t.nodeElement.getNodeName()==e.objectName.toString()||(t=[...this.nodes.find((t=>e.objectName.toString()==t.getNodeName()))?.getPinElements()??[]].find((t=>e.pinGuid.toString()==t.getPinId().toString()))),t}getLinks(e=null,t=null){if(null==e!=(null==t)){const i=e??t;return this.links.filter((e=>e.source==i||e.destination==i))}return null!=e&&null!=t?this.links.filter((i=>i.source==e&&i.destination==t||i.source==t&&i.destination==e)):this.links}getLink(e,t,i=!1){return this.links.find((r=>r.source==e&&r.destination==t||!i&&r.source==t&&r.destination==e))}selectAll(){this.getNodes().forEach((e=>wi.nodeSelectToggleFunction(e,!0)))}unselectAll(){this.getNodes().forEach((e=>wi.nodeSelectToggleFunction(e,!1)))}addGraphElement(...e){const t=e=>{const i=e.currentTarget;i.removeEventListener(ne.removeEventName,t);const[r,s]=i instanceof ni?[this.nodes,i.entity]:i instanceof Bt?[this.links]:null,n=r?.indexOf(i);if(n>=0){const e=r.pop();ne.entity.isExported=!0));continue}const e=i.entity.getObjectName(),r=this.entity.getHomonymObjectEntity(i.entity);r&&(r.Name=this.entity.takeFreeName(e)),this.nodes.push(i),this.entity.addObjectEntity(i.entity),i.addEventListener(ne.removeEventName,t),this.template.nodesContainerElement?.appendChild(i)}else i instanceof Bt&&!this.links.includes(i)&&(this.links.push(i),i.addEventListener(ne.removeEventName,t),this.template.linksContainerElement&&!this.template.linksContainerElement.contains(i)&&this.template.linksContainerElement.appendChild(i));e.filter((e=>e instanceof ni)).forEach((t=>t.sanitizeLinks(e))),e.filter((e=>e instanceof ni&&e.getType()==ne.paths.comment)).forEach((e=>e.updateComplete.then((()=>e.template.manageNodesBind()))))}removeGraphElement(...e){for(let t of e){if(t.closest("ueb-blueprint")!==this)return;t.remove()}}setFocused(e=!0){if(this.focused==e)return;let t=new CustomEvent(e?ne.focusEventName.begin:ne.focusEventName.end);this.focused=e,this.focused||this.unselectAll(),this.dispatchEvent(t)}acknowledgeEditText(e){const t=new CustomEvent(e?ne.editTextEventName.begin:ne.editTextEventName.end);this.dispatchEvent(t)}}customElements.define("ueb-blueprint",wi);class Si extends Gt{#ot;get locationChangeCallback(){return this.#ot}set locationChangeCallback(e){this.#ot=e}movementSpace;movementSpaceSize=[0,0];firstUpdated(e){super.firstUpdated(e),this.movementSpace=this.element.parentElement}setup(){super.setup();const e=this.movementSpace.getBoundingClientRect();this.movementSpaceSize=[e.width,e.height]}createDraggableObject(){return new Ot(this.element,this.blueprint,{draggableElement:this.movementSpace,ignoreTranslateCompensate:!0,moveEverywhere:!0,movementSpace:this.movementSpace,repositionOnClick:!0,stepSize:1})}adjustLocation(e,t){return this.locationChangeCallback?.(e,t),[e,t]}}class Ei extends Si{adjustLocation(e,t){const i=Math.round(this.movementSpaceSize[0]/2);e-=i,t=-(t-i);let[r,s]=ue.getPolarCoordinates(e,t);return r=Math.min(r,i),[e,t]=ue.getCartesianCoordinates(r,s),this.locationChangeCallback?.(e/i,t/i),[e=Math.round(e+i),t=Math.round(-t+i)]}}class Ci extends Vt{windowElement;setup(){super.setup(),this.windowElement=this.closest("ueb-window")}setLocation(e,t){super.setLocation(...this.template.adjustLocation(e,t))}}class Ni extends Ci{constructor(){super(),super.initialize({},new Ei)}static newObject(){return new Ni}initialize(){}}class xi extends Si{adjustLocation(e,t){return e=ue.clamp(e,0,this.movementSpaceSize[0]),t=ue.clamp(t,0,this.movementSpaceSize[1]),this.locationChangeCallback?.(e/this.movementSpaceSize[0],1-t/this.movementSpaceSize[1]),[e,t]}}class Pi extends Ci{constructor(){super(),super.initialize({},new xi)}static newObject(){return new Pi}initialize(){}}class ki extends $t{constructor(e,t,i={}){i.consumeEvent=!0,super(e,t,i)}}class Ti extends Lt{#lt;#ct;#ut=e=>this.element.selectedOption=e.target.selectedOptions[0].value;render(){return H` `}firstUpdated(e){super.firstUpdated(e),this.#lt=this.element.querySelector("select:first-child"),this.#ct=this.element.querySelector("select:last-child");const t=new Event("input",{bubbles:!0});this.#lt.dispatchEvent(t)}updated(e){super.updated(e);const t=this.#ct.getBoundingClientRect();this.element.style.setProperty("--ueb-dropdown-width",t.width+"px")}createInputObjects(){return[...super.createInputObjects(),new ki(this.element,this.blueprint)]}setSelectedValue(e){this.element.querySelector(`option[value="${e}"]`).defaultSelected=!0}getSelectedValue(){return this.#lt.value}}class Ai extends he{static properties={...super.properties,options:{type:Object},selectedOption:{type:String}};constructor(){super(),super.initialize({},new Ti),this.options=[],this.selectedOption=""}static newObject(e){return new Ai}initialize(){}getValue(){return this.template.getSelectedValue()}}class Li extends Lt{#ht=()=>{this.blueprint.acknowledgeEditText(!0),this.element.selectOnFocus&&getSelection().selectAllChildren(this.element)};#pt=()=>{this.blueprint.acknowledgeEditText(!1),getSelection().removeAllRanges()};#dt=e=>e.target.querySelectorAll("br").forEach((e=>e.remove()));#mt=e=>{"Enter"!=e.code||e.shiftKey||e.target.blur()};initialize(e){super.initialize(e),this.element.classList.add("ueb-pin-input-content"),this.element.setAttribute("role","textbox"),this.element.contentEditable="true"}firstUpdated(e){super.firstUpdated(e);const t=new Event("input",{bubbles:!0});this.element.dispatchEvent(t)}createInputObjects(){return[...super.createInputObjects(),new ki(this.element,this.blueprint)]}setup(){super.setup(),this.element.addEventListener("focus",this.#ht),this.element.addEventListener("focusout",this.#pt),this.element.singleLine&&this.element.addEventListener("input",this.#dt),this.element.blurOnEnter&&this.element.addEventListener("keydown",this.#mt)}cleanup(){super.cleanup(),this.element.removeEventListener("focus",this.#ht),this.element.removeEventListener("focusout",this.#pt),this.element.removeEventListener("input",this.#dt),this.element.removeEventListener("keydown",this.#mt)}}class Mi extends he{static properties={...super.properties,singleLine:{type:Boolean,attribute:"data-single-line",converter:ue.booleanConverter,reflect:!0},selectOnFocus:{type:Boolean,attribute:"data-select-focus",converter:ue.booleanConverter,reflect:!0},blurOnEnter:{type:Boolean,attribute:"data-blur-enter",converter:ue.booleanConverter,reflect:!0}};constructor(){super(),this.singleLine=!1,this.selectOnFocus=!0,this.blurOnEnter=!0,super.initialize({},new Li)}static newObject(){return new Mi}initialize(){}}class Ii extends Zt{#gt;#bt=()=>this.element.setDefaultValue(this.#gt.checked);firstUpdated(e){super.firstUpdated(e),this.#gt=this.element.querySelector(".ueb-pin-input")}setup(){super.setup(),this.#gt?.addEventListener("change",this.#bt)}cleanup(){super.cleanup(),this.#gt?.removeEventListener("change",this.#bt)}createInputObjects(){return[...super.createInputObjects(),new ki(this.#gt,this.blueprint)]}renderInput(){return H``}}class Bi extends Zt{static singleLineInput=!1;static selectOnFocus=!0;static saveEachInputChange=!1;#vt;get inputWrapper(){return this.#vt}#yt;static stringFromInputToUE(e){return e.replace(/(?=\n\s*)\n$/,"")}static stringFromUEToInput(e){return e.replaceAll(/(?:\r|(?<=(?:^|[^\\])(?:\\\\)*)\\r)(?=\n)/g,"").replace(/(?<=\n\s*)$/,"\n")}#ft=()=>this.setInputs(this.getInputs(),!0);#wt=e=>this.#St(e.target);#St(e){const t=this.blueprint.scaleCorrect(this.#vt.getBoundingClientRect().width)+this.nameWidth,i=this.element.classList.contains("ueb-pin-input-wrap");!i&&t>ne.pinInputWrapWidth?this.element.classList.add("ueb-pin-input-wrap"):i&&t<=ne.pinInputWrapWidth&&this.element.classList.remove("ueb-pin-input-wrap")}firstUpdated(e){super.firstUpdated(e);this.constructor.canWrapInput&&this.isInputRendered()&&(this.element.addEventListener("input",this.#wt),this.nameWidth=this.blueprint.scaleCorrect(this.element.querySelector(".ueb-pin-name")?.getBoundingClientRect().width??0)),this.#vt=this.element.querySelector(".ueb-pin-input-wrapper"),this.#yt=[...this.element.querySelectorAll("ueb-input")]}setup(){super.setup();const e=this.constructor;e.saveEachInputChange?this.element.addEventListener("input",this.#ft):this.element.addEventListener("focusout",this.#ft),e.canWrapInput&&this.isInputRendered()&&(this.element.addEventListener("input",this.#wt),this.element.nodeElement.addEventListener(ne.nodeReflowEventName,this.#wt))}cleanup(){super.cleanup(),this.element.nodeElement.removeEventListener(ne.nodeReflowEventName,this.#wt),this.element.removeEventListener("input",this.#wt),this.element.removeEventListener("input",this.#ft),this.element.removeEventListener("focusout",this.#ft)}getInput(){return this.getInputs().reduce(((e,t)=>e+t),"")}getInputs(){return this.#yt.map((e=>ue.clearHTMLWhitespace(e.innerHTML)))}setInputs(e=[],t=!0){this.#yt.forEach(this.constructor.singleLineInput?(t,i)=>t.innerText=e[i]:(t,i)=>t.innerText=e[i].replaceAll("\n","")),t&&this.setDefaultValue(e.map((e=>Bi.stringFromInputToUE(e))),e),this.element.requestUpdate(),this.element.nodeElement.acknowledgeReflow()}setDefaultValue(e=[],t=e){this.element.setDefaultValue(e.join(""))}renderInput(){const e=this.constructor,t=e.singleLineInput,i=e.selectOnFocus;return H`
`}}class Vi extends Zt{renderIcon(){return De.execPin}renderName(){let e=this.element.entity.PinName;if(this.element.entity.PinFriendlyName)e=this.element.entity.PinFriendlyName.toString();else if("execute"===e||"then"===e)return H``;return H`${this.element.getPinDisplayName()}`}}class $i extends Bi{static singleLineInput=!0;setInputs(e=[],t=!1){if(e&&0!=e.length||(e=[this.getInput()]),super.setInputs(e,!1),t){let i=[];for(const r of e){let e=parseFloat(r);isNaN(e)&&(e=0,t=!1),i.push(e)}this.setDefaultValue(i,e)}}setDefaultValue(e=[],t){this.element.setDefaultValue(e[0]),this.element.requestUpdate()}}class Oi extends $i{setDefaultValue(e=[],t){this.element.setDefaultValue(new Ke(e[0])),this.element.requestUpdate()}renderInput(){return H`
`}} +var te,ie;class se extends b{constructor(){super(...arguments),this.renderOptions={host:this},this._$Do=void 0}createRenderRoot(){var e,t;const i=super.createRenderRoot();return null!==(e=(t=this.renderOptions).renderBefore)&&void 0!==e||(t.renderBefore=i.firstChild),i}update(e){const t=this.render();this.hasUpdated||(this.renderOptions.isConnected=this.isConnected),super.update(e),this._$Do=((e,t,i)=>{var s,n;const r=null!==(s=null==i?void 0:i.renderBefore)&&void 0!==s?s:t;let a=r._$litPart$;if(void 0===a){const e=null!==(n=null==i?void 0:i.renderBefore)&&void 0!==n?n:null;r._$litPart$=a=new K(t.insertBefore(P(),e),e,void 0,null!=i?i:{})}return a._$AI(e),a})(t,this.renderRoot,this.renderOptions)}connectedCallback(){var e;super.connectedCallback(),null===(e=this._$Do)||void 0===e||e.setConnected(!0)}disconnectedCallback(){var e;super.disconnectedCallback(),null===(e=this._$Do)||void 0===e||e.setConnected(!1)}render(){return O}}se.finalized=!0,se._$litElement$=!0,null===(te=globalThis.litElementHydrateSupport)||void 0===te||te.call(globalThis,{LitElement:se});const ne=globalThis.litElementPolyfillSupport;null==ne||ne({LitElement:se}),(null!==(ie=globalThis.litElementVersions)&&void 0!==ie?ie:globalThis.litElementVersions=[]).push("3.3.3");class re{static nodeColors={black:r``,blue:r``,darkBlue:r``,darkerBlue:r``,darkTurquoise:r``,gray:r``,green:r``,intenseGreen:r``,lime:r``,red:r``,turquoise:r``,violet:r``,yellow:r``};static alphaPattern="repeating-conic-gradient(#7c8184 0% 25%, #c2c3c4 0% 50%) 50% / 10px 10px";static colorDragEventName="ueb-color-drag";static colorPickEventName="ueb-color-pick";static colorWindowEventName="ueb-color-window";static colorWindowName="Color Picker";static defaultCommentHeight=96;static defaultCommentWidth=400;static distanceThreshold=5;static dragEventName="ueb-drag";static dragGeneralEventName="ueb-drag-general";static edgeScrollThreshold=50;static editTextEventName={begin:"ueb-edit-text-begin",end:"ueb-edit-text-end"};static expandGridSize=400;static focusEventName={begin:"blueprint-focus",end:"blueprint-unfocus"};static fontSize=r``;static gridAxisLineColor=r``;static gridExpandThreshold=.25;static gridLineColor=r``;static gridLineWidth=1;static gridSet=8;static gridSetLineColor=r``;static gridShrinkThreshold=4;static gridSize=16;static hexColorRegex=/^\s*#(?[0-9a-fA-F]{2})(?[0-9a-fA-F]{2})(?[0-9a-fA-F]{2})([0-9a-fA-F]{2})?|#(?[0-9a-fA-F])(?[0-9a-fA-F])(?[0-9a-fA-F])\s*$/;static indentation=" ";static keysSeparator=/[\.\(\)]/;static knotOffset=[-re.gridSize,-.5*re.gridSize];static lineTracePattern=/LineTrace(Single|Multi)(\w*)/;static linkCurveHeight=15;static linkCurveWidth=80;static linkMinWidth=100;static nameRegexSpaceReplacement=new RegExp("^K2(?:[Nn]ode)?_|(?<=[a-z])(?=[A-Z0-9])|(?<=[A-Z])(?{let s=100-e;return`M ${e} 0 C ${t.toFixed(3)} 0, ${i.toFixed(3)} 0, 50 50 S ${(s-t+e).toFixed(3)} 100, ${s.toFixed(3)} 100`};static maxZoom=7;static minZoom=-12;static mouseClickButton=0;static mouseRightClickButton=2;static mouseWheelZoomThreshold=80;static nodeDragEventName="ueb-node-drag";static nodeDragGeneralEventName="ueb-node-drag-general";static nodeTitle=(e,t)=>`${e}_${t}`;static nodeRadius=8;static nodeReflowEventName="ueb-node-reflow";static paths={actorBoundEvent:"/Script/BlueprintGraph.K2Node_ActorBoundEvent",addDelegate:"/Script/BlueprintGraph.K2Node_AddDelegate",ambientSound:"/Script/Engine.AmbientSound",asyncAction:"/Script/BlueprintGraph.K2Node_AsyncAction",blueprint:"/Script/Engine.Blueprint",blueprintGameplayTagLibrary:"/Script/GameplayTags.BlueprintGameplayTagLibrary",blueprintMapLibrary:"/Script/Engine.BlueprintMapLibrary",blueprintSetLibrary:"/Script/Engine.BlueprintSetLibrary",callArrayFunction:"/Script/BlueprintGraph.K2Node_CallArrayFunction",callDelegate:"/Script/BlueprintGraph.K2Node_CallDelegate",callFunction:"/Script/BlueprintGraph.K2Node_CallFunction",comment:"/Script/UnrealEd.EdGraphNode_Comment",commutativeAssociativeBinaryOperator:"/Script/BlueprintGraph.K2Node_CommutativeAssociativeBinaryOperator",componentBoundEvent:"/Script/BlueprintGraph.K2Node_ComponentBoundEvent",createDelegate:"/Script/BlueprintGraph.K2Node_CreateDelegate",customEvent:"/Script/BlueprintGraph.K2Node_CustomEvent",doN:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:Do N",doOnce:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:DoOnce",dynamicCast:"/Script/BlueprintGraph.K2Node_DynamicCast",eAttachmentRule:"/Script/Engine.EAttachmentRule",edGraph:"/Script/Engine.EdGraph",eDrawDebugTrace:"/Script/Engine.EDrawDebugTrace",eMaterialSamplerType:"/Script/Engine.EMaterialSamplerType",eNiagara_Float4Channel:"/Niagara/Enums/ENiagara_Float4Channel.ENiagara_Float4Channel",enum:"/Script/CoreUObject.Enum",enumLiteral:"/Script/BlueprintGraph.K2Node_EnumLiteral",eSamplerSourceMode:"/Script/Engine.ESamplerSourceMode",eSearchCase:"/Script/CoreUObject.ESearchCase",eSearchDir:"/Script/CoreUObject.ESearchDir",eSpawnActorCollisionHandlingMethod:"/Script/Engine.ESpawnActorCollisionHandlingMethod",eTextureMipValueMode:"/Script/Engine.ETextureMipValueMode",eTraceTypeQuery:"/Script/Engine.ETraceTypeQuery",event:"/Script/BlueprintGraph.K2Node_Event",executionSequence:"/Script/BlueprintGraph.K2Node_ExecutionSequence",flipflop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:FlipFlop",forEachElementInEnum:"/Script/BlueprintGraph.K2Node_ForEachElementInEnum",forEachLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ForEachLoop",forEachLoopWithBreak:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ForEachLoopWithBreak",forLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ForLoop",forLoopWithBreak:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ForLoopWithBreak",functionEntry:"/Script/BlueprintGraph.K2Node_FunctionEntry",functionResult:"/Script/BlueprintGraph.K2Node_FunctionResult",gameplayTag:"/Script/GameplayTags.GameplayTag",getInputAxisKeyValue:"/Script/BlueprintGraph.K2Node_GetInputAxisKeyValue",ifThenElse:"/Script/BlueprintGraph.K2Node_IfThenElse",inputAxisKeyEvent:"/Script/BlueprintGraph.K2Node_InputAxisKeyEvent",inputDebugKey:"/Script/InputBlueprintNodes.K2Node_InputDebugKey",inputKey:"/Script/BlueprintGraph.K2Node_InputKey",inputVectorAxisEvent:"/Script/BlueprintGraph.K2Node_InputVectorAxisEvent",isValid:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:IsValid",kismetArrayLibrary:"/Script/Engine.KismetArrayLibrary",kismetMathLibrary:"/Script/Engine.KismetMathLibrary",knot:"/Script/BlueprintGraph.K2Node_Knot",linearColor:"/Script/CoreUObject.LinearColor",literal:"/Script/BlueprintGraph.K2Node_Literal",macro:"/Script/BlueprintGraph.K2Node_MacroInstance",makeArray:"/Script/BlueprintGraph.K2Node_MakeArray",makeMap:"/Script/BlueprintGraph.K2Node_MakeMap",makeSet:"/Script/BlueprintGraph.K2Node_MakeSet",makeStruct:"/Script/BlueprintGraph.K2Node_MakeStruct",materialExpressionComponentMask:"/Script/Engine.MaterialExpressionComponentMask",materialExpressionConstant:"/Script/Engine.MaterialExpressionConstant",materialExpressionConstant2Vector:"/Script/Engine.MaterialExpressionConstant2Vector",materialExpressionConstant3Vector:"/Script/Engine.MaterialExpressionConstant3Vector",materialExpressionConstant4Vector:"/Script/Engine.MaterialExpressionConstant4Vector",materialExpressionFunctionInput:"/Script/Engine.MaterialExpressionFunctionInput",materialExpressionLogarithm:"/Script/InterchangeImport.MaterialExpressionLogarithm",materialExpressionLogarithm10:"/Script/Engine.MaterialExpressionLogarithm10",materialExpressionLogarithm2:"/Script/Engine.MaterialExpressionLogarithm2",materialExpressionMaterialFunctionCall:"/Script/Engine.MaterialExpressionMaterialFunctionCall",materialExpressionSquareRoot:"/Script/Engine.MaterialExpressionSquareRoot",materialExpressionTextureCoordinate:"/Script/Engine.MaterialExpressionTextureCoordinate",materialExpressionTextureSample:"/Script/Engine.MaterialExpressionTextureSample",materialGraphNode:"/Script/UnrealEd.MaterialGraphNode",materialGraphNodeComment:"/Script/UnrealEd.MaterialGraphNode_Comment",metasoundEditorGraphExternalNode:"/Script/MetasoundEditor.MetasoundEditorGraphExternalNode",multiGate:"/Script/BlueprintGraph.K2Node_MultiGate",niagaraBool:"/Script/Niagara.NiagaraBool",niagaraClipboardContent:"/Script/NiagaraEditor.NiagaraClipboardContent",niagaraDataInterfaceVolumeTexture:"/Script/Niagara.NiagaraDataInterfaceVolumeTexture",niagaraFloat:"/Script/Niagara.NiagaraFloat",niagaraMatrix:"/Script/Niagara.NiagaraMatrix",niagaraNodeFunctionCall:"/Script/NiagaraEditor.NiagaraNodeFunctionCall",niagaraNodeOp:"/Script/NiagaraEditor.NiagaraNodeOp",niagaraNumeric:"/Script/Niagara.NiagaraNumeric",niagaraPosition:"/Script/Niagara.NiagaraPosition",pawn:"/Script/Engine.Pawn",pcgEditorGraphNode:"/Script/PCGEditor.PCGEditorGraphNode",pcgEditorGraphNodeInput:"/Script/PCGEditor.PCGEditorGraphNodeInput",pcgEditorGraphNodeOutput:"/Script/PCGEditor.PCGEditorGraphNodeOutput",pcgHiGenGridSizeSettings:"/Script/PCG.PCGHiGenGridSizeSettings",pcgSubgraphSettings:"/Script/PCG.PCGSubgraphSettings",promotableOperator:"/Script/BlueprintGraph.K2Node_PromotableOperator",quat4f:"/Script/CoreUObject.Quat4f",reverseForEachLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ReverseForEachLoop",rotator:"/Script/CoreUObject.Rotator",select:"/Script/BlueprintGraph.K2Node_Select",self:"/Script/BlueprintGraph.K2Node_Self",slateBlueprintLibrary:"/Script/UMG.SlateBlueprintLibrary",spawnActorFromClass:"/Script/BlueprintGraph.K2Node_SpawnActorFromClass",switchEnum:"/Script/BlueprintGraph.K2Node_SwitchEnum",switchGameplayTag:"/Script/GameplayTagsEditor.GameplayTagsK2Node_SwitchGameplayTag",switchInteger:"/Script/BlueprintGraph.K2Node_SwitchInteger",switchName:"/Script/BlueprintGraph.K2Node_SwitchName",switchString:"/Script/BlueprintGraph.K2Node_SwitchString",timeline:"/Script/BlueprintGraph.K2Node_Timeline",timeManagementBlueprintLibrary:"/Script/TimeManagement.TimeManagementBlueprintLibrary",transform:"/Script/CoreUObject.Transform",userDefinedEnum:"/Script/Engine.UserDefinedEnum",variableGet:"/Script/BlueprintGraph.K2Node_VariableGet",variableSet:"/Script/BlueprintGraph.K2Node_VariableSet",vector:"/Script/CoreUObject.Vector",vector2D:"/Script/CoreUObject.Vector2D",vector3f:"/Script/CoreUObject.Vector3f",vector4f:"/Script/CoreUObject.Vector4f",whileLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:WhileLoop"};static pinInputWrapWidth=143;static removeEventName="ueb-element-delete";static scale={[-12]:.133333,[-11]:.166666,[-10]:.2,[-9]:.233333,[-8]:.266666,[-7]:.3,[-6]:.333333,[-5]:.375,[-4]:.5,[-3]:.675,[-2]:.75,[-1]:.875,0:1,1:1.25,2:1.375,3:1.5,4:1.675,5:1.75,6:1.875,7:2};static smoothScrollTime=1e3;static stringEscapedCharacters=/["\\]/g;static subObjectAttributeNamePrefix="#SubObject";static subObjectAttributeNameFromEntity=(e,t=!1)=>this.subObjectAttributeNamePrefix+(!t&&e.Class?`_${e.Class.type}`:"")+"_"+e.Name;static subObjectAttributeNameFromReference=(e,t=!1)=>this.subObjectAttributeNamePrefix+(t?"":"_"+e.type)+"_"+e.path;static subObjectAttributeNameFromName=e=>this.subObjectAttributeNamePrefix+"_"+e;static switchTargetPattern=/\/Script\/[\w\.\/\:]+K2Node_Switch([A-Z]\w+)+/;static trackingMouseEventName={begin:"ueb-tracking-mouse-begin",end:"ueb-tracking-mouse-end"};static unescapedBackslash=/(?<=(?:[^\\]|^)(?:\\\\)*)\\(?!\\)/;static windowApplyEventName="ueb-window-apply";static windowApplyButtonText="OK";static windowCancelEventName="ueb-window-cancel";static windowCancelButtonText="Cancel";static windowCloseEventName="ueb-window-close";static CommonEnums={[this.paths.eAttachmentRule]:["KeepRelative","KeepWorld","SnapToTarget"],[this.paths.eMaterialSamplerType]:["Color","Grayscale","Alpha","Normal","Masks","Distance Field Font","Linear Color","Linear Grayscale","Data","External","Virtual Color","Virtual Grayscale","Virtual Alpha","Virtual Normal","Virtual Mask","Virtual Linear Color","Virtual Linear Grayscal"],[this.paths.eNiagara_Float4Channel]:[["NewEnumerator0","R"],["NewEnumerator1","G"],["NewEnumerator2","B"],["NewEnumerator3","A"]],[this.paths.eSamplerSourceMode]:["From texture asset","Shared: Wrap","Shared: Clamp","Hidden"],[this.paths.eSpawnActorCollisionHandlingMethod]:[["Undefined","Default"],["AlwaysSpawn","Always Spawn, Ignore Collisions"],["AdjustIfPossibleButAlwaysSpawn","Try To Adjust Location, But Always Spawn"],["AdjustIfPossibleButDontSpawnIfColliding","Try To Adjust Location, Don't Spawn If Still Colliding"],["DontSpawnIfColliding","Do Not Spawn"]],[this.paths.eSearchCase]:["CaseSensitive","IgnoreCase"],[this.paths.eSearchDir]:["FromStart","FromEnd"],[this.paths.eDrawDebugTrace]:["None","ForOneFrame","ForDuration","Persistent"],[this.paths.eTextureMipValueMode]:["None (use computed mip level)","MipLevel (absolute, 0 is full resolution)","MipBias (relative to the computed mip level)","Derivative (explicit derivative to compute mip level)"],[this.paths.eTraceTypeQuery]:[["TraceTypeQuery1","Visibility"],["TraceTypeQuery2","Camera"]]};static ModifierKeys=["Ctrl","Shift","Alt","Meta"];static rgba=["R","G","B","A"];static Keys={Backspace:"Backspace",Tab:"Tab",LeftControl:"ControlLeft",RightControl:"ControlRight",LeftShift:"ShiftLeft",RightShift:"ShiftRight",LeftAlt:"AltLeft",RightAlt:"AltRight",Enter:"Enter",Pause:"Pause",CapsLock:"CapsLock",Escape:"Escape",Space:"Space",PageUp:"PageUp",PageDown:"PageDown",End:"End",Home:"Home",ArrowLeft:"ArrowLeft",ArrowUp:"ArrowUp",ArrowRight:"ArrowRight",ArrowDown:"ArrowDown",PrintScreen:"PrintScreen",Insert:"Insert",Delete:"Delete",Zero:"Digit0",One:"Digit1",Two:"Digit2",Three:"Digit3",Four:"Digit4",Five:"Digit5",Six:"Digit6",Seven:"Digit7",Eight:"Digit8",Nine:"Digit9",A:"KeyA",B:"KeyB",C:"KeyC",D:"KeyD",E:"KeyE",F:"KeyF",G:"KeyG",H:"KeyH",I:"KeyI",K:"KeyK",L:"KeyL",M:"KeyM",N:"KeyN",O:"KeyO",P:"KeyP",Q:"KeyQ",R:"KeyR",S:"KeyS",T:"KeyT",U:"KeyU",V:"KeyV",W:"KeyW",X:"KeyX",Y:"KeyY",Z:"KeyZ",NumPadZero:"Numpad0",NumPadOne:"Numpad1",NumPadTwo:"Numpad2",NumPadThree:"Numpad3",NumPadFour:"Numpad4",NumPadFive:"Numpad5",NumPadSix:"Numpad6",NumPadSeven:"Numpad7",NumPadEight:"Numpad8",NumPadNine:"Numpad9",Multiply:"NumpadMultiply",Add:"NumpadAdd",Subtract:"NumpadSubtract",Decimal:"NumpadDecimal",Divide:"NumpadDivide",F1:"F1",F2:"F2",F3:"F3",F4:"F4",F5:"F5",F6:"F6",F7:"F7",F8:"F8",F9:"F9",F10:"F10",F11:"F11",F12:"F12",NumLock:"NumLock",ScrollLock:"ScrollLock"}}class ae{static booleanConverter={fromAttribute:(e,t)=>{},toAttribute:(e,t)=>!0===e?"true":!1===e?"false":""};static sigmoid(e,t=1.7){return 1/(1+e/(1-e)**-t)}static sigmoidPositive(e,t=3.7,i=1.1){return 1-Math.exp(-((e/i)**t))}static clamp(e,t=-1/0,i=1/0){return Math.min(Math.max(e,t),i)}static getScale(e){const t=e.blueprint?.getScale()??getComputedStyle(e).getPropertyValue("--ueb-scale");return""!=t?parseFloat(t):1}static minDecimals(e,t=1,i=1e-8){const s=e*10**t;return Math.abs(s%1)>i?e.toString():e.toFixed(t)}static numberFromText(e=""){switch(e=e.toLowerCase()){case"zero":return 0;case"one":return 1;case"two":return 2;case"three":return 3;case"four":return 4;case"five":return 5;case"six":return 6;case"seven":return 7;case"eight":return 8;case"nine":return 9}}static roundDecimals(e,t=1){const i=10**t;return Math.round(e*i)/i}static printNumber(e){return e==Number.POSITIVE_INFINITY?"inf":e==Number.NEGATIVE_INFINITY?"-inf":ae.minDecimals(e)}static printExponential(e){if(e==Number.POSITIVE_INFINITY)return"inf";if(e==Number.NEGATIVE_INFINITY)return"-inf";const t=Math.round(e);if(t>=1e3){const i=Math.floor(Math.log10(t));return`${Math.round(e/10**(i-2))/100}e+${i<10?"0":""}${i}`}return 0==Math.floor(e)?e.toString():this.roundDecimals(e,Math.max(0,3-Math.floor(e).toString().length)).toString()}static approximatelyEqual(e,t,i=1e-8){return!(Math.abs(e-t)>i)}static convertLocation(e,t,i=!1){const s=i?1:1/ae.getScale(t),n=t.getBoundingClientRect();return[Math.round((e[0]-n.x)*s),Math.round((e[1]-n.y)*s)]}static isSerialized(e,t){return e.attributes?.[t]?.serialized??e.constructor.attributes?.[t]?.serialized??!1}static objectGet(e,t,i=void 0){if(void 0!==e){if(!(t instanceof Array))throw new TypeError("UEBlueprint: Expected keys to be an array");return 0!=t.length&&t[0]in e&&void 0!==e[t[0]]?1==t.length?e[t[0]]:ae.objectGet(e[t[0]],t.slice(1),i):i}}static objectSet(e,t,i,s=Object){if(!(t instanceof Array))throw new TypeError("Expected keys to be an array.");if(1==t.length){if(t[0]in e||void 0===e[t[0]])return e[t[0]]=i,!0}else if(t.length>0)return e[t[0]]instanceof Object||(e[t[0]]=new s),ae.objectSet(e[t[0]],t.slice(1),i,s);return!1}static equals(e,t){for(;e instanceof MirroredEntity;)e=e.get();for(;t instanceof MirroredEntity;)t=t.get();return e?.equals&&t?.equals?e.equals(t):(e=ae.sanitize(e),t=ae.sanitize(t),e?.constructor===BigInt&&t?.constructor===Number?t=BigInt(t):e?.constructor===Number&&t?.constructor===BigInt&&(e=BigInt(e)),e===t||e instanceof Array&&t instanceof Array&&(e.length===t.length&&e.every(((e,i)=>ae.equals(e,t[i])))))}static getType(e){return null===e?null:e?.constructor===Object&&e?.type instanceof Function?e.type:e?.constructor}static isValueOfType(e,t,i=!1){return t instanceof MirroredEntity&&(t=t.getTargetType()),i&&null===e||e instanceof t||e?.constructor===t}static snapToGrid(e,t,i){return 1===i?[e,t]:[i*Math.floor(e/i),i*Math.floor(t/i)]}static mergeArrays(e=[],t=[],i=((e,t)=>e==t)){let s=[];e=[...e],t=[...t];e:for(;;){for(let n=0;n|
/g,"\n").replaceAll(/(\)/g,"")}static encodeHTMLWhitespace(e){return e.replaceAll(" "," ")}static capitalFirstLetter(e){return 0===e.length?e:e.charAt(0).toUpperCase()+e.slice(1)}static formatStringName(e=""){return e.replace(/^\s*b(?=[A-Z])/,"").replaceAll(re.nameRegexSpaceReplacement," ").trim().split(" ").map((e=>ae.capitalFirstLetter(e))).join(" ")}static getIdFromReference(e){return e.replace(/(?:.+\.)?([^\.]+)$/,"$1").replaceAll(/(?<=[a-z\d])(?=[A-Z])|(?<=[a-zA-Z])(?=\d)|(?<=[A-Z]{2})(?=[A-Z][a-z])/g,"-").toLowerCase()}static getNameFromPath(e,t=!1){const i=t?/([^\.\/]+?)(?:_\d+)$/:/([^\.\/]+)$/;return e.match(i)?.[1]??""}static printLinearColor(e){return`${Math.round(255*e.R.valueOf())}, ${Math.round(255*e.G.valueOf())}, ${Math.round(255*e.B.valueOf())}`}static getPolarCoordinates(e,t,i=!1){let s=Math.atan2(t,e);return i&&s<0&&(s=2*Math.PI+s),[Math.sqrt(e*e+t*t),s]}static getCartesianCoordinates(e,t){return[e*Math.cos(t),e*Math.sin(t)]}static range(e=0,t=0,i=(t>=e?1:-1)){return Array.from({length:Math.ceil((t-e)/i)},((t,s)=>e+s*i))}static getFirstWordOrder(e){return new RegExp(/\s*/.source+e.join(/[^\n]+\n\s*/.source)+/\s*/.source)}static paste(e,t){const i=new ClipboardEvent("paste",{bubbles:!0,cancelable:!0,clipboardData:new DataTransfer});i.clipboardData.setData("text",t),e.dispatchEvent(i)}static async copy(e){const t=new ClipboardEvent("copy",{bubbles:!0,cancelable:!0,clipboardData:new DataTransfer});e.dispatchEvent(t)}static animate(e,t,i,s,n=(e=>{}),r=(e=>{const t=e**3.5;return t/(t+(1-e)**3.5)})){let a;const o=l=>{void 0===a&&(a=l);let u=(l-a)/i;ae.approximatelyEqual(u,1)||u>1?u=1:n(requestAnimationFrame(o));const c=e+(t-e)*r(u);s(c)};n(requestAnimationFrame(o))}}class oe extends se{#e;get blueprint(){return this.#e}set blueprint(e){this.#e=e}#t;get entity(){return this.#t}set entity(e){this.#t=e}#i;get template(){return this.#i}isInitialized=!1;isSetup=!1;inputObjects=[];initialize(e,t){this.requestUpdate(),this.#t=e,this.#i=t,this.#i.initialize(this),this.isConnected&&this.updateComplete.then((()=>this.setup())),this.isInitialized=!0}connectedCallback(){super.connectedCallback(),this.blueprint=this.closest("ueb-blueprint"),this.isInitialized&&(this.requestUpdate(),this.updateComplete.then((()=>this.setup())))}disconnectedCallback(){super.disconnectedCallback(),this.isSetup&&this.updateComplete.then((()=>this.cleanup())),this.acknowledgeDelete()}createRenderRoot(){return this}setup(){this.template.setup(),this.isSetup=!0}cleanup(){this.template.cleanup(),this.isSetup=!1}willUpdate(e){super.willUpdate(e),this.template.willUpdate(e)}update(e){super.update(e),this.template.update(e)}render(){return this.template.render()}firstUpdated(e){super.firstUpdated(e),this.template.firstUpdated(e),this.template.inputSetup()}updated(e){super.updated(e),this.template.updated(e)}acknowledgeDelete(){let e=new CustomEvent(re.removeEventName);this.dispatchEvent(e)}isSameGraph(e){return this.blueprint&&this.blueprint==e?.blueprint}}class le extends oe{static properties={...super.properties,fromX:{type:Number,attribute:!1},fromY:{type:Number,attribute:!1},toX:{type:Number,attribute:!1},toY:{type:Number,attribute:!1}};constructor(){super(),this.fromX=0,this.fromY=0,this.toX=0,this.toY=0}setBothLocations([e,t]){this.fromX=e,this.fromY=t,this.toX=e,this.toY=t}addSourceLocation(e,t){this.fromX+=e,this.fromY+=t}addDestinationLocation(e,t){this.toX+=e,this.toY+=t}}class ue{static deleteNodes="Delete";static duplicateNodes="(bCtrl=True,Key=D)";static enableLinkDelete="LeftAlt";static enableZoomIn=["LeftControl","RightControl"];static selectAllNodes="(bCtrl=True,Key=A)"}class ce{static#s=new Map;static registerElement(e,t){ce.#s.set(e,t)}static getConstructor(e){return ce.#s.get(e)}}class he{static makeSuccess(e,t,i=null,s=0){return{status:!0,value:t,position:e,bestParser:i,bestPosition:s}}static makeFailure(e=0,t=null,i=0){return{status:!1,value:null,position:e,bestParser:t,bestPosition:i}}static makeContext(e=null,t=""){return{parsernostrum:e,input:t,highlighted:null}}static makePathNode(e,t=0,i=null){return{parent:i,current:e,index:t}}}class pe{static indentation=" ";static highlight="Last valid parser";Self;static frame(e,t="",i=""){t=e?"[ "+t+" ]":"";let s=e.split("\n");const n=Math.max(...s.map((e=>e.length))),r=n";const n=this.isVisited(i),r=this.isHighlighted(e,i);let a=n?"<...>":this.doToString(e,r?"":t,i,s);return r&&(a=pe.frame(a,pe.highlight,t)),a}doToString(e,t,i,s){return`${this.constructor.name} does not implement toString()`}}class de extends pe{#n;get value(){return this.#n}constructor(e){super(),this.#n=e}parse(e,t,i,s){i=this.makePath(i,s);const n=t+this.#n.length,r=e.input.substring(t,n);return this.#n===r?he.makeSuccess(n,this.#n,i,n):he.makeFailure()}doToString(e,t,i,s){return`"${this.value.replaceAll("\n","\\n").replaceAll('"','\\"')}"`}}class me extends pe{static instance=new me;parse(e,t,i,s){return i=this.makePath(i,s),he.makeSuccess(t,"",i,0)}doToString(e,t,i,s){return""}}class ge extends pe{#r;get parsers(){return this.#r}constructor(...e){super(),this.#r=e}parse(e,t,i,s){i=this.makePath(i,s);const n=he.makeSuccess(0,"");for(let s=0;sn.bestPosition&&(n.bestParser=r.bestParser,n.bestPosition=r.bestPosition),r.status)return n.value=r.value,n.position=r.position,n}return n.status=!1,n.value=null,n}doToString(e,t,i,s){if(2===this.#r.length&&this.#r[1]instanceof me){let s=this.#r[0].toString(e,t,i,0);return this.#r[0]instanceof de||(s="<"+s+">"),s+="?",s}const n=t+pe.indentation;let r="ALT<\n"+n+this.#r.map(((t,s)=>t.toString(e,n+" ".repeat(0===s?0:pe.indentation.length-2),i,s))).join("\n"+n+"| ")+"\n"+t+">";return r}}class be extends pe{#a;get parser(){return this.#a}#o;constructor(e,t){super(),this.#a=e,this.#o=t}parse(e,t,i,s){i=this.makePath(i,s);const n=this.#a.parse(e,t,i,0);if(!n.status)return n;const r=this.#o(n.value,e.input,n.position).getParser().parse(e,n.position);return n.bestPosition>r.bestPosition&&(r.bestParser=n.bestParser,r.bestPosition=n.bestPosition),r}doToString(e,t,i,s){return this.#a.toString(e,t,i,0)+" => chained"}}class ve extends pe{static instance=new ve;parse(e,t,i,s){return he.makeFailure()}doToString(e,t,i,s){return""}}class fe extends pe{#a;get parser(){return this.#a}#l="";constructor(e,t){super(),this.#a=e,this.#l=t}makePath(e,t){return e}parse(e,t,i,s){return this.parse=this.#a.parse.bind(this.#a),this.parse(e,t,i,s)}doToString(e,t,i,s){let n=this.#a.toString(e,"",i,s);return n=pe.frame(n,this.#l,t),n}}class ye extends pe{#a;#u;constructor(e){super(),this.#a=e}makePath(e,t){return e}isHighlighted(e,t){if(super.isHighlighted(e,t)){const i={parent:t,parser:this.#u,index:0};e.highlighted=e.highlighted instanceof pe?this.#u:i}return!1}resolve(){return this.#u||(this.#u=this.#a().getParser()),this.#u}parse(e,t,i,s){return this.resolve(),this.parse=this.#u.parse.bind(this.#u),this.parse(e,t,i,s)}doToString(e,t,i,s){return this.resolve(),this.doToString=this.#u.toString.bind(this.#u),this.doToString(e,t,i,s)}}class we extends pe{#a;get parser(){return this.#a}#c;get type(){return this.#c}static Type={NEGATIVE_AHEAD:"?!",NEGATIVE_BEHIND:"?String.raw`[^${e}\\]*(?:\\.[^${e}\\]*)*`;static#g=/[-\+]?(?:\d*\.)?\d+/;static common={number:new RegExp(this.#g.source+String.raw`(?!\.)`),numberInteger:/[\-\+]?\d+(?!\.\d)/,numberNatural:/\d+/,numberExponential:new RegExp(this.#g.source+String.raw`(?:[eE][\+\-]?\d+)?(?!\.)`),numberUnit:/\+?(?:0(?:\.\d+)?|1(?:\.0+)?)(?![\.\d])/,numberByte:/0*(?:25[0-5]|2[0-4]\d|1?\d?\d)(?!\d|\.)/,whitespace:/\s+/,whitespaceOpt:/\s*/,whitespaceInline:/[^\S\n]+/,whitespaceInlineOpt:/[^\S\n]*/,whitespaceMultiline:/\s*?\n\s*/,doubleQuotedString:new RegExp(`"(${this.#m('"')})"`),singleQuotedString:new RegExp(`'(${this.#m("'")})'`),backtickQuotedString:new RegExp("`("+this.#m("`")+")`")};constructor(e,t){super(),this.#h=e,this.#p=new RegExp(`^(?:${e.source})`,e.flags),this.#d=t}parse(e,t,i,s){i=this.makePath(i,s);const n=this.#p.exec(e.input.substring(t));n&&(t+=n[0].length);return n?he.makeSuccess(t,this.#d(n),i,t):he.makeFailure()}doToString(e,t,i,s){let n="/"+this.#h.source+"/";const r=Object.entries(Se.common).find((([e,t])=>t.source===this.#h.source))?.[0];return r&&(n="P."+r),n}}class Ee extends pe{#a;get parser(){return this.#a}#b;get mapper(){return this.#b}constructor(e,t){super(),this.#a=e,this.#b=t}isHighlighted(e,t){if(super.isHighlighted(e,t)){const i={parent:t,parser:this.#a,index:0};e.highlighted=e.highlighted instanceof pe?this.#a:i}return!1}parse(e,t,i,s){i=this.makePath(i,s);const n=this.#a.parse(e,t,i,0);return n.status&&(n.value=this.#b(n.value)),n}doToString(e,t,i,s){let n=this.#a.toString(e,t,i,0);if(this.#a instanceof Se&&Object.values(Se.common).includes(this.#a.regexp))return this.#a.regexp===Se.common.numberInteger&&this.#b===BigInt?"P.numberBigInteger":n;let r=this.#b.toString();return(r.length>60||r.includes("\n"))&&(r="(...) => { ... }"),n+=` -> map<${r}>`,n}}class Ce extends Se{static#b=e=>e;constructor(e){super(e,Ce.#b)}}class Ne extends Se{constructor(e,t=0){super(e,(e=>e[t]))}}class xe extends pe{#r;get parsers(){return this.#r}constructor(...e){super(),this.#r=e}parse(e,t,i,s){i=this.makePath(i,s);const n=new Array(this.#r.length),r=he.makeSuccess(t,n);for(let t=0;tr.bestPosition&&(r.bestParser=s.bestParser,r.bestPosition=s.bestPosition),!s.status){r.status=!1,r.value=null;break}r.value[t]=s.value,r.position=s.position}return r}doToString(e,t,i,s){const n=t+pe.indentation,r="SEQ<\n"+n+this.#r.map(((t,s)=>t.toString(e,n,i,s))).join("\n"+n)+"\n"+t+">";return r}}class Pe extends pe{#a;get parser(){return this.#a}#v;get min(){return this.#v}#f;get max(){return this.#f}constructor(e,t=0,i=Number.POSITIVE_INFINITY){if(super(),t>i)throw new Error("Min is greater than max");this.#a=e,this.#v=t,this.#f=i}parse(e,t,i,s){i=this.makePath(i,s);const n=he.makeSuccess(t,[],i);for(let t=0;tn.bestPosition&&(n.bestParser=s.bestParser,n.bestPosition=s.bestPosition),!s.status){te;static#w=([e,t])=>t;static#S=([e,t])=>[e,...t];static#E=e=>e instanceof Array?e.join(""):e;static#m=e=>String.raw`[^${e}\\]*(?:\\.[^${e}\\]*)*`;static number=this.reg(Se.common.number).map(Number);static numberInteger=this.reg(Se.common.numberInteger).map(Number);static numberBigInteger=this.reg(this.numberInteger.getParser().parser.regexp).map(BigInt);static numberNatural=this.reg(Se.common.numberNatural).map(Number);static numberExponential=this.reg(Se.common.numberExponential).map(Number);static numberUnit=this.reg(Se.common.numberUnit).map(Number);static numberByte=this.reg(Se.common.numberByte).map(Number);static whitespace=this.reg(Se.common.whitespace);static whitespaceOpt=this.reg(Se.common.whitespaceOpt);static whitespaceInline=this.reg(Se.common.whitespaceInline);static whitespaceInlineOpt=this.reg(Se.common.whitespaceInlineOpt);static whitespaceMultiline=this.reg(Se.common.whitespaceMultiline);static doubleQuotedString=this.reg(Se.common.doubleQuotedString,1);static singleQuotedString=this.reg(Se.common.singleQuotedString,1);static backtickQuotedString=this.reg(Se.common.backtickQuotedString,1);constructor(e,t=!1){this.#a=e}static#C(e){const t=[];for(;e;)t.push(e),e=e.parent;t.reverse();let i=new Map;for(let e=1;ei<=s||i>e))),i.set(t[e].current,s),t.splice(s+1,e-s),e=s):i.set(t[e].current,e)}return t[t.length-1]}getParser(){return this.#a}run(e){const t=this.#a.parse(he.makeContext(this,e),0,he.makePathNode(),0);return t.position!==e.length&&(t.status=!1),t}parse(e,t=!0){const i=this.run(e);if(i.status)return i.value;const s=[Math.ceil(30),Math.floor(30)],n=ke.lineColumnFromOffset(e,i.bestPosition);let r=i.bestPosition;const a=e.replaceAll(/^(\s)+|\s{6,}|\s*?\n\s*/g,((e,t,s)=>{let n=t?"...":" ... ";return s<=i.bestPosition&&(i.bestPosition0&&(c="..."+c,u+=3),s[1]e.getParser()))));return t}static alt(...e){return new this(new ge(...e.map((e=>e.getParser()))))}static lookahead(e){return new this(new we(e.getParser(),we.Type.POSITIVE_AHEAD))}static lazy(e){return new this(new ye(e))}times(e,t=e){return new ke(new Pe(this.#a,e,t))}many(){return this.times(0,Number.POSITIVE_INFINITY)}atLeast(e){return this.times(e,Number.POSITIVE_INFINITY)}atMost(e){return this.times(0,e)}opt(){return ke.alt(this,ke.success())}sepBy(e,t=!1){return ke.seq(this,ke.seq(e,this).map(ke.#w).many()).map(ke.#S)}skipSpace(){return ke.seq(this,ke.whitespaceOpt).map(ke.#y)}map(e){return new ke(new Ee(this.#a,e))}chain(e){return new ke(new be(this.#a,e))}assert(e){return this.chain(((t,i,s)=>e(t,i,s)?ke.success().map((()=>t)):ke.failure()))}join(e=""){return this.map(ke.#E)}label(e=""){return new ke(new fe(this.#a,e))}toString(e="",t=!1,i=null){i instanceof ke&&(i=i.getParser());const s=he.makeContext(this,"");s.highlighted=i;const n=he.makePathNode();return(t?"\n"+e:"")+this.#a.toString(s,e,n)}}class Ae{static#N={nullable:!1,ignored:!1,serialized:!1,expected:!1,inlined:!1,quoted:!1,silent:!1,uninitialized:!1};constructor(e){this.type=e.type??e.default?.constructor,this.default=e.default,this.nullable=e.nullable??null===e.default,this.ignored=e.ignored,this.serialized=e.serialized,this.expected=e.expected,this.inlined=e.inlined,this.quoted=e.quoted,this.silent=e.silent,this.uninitialized=e.uninitialized,this.predicate=e.predicate,this.type===Array&&this.default instanceof Array&&this.default.length>0&&(this.type=this.default.map((e=>e.constructor)).reduce(((e,t)=>(e.includes(t)||e.push(t),e)),[]))}static createType(e){return new Ae({type:e})}static createValue(e){return new Ae({default:e})}static hasAttribute(e,t,i,s=e.constructor){const n=e,r=n.attributes[t]?.[i];return r??s?.attributes?.[t]?.[i]??Ae.#N[i]}static getAttribute(e,t,i,s=e.constructor){let n=e.attributes?.[t]?.[i];return void 0!==n?n:(n=(s?.attributes)?.[t]?.[i],void 0!==n?n:(n=Ae.#N[i],void 0!==n?n:void 0))}get(e){return this[e]??Ae.#N[e]}}class Le{static same=e=>e;static notWrapped=(e,t)=>t;static bracketsWrapped=(e,t)=>`(${t})`;static wrap=this.notWrapped;static attributeSeparator=",";static trailingSeparator=!1;static printKey=e=>e;static grammar=ke.failure();static attributes={};static lookbehind="";#x=this.Self().lookbehind;get lookbehind(){return this.#x}set lookbehind(e){throw this.#x=e}#P;get keys(){return this.#P??Object.keys(this.Self().attributes)}set keys(e){this.#P=[...new Set(e)]}static default;static nullable=!1;static ignored=!1;static serialized=!1;static expected=!1;static inlined=!1;static quoted=!1;static silent=!1;static uninitialized=!1;constructor(e={}){const t=ae.mergeArrays(Object.keys(e.attributes),Object.keys(this.Self().attributes));for(const i of t){if(void 0!==e[i]){this[i]=e[i];continue}const t=this.Self().attributes[i];void 0===t.default||(this[i]=t.default(t))}}showProperty(e){let t=this[e];const i=t.Self();if(i.silent&&void 0!==i.default){void 0===i["#default"]&&(i["#default"]=i.default(i));const e=i["#default"];return!t.equals(e)}return!0}static asUniqueClass(){return this.name.length?class extends(this){}:this}static withDefault(e=(e=>new e)){const t=this.asUniqueClass();return t.default=e,t}static flagNullable(e=!0){const t=this.asUniqueClass();return t.nullable=e,t}static flagSerialized(e=!0){const t=this.asUniqueClass();return t.serialized=e,t}static flagInlined(e=!0){const t=this.asUniqueClass();return t.inlined=e,t}static flagSilent(e=!0){const t=this.asUniqueClass();return t.silent=e,t}Self(){return this.constructor}listenAttribute(e,t){const i=Object.getOwnPropertyDescriptor(this,e),s=i.set;s?(i.set=e=>{s(e),t(e)},Object.defineProperties(this,{[e]:i})):i.value&&Object.defineProperties(this,{["#"+e]:{value:i.value,writable:!0,enumerable:!1},[e]:{enumerable:!0,get(){return this["#"+e]},set(i){i!=this["#"+e]&&(t(i),this["#"+e]=i)}}})}equals(e){const t=Object.keys(this),i=Object.keys(e);if(t.length!=i.length)return!1;for(let s=0;si(`${a}.${e}`)));continue}let l=i(a);l.length&&(s.quoted&&(l=`"${l}"`),n+=s.attributeSeparator.includes("\n")?t:"");let u=o.toString(e,t,i);s.serialized&&(u=`"${u.replaceAll(/(?<=(?:[^\\]|^)(?:\\\\)*?)"/,'\\"')}"`),n+=u}return s.trailingSeparator&&n.length&&(n+=s.attributeSeparator),s.wrap(this,n)}}class Me extends Le{static type;constructor(e=null){super(),this.getter=e}static of(e){const t=this.asUniqueClass();return t.type=e,t.grammar=t.getTargetType().grammar.map((e=>new this)),t}static getTargetType(){const e=this.type;return e.prototype instanceof Me?e.getTargetType():e}toString(){return this.getter().toString()}}class Te{static grammar=ke.failure()}class Ie{static separatedBy=(e,t,i=1)=>new RegExp(e+"(?:"+t+e+")"+(1===i?"*":2===i?"+":`{${i},}`));static Regex=class{static HexDigit=/[0-9a-fA-F]/;static InsideString=/(?:[^"\\]|\\.)*/;static InsideSingleQuotedString=/(?:[^'\\]|\\.)*/;static Integer=/[\-\+]?\d+(?!\d|\.)/;static Number=/[-\+]?(?:\d*\.)?\d+(?!\d|\.)/;static RealUnit=/\+?(?:0(?:\.\d+)?|1(?:\.0+)?)(?![\.\d])/;static Word=Ie.separatedBy("[a-zA-Z]","_");static Symbol=/[a-zA-Z_]\w*/;static DotSeparatedSymbols=Ie.separatedBy(this.Symbol.source,"\\.");static MultipleWordsSymbols=Ie.separatedBy(this.Symbol.source,"(?:\\.|\\ +)");static PathFragment=Ie.separatedBy(this.Symbol.source,"[\\.:]");static PathSpaceFragment=Ie.separatedBy(this.Symbol.source,"[\\.:\\ ]");static Path=new RegExp(`(?:\\/${this.PathFragment.source}){2,}`)};static null=ke.reg(/\(\s*\)/).map((()=>null));static true=ke.reg(/true/i).map((()=>!0));static false=ke.reg(/false/i).map((()=>!1));static number=ke.regArray(new RegExp(`(${ke.number.getParser().parser.regexp.source})|(\\+?inf)|(-inf)`)).map((([e,t,i,s])=>t?Number(t):i?Number.POSITIVE_INFINITY:Number.NEGATIVE_INFINITY));static bigInt=ke.reg(new RegExp(ke.number.getParser().parser.regexp.source)).map(BigInt).map((e=>void 0!==e[2]?Number.POSITIVE_INFINITY:void 0!==e[3]?Number.NEGATIVE_INFINITY:Number(e[1])));static naturalNumber=ke.lazy((()=>ke.reg(/\d+/).map(Number)));static string=ke.doubleQuotedString.map((e=>ae.unescapeString(e)));static colorValue=ke.numberByte;static word=ke.reg(Ie.Regex.Word);static symbol=ke.reg(Ie.Regex.Symbol);static symbolQuoted=ke.reg(new RegExp('"('+Ie.Regex.Symbol.source+')"'),1);static attributeName=ke.reg(Ie.Regex.DotSeparatedSymbols);static attributeNameQuoted=ke.reg(new RegExp('"('+Ie.Regex.InsideString.source+')"'),1);static guid=ke.reg(new RegExp(`${Ie.Regex.HexDigit.source}{32}`));static commaSeparation=ke.reg(/\s*,\s*(?!\))/);static commaOrSpaceSeparation=ke.reg(/\s*,\s*(?!\))|\s+/);static equalSeparation=ke.reg(/\s*=\s*/);static hexColorChannel=ke.reg(new RegExp(Ie.Regex.HexDigit.source+"{2}"));static grammarFor(e,t=e?.type,i=this.unknownValue){let s=i;if(t===Array||t instanceof Array){if(e?.inlined)return this.grammarFor(void 0,t[0]);s=ke.seq(ke.reg(/\(\s*/),this.grammarFor(void 0,t[0]).sepBy(this.commaSeparation).opt(),ke.reg(/\s*(?:,\s*)?\)/)).map((([e,t,i])=>t instanceof Array?t:[]))}else if(t instanceof Union)s=t.values.map((e=>this.grammarFor(void 0,e))).reduce(((e,t)=>t&&t!==this.unknownValue&&e!==this.unknownValue?ke.alt(e,t):this.unknownValue));else{if(t instanceof Me)return this.grammarFor(void 0,t.getTargetType()).map((e=>new Me(t.type,(()=>e))));if(e?.constructor===Object)s=this.grammarFor(void 0,t);else switch(t){case Boolean:s=this.boolean;break;case null:s=this.null;break;case Number:s=this.number;break;case BigInt:s=this.bigInt;break;case String:s=this.string;break;default:t?.prototype instanceof Te&&(s=t.grammar)}}return e&&(e.serialized&&t.constructor!==String&&(s=s==this.unknownValue?this.string:ke.seq(ke.str('"'),s,ke.str('"')).map((([e,t,i])=>t))),e.nullable&&(s=ke.alt(s,this.null))),s}static getAttribute(e,t){let i,s;if(e instanceof Union)for(let s of e.values)if(i=this.getAttribute(s,t))return i;return e instanceof Le.constructor?(i=e.attributes[t[0]],s=i?.type):e instanceof Array&&(i=e[t[0]],s=i),t.length>1?this.getAttribute(s,t.slice(1)):i}static createAttributeGrammar(e,t=this.attributeName,i=this.equalSeparation,s=((e,t,i)=>{})){return ke.seq(t,i).chain((([t,i])=>{const n=t.split(re.keysSeparator),r=this.getAttribute(e,n);return this.grammarFor(r).map((e=>t=>{s(t,n,e),ae.objectSet(t,n,e)}))}))}static createEntityGrammar(e,t=!0,i=this.commaSeparation){const s=e.attributes.lookbehind.default;return ke.seq(ke.reg(s instanceof Union?new RegExp(`(${s.values.reduce(((e,t)=>e+"|"+t))})\\s*\\(\\s*`):s.constructor==String&&s.length>0?new RegExp(`(${s})\\s*\\(\\s*`):/()\(\s*/,1),this.createAttributeGrammar(e).sepBy(i),ke.reg(/\s*(?:,\s*)?\)/)).map((([e,t,i])=>{let s={};return t.forEach((e=>e(s))),e.length&&(s.lookbehind=e),s})).chain((i=>{let s=Object.keys(i);if(Object.keys(e.attributes).filter((t=>e.attributes[t].expected)).find((e=>!s.includes(e)&&e)))return ke.failure();const n=Object.keys(i).filter((t=>!(t in e.attributes))).length;return!t&&n>0?ke.failure():ke.success().map((()=>new e(i)))}))}static unknownValue}class $e extends Le{static grammar=ke.number.map((e=>new this(e)));constructor(e=0){super(),this.value=e}valueOf(){return this.value}toString(){return this.value.toFixed(6)}}class De extends Le{static attributes={...super.attributes,R:$e.withDefault(),G:$e.withDefault(),B:$e.withDefault(),A:$e.withDefault((e=>new e(1)))};static grammar=Ie.createEntityGrammar(this,!1);#k=new $e;get H(){return this.#k}set H(e){this.#k=e}#A=new $e;get S(){return this.#k}set S(e){this.#k=e}#L=new $e;get V(){return this.#k}set V(e){this.#k=e}static linearToSRGB(e){return e<=0?0:e>=1?1:e<.0031308?12.92*e:1.055*Math.pow(e,1/2.4)-.055}static sRGBtoLinear(e){return e<=0?0:e>=1?1:e<.04045?e/12.92:Math.pow((e+.055)/1.055,2.4)}static getWhite(){return new De({R:1,G:1,B:1})}static getLinearColorFromHexGrammar(){const e=/[0-9a-fA-F]/;return ke.regArray(new RegExp("#("+e.source+"{2})("+e.source+"{2})("+e.source+"{2})("+e.source+"{2})?")).map((([e,t,i,s,n])=>new this({R:parseInt(t,16)/255,G:parseInt(i,16)/255,B:parseInt(s,16)/255,A:parseInt(n??"FF",16)/255})))}static getLinearColorRGBListGrammar(){return ke.seq(ke.numberByte,Ie.commaSeparation,ke.numberByte,Ie.commaSeparation,ke.numberByte).map((([e,t,i,s,n])=>new this({R:e/255,G:i/255,B:n/255,A:1})))}static getLinearColorRGBGrammar(){return ke.seq(ke.reg(/rgb\s*\(\s*/),this.getLinearColorRGBListGrammar(),ke.reg(/\s*\)/)).map((([e,t,i])=>t))}static getLinearColorRGBAGrammar(){return ke.seq(ke.reg(/rgba\s*\(\s*/),this.getLinearColorRGBListGrammar(),ke.reg(/\s*\)/)).map((([e,t,i])=>t))}static getLinearColorFromAnyFormat(){return ke.alt(this.getLinearColorFromHexGrammar(),this.getLinearColorRGBAGrammar(),this.getLinearColorRGBGrammar(),this.getLinearColorRGBListGrammar())}constructor(e){super(e),e instanceof Array&&(e={R:e[0]??0,G:e[1]??0,B:e[2]??0,A:e[3]??1}),this.R,this.G,this.B,this.A,this.#M()}#M(){const e=this.R.value,t=this.G.value,i=this.B.value;if(ae.approximatelyEqual(e,t)&&ae.approximatelyEqual(e,i)&&ae.approximatelyEqual(t,i))return this.S.value=0,void(this.V.value=e);const s=Math.max(e,t,i),n=Math.min(e,t,i),r=s-n;let a;switch(s){case n:a=0;break;case e:a=(t-i)/r+(te.toString(16).toUpperCase().padStart(2,"0"))).join("")}toSRGBAString(){return this.toSRGBA().map((e=>e.toString(16).toUpperCase().padStart(2,"0"))).join("")}toHSVA(){return[this.H.value,this.S.value,this.V.value,this.A.value]}toNumber(){return(Math.round(255*this.R.value)<<24)+(Math.round(255*this.G.value)<<16)+(Math.round(255*this.B.value)<<8)+Math.round(255*this.A.value)}setFromRGBANumber(e){this.A.value=(255&e)/255,this.B.value=(e>>8&255)/255,this.G.value=(e>>16&255)/255,this.R.value=(e>>24&255)/255,this.#M()}setFromSRGBANumber(e){this.A.value=(255&e)/255,this.B.value=De.sRGBtoLinear((e>>8&255)/255),this.G.value=De.sRGBtoLinear((e>>16&255)/255),this.R.value=De.sRGBtoLinear((e>>24&255)/255),this.#M()}toArray(){return[this.R.value,this.G.value,this.B.value,this.A.value]}toString(){return ae.printLinearColor(this)}}class Be{static arrayPin=H``;static branchNode=H``;static breakStruct=H``;static cast=H``;static close=H``;static convert=H``;static correct=H``;static delegate=H``;static doN=H``;static doOnce=H``;static enum=H``;static event=H``;static execPin=H``;static expandIcon=H``;static flipflop=H``;static forEachLoop=H``;static functionSymbol=H``;static gamepad=H``;static genericPin=H``;static keyboard=H``;static loop=H``;static macro=H``;static mapPin=H``;static makeArray=H``;static makeMap=H``;static makeSet=H``;static makeStruct=H``;static metasoundFunction=H``;static mouse=H``;static node=H``;static operationPin=H``;static pcgStackPin=H``;static pcgPin=H``;static pcgParamPin=H``;static pcgSpatialPin=H``;static plusCircle=H``;static questionMark=H``;static referencePin=H``;static reject=H``;static setPin=H``;static select=H``;static sequence=H``;static sound=H``;static spawnActor=H``;static switch=H``;static timer=H``;static touchpad=H``}const Ve=/\/Script\/SequencerScripting\.MovieSceneScripting(.+)Channel/,He={A_AccentGrave:"à",Add:"Num +",C_Cedille:"ç",Decimal:"Num .",Divide:"Num /",E_AccentAigu:"é",E_AccentGrave:"è",F1:"F1",F10:"F10",F11:"F11",F12:"F12",F2:"F2",F3:"F3",F4:"F4",F5:"F5",F6:"F6",F7:"F7",F8:"F8",F9:"F9",Gamepad_Special_Left_X:"Touchpad Button X Axis",Gamepad_Special_Left_Y:"Touchpad Button Y Axis",Mouse2D:"Mouse XY 2D-Axis",Multiply:"Num *",Section:"§",Subtract:"Num -",Tilde:"`"};function Oe(e){let t;switch(e.getType()){case re.paths.asyncAction:if(e.ProxyFactoryFunctionName)return ae.formatStringName(e.ProxyFactoryFunctionName);case re.paths.actorBoundEvent:case re.paths.componentBoundEvent:return`${ae.formatStringName(e.DelegatePropertyName)} (${e.ComponentPropertyName??"Unknown"})`;case re.paths.callDelegate:return`Call ${e.DelegateReference?.MemberName??"None"}`;case re.paths.createDelegate:return"Create Event";case re.paths.customEvent:if(e.CustomFunctionName)return e.CustomFunctionName;case re.paths.dynamicCast:return e.TargetType?`Cast To ${e.TargetType?.getName()}`:"Bad cast node";case re.paths.enumLiteral:return`Literal enum ${e.Enum?.getName()}`;case re.paths.event:return`Event ${(e.EventReference?.MemberName??"").replace(/^Receive/,"")}`;case re.paths.executionSequence:return"Sequence";case re.paths.forEachElementInEnum:return`For Each ${e.Enum?.getName()}`;case re.paths.forEachLoopWithBreak:return"For Each Loop with Break";case re.paths.functionEntry:return"UserConstructionScript"===e.FunctionReference?.MemberName?"Construction Script":e.FunctionReference?.MemberName;case re.paths.functionResult:return"Return Node";case re.paths.ifThenElse:return"Branch";case re.paths.makeStruct:if(e.StructType)return`Make ${e.StructType.getName()}`;case re.paths.materialExpressionComponentMask:{const t=e.getMaterialSubobject();return`Mask ( ${re.rgba.filter((e=>!0===t[e].get())).map((e=>e+" ")).join("")})`}case re.paths.materialExpressionConstant:t??=[e.getCustomproperties().find((e=>"Value"==e.PinName))?.DefaultValue];case re.paths.materialExpressionConstant2Vector:t??=[e.getCustomproperties().find((e=>"X"==e.PinName))?.DefaultValue,e.getCustomproperties().find((e=>"Y"==e.PinName))?.DefaultValue];case re.paths.materialExpressionConstant3Vector:if(!t){const i=e.getCustomproperties().find((e=>"Constant"==e.PinName))?.DefaultValue;t=[i.X,i.Y,i.Z]}case re.paths.materialExpressionConstant4Vector:if(!t){const i=e.getCustomproperties().find((e=>"Constant"==e.PinName))?.DefaultValue;t=[i.R,i.G,i.B,i.A].map((e=>e.valueOf()))}if(t.length>0)return t.map((e=>ae.printExponential(e))).reduce(((e,t)=>e+","+t));break;case re.paths.materialExpressionFunctionInput:{const t=e.getMaterialSubobject();return`Input ${t?.InputName??"In"} (${t?.InputType?.value.match(/^.+?_(\w+)$/)?.[1]??"Vector3"})`}case re.paths.materialExpressionLogarithm:return"Ln";case re.paths.materialExpressionLogarithm10:return"Log10";case re.paths.materialExpressionLogarithm2:return"Log2";case re.paths.materialExpressionMaterialFunctionCall:const i=e.getMaterialSubobject()?.MaterialFunction;if(i)return i.getName();break;case re.paths.materialExpressionSquareRoot:return"Sqrt";case re.paths.metasoundEditorGraphExternalNode:{const t=e.ClassName?.Name;if(t)return"Add"===t?"+":t}case re.paths.pcgEditorGraphNodeInput:return"Input";case re.paths.pcgEditorGraphNodeOutput:return"Output";case re.paths.spawnActorFromClass:let s=e.getCustomproperties().find((e=>"ReturnValue"==e.PinName))?.PinType?.PinSubCategoryObject?.getName();return"Actor"===s&&(s=null),`SpawnActor ${ae.formatStringName(s??"NONE")}`;case re.paths.switchEnum:return`Switch on ${e.Enum?.getName()??"Enum"}`;case re.paths.switchInteger:return"Switch on Int";case re.paths.variableGet:return"";case re.paths.variableSet:return"SET"}let i=e.switchTarget();if(i)return"E"!==i[0]&&(i=ae.formatStringName(i)),`Switch on ${i}`;if(e.isComment())return e.NodeComment;const s=e.getHIDAttribute();if(s){const t=s.toString();let i=function(e){let t=He[e];if(t)return t;if(t=ae.numberFromText(e)?.toString(),t)return t;const i=e.match(/NumPad([a-zA-Z]+)/);return i&&(t=ae.numberFromText(i[1]).toString(),t)?"Num "+t:void 0}(t)??ae.formatStringName(t);return e.getClass()===re.paths.inputDebugKey?i="Debug Key "+i:e.getClass()===re.paths.getInputAxisKeyValue&&(i="Get "+i),i}if(e.getClass()===re.paths.macro)return ae.formatStringName(e.MacroGraphReference?.getMacroName());if(e.isMaterial()&&e.getMaterialSubobject()){let t=Oe(e.getMaterialSubobject());return t=t.match(/Material Expression (.+)/)?.[1]??t,t}if(e.isPcg()&&e.getPcgSubobject()){let t=e.getPcgSubobject();return t.NodeTitle?t.NodeTitle:Oe(t)}const n=e.getSubgraphObject();if(n)return n.Graph.getName();const r=e.getSettingsObject();if(r){if(r.ExportPath.type===re.paths.pcgHiGenGridSizeSettings)return`Grid Size: ${r.HiGenGridSize?.toString().match(/\d+/)?.[0]?.concat("00")??r.HiGenGridSize?.toString().match(/^\w+$/)?.[0]??"256"}`;if(r.BlueprintElementInstance)return ae.formatStringName(r.BlueprintElementType.getName());if(r.Operation){const e=r.Name.match(/PCGMetadata(\w+)Settings_\d+/);if(e)return ae.formatStringName(e[1]+": "+r.Operation)}const e=r.getSubgraphObject();if(e&&e.Graph)return e.Graph.getName()}let a=e.FunctionReference?.MemberName;if(a){const t=e.FunctionReference.MemberParent?.path??"";switch(a){case"AddKey":let e=t.match(Ve);if(e)return`Add Key (${ae.formatStringName(e[1])})`;case"Concat_StrStr":return"Append"}const i=a.match(re.lineTracePattern);if(i)return"Line Trace"+("Multi"===i[1]?" Multi ":" ")+(""===i[2]?"By Channel":ae.formatStringName(i[2]));switch(t){case re.paths.blueprintGameplayTagLibrary:case re.paths.kismetMathLibrary:case re.paths.slateBlueprintLibrary:case re.paths.timeManagementBlueprintLibrary:const e=a.match(/[BF]([A-Z]\w+)/);switch(e&&(a=e[1]),a){case"Abs":return"ABS";case"BooleanAND":return"AND";case"BooleanNAND":return"NAND";case"BooleanOR":return"OR";case"Exp":return"e";case"LineTraceSingle":return"Line Trace By Channel";case"Max":case"MaxInt64":return"MAX";case"Min":case"MinInt64":return"MIN";case"Not_PreBool":return"NOT";case"Sin":return"SIN";case"Sqrt":return"SQRT";case"Square":return"^2";case"CrossProduct2D":return"cross";case"Vector4_CrossProduct3":return"cross3";case"DotProduct2D":case"Vector4_DotProduct":return"dot";case"Vector4_DotProduct3":return"dot3"}if(a.startsWith("Add_"))return"+";if(a.startsWith("And_"))return"&";if(a.startsWith("Conv_"))return"";if(a.startsWith("Cross_"))return"cross";if(a.startsWith("Divide_"))return String.fromCharCode(247);if(a.startsWith("Dot_"))return"dot";if(a.startsWith("EqualEqual_"))return"==";if(a.startsWith("Greater_"))return">";if(a.startsWith("GreaterEqual_"))return">=";if(a.startsWith("Less_"))return"<";if(a.startsWith("LessEqual_"))return"<=";if(a.startsWith("Multiply_"))return String.fromCharCode(10799);if(a.startsWith("Not_"))return"~";if(a.startsWith("NotEqual_"))return"!=";if(a.startsWith("Or_"))return"|";if(a.startsWith("Percent_"))return"%";if(a.startsWith("Subtract_"))return"-";if(a.startsWith("Xor_"))return"^";break;case re.paths.blueprintSetLibrary:{const e=a.match(/Set_(\w+)/);if(e)return ae.formatStringName(e[1]).toUpperCase()}break;case re.paths.blueprintMapLibrary:{const e=a.match(/Map_(\w+)/);if(e)return ae.formatStringName(e[1]).toUpperCase()}break;case re.paths.kismetArrayLibrary:{const e=a.match(/Array_(\w+)/);if(e)return e[1].toUpperCase()}}return ae.formatStringName(a)}if(e.OpName){switch(e.OpName){case"Boolean::LogicAnd":return"Logic AND";case"Boolean::LogicEq":return"==";case"Boolean::LogicNEq":return"!=";case"Boolean::LogicNot":return"Logic NOT";case"Boolean::LogicOr":return"Logic OR";case"Matrix::MatrixMultiply":return"Multiply (Matrix * Matrix)";case"Matrix::MatrixVectorMultiply":return"Multiply (Matrix * Vector4)";case"Numeric::Abs":return"Abs";case"Numeric::Add":return"+";case"Numeric::DistancePos":return"Distance";case"Numeric::Mul":return String.fromCharCode(10799)}return ae.formatStringName(e.OpName).replaceAll("::"," ")}return e.FunctionDisplayName?ae.formatStringName(e.FunctionDisplayName):e.ObjectRef?e.ObjectRef.getName():ae.formatStringName(e.getNameAndCounter()[0])}var Re;"undefined"==typeof window?import("crypto").then((e=>Re=e.default)).catch():Re=window.crypto;class Ge extends Le{static grammar=ke.reg(/[0-9a-fA-F]{32}/).map((e=>new this(e)));static generateGuid(){let e=new Uint32Array(4);Re.getRandomValues(e);let t="";return e.forEach((e=>{t+=("0".repeat(8)+e.toString(16).toUpperCase()).slice(-8)})),t}constructor(e=Ge.generateGuid()){super(),this.value=e}valueOf(){return this.value}toString(){return this.value}}const ze={[re.paths.niagaraBool]:r``,[re.paths.niagaraDataInterfaceVolumeTexture]:r``,[re.paths.niagaraFloat]:r``,[re.paths.niagaraMatrix]:r``,[re.paths.niagaraNumeric]:r``,[re.paths.niagaraPosition]:r``,[re.paths.quat4f]:r``,[re.paths.rotator]:r``,[re.paths.transform]:r``,[re.paths.vector]:r``,[re.paths.vector3f]:r``,[re.paths.vector4f]:r``,Any:r``,"Any[]":r``,audio:r``,blue:r``,bool:r``,byte:r``,class:r``,default:r``,delegate:r``,enum:r``,exec:r``,float:r``,green:r``,int:r``,int32:r``,int64:r``,interface:r``,name:r``,object:r``,Param:r``,"Param[]":r``,Point:r``,"Point[]":r``,real:r``,red:r``,string:r``,struct:r``,Surface:r``,"Surface[]":r``,text:r``,time:r``,Volume:r``,"Volume[]":r``,wildcard:r``},_e=r``;class Fe extends Le{static alternatives=[];static createGrammar(){return this.alternatives.map((e=>e.grammar)).reduce(((e,t)=>t&&t!==Ie.unknownValue&&e!==Ie.unknownValue?ke.alt(e,t):Ie.unknownValue))}static accepting(...e){const t=this.asUniqueClass();return t.alternatives=e,t.grammar=t.createGrammar(),t}}class je extends Le{static type;constructor(e=[]){super(),this.values=e}static createGrammar(e=this.type.grammar){return this.inlined?e:ke.seq(ke.reg(/\(\s*/),e.sepBy(Ie.commaSeparation).opt(),ke.reg(/\s*(?:,\s*)?\)/)).map((([e,t,i])=>new this(t instanceof Array?t:[])))}static of(e){const t=this.asUniqueClass();return t.type=e,this.grammar=t.createGrammar(),t}valueOf(){return this.values}}class Ue extends Le{static grammar=ke.regArray(/(true)|false/i).map((e=>e[1]?new this(!0):new this(!1)));constructor(e=!1){super(),this.value=e}valueOf(){return this.value}toString(){return this.value.toString()}}class We extends Le{static grammar=ke.regArray(new RegExp(`(${ke.number.getParser().parser.regexp.source})|(\\+?inf)|(-inf)`)).map((([e,t,i,s])=>new this(t?Number(t):i?Number.POSITIVE_INFINITY:Number.NEGATIVE_INFINITY)));#n;get value(){return this.#n}set value(e){-0===e&&(e=0),this.#n=e}constructor(e=0){super(),this.value=e}valueOf(){return this.value}toString(){return this.value.toString()}}class Ke extends We{static grammar=ke.numberInteger.map((e=>new this(e)));set value(e){e>=-(1<<31)&&e<1<<31&&(e=Math.floor(e),super.value=e)}}class Ye extends Ke{static grammar=ke.numberByte.map((e=>new this(e)));set value(e){e%1==0&&e>=0&&e<256&&(super.value=e)}}class Xe extends Le{static f;static from(e){const t=this.asUniqueClass();return t.f=e,t}compute(e){return this.Self().f(e)}}class qe extends Le{static grammar=Ie.symbol.map((e=>new this(e)));constructor(e=""){super(),this.value=e}valueOf(){return this.value}toString(){return this.value}}class Ze extends qe{static grammar=Ie.symbol.map((e=>new this(e)))}class Qe extends Ze{static grammar=ke.reg(Ie.Regex.InsideString).map((e=>new this(e)))}class Je extends Le{static lookbehind="INVTEXT";static grammar=ke.alt(ke.seq(ke.reg(new RegExp(`${this.lookbehind}\\s*\\(`)),ke.doubleQuotedString,ke.reg(/\s*\)/)).map((([e,t,i])=>new this(t))),ke.reg(new RegExp(this.lookbehind)).map((()=>new this))).map((e=>new this(e)));constructor(e=""){super(),this.value=e}toString(){return this.value}}class et extends Le{static lookbehind="NSLOCTEXT";static grammar=ke.regArray(new RegExp(String.raw`${this.attributes.lookbehind.default}\s*\(`+String.raw`\s*"(${Ie.Regex.InsideString.source})"\s*,`+String.raw`\s*"(${Ie.Regex.InsideString.source})"\s*,`+String.raw`\s*"(${Ie.Regex.InsideString.source})"\s*`+String.raw`(?:,\s+)?`+String.raw`\)`,"m")).map((e=>new this(ae.unescapeString(e[1]),ae.unescapeString(e[2]),ae.unescapeString(e[3]))));#T;get namespace(){return this.#T}set namespace(e){this.#T=e}#I;get key(){return this.#I}set key(e){this.#I=e}#n;get value(){return this.#n}set value(e){this.#n=e}constructor(e="",t="",i=""){super(),this.namespace=e,this.key=t,this.value=i}toString(){return ae.capitalFirstLetter(this.value)}}class tt extends Le{static grammar=ke.doubleQuotedString.map((e=>ae.unescapeString(e)));constructor(e=""){super(),this.value=e}valueOf(){return this.value}toString(){return this.value.toString()}}class it extends Le{static lookbehind=["LOCGEN_FORMAT_NAMED","LOCGEN_FORMAT_ORDERED"];static grammar=ke.seq(ke.reg(new RegExp(String.raw`(${this.lookbehind.reduce(((e,t)=>e+"|"+t))})\s*\(\s*)`),1),ke.alt(...[tt,et,Je,it].map((e=>e.grammar))).sepBy(ke.reg(/\s*\,\s*/)),ke.reg(/\s*\)/)).map((([e,t])=>{const i=new this(t);return i.lookbehind=e,i}));constructor(e){super(),this.values=e}toString(){const e=this.values?.[0]?.toString();if(!e)return"";const t=this.values.slice(1).map((e=>e.toString()));return"LOCGEN_FORMAT_NAMED"==this.lookbehind?e.replaceAll(/\{([a-zA-Z]\w*)\}/g,((e,i)=>{const s=t.indexOf(i)+1;return s>0&&s{const s=Number(i);return snew this(e)));#n;get value(){return this.#n}set value(e){e>=-(1n<<63n)&&e<1n<<63n&&(this.#n=e)}constructor(e=0n){super(),this.value=BigInt(e)}valueOf(){return this.value}toString(){return this.value.toString()}}class nt extends Le{static#$=ke.regArray(new RegExp(`'"(${Ie.Regex.InsideString.source})"'|'(${Ie.Regex.InsideSingleQuotedString.source})'`)).map((([e,t,i])=>t??i));static typeReference=ke.reg(new RegExp(Ie.Regex.Path.source+"|"+Ie.symbol.getParser().regexp.source));static fullReferenceGrammar=ke.regArray(new RegExp("("+this.typeReference.getParser().regexp.source+")(?:"+this.#$.getParser().parser.regexp.source+")")).map((([e,t,...i])=>new this(t,i.find((e=>e)),e)));static fullReferenceSerializedGrammar=ke.regArray(new RegExp('"('+Ie.Regex.InsideString.source+"?)(?:'("+Ie.Regex.InsideSingleQuotedString.source+"?)')?\"")).map((([e,t,i])=>new this(t,i,e)));static typeReferenceGrammar=this.typeReference.map((e=>new this(e,"",e)));static grammar=ke.alt(this.fullReferenceSerializedGrammar,this.fullReferenceGrammar,this.typeReferenceGrammar);#c;get type(){return this.#c}set type(e){this.#c=e}#D;get path(){return this.#D}set path(e){this.#D=e}#B;get full(){return this.#B}set full(e){this.#B=e}constructor(e="None",t="",i=null){super(),this.#c=e,this.#D=t,this.#B=i??`"${this.type+(this.path?`'${this.path}'`:"")}"`}static createNoneInstance(){return new nt("None")}getName(e=!1){return ae.getNameFromPath(this.path.replace(/_C$/,""),e)}toString(){return this.full}}class rt extends Le{static grammar=Ie.symbol.map((e=>new this(e)));constructor(e=""){super(),this.value=e}valueOf(){return this.value}toString(){return this.value.toString()}}class at extends Le{static grammar=ke.seq(rt.grammar,ke.whitespace,Ge.grammar).map((([e,t,i])=>new this(e,i)));constructor(e=null,t=null){super(),this.objectName=e,this.pinGuid=t}}class ot extends Le{static attributes={...super.attributes,MemberParent:nt,MemberName:tt,MemberGuid:Ge};static grammar=Ie.createEntityGrammar(this);constructor(e){super(e),this.MemberParent,this.MemberName,this.MemberGuid}}class lt extends Le{static attributes={...super.attributes,PinCategory:tt.withDefault(),PinSubCategory:tt.withDefault(),PinSubCategoryObject:nt.withDefault(),PinSubCategoryMemberReference:ot.withDefault((e=>null)),PinValueType:lt.withDefault(),ContainerType:rt,bIsReference:Ue.withDefault(),bIsConst:Ue.withDefault(),bIsWeakPointer:Ue.withDefault(),bIsUObjectWrapper:Ue.withDefault(),bSerializeAsSinglePrecisionFloat:Ue.withDefault()};static grammar=Ie.createEntityGrammar(this);constructor(e={}){super(e),this.PinCategory,this.PinSubCategory,this.PinSubCategoryObject,this.PinSubCategoryMemberReference,this.PinValueType,this.ContainerType,this.bIsReference,this.bIsConst,this.bIsWeakPointer,this.bIsUObjectWrapper,this.bIsUObjectWrapper,this.bSerializeAsSinglePrecisionFloat}copyTypeFrom(e){for(const t of this.keys)void 0!==e[t]&&(this[t]=e[t])}}class ut extends Le{static attributes={...super.attributes,X:We.withDefault(),Y:We.withDefault()};static grammar=Ie.createEntityGrammar(this,!1);constructor(e){super(e),this.X,this.Y}toArray(){return[this.X.valueOf(),this.Y.valueOf()]}}class ct extends ut{static grammar=ke.alt(ke.regArray(new RegExp(/X\s*=\s*/.source+"(?"+ke.number.getParser().parser.regexp.source+")\\s+"+/Y\s*=\s*/.source+"(?"+ke.number.getParser().parser.regexp.source+")")).map((({groups:{x:e,y:t}})=>new this({X:Number(e),Y:Number(t)}))),ut.grammar)}class ht extends Le{static attributes={...super.attributes,R:We.withDefault(),P:We.withDefault(),Y:We.withDefault()};static grammar=Ie.createEntityGrammar(this,!1);constructor(e){super(e),this.R,this.P,this.Y}getRoll(){return this.R}getPitch(){return this.P}getYaw(){return this.Y}}class pt extends ht{static grammar=ke.alt(ke.regArray(new RegExp(`(${ke.number.getParser().parser.regexp.source})`+String.raw`\s*,\s*`+`(${ke.number.getParser().parser.regexp.source})`+String.raw`\s*,\s*`+`(${ke.number.getParser().parser.regexp.source})`)).map((([e,t,i,s])=>new this({R:Number(s),P:Number(t),Y:Number(i)}))),ht.grammar)}class dt extends ut{static grammar=ke.alt(ke.regArray(new RegExp(`(${ke.number.getParser().parser.regexp.source})`+String.raw`\s*,\s*`+`(${ke.number.getParser().parser.regexp.source})`)).map((([e,t,i])=>new this({X:Number(t),Y:Number(i)}))),ut.grammar)}class mt extends Le{static attributes={...super.attributes,X:We.withDefault(),Y:We.withDefault(),Z:We.withDefault(),W:We.withDefault()};static grammar=Ie.createEntityGrammar(mt,!1);constructor(e){super(e),this.X,this.Y,this.Z,this.W}toArray(){return[this.X.valueOf(),this.Y.valueOf(),this.Z.valueOf(),this.W.valueOf()]}}class gt extends mt{static grammar=this.createGrammar();static createGrammar(){return ke.number.getParser().parser.regexp.source,ke.alt(ke.regArray(new RegExp(`(${ke.number.getParser().parser.regexp.source})`+String.raw`\s*,\s*`+`(${ke.number.getParser().parser.regexp.source})`+String.raw`\s*,\s*`+`(${ke.number.getParser().parser.regexp.source})`+String.raw`\s*,\s*`+`(${ke.number.getParser().parser.regexp.source})`)).map((([e,t,i,s,n])=>new this({X:Number(t),Y:Number(i),Z:Number(s),W:Number(n)}))),mt.grammar)}}class bt extends Le{static attributes={...super.attributes,X:We.withDefault(),Y:We.withDefault(),Z:We.withDefault()};static grammar=Ie.createEntityGrammar(bt,!1);constructor(e){super(e),this.X,this.Y,this.Z}toArray(){return[this.X.valueOf(),this.Y.valueOf(),this.Z.valueOf()]}}class vt extends bt{static grammar=ke.alt(ke.regArray(new RegExp(`(${ke.number.getParser().parser.regexp.source})`+String.raw`\s*,\s*`+`(${ke.number.getParser().parser.regexp.source})`+String.raw`\s*,\s*`+`(${ke.number.getParser().parser.regexp.source})`)).map((([e,t,i,s])=>new this({X:Number(t),Y:Number(i),Z:Number(s)}))),bt.grammar)}class ft extends Le{static lookbehind="INVTEXT";static#V={[re.paths.linearColor]:De,[re.paths.rotator]:ht,[re.paths.vector]:bt,[re.paths.vector2D]:ut,[re.paths.vector4f]:mt,bool:Ue,byte:Ye,enum:Ze,exec:tt,int:Ke,int64:st,name:tt,real:We,string:tt};static#H={enum:Qe,rg:ct,[re.paths.rotator]:pt,[re.paths.vector]:vt,[re.paths.vector2D]:dt,[re.paths.vector3f]:vt,[re.paths.vector4f]:gt};static attributes={...super.attributes,PinId:Ge.withDefault(),PinName:tt.withDefault(),PinFriendlyName:Fe.accepting(et,it,Je,tt),PinToolTip:tt,Direction:tt,PinType:lt.withDefault().flagInlined(),LinkedTo:je.of(at),SubPins:je.of(at),ParentPin:at,DefaultValue:Xe.from((e=>e.getEntityType(!0)??tt)).flagSerialized(),AutogeneratedDefaultValue:tt,DefaultObject:nt,PersistentGuid:Ge,bHidden:Ue.withDefault(),bNotConnectable:Ue.withDefault(),bDefaultValueIsReadOnly:Ue.withDefault(),bDefaultValueIsIgnored:Ue.withDefault(),bAdvancedView:Ue.withDefault(),bOrphanedPin:Ue.withDefault()};static grammar=Ie.createEntityGrammar(this);#O=!1;set recomputesNodeTitleOnChange(e){this.#O=e}get recomputesNodeTitleOnChange(){return this.#O}#R;get objectEntity(){return this.#R}set objectEntity(e){this.#R=e}#G;get pinIndex(){return this.#G}set pinIndex(e){this.#G=e}constructor(e={}){super(e),this.objectEntity,this.pinIndex,this.PinId,this.PinName,this.PinFriendlyName,this.PinToolTip,this.Direction,this.PinType,this.LinkedTo,this.DefaultValue,this.AutogeneratedDefaultValue,this.DefaultObject,this.PersistentGuid,this.bHidden,this.bNotConnectable,this.bDefaultValueIsReadOnly,this.bDefaultValueIsIgnored,this.bAdvancedView,this.bOrphanedPin}static fromLegacyObject(e){return new ft(e)}getType(){const e=this.PinType.PinCategory.toLocaleLowerCase();if("struct"===e||"class"===e||"object"===e||"type"===e)return this.PinType.PinSubCategoryObject.path;if(this.isEnum())return"enum";if(this.objectEntity?.isPcg()){const e=this.objectEntity.getPcgSubobject(),t=this.isInput()?e.InputPins?.[this.pinIndex]:e.OutputPins?.[this.pinIndex];if(t){const i=e[re.subObjectAttributeNameFromReference(t,!0)];let s=i.Properties?.AllowedTypes?.toString()??"";if(""==s&&(s=this.PinType.PinCategory??"",""==s&&(s="Any")),s)return!1!==i.Properties.bAllowMultipleData&&!1!==i.Properties.bAllowMultipleConnections&&(s+="[]"),s}}if("optional"===e)switch(this.PinType.PinSubCategory){case"red":return"real";case"rg":return"rg";case"rgb":return re.paths.vector;case"rgba":return re.paths.linearColor;default:return this.PinType.PinSubCategory}return e}getEntityType(e=!1){const t=this.getType(),i=ft.#V[t],s=ft.#H[t];return e&&void 0!==s?s:i}pinTitle(){return function(e){let t,i=e.PinFriendlyName?e.PinFriendlyName.toString():ae.formatStringName(e.PinName??"");return e.PinToolTip&&(t=e.PinToolTip.match(/\s*(.+?(?=\n)|.+\S)\s*/))&&t[1].toLowerCase()===i.toLowerCase()?t[1]:i}(this)}copyTypeFrom(e){this.PinType.PinCategory=e.PinType.PinCategory,this.PinType.PinSubCategory=e.PinType.PinSubCategory,this.PinType.PinSubCategoryObject=e.PinType.PinSubCategoryObject,this.PinType.PinSubCategoryMemberReference=e.PinType.PinSubCategoryMemberReference,this.PinType.PinValueType=e.PinType.PinValueType,this.PinType.ContainerType=e.PinType.ContainerType,this.PinType.bIsReference=e.PinType.bIsReference,this.PinType.bIsConst=e.PinType.bIsConst,this.PinType.bIsWeakPointer=e.PinType.bIsWeakPointer,this.PinType.bIsUObjectWrapper=e.PinType.bIsUObjectWrapper,this.PinType.bSerializeAsSinglePrecisionFloat=e.PinType.bSerializeAsSinglePrecisionFloat}getDefaultValue(e=!1){return void 0===this.DefaultValue&&e&&(this.DefaultValue=new(this.getEntityType(!0))),this.DefaultValue}isEnum(){const e=this.PinType.PinSubCategoryObject.type;return e===re.paths.enum||e===re.paths.userDefinedEnum||"enum"===e.toLowerCase()}isExecution(){return"exec"===this.PinType.PinCategory}isHidden(){return this.bHidden}isInput(){return!this.bHidden&&"EGPD_Output"!=this.Direction}isOutput(){return!this.bHidden&&"EGPD_Output"==this.Direction}isLinked(){return this.LinkedTo?.length>0??!1}linkTo(e,t){const i=this.LinkedTo?.some((i=>i.objectName.toString()==e&&i.pinGuid.valueOf()==t.PinId.valueOf()));return!i&&((this.LinkedTo??=[]).push(new at({objectName:e,pinGuid:t.PinId})),!0)}unlinkFrom(e,t){const i=this.LinkedTo?.findIndex((i=>i.objectName.toString()==e&&i.pinGuid.valueOf()==t.PinId.valueOf()));return i>=0&&(this.LinkedTo.splice(i,1),0===this.LinkedTo.length&&void 0===ft.attributes.LinkedTo.default&&(this.LinkedTo=void 0),!0)}getSubCategory(){return this.PinType.PinSubCategoryObject.path}pinColor(){return function(e){if("mask"==e.PinType.PinCategory){const t=ze[e.PinType.PinSubCategory];if(t)return t}else if("optional"==e.PinType.PinCategory)return _e;return ze[e.getType()]??ze[e.PinType.PinCategory.toLowerCase()]??ze.default}(this)}}const yt=e=>e.PinName.match(/^\s*([A-Z])\s*$/)?.[1]?.charCodeAt(0)-"A".charCodeAt(0);class wt extends Le{static attributeConverter={fromAttribute:(e,t)=>new wt(e),toAttribute:(e,t)=>e.toString()};static grammar=Ie.symbol.map((e=>new this(e)));constructor(e){super(),this.value=e}valueOf(){return this.value}toString(){return this.value.toString()}}class St extends Le{static attributes={...super.attributes,MacroGraph:nt,GraphBlueprint:nt,GraphGuid:Ge};static grammar=Ie.createEntityGrammar(this);constructor(e){super(e),this.MacroGraph,this.GraphBlueprint,this.GuidEntity}getMacroName(){const e=this.MacroGraph.path.search(":");return this.MacroGraph.path.substring(e+1)}}class Et extends Ke{static grammar=ke.numberNatural.map((e=>new this(e)));set value(e){e=Math.round(ae.clamp(this.value,0)),super.value=e}constructor(e=0){super(e)}}class Ct extends Le{static attributes={...super.attributes,ScriptVariable:nt,OriginalChangeId:Ge};static grammar=Ie.createEntityGrammar(this);constructor(e={}){super(e),this.ScriptVariable,this.OriginalChangeId}}class Nt extends ft{static grammar=ke.seq(ke.reg(new RegExp(`(${Ie.Regex.Symbol.source})\\s*\\(\\s*`),1),Ie.createAttributeGrammar(this).sepBy(Ie.commaSeparation),ke.reg(/\s*(?:,\s*)?\)/)).map((([e,t,i])=>{e??="";let s={};return e.length&&(s.lookbehind=e),t.forEach((e=>e(s))),new this(s)}))}class xt extends Le{static attributes={...super.attributes,MemberScope:tt,MemberName:tt.withDefault(),MemberGuid:Ge,bSelfContext:Ue};static grammar=Ie.createEntityGrammar(this);constructor(e){super(e),this.MemberName,this.GuidEntity,this.bSelfContext}}class Pt extends Le{#z=!1;get _exported(){return this.#z}set _exported(e){this.#z=e}static attributes={...super.attributes,Class:nt,Name:tt,Archetype:nt,ExportPath:nt,ObjectRef:nt,BlueprintElementType:nt,BlueprintElementInstance:nt,PinNames:je.of(tt).flagInlined(),AxisKey:qe,InputAxisKey:qe,InputName:tt,InputType:qe,NumAdditionalInputs:Et,bIsPureFunc:Ue,bIsConstFunc:Ue,bIsCaseSensitive:Ue,VariableReference:xt,SelfContextInfo:qe,DelegatePropertyName:tt,DelegateOwnerClass:nt,ComponentPropertyName:tt,EventReference:ot,FunctionReference:ot,FunctionScript:nt,CustomFunctionName:tt,TargetType:nt,MacroGraphReference:St,Enum:nt,EnumEntries:je.of(tt).flagInlined(),InputKey:qe,OpName:tt,CachedChangeId:Ge,FunctionDisplayName:tt,AddedPins:je.of(Nt).withDefault().flagInlined().flagSilent(),ChangeId:Ge,MaterialFunction:nt,bOverrideFunction:Ue,bInternalEvent:Ue,bConsumeInput:Ue,bExecuteWhenPaused:Ue,bOverrideParentBinding:Ue,bControl:Ue,bAlt:Ue,bShift:Ue,bCommand:Ue,CommentColor:De,bCommentBubbleVisible_InDetailsPanel:Ue,bColorCommentBubble:Ue,ProxyFactoryFunctionName:tt,ProxyFactoryClass:nt,ProxyClass:nt,StructType:nt,MaterialExpression:nt,MaterialExpressionComment:nt,MoveMode:qe,TimelineName:tt,TimelineGuid:Ge,SizeX:Me.of(Ke),SizeY:Me.of(Ke),Text:Me.of(tt),MaterialExpressionEditorX:Me.of(Ke),MaterialExpressionEditorY:Me.of(Ke),NodeTitle:tt,NodeTitleColor:De,PositionX:Me.of(Ke),PositionY:Me.of(Ke),SettingsInterface:nt,PCGNode:nt,HiGenGridSize:qe,Operation:qe,NodePosX:Ke,NodePosY:Ke,NodeHeight:Ke,NodeWidth:Ke,Graph:nt,SubgraphInstance:tt,InputPins:je.of(nt).flagInlined(),OutputPins:je.of(nt).flagInlined(),bExposeToLibrary:Ue,bCanRenameNode:Ue,bCommentBubblePinned:Ue,bCommentBubbleVisible:Ue,NodeComment:tt,AdvancedPinDisplay:wt,DelegateReference:xt,EnabledState:wt,NodeGuid:Ge,ErrorType:Ke,ErrorMsg:tt,ScriptVariables:je.of(Ct),Node:Me.of(nt),ExportedNodes:tt,CustomProperties:je.of(Fe.accepting(ft,Nt))};static#_=/^(\w+?)(?:_(\d+))?$/;static customPropertyGrammar=ke.seq(ke.reg(/CustomProperties\s+/),this.attributes.CustomProperties.type.grammar).map((([e,t])=>e=>{(e.CustomProperties??=[]).push(t)}));static inlinedArrayEntryGrammar=ke.seq(ke.alt(Ie.symbolQuoted.map((e=>[e,!0])),Ie.symbol.map((e=>[e,!1]))),ke.reg(new RegExp("\\s*\\(\\s*(\\d+)\\s*\\)\\s*\\=\\s*"),1).map(Number)).chain((([[e,t],i])=>Ie.grammarFor(this.attributes[e]).map((s=>n=>{(n[e]??=[])[i]=s,ae.objectSet(n,["attributes",e,"quoted"],t),this.attributes[e]?.inlined||(n.attributes||Le.defineAttributes(n,{}),ae.objectSet(n,["attributes",e,"type"],[s.constructor]),ae.objectSet(n,["attributes",e,"inlined"],!0))}))));static grammar=this.createGrammar();static createSubObjectGrammar(){return ke.lazy((()=>this.grammar)).map((e=>t=>t[re.subObjectAttributeNameFromEntity(e)]=e))}static createGrammar(){return ke.seq(ke.reg(/Begin +Object/),ke.seq(ke.whitespace,ke.alt(this.createSubObjectGrammar(),this.customPropertyGrammar,Ie.createAttributeGrammar(this,ke.reg(Ie.Regex.MultipleWordsSymbols)),Ie.createAttributeGrammar(this,Ie.attributeNameQuoted,void 0,((e,t,i)=>ae.objectSet(e,["attributes",...t,"quoted"],!0))),this.inlinedArrayEntryGrammar)).map((([e,t])=>t)).many(),ke.reg(/\s+End +Object/)).map((([e,t,i])=>{const s={};return t.forEach((e=>e(s))),new this(s)}))}static getMultipleObjectsGrammar(){return ke.seq(ke.whitespaceOpt,this.grammar,ke.seq(ke.whitespace,this.grammar).map((([e,t])=>t)).many(),ke.whitespaceOpt).map((([e,t,i,s])=>[t,...i]))}#F;constructor(e={}){if("NodePosX"in e!="NodePosY"in e){const t=Object.entries(e),[i,s]="NodePosX"in e?["NodePosY",Object.keys(e).indexOf("NodePosX")+1]:["NodePosX",Object.keys(e).indexOf("NodePosY")],n=[i,new(Ae.getAttribute(e,i,"type",Pt))];t.splice(s,0,n),e=Object.fromEntries(t)}super(e),this.CustomProperties,this.bIsPureFunc,this.isExported,this.ComponentPropertyName,this.EventReference,this.FunctionReference,this.AdvancedPinDisplay,this.EnabledState,this.NodeHeight,this.NodePosX,this.NodePosY,this.NodeWidth,this.CommentColor,this.NodeTitleColor,this.MacroGraphReference,this.MaterialExpressionEditorX,this.MaterialExpressionEditorY,this.SizeX,this.SizeY,this.Text,this.PositionX,this.PositionY,this.Node,this.PinTags,this.NumAdditionalInputs,this.InputPins,this.OutputPins,this.Archetype,this.BlueprintElementInstance,this.BlueprintElementType,this.Class,this.Enum,this.ExportPath,this.FunctionScript,this.Graph,this.MaterialExpression,this.MaterialExpressionComment,this.MaterialFunction,this.ObjectRef,this.PCGNode,this.SettingsInterface,this.StructType,this.TargetType,this.ScriptVariables,this.EnumEntries,this.PinNames,this.CustomFunctionName,this.DelegatePropertyName,this.ExportedNodes,this.FunctionDisplayName,this.InputName,this.Name,this.NodeComment,this.NodeTitle,this.Operation,this.OpName,this.ProxyFactoryFunctionName,this.SubgraphInstance,this.Text,this.AxisKey,this.HiGenGridSize,this.InputAxisKey,this.InputKey,this.InputType,this.AddedPins,this.DelegateReference,this.VariableReference,this.Pins instanceof Array&&this.Pins.forEach((e=>{const t=this[re.subObjectAttributeNameFromReference(e,!0)];if(t){const e=ft.fromLegacyObject(t);e.LinkedTo=[],this.getCustomproperties(!0).push(e),ae.objectSet(this,["attributes","CustomProperties","ignored"],!0)}}));const t=this.getMaterialSubobject();if(t){const e=t;if(void 0!==e.SizeX&&(e.SizeX.getter=()=>this.NodeWidth),e.SizeY&&(e.SizeY.getter=()=>this.NodeHeight),e.Text&&(e.Text.getter=()=>this.NodeComment),e.MaterialExpressionEditorX&&(e.MaterialExpressionEditorX.getter=()=>this.NodePosX),e.MaterialExpressionEditorY&&(e.MaterialExpressionEditorY.getter=()=>this.NodePosY),this.getType()===re.paths.materialExpressionComponentMask){const t=re.rgba.map((e=>this.getPinEntities().find((t=>t.PinName===e&&(t.recomputesNodeTitleOnChange=!0)))));e.R=new(Me.of(Ue).withDefault().flagSilent())((()=>t[0].DefaultValue)),e.G=new(Me.of(Ue).withDefault().flagSilent())((()=>t[1].DefaultValue)),e.B=new(Me.of(Ue).withDefault().flagSilent())((()=>t[2].DefaultValue)),e.A=new(Me.of(Ue).withDefault().flagSilent())((()=>t[3].DefaultValue)),e.keys=[...re.rgba,...super.keys.filter((e=>!re.rgba.includes(e)))]}}const i=this.getPcgSubobject();i&&(i.PositionX&&(i.PositionX.getter=()=>this.NodePosX),i.PositionY&&(i.PositionY.getter=()=>this.NodePosY),i.getSubobjects().forEach((e=>{if(void 0!==e.Node){const t=e.Node.get();t.type===this.PCGNode.type&&t.path===`${this.Name}.${this.PCGNode.path}`&&(e.Node.getter=()=>new nt(this.PCGNode.type,`${this.Name}.${this.PCGNode.path}`))}})));let s=0,n=0;this.CustomProperties?.forEach(((e,t)=>{e.objectEntity=this,e.pinIndex=e.isInput()?s++:e.isOutput()?n++:t}))}getClass(){if(!this.#F&&(this.#F=(this.Class?.path?this.Class.path:this.Class?.type)??(this.ExportPath?.path?this.ExportPath.path:this.ExportPath?.type)??"",this.#F&&!this.#F.startsWith("/"))){let e=Object.values(re.paths).find((e=>e.endsWith("."+this.#F)));e&&(this.#F=e)}return this.#F}getType(){let e=this.getClass();return this.MacroGraphReference?.MacroGraph?.path?this.MacroGraphReference.MacroGraph.path:this.MaterialExpression?this.MaterialExpression.type:e}getObjectName(e=!1){return e?this.getNameAndCounter()[0]:this.Name}getNameAndCounter(){const e=this.getObjectName().match(Pt.#_);return e?[e[1]??"",parseInt(e[2]??"0")]:["",0]}getCounter(){return this.getNameAndCounter()[1]}getNodeWidth(){return this.NodeWidth??this.isComment()?re.defaultCommentWidth:void 0}setNodeWidth(e){this.NodeWidth||(this.NodeWidth=new Ke),this.NodeWidth.value=e}getNodeHeight(){return this.NodeHeight??this.isComment()?re.defaultCommentHeight:void 0}setNodeHeight(e){this.NodeHeight||(this.NodeHeight=new Ke),this.NodeHeight.value=e}getNodePosX(){return this.NodePosX?.value??0}setNodePosX(e){this.NodePosX||(this.NodePosX=new Ke),this.NodePosX.value=Math.round(e)}getNodePosY(){return this.NodePosY?.value??0}setNodePosY(e){this.NodePosY||(this.NodePosY=new Ke),this.NodePosY.value=Math.round(e)}getCustomproperties(e=!1){return e&&!this.CustomProperties&&(this.CustomProperties=[]),this.CustomProperties??[]}getPinEntities(){return this.getCustomproperties().filter((e=>e.constructor===ft))}getSubobjects(){return Object.keys(this).filter((e=>e.startsWith(re.subObjectAttributeNamePrefix))).flatMap((e=>[this[e],...this[e].getSubobjects()]))}switchTarget(){const e=this.getClass().match(re.switchTargetPattern);if(e)return e[1]}isEvent(){switch(this.getClass()){case re.paths.actorBoundEvent:case re.paths.componentBoundEvent:case re.paths.customEvent:case re.paths.event:case re.paths.inputAxisKeyEvent:case re.paths.inputVectorAxisEvent:return!0}return!1}isComment(){switch(this.getClass()){case re.paths.comment:case re.paths.materialGraphNodeComment:return!0}return!1}isMaterial(){return this.getClass()===re.paths.materialGraphNode}getMaterialSubobject(){const e=this.MaterialExpression??this.MaterialExpressionComment;return e?this[re.subObjectAttributeNameFromReference(e,!0)]:null}isPcg(){return this.getClass()===re.paths.pcgEditorGraphNode||this.getPcgSubobject()}isNiagara(){return this.Class&&(this.Class.type?this.Class.type:this.Class.path)?.startsWith("/Script/NiagaraEditor.")}getPcgSubobject(){const e=this.PCGNode;return e?this[re.subObjectAttributeNameFromReference(e,!0)]:null}getSettingsObject(){const e=this.SettingsInterface;return e?this[re.subObjectAttributeNameFromReference(e,!0)]:null}getSubgraphObject(){const e=this.SubgraphInstance;return e?this[re.subObjectAttributeNameFromName(e)]:null}isDevelopmentOnly(){const e=this.getClass();return"DevelopmentOnly"===this.EnabledState?.toString()||e.includes("Debug",Math.max(0,e.lastIndexOf(".")))}getHIDAttribute(){return this.InputKey??this.AxisKey??this.InputAxisKey}getDelegatePin(){return this.getCustomproperties().find((e=>"delegate"===e.PinType.PinCategory))}nodeColor(){return function(e){switch(e.getType()){case re.paths.materialExpressionConstant2Vector:case re.paths.materialExpressionConstant3Vector:case re.paths.materialExpressionConstant4Vector:return re.nodeColors.yellow;case re.paths.makeStruct:return re.nodeColors.darkBlue;case re.paths.materialExpressionMaterialFunctionCall:return re.nodeColors.blue;case re.paths.materialExpressionFunctionInput:return re.nodeColors.red;case re.paths.materialExpressionTextureSample:return re.nodeColors.darkTurquoise;case re.paths.materialExpressionTextureCoordinate:case re.paths.pcgEditorGraphNodeInput:case re.paths.pcgEditorGraphNodeOutput:return re.nodeColors.red}switch(e.getClass()){case re.paths.callFunction:return e.bIsPureFunc?re.nodeColors.green:re.nodeColors.blue;case re.paths.niagaraNodeFunctionCall:return re.nodeColors.darkerBlue;case re.paths.dynamicCast:return re.nodeColors.turquoise;case re.paths.inputDebugKey:case re.paths.inputKey:return re.nodeColors.red;case re.paths.createDelegate:case re.paths.enumLiteral:case re.paths.makeArray:case re.paths.makeMap:case re.paths.materialGraphNode:case re.paths.select:return re.nodeColors.green;case re.paths.executionSequence:case re.paths.ifThenElse:case re.paths.macro:case re.paths.multiGate:return re.nodeColors.gray;case re.paths.functionEntry:case re.paths.functionResult:return re.nodeColors.violet;case re.paths.timeline:return re.nodeColors.yellow}if(e.switchTarget())return re.nodeColors.lime;if(e.isEvent())return re.nodeColors.red;if(e.isComment())return(e.CommentColor?e.CommentColor:De.getWhite()).toDimmedColor().toCSSRGBValues();const t=e.getPcgSubobject();if(t){if(t.NodeTitleColor)return t.NodeTitleColor.toDimmedColor(.1).toCSSRGBValues();switch(e.PCGNode?.getName(!0)){case"Branch":case"Select":return re.nodeColors.intenseGreen}}return e.bIsPureFunc?re.nodeColors.green:re.nodeColors.blue}(this)}nodeIcon(){return function(e){if(e.isMaterial()||e.isPcg()||e.isNiagara())return null;switch(e.getType()){case re.paths.addDelegate:case re.paths.asyncAction:case re.paths.callDelegate:case re.paths.createDelegate:case re.paths.functionEntry:case re.paths.functionResult:return Be.node;case re.paths.customEvent:return Be.event;case re.paths.doN:return Be.doN;case re.paths.doOnce:return Be.doOnce;case re.paths.dynamicCast:return Be.cast;case re.paths.enumLiteral:return Be.enum;case re.paths.event:return Be.event;case re.paths.executionSequence:case re.paths.multiGate:return Be.sequence;case re.paths.flipflop:return Be.flipflop;case re.paths.forEachElementInEnum:case re.paths.forLoop:case re.paths.forLoopWithBreak:case re.paths.whileLoop:return Be.loop;case re.paths.forEachLoop:case re.paths.forEachLoopWithBreak:return Be.forEachLoop;case re.paths.ifThenElse:return Be.branchNode;case re.paths.isValid:return Be.questionMark;case re.paths.makeArray:return Be.makeArray;case re.paths.makeMap:return Be.makeMap;case re.paths.makeSet:return Be.makeSet;case re.paths.makeStruct:return Be.makeStruct;case re.paths.metasoundEditorGraphExternalNode:return Be.metasoundFunction;case re.paths.select:return Be.select;case re.paths.spawnActorFromClass:return Be.spawnActor;case re.paths.timeline:return Be.timer}if(e.switchTarget())return Be.switch;if(Oe(e).startsWith("Break"))return Be.breakStruct;if(e.getClass()===re.paths.macro)return Be.macro;const t=e.getHIDAttribute()?.toString();return t?t.includes("Mouse")?Be.mouse:t.includes("Gamepad_Special")?Be.keyboard:t.includes("Gamepad")||t.includes("Steam")?Be.gamepad:t.includes("Touch")?Be.touchpad:Be.keyboard:e.getDelegatePin()?Be.event:e.ObjectRef?.type===re.paths.ambientSound?Be.sound:Be.functionSymbol}(this)}additionalPinInserter(){return function(e){let t,i,s,n;switch(e.getType()){case re.paths.commutativeAssociativeBinaryOperator:case re.paths.promotableOperator:switch(n=e.FunctionReference?.MemberName,n){default:if(!(n?.startsWith("Add_")||n?.startsWith("Subtract_")||n?.startsWith("Multiply_")||n?.startsWith("Divide_")))break;case"And_Int64Int64":case"And_IntInt":case"BMax":case"BMin":case"BooleanAND":case"BooleanNAND":case"BooleanOR":case"Concat_StrStr":case"FMax":case"FMin":case"Max":case"MaxInt64":case"Min":case"MinInt64":case"Or_Int64Int64":case"Or_IntInt":t??=()=>e.getPinEntities().filter((e=>e.isInput())),i??=yt,s??=(i,s=-1,n=-1)=>{const r=String.fromCharCode(i>=0?i:n+"A".charCodeAt(0)+1);return e.NumAdditionalInputs=t().length-1,r}}break;case re.paths.multiGate:t??=()=>e.getPinEntities().filter((e=>e.isOutput())),i??=e=>Number(e.PinName.match(/^\s*Out[_\s]+(\d+)\s*$/i)?.[1]),s??=(e,t=-1,i=-1,s)=>`Out ${e>=0?e:t>0?"Out 0":i+1}`;break;case re.paths.switchInteger:t??=()=>e.getPinEntities().filter((e=>e.isOutput())),i??=e=>Number(e.PinName.match(/^\s*(\d+)\s*$/)?.[1]),s??=(e,t=-1,i=-1,s)=>(e<0?i+1:e).toString();break;case re.paths.switchGameplayTag:s??=(t,i=-1,s=-1,n)=>{const r=`Case_${t>=0?t:i>0?"0":s+1}`;return e.PinNames??=[],e.PinNames.push(r),delete e.PinTags[e.PinTags.length-1],e.PinTags[e.PinTags.length]=null,r};case re.paths.switchName:case re.paths.switchString:t??=()=>e.getPinEntities().filter((e=>e.isOutput())),i??=e=>Number(e.PinName.match(/^\s*Case[_\s]+(\d+)\s*$/i)?.[1]),s??=(t,i=-1,s=-1,n)=>{const r=`Case_${t>=0?t:i>0?"0":s+1}`;return e.PinNames??=[],e.PinNames.push(r),r}}if(t)return()=>{let n=Number.MAX_SAFE_INTEGER,r=Number.MIN_SAFE_INTEGER,a=[];const o=t().reduce(((e,t)=>{const s=i(t);if(isNaN(s)){if(void 0===e)return t}else if(a.push(s),n=Math.min(s,n),s>r)return r=s,t;return e}),void 0);if(n!==Number.MAX_SAFE_INTEGER&&r!==Number.MIN_SAFE_INTEGER||(n=void 0,r=void 0),!o)return null;a.sort(((e,t)=>e{const t=e-l>1;return l=e,t}));const c=new ft(o);return c.PinId=Ge.generateGuid(),c.PinName=s(u,n,r,c),c.PinToolTip=void 0,e.getCustomproperties(!0).push(c),c}}(this)}}class kt extends Pt{constructor(e={},t=void 0){e.Class=new nt(re.paths.knot),e.Name="K2Node_Knot";const i=new ft({PinName:"InputPin"}),s=new ft({PinName:"OutputPin",Direction:"EGPD_Output"});t&&(i.copyTypeFrom(t),s.copyTypeFrom(t)),e.CustomProperties=[i,s],super(e)}}class At{#j;get target(){return this.#j}#e;get blueprint(){return this.#e}consumeEvent;options;listenHandler=()=>this.listenEvents();unlistenHandler=()=>this.unlistenEvents();constructor(e,t,i={}){i.consumeEvent??=!1,i.listenOnFocus??=!1,i.unlistenOnTextEdit??=!1,this.#j=e,this.#e=t,this.consumeEvent=i.consumeEvent,this.options=i}setup(){this.options.listenOnFocus&&(this.blueprint.addEventListener(re.focusEventName.begin,this.listenHandler),this.blueprint.addEventListener(re.focusEventName.end,this.unlistenHandler)),this.options.unlistenOnTextEdit&&(this.blueprint.addEventListener(re.editTextEventName.begin,this.unlistenHandler),this.blueprint.addEventListener(re.editTextEventName.end,this.listenHandler)),this.blueprint.focused&&this.listenEvents()}cleanup(){this.unlistenEvents(),this.blueprint.removeEventListener(re.focusEventName.begin,this.listenHandler),this.blueprint.removeEventListener(re.focusEventName.end,this.unlistenHandler),this.blueprint.removeEventListener(re.editTextEventName.begin,this.unlistenHandler),this.blueprint.removeEventListener(re.editTextEventName.end,this.listenHandler)}listenEvents(){}unlistenEvents(){}}class Lt extends Le{static attributes={...super.attributes,ActionName:tt,bShift:Ue,bCtrl:Ue,bAlt:Ue,bCmd:Ue,Key:wt};static grammar=ke.alt(wt.grammar.map((e=>{const t=new this;return t.Key=e,t})),Ie.createEntityGrammar(this));constructor(){super(),this.ActionName,this.bShift,this.bCtrl,this.bAlt,this.bCmd,this.Key}}class Mt extends At{static#U=e=>{};#W;pressedKey="";constructor(e,t,i={},s=Mt.#U,n=Mt.#U){i.activationKeys??=[],i.consumeEvent??=!0,i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,i.activationKeys instanceof Array||(i.activationKeys=[i.activationKeys]),i.activationKeys=i.activationKeys.map((e=>{if(e instanceof Lt)return e;if(e.constructor===String){const t=Lt.grammar.run(e);if(t.status)return t.value}throw new Error("Unexpected key value")})),super(e,t,i),this.onKeyDown=s,this.onKeyUp=n,this.#W=this.options.activationKeys??[];let r=this;this.keyDownHandler=e=>{r.#W.some((t=>(e=>e.bShift||"LeftShift"==e.Key||"RightShift"==e.Key)(t)==e.shiftKey&&(e=>e.bCtrl||"LeftControl"==e.Key||"RightControl"==e.Key)(t)==e.ctrlKey&&(e=>e.bAlt||"LeftAlt"==e.Key||"RightAlt"==e.Key)(t)==e.altKey&&re.Keys[t.Key.value]==e.code))&&(this.consumeEvent&&(e.preventDefault(),e.stopImmediatePropagation()),this.pressedKey=e.code,r.fire(),document.removeEventListener("keydown",r.keyDownHandler),document.addEventListener("keyup",r.keyUpHandler))},this.keyUpHandler=e=>{r.#W.some((t=>t.bShift&&"Shift"==e.key||t.bCtrl&&"Control"==e.key||t.bAlt&&"Alt"==e.key||t.bCmd&&"Meta"==e.key||re.Keys[t.Key.value]==e.code))&&(this.consumeEvent&&e.stopImmediatePropagation(),r.unfire(),this.pressedKey="",document.removeEventListener("keyup",this.keyUpHandler),document.addEventListener("keydown",this.keyDownHandler))}}listenEvents(){document.addEventListener("keydown",this.keyDownHandler)}unlistenEvents(){document.removeEventListener("keydown",this.keyDownHandler)}fire(){this.onKeyDown(this)}unfire(){this.onKeyUp(this)}}class Tt extends At{#K=[0,0];get location(){return this.#K}#Y;get enablerKey(){return this.#Y}#X=!0;get enablerActivated(){return this.#X}constructor(e,t,i={}){i.ignoreTranslateCompensate??=!1,i.ignoreScale??=!1,i.movementSpace??=t.getGridDOMElement()??document.documentElement,super(e,t,i),this.movementSpace=i.movementSpace,i.enablerKey&&(this.#Y=i.enablerKey,this.#Y.onKeyDown=()=>this.#X=!0,this.#Y.onKeyUp=()=>this.#X=!1,this.#Y.consumeEvent=!1,this.#Y.listenEvents(),this.#X=!1)}setLocationFromEvent(e){let t=ae.convertLocation([e.clientX,e.clientY],this.movementSpace,this.options.ignoreScale);return t=this.options.ignoreTranslateCompensate?t:this.blueprint.compensateTranslation(t[0],t[1]),this.#K=[...t],this.#K}}class It extends Tt{static#U=e=>{};#q=e=>{if(this.blueprint.setFocused(!0),!this.enablerKey||this.enablerActivated)if(e.button===this.options.clickButton)this.options.strictTarget&&e.target!==e.currentTarget||(this.consumeEvent&&e.stopImmediatePropagation(),document.addEventListener("mouseup",this.#Z),this.setLocationFromEvent(e),this.clickedPosition[0]=this.location[0],this.clickedPosition[1]=this.location[1],this.blueprint.mousePosition[0]=this.location[0],this.blueprint.mousePosition[1]=this.location[1],this.clicked(this.clickedPosition));else this.options.exitAnyButton||this.#Z(e)};#Z=e=>{this.options.exitAnyButton&&e.button!=this.options.clickButton||(this.consumeEvent&&e.stopImmediatePropagation(),document.removeEventListener("mouseup",this.#Z),this.unclicked())};clickedPosition=[0,0];constructor(e,t,i={},s=It.#U,n=It.#U){i.clickButton??=re.mouseClickButton,i.consumeEvent??=!0,i.exitAnyButton??=!0,i.strictTarget??=!1,super(e,t,i),this.onClick=s,this.onUnclick=n,this.listenEvents()}listenEvents(){this.target.addEventListener("mousedown",this.#q),this.options.clickButton===re.mouseRightClickButton&&this.target.addEventListener("contextmenu",(e=>e.preventDefault()))}unlistenEvents(){this.target.removeEventListener("mousedown",this.#q)}clicked(e){this.onClick(this)}unclicked(e){this.onUnclick(this)}}class $t extends Tt{static ignoreDbClick=e=>{};#Q=e=>{this.options.strictTarget&&e.target!==e.currentTarget||(this.consumeEvent&&e.stopImmediatePropagation(),this.clickedPosition=this.setLocationFromEvent(e),this.blueprint.mousePosition=[...this.clickedPosition],this.dbclicked(this.clickedPosition))};#J;get onDbClick(){return this.#J}set onDbClick(e){this.#J=e}clickedPosition=[0,0];constructor(e,t,i={},s=$t.ignoreDbClick){i.consumeEvent??=!0,i.strictTarget??=!1,super(e,t,i),this.#J=s,this.listenEvents()}listenEvents(){this.target.addEventListener("dblclick",this.#Q)}unlistenEvents(){this.target.removeEventListener("dblclick",this.#Q)}dbclicked(e){this.onDbClick(e)}}class Dt{element;get blueprint(){return this.element.blueprint}#ee=[];get inputObjects(){return this.#ee}initialize(e){this.element=e}createInputObjects(){return[]}setup(){this.#ee.forEach((e=>e.setup()))}cleanup(){this.#ee.forEach((e=>e.cleanup()))}willUpdate(e){}update(e){}render(){return H``}firstUpdated(e){}updated(e){}inputSetup(){this.#ee=this.createInputObjects()}}class Bt extends Dt{update(e){super.update(e);const[t,i,s,n]=[Math.round(this.element.fromX),Math.round(this.element.fromY),Math.round(this.element.toX),Math.round(this.element.toY)],[r,a,o,l]=[Math.min(t,s),Math.min(i,n),Math.abs(t-s),Math.abs(i-n)];(e.has("fromX")||e.has("toX"))&&(this.element.style.left=`${r}px`,this.element.style.width=`${o}px`),(e.has("fromY")||e.has("toY"))&&(this.element.style.top=`${a}px`,this.element.style.height=`${l}px`)}}class Vt extends Bt{static decreasingValue(e,t){const i=-e*t[0]**2,s=t[1]-i/t[0];return e=>i/e+s}static clampedLine(e,t){if(e[0]>t[0]){const i=e;e=t,t=i}const i=(t[1]-e[1])/(t[0]-e[0]),s=e[1]-i*e[0];return n=>nt[0]?t[1]:i*n+s}static c1DecreasingValue=Vt.decreasingValue(-.15,[100,15]);static c2DecreasingValue=Vt.decreasingValue(-.05,[500,130]);static c2Clamped=Vt.clampedLine([0,80],[200,40]);#te=`ueb-id-${Math.floor(1e12*Math.random())}`;#ie=e=>{const t=new kt({},this.element.source.entity),i=ce.getConstructor("ueb-node").newObject(t);i.setLocation(...this.blueprint.snapToGrid(...e));const s=i.template;this.blueprint.addGraphElement(i);const n=this.element.getInputPin(),r=this.element.getOutputPin();this.element.source=null,this.element.destination=null;const a=ce.getConstructor("ueb-link").newObject(r,s.inputPin);this.blueprint.addGraphElement(a),this.element.source=s.outputPin,this.element.destination=n};createInputObjects(){const e=this.element.querySelector(".ueb-link-area");return[...super.createInputObjects(),new $t(e,this.blueprint,void 0,(e=>{e[0]+=re.knotOffset[0],e[1]+=re.knotOffset[1],e=ae.snapToGrid(e[0],e[1],re.gridSize),this.#ie(e)})),new It(e,this.blueprint,{enablerKey:new Mt(this.blueprint,this.blueprint,{activationKeys:ue.enableLinkDelete})},(()=>this.blueprint.removeGraphElement(this.element)))]}willUpdate(e){super.willUpdate(e);const t=this.element.source,i=this.element.destination;if(e.has("fromX")||e.has("toX")){const e=this.element.fromX,s=this.element.toX,n=t?.nodeElement.getType()==re.paths.knot,r=i?.nodeElement.getType()==re.paths.knot;!n||i&&!r||(t?.isInput()&&s>e+re.distanceThreshold?this.element.source=t.nodeElement.template.outputPin:t?.isOutput()&&se+re.distanceThreshold&&(this.element.destination=i.nodeElement.template.inputPin))}const s=Math.max(Math.abs(this.element.fromX-this.element.toX),1),n=Math.max(Math.abs(this.element.fromY-this.element.toY),1),r=Math.max(s,re.linkMinWidth),a=s/r,o=this.element.originatesFromInput?this.element.fromXthis.element.toY?1:0)),this.element.style.setProperty("--ueb-start-percentage",`${Math.round(this.element.startPercentage)}%`),this.element.style.setProperty("--ueb-link-start",`${Math.round(this.element.startPixels)}`)}render(){return H` ${this.element.linkMessageIcon||this.element.linkMessageText?H``:R}`}}class Ht extends le{static properties={...super.properties,dragging:{type:Boolean,attribute:"data-dragging",converter:ae.booleanConverter,reflect:!0},originatesFromInput:{type:Boolean,attribute:!1},svgPathD:{type:String,attribute:!1},linkMessageIcon:{type:String,attribute:!1},linkMessageText:{type:String,attribute:!1}};#se;get source(){return this.#se}set source(e){this.#ne(e,!1)}#re;get destination(){return this.#re}set destination(e){this.#ne(e,!0)}#ae=()=>this.remove();#oe=e=>this.addSourceLocation(...e.detail.value);#le=e=>this.addDestinationLocation(...e.detail.value);#ue=e=>this.setSourceLocation();#ce=e=>this.setDestinationLocation();linkMessageIcon=R;linkMessageText=R;pathElement;constructor(){super(),this.dragging=!1,this.originatesFromInput=!1,this.startPercentage=0,this.svgPathD="",this.startPixels=0}static newObject(e,t){const i=new Ht;return i.initialize(e,t),i}initialize(e,t){super.initialize({},new Vt),e&&(this.source=e,t||(this.toX=this.fromX,this.toY=this.fromY)),t&&(this.destination=t,e||(this.fromX=this.toX,this.fromY=this.toY))}#ne(e,t){const i=()=>t?this.destination:this.source;if(i()!=e){if(i()){const e=i().getNodeElement();e.removeEventListener(re.removeEventName,this.#ae),e.removeEventListener(re.nodeDragEventName,t?this.#le:this.#oe),e.removeEventListener(re.nodeReflowEventName,t?this.#ce:this.#ue),this.#he()}if(t?this.#re=e:this.#se=e,i()){const e=i().getNodeElement();e.addEventListener(re.removeEventName,this.#ae),e.addEventListener(re.nodeDragEventName,t?this.#le:this.#oe),e.addEventListener(re.nodeReflowEventName,t?this.#ce:this.#ue),t?this.setDestinationLocation():(this.setSourceLocation(),this.originatesFromInput=this.source.isInput()),this.#pe()}}}#pe(){this.source&&this.destination&&(this.source.linkTo(this.destination),this.destination.linkTo(this.source))}#he(){this.source&&this.destination&&(this.source.unlinkFrom(this.destination,!1),this.destination.unlinkFrom(this.source,!1))}cleanup(){super.cleanup(),this.#he(),this.source=null,this.destination=null}setSourceLocation(e=null,t=!0){if(null==e){const i=this;if(t&&(!this.hasUpdated||!this.source.hasUpdated))return void Promise.all([this.updateComplete,this.source.updateComplete]).then((()=>i.setSourceLocation(null,!1)));e=this.source.template.getLinkLocation()}const[i,s]=e;this.fromX=i,this.fromY=s}setDestinationLocation(e=null,t=!0){if(null==e){const i=this;if(t&&(!this.hasUpdated||!this.destination.hasUpdated))return void Promise.all([this.updateComplete,this.destination.updateComplete]).then((()=>i.setDestinationLocation(null,!1)));e=this.destination.template.getLinkLocation()}this.toX=e[0],this.toY=e[1]}getInputPin(){return this.source?.isInput()?this.source:this.destination}setInputPin(e){this.source?.isInput()&&(this.source=e),this.destination=e}getOutputPin(){return this.destination?.isOutput()?this.destination:this.source}setOutputPin(e){this.destination?.isOutput()&&(this.destination=e),this.source=e}startDragging(){this.dragging=!0}finishDragging(){this.dragging=!1}removeMessage(){this.linkMessageIcon=R,this.linkMessageText=R}setMessageConvertType(){this.linkMessageIcon=Be.convert,this.linkMessageText=H`Convert ${this.source.pinType} to ${this.destination.pinType}.`}setMessageCorrect(){this.linkMessageIcon=Be.correct,this.linkMessageText=R}setMessageReplace(){this.linkMessageIcon=Be.correct,this.linkMessageText=R}setMessageDirectionsIncompatible(){this.linkMessageIcon=Be.reject,this.linkMessageText=H`Directions are not compatbile.`}setMessagePlaceNode(){this.linkMessageIcon=R,this.linkMessageText=H`Place a new node.`}setMessageReplaceLink(){this.linkMessageIcon=Be.correct,this.linkMessageText=H`Replace existing input connections.`}setMessageReplaceOutputLink(){this.linkMessageIcon=Be.correct,this.linkMessageText=H`Replace existing output connections.`}setMessageSameNode(){this.linkMessageIcon=Be.reject,this.linkMessageText=H`Both are on the same node.`}setMessageTypesIncompatible(e,t){this.linkMessageIcon=Be.reject,this.linkMessageText=H`${ae.capitalFirstLetter(e.pinType)} is not compatible with ${ae.capitalFirstLetter(t.pinType)}.`}}class Ot extends oe{static properties={...super.properties,locationX:{type:Number,attribute:!1},locationY:{type:Number,attribute:!1},sizeX:{type:Number,attribute:!1},sizeY:{type:Number,attribute:!1}};static dragEventName=re.dragEventName;static dragGeneralEventName=re.dragGeneralEventName;constructor(){super(),this.locationX=0,this.locationY=0,this.sizeX=0,this.sizeY=0}computeSizes(){const e=this.getBoundingClientRect();this.sizeX=this.blueprint.scaleCorrect(e.width),this.sizeY=this.blueprint.scaleCorrect(e.height)}firstUpdated(e){super.firstUpdated(e),this.computeSizes()}setLocation(e,t,i=!0){const s=e-this.locationX,n=t-this.locationY;if(this.locationX=e,this.locationY=t,this.blueprint&&i){const e=new CustomEvent(this.constructor.dragEventName,{detail:{value:[s,n]},bubbles:!1,cancelable:!0});this.dispatchEvent(e)}}addLocation(e,t,i=!0){this.setLocation(this.locationX+e,this.locationY+t,i)}acknowledgeDrag(e){const t=new CustomEvent(this.constructor.dragGeneralEventName,{detail:{value:e},bubbles:!0,cancelable:!0});this.dispatchEvent(t)}snapToGrid(){const e=ae.snapToGrid(this.locationX,this.locationY,re.gridSize);this.locationX==e[0]&&this.locationY==e[1]||this.setLocation(e[0],e[1])}topBoundary(e=!1){return this.template.topBoundary(e)}rightBoundary(e=!1){return this.template.rightBoundary(e)}bottomBoundary(e=!1){return this.template.bottomBoundary(e)}leftBoundary(e=!1){return this.template.leftBoundary(e)}}class Rt extends Tt{#q=e=>{if(this.blueprint.setFocused(!0),e.button===this.options.clickButton)this.options.strictTarget&&e.target!=e.currentTarget||(this.consumeEvent&&e.stopImmediatePropagation(),this.#de.addEventListener("mousemove",this.#me),document.addEventListener("mouseup",this.#Z),this.setLocationFromEvent(e),this.clickedPosition[0]=this.location[0],this.clickedPosition[1]=this.location[1],this.blueprint.mousePosition[0]=this.location[0],this.blueprint.mousePosition[1]=this.location[1],this.target instanceof Ot&&(this.clickedOffset=[this.clickedPosition[0]-this.target.locationX,this.clickedPosition[1]-this.target.locationY]),this.clicked(this.clickedPosition));else this.options.exitAnyButton||this.#Z(e)};#me=e=>{this.consumeEvent&&e.stopImmediatePropagation(),this.#de.removeEventListener("mousemove",this.#me),this.#de.addEventListener("mousemove",this.#ge);const t=this.getEvent(re.trackingMouseEventName.begin);this.#be=0==this.target.dispatchEvent(t),this.setLocationFromEvent(e),this.lastLocation=ae.snapToGrid(this.clickedPosition[0],this.clickedPosition[1],this.stepSize),this.startDrag(this.location),this.started=!0,this.#ge(e)};#ge=e=>{this.consumeEvent&&e.stopImmediatePropagation();const t=this.setLocationFromEvent(e),i=[e.movementX,e.movementY];if(this.dragTo(t,i),this.#be&&(this.blueprint.mousePosition=t),this.options.scrollGraphEdge){const e=Math.sqrt(i[0]*i[0]+i[1]*i[1]),s=this.blueprint.scaleCorrect(re.edgeScrollThreshold),n=this.blueprint.template.gridLeftVisibilityBoundary()+s,r=this.blueprint.template.gridRightVisibilityBoundary()-s;let a=0;t[0]r&&(a=t[0]-r);const o=this.blueprint.template.gridTopVisibilityBoundary()+s,l=this.blueprint.template.gridBottomVisibilityBoundary()-s;let u=0;t[1]l&&(u=t[1]-l),a=ae.clamp(this.blueprint.scaleCorrectReverse(a)**3*e*.6,-20,20),u=ae.clamp(this.blueprint.scaleCorrectReverse(u)**3*e*.6,-20,20),this.blueprint.scrollDelta(a,u)}};#Z=e=>{if(!this.options.exitAnyButton||e.button==this.options.clickButton){if(this.consumeEvent&&e.stopImmediatePropagation(),this.#de.removeEventListener("mousemove",this.#me),this.#de.removeEventListener("mousemove",this.#ge),document.removeEventListener("mouseup",this.#Z),this.started&&this.endDrag(),this.unclicked(),this.#be){const e=this.getEvent(re.trackingMouseEventName.end);this.target.dispatchEvent(e),this.#be=!1}this.started=!1}};#be=!1;#de;#ve;get draggableElement(){return this.#ve}clickedOffset=[0,0];clickedPosition=[0,0];lastLocation=[0,0];started=!1;stepSize=1;constructor(e,t,i={}){i.clickButton??=re.mouseClickButton,i.consumeEvent??=!0,i.draggableElement??=e,i.exitAnyButton??=!0,i.moveEverywhere??=!1,i.movementSpace??=t?.getGridDOMElement(),i.repositionOnClick??=!1,i.scrollGraphEdge??=!1,i.strictTarget??=!1,super(e,t,i),this.stepSize=Number(i.stepSize??re.gridSize),this.#de=this.options.moveEverywhere?document.documentElement:this.movementSpace,this.#ve=this.options.draggableElement,this.listenEvents()}listenEvents(){super.listenEvents(),this.#ve.addEventListener("mousedown",this.#q),this.options.clickButton===re.mouseRightClickButton&&this.#ve.addEventListener("contextmenu",(e=>e.preventDefault()))}unlistenEvents(){super.unlistenEvents(),this.#ve.removeEventListener("mousedown",this.#q)}getEvent(e){return new CustomEvent(e,{detail:{tracker:this},bubbles:!0,cancelable:!0})}clicked(e){}startDrag(e){}dragTo(e,t){}endDrag(){}unclicked(e){}}class Gt extends Rt{clicked(e){this.options.repositionOnClick&&(this.target.setLocation(...this.stepSize>1?ae.snapToGrid(e[0],e[1],this.stepSize):e),this.clickedOffset=[0,0])}dragTo(e,t){const i=[this.target.locationX??this.lastLocation[0],this.target.locationY??this.lastLocation[1]],[s,n]=this.stepSize>1?[ae.snapToGrid(e[0],e[1],this.stepSize),ae.snapToGrid(i[0],i[1],this.stepSize)]:[e,i];0==(t=[s[0]-this.lastLocation[0],s[1]-this.lastLocation[1]])[0]&&0==t[1]||(t[0]+=n[0]-i[0],t[1]+=n[1]-i[1],this.dragAction(s,t),this.lastLocation=s)}dragAction(e,t){this.target.setLocation(e[0]-this.clickedOffset[0],e[1]-this.clickedOffset[1])}}class zt extends Gt{#fe;#ye;#we;#Se;constructor(e,t,i={}){super(e,t,i),i.onClicked&&(this.#fe=i.onClicked),i.onStartDrag&&(this.#ye=i.onStartDrag),i.onDrag&&(this.#we=i.onDrag),i.onEndDrag&&(this.#Se=i.onEndDrag)}clicked(e){super.clicked(e),this.#fe?.()}startDrag(){super.startDrag(),this.#ye?.()}dragAction(e,t){this.#we?.(e,t)}endDrag(){super.endDrag(),this.#Se?.()}}class _t extends Gt{constructor(e,t,i={}){super(e,t,i),this.draggableElement.classList.add("ueb-draggable")}startDrag(){this.target.selected||(this.blueprint.unselectAll(),this.target.setSelected(!0))}dragAction(e,t){this.target.acknowledgeDrag(t)}unclicked(){this.started?(this.blueprint.getNodes(!0).forEach((e=>e.boundComments.filter((t=>!e.isInsideComment(t))).forEach((t=>e.unbindFromComment(t))))),this.blueprint.getCommentNodes().forEach((e=>e.template.manageNodesBind()))):(this.blueprint.unselectAll(),this.target.setSelected(!0))}}class Ft extends Dt{getDraggableElement(){return this.element}createDraggableObject(){const e=this.getDraggableElement();return new Gt(this.element,this.blueprint,{draggableElement:e})}createInputObjects(){return[...super.createInputObjects(),this.createDraggableObject(),new Mt(this.element,this.blueprint,{activationKeys:[re.Keys.ArrowUp,re.Keys.ArrowRight,re.Keys.ArrowDown,re.Keys.ArrowLeft]},(e=>e.target.acknowledgeDrag([e.pressedKey===re.Keys.ArrowLeft?-re.gridSize:e.pressedKey===re.Keys.ArrowRight?re.gridSize:0,e.pressedKey===re.Keys.ArrowUp?-re.gridSize:e.pressedKey===re.Keys.ArrowDown?re.gridSize:0])))]}topBoundary(e=!1){return this.element.locationY}rightBoundary(e=!1){return this.element.locationX+this.element.sizeX}bottomBoundary(e=!1){return this.element.locationY+this.element.sizeY}leftBoundary(e=!1){return this.element.locationX}centerInViewport(){const e=Math.min(this.blueprint.template.viewportSize[0]/10,this.blueprint.template.viewportSize[1]/10),t=this.leftBoundary()-this.blueprint.template.gridLeftVisibilityBoundary(),i=this.blueprint.template.gridRightVisibilityBoundary()-this.rightBoundary();let s=Math.max((t+i)/2,e);const n=this.topBoundary()-this.blueprint.template.gridTopVisibilityBoundary(),r=this.blueprint.template.gridBottomVisibilityBoundary()-this.bottomBoundary();let a=Math.max((n+r)/2,e);this.blueprint.scrollDelta(t-s,n-a,!0)}}class jt extends Ft{update(e){super.update(e),e.has("locationX")&&(this.element.style.left=`${this.element.locationX}px`),e.has("locationY")&&(this.element.style.top=`${this.element.locationY}px`)}}class Ut extends jt{getDraggableElement(){return this.element}createDraggableObject(){return new _t(this.element,this.blueprint,{draggableElement:this.getDraggableElement(),scrollGraphEdge:!0})}firstUpdated(e){super.firstUpdated(e),this.element.selected&&!this.element.listeningDrag&&this.element.setSelected(!0)}}class Wt extends Ut{static nodeStyleClasses=["ueb-node-style-default"];#Ee=!1;pinInserter;inputContainer;outputContainer;pinElement;addPinHandler=()=>{const e=this.pinInserter?.();e&&(this.defaultPin&&this.defaultPin.isInput()===e.isInput()?this.defaultPin.before(this.createPinElement(e)):(e.isInput()?this.inputContainer:this.outputContainer).appendChild(this.createPinElement(e)),this.element.acknowledgeReflow())};toggleAdvancedDisplayHandler=()=>{this.element.toggleShowAdvancedPinDisplay(),this.element.requestUpdate(),this.element.updateComplete.then((()=>this.element.acknowledgeReflow()))};createPinElement(e){const t=ce.getConstructor("ueb-pin").newObject(e,void 0,this.element);return this.pinInserter&&!this.defaultPin&&"Default"===t.getPinName()&&(this.defaultPin=t,this.defaultPin.classList.add("ueb-node-variadic-default")),t}initialize(e){super.initialize(e),this.element.classList.add(...this.constructor.nodeStyleClasses),this.element.style.setProperty("--ueb-node-color",this.getColor().cssText),this.pinInserter=this.element.entity.additionalPinInserter(),this.pinInserter&&this.element.classList.add("ueb-node-is-variadic")}getColor(){return this.element.entity.nodeColor()}render(){return H`
${this.renderTop()}
${this.pinInserter?H`
Add pin ${Be.plusCircle}
`:R} ${this.element.entity.isDevelopmentOnly()?H`
Development Only
`:R} ${this.element.advancedPinDisplay?H`
${Be.expandIcon}
`:R}
`}renderNodeIcon(){return this.element.entity.nodeIcon()}renderNodeName(){return this.element.nodeDisplayName}renderTop(){const e=this.renderNodeIcon(),t=this.renderNodeName();return H`
${e?H`
${e}
`:R} ${t?H`
${t} ${this.#Ee&&this.getTargetType().length>0?H`
Target is ${ae.formatStringName(this.getTargetType())}
`:R}
`:R}
`}firstUpdated(e){super.firstUpdated(e),this.inputContainer=this.element.querySelector(".ueb-node-inputs"),this.outputContainer=this.element.querySelector(".ueb-node-outputs"),this.setupPins(),this.element.updateComplete.then((()=>this.element.acknowledgeReflow()))}setupPins(){this.element.nodeNameElement=this.element.querySelector(".ueb-node-name-text");let e=!1,t=!1;for(const i of this.element.getPinElements())i!==this.defaultPin&&(i.isInput()?(this.inputContainer.appendChild(i),e=!0):i.isOutput()&&(this.outputContainer.appendChild(i),t=!0));this.defaultPin&&(this.defaultPin.isInput()?this.inputContainer:this.outputContainer).appendChild(this.defaultPin),e&&this.element.classList.add("ueb-node-has-inputs"),t&&this.element.classList.add("ueb-node-has-outputs")}createPinElements(){return this.element.getPinEntities().filter((e=>!e.isHidden())).map((e=>(this.#Ee=this.#Ee||"self"===e.PinName&&"Target"===e.pinTitle(),this.createPinElement(e))))}getTargetType(){return this.element.entity.FunctionReference?.MemberParent?.getName()??"Untitled"}getPinElements(e){return e.querySelectorAll("ueb-pin")}linksChanged(){}}class Kt extends Wt{#Ce=document.createElement("div");#Ne=document.createElement("div");#xe=document.createElement("div");#Pe=document.createElement("div");#ke=document.createElement("div");#Ae=document.createElement("div");#Le=document.createElement("div");#Me=document.createElement("div");initialize(e){super.initialize(e),this.element.classList.add("ueb-resizeable"),this.#Ce.classList.add("ueb-resizeable-top"),this.#Ne.classList.add("ueb-resizeable-right"),this.#xe.classList.add("ueb-resizeable-bottom"),this.#Pe.classList.add("ueb-resizeable-left"),this.#ke.classList.add("ueb-resizeable-top-right"),this.#Ae.classList.add("ueb-resizeable-bottom-right"),this.#Le.classList.add("ueb-resizeable-bottom-left"),this.#Me.classList.add("ueb-resizeable-top-left")}update(e){super.update(e),this.element.sizeX>=0&&e.has("sizeX")&&(this.element.style.width=`${this.element.sizeX}px`),this.element.sizeY>=0&&e.has("sizeY")&&(this.element.style.height=`${this.element.sizeY}px`)}firstUpdated(e){super.firstUpdated(e),this.element.append(this.#Ce,this.#Ne,this.#xe,this.#Pe,this.#ke,this.#Ae,this.#Le,this.#Me)}createInputObjects(){return[...super.createInputObjects(),new zt(this.#Ce,this.blueprint,{onDrag:(e,t)=>{t[1]=e[1]-this.element.topBoundary(),this.setSizeY(this.element.sizeY-t[1])&&this.element.addLocation(0,t[1],!1)},onEndDrag:()=>this.endResize()}),new zt(this.#Ne,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.rightBoundary(),this.setSizeX(this.element.sizeX+t[0])},onEndDrag:()=>this.endResize()}),new zt(this.#xe,this.blueprint,{onDrag:(e,t)=>{t[1]=e[1]-this.element.bottomBoundary(),this.setSizeY(this.element.sizeY+t[1])},onEndDrag:()=>this.endResize()}),new zt(this.#Pe,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.leftBoundary(),this.setSizeX(this.element.sizeX-t[0])&&this.element.addLocation(t[0],0,!1)},onEndDrag:()=>this.endResize()}),new zt(this.#ke,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.rightBoundary(),t[1]=e[1]-this.element.topBoundary(),this.setSizeX(this.element.sizeX+t[0]),this.setSizeY(this.element.sizeY-t[1])&&this.element.addLocation(0,t[1],!1)},onEndDrag:()=>this.endResize()}),new zt(this.#Ae,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.rightBoundary(),t[1]=e[1]-this.element.bottomBoundary(),this.setSizeX(this.element.sizeX+t[0]),this.setSizeY(this.element.sizeY+t[1])},onEndDrag:()=>this.endResize()}),new zt(this.#Le,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.leftBoundary(),t[1]=e[1]-this.element.bottomBoundary(),this.setSizeX(this.element.sizeX-t[0])&&this.element.addLocation(t[0],0,!1),this.setSizeY(this.element.sizeY+t[1])},onEndDrag:()=>this.endResize()}),new zt(this.#Me,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.leftBoundary(),t[1]=e[1]-this.element.topBoundary(),this.setSizeX(this.element.sizeX-t[0])&&this.element.addLocation(t[0],0,!1),this.setSizeY(this.element.sizeY-t[1])&&this.element.addLocation(0,t[1],!1)},onEndDrag:()=>this.endResize()})]}setSizeX(e){return this.element.setNodeWidth(e),!0}setSizeY(e){return this.element.setNodeHeight(e),!0}endResize(){}}class Yt extends Kt{#Te=0;initialize(e){super.initialize(e),e.classList.add("ueb-node-style-comment","ueb-node-resizeable"),e.sizeX=25*re.gridSize,e.sizeY=6*re.gridSize,super.initialize(e)}getDraggableElement(){return this.element.querySelector(".ueb-node-top")}render(){return H`
`}firstUpdated(e){super.firstUpdated(e);const t=this.getDraggableElement().getBoundingClientRect();this.#Te=t.height}manageNodesBind(){let e=this.blueprint.getNodes();for(let t of e)t.topBoundary()>=this.element.topBoundary()&&t.rightBoundary()<=this.element.rightBoundary()&&t.bottomBoundary()<=this.element.bottomBoundary()&&t.leftBoundary()>=this.element.leftBoundary()?t.bindToComment(this.element):t.unbindFromComment(this.element)}setSizeX(e){return(e=Math.round(e))>=2*re.gridSize&&(this.element.setNodeWidth(e),!0)}setSizeY(e){return(e=Math.round(e))>=2*re.gridSize&&(this.element.setNodeHeight(e),!0)}endResize(){this.manageNodesBind()}topBoundary(e=!1){return this.element.locationY}rightBoundary(e=!1){return this.element.locationX+this.element.sizeX}bottomBoundary(e=!1){return e?this.element.locationY+this.#Te:super.bottomBoundary()}leftBoundary(e=!1){return this.element.locationX}}class Xt extends Rt{#Ie;#$e=null;#De=e=>{if(!this.enteredPin){this.linkValid=!1,this.enteredPin=e.target;const t=this.link.source??this.target,i=this.enteredPin,s=t.isOutput()?t:i;t.nodeElement.getType()===re.paths.knot||i.nodeElement.getType()===re.paths.knot?(this.link.setMessageCorrect(),this.linkValid=!0):t.getNodeElement()===i.getNodeElement()?this.link.setMessageSameNode():t.isOutput()===i.isOutput()?this.link.setMessageDirectionsIncompatible():this.blueprint.getLinks(t,i).length?(this.link.setMessageReplaceLink(),this.linkValid=!0):"exec"===s.entity.getType()&&s.isLinked?(this.link.setMessageReplaceOutputLink(),this.linkValid=!0):"object"==t.entity.PinType.PinCategory&&"object"==i.entity.PinType.PinCategory||t.pinType==i.pinType?(this.link.setMessageCorrect(),this.linkValid=!0):(this.link.setMessageTypesIncompatible(t,i),this.linkValid=!1)}};#Be=e=>{this.enteredPin==e.target&&(this.enteredPin=null,this.linkValid=!1,this.link?.setMessagePlaceNode())};link;enteredPin;linkValid=!1;constructor(e,t,i={}){i.scrollGraphEdge??=!0,super(e,t,i)}startDrag(e){this.target.nodeElement.getType()==re.paths.knot&&(this.#$e=this.target),this.link=ce.getConstructor("ueb-link").newObject(this.target,null),this.blueprint.template.linksContainerElement.prepend(this.link),this.link.setMessagePlaceNode(),this.#Ie=this.blueprint.querySelectorAll("ueb-pin"),this.#Ie.forEach((e=>{e!=this.target&&(e.addEventListener("mouseenter",this.#De),e.addEventListener("mouseleave",this.#Be))})),this.link.startDragging(),this.link.setDestinationLocation(e)}dragTo(e,t){this.link.setDestinationLocation(e)}endDrag(){if(this.#Ie.forEach((e=>{e.removeEventListener("mouseenter",this.#De),e.removeEventListener("mouseleave",this.#Be)})),this.#Ie=null,this.enteredPin&&this.linkValid){if(this.#$e){const e=this.#$e!==this.link.source?this.link.source:this.enteredPin;if(this.#$e.isInput()&&e.isInput()||this.#$e.isOutput()&&e.isOutput()){const e=this.#$e.template.getOppositePin();this.#$e===this.link.source?this.link.source=e:this.enteredPin=e}}else this.enteredPin.nodeElement.getType()===re.paths.knot&&(this.enteredPin=this.enteredPin.template.getOppositePin());this.link.source.getLinks().find((e=>e.equals(this.enteredPin.createPinReference())))?this.link.remove():(this.blueprint.addGraphElement(this.link),this.link.destination=this.enteredPin)}else this.link.remove();this.enteredPin=null,this.link.removeMessage(),this.link.finishDragging(),this.link=null}}class qt extends Wt{#Ve=!1;#He=!1;displayName="";static nodeStyleClasses=["ueb-node-style-glass"];initialize(e){super.initialize(e),this.displayName=this.element.nodeDisplayName}render(){return H`
${this.displayName?H`
${this.displayName}
`:R} ${this.#Ve?H`
`:R} ${this.#He?H`
`:R} ${this.pinInserter?H`
Add pin ${Be.plusCircle}
`:R}
`}createPinElements(){return this.element.getPinEntities().filter((e=>!e.isHidden())).map((e=>{this.#Ve||=e.isInput(),this.#He||=e.isOutput();return ce.getConstructor("ueb-pin").newObject(e,void 0,this.element)}))}}class Zt extends qt{static nodeStyleClasses=["ueb-node-style-metasound","ueb-node-style-operation"]}class Qt extends qt{static nodeStyleClasses=[...super.nodeStyleClasses,"ueb-node-style-conversion"]}class Jt extends qt{static nodeStyleClasses=[...super.nodeStyleClasses,"ueb-node-style-operation"]}class ei extends Dt{static canWrapInput=!0;#Oe;get iconElement(){return this.#Oe}#Re;get wrapperElement(){return this.#Re}isNameRendered=!0;initialize(e){if(super.initialize(e),this.element.nodeElement){const e=this.element.nodeElement.template;this.isNameRendered=!(e instanceof Qt||e instanceof Jt||e instanceof Zt)}}setup(){super.setup(),this.element.nodeElement=this.element.closest("ueb-node");const e=this.element.nodeElement.template;(e instanceof Qt||e instanceof Jt)&&(this.isNameRendered=!1,this.element.requestUpdate())}createInputObjects(){return[new Xt(this.element,this.blueprint,{moveEverywhere:!0,draggableElement:this.getClickableElement()})]}render(){const e=H`
${this.renderIcon()}
`,t=H`
${this.isNameRendered?this.renderName():R} ${this.isInputRendered()?this.renderInput():H``}
`;return H`
${this.element.isInput()?H`${e}${t}`:H`${t}${e}`}
`}renderIcon(){if(this.element.nodeElement.entity.isPcg())switch(this.element.entity.getType()){case"Any":return Be.pcgPin;case"Param":case"Param[]":return Be.pcgParamPin;case"Spatial":case"Spatial[]":return Be.pcgSpatialPin;case"Any[]":case"Point[]":case"Surface[]":case"Volume[]":if(this.element.isOutput())return Be.pcgPin;case"Point":case"Surface":case"Volume":return Be.pcgStackPin}switch(this.element.entity.PinType?.ContainerType?.toString()){case"Array":return Be.arrayPin;case"Set":return Be.setPin;case"Map":return Be.mapPin}return"delegate"===this.element.entity.PinType?.PinCategory?.toLocaleLowerCase()?Be.delegate:this.element.nodeElement?.template instanceof Jt?Be.operationPin:Be.genericPin}renderName(){let e=this.element.getPinDisplayName();const t=this.element.nodeElement,i=this.element.getPinName();return t.getType()==re.paths.makeStruct&&i==t.entity.StructType.getName()&&(e=i),H`${e}`}isInputRendered(){return this.element.isInput()&&!this.element.entity.bDefaultValueIsIgnored&&!this.element.entity.PinType.bIsReference}renderInput(){return H``}updated(e){if(super.updated(e),this.element.isInput()&&e.has("isLinked")){const e=this.element.nodeElement;this.element.requestUpdate(),this.element.updateComplete.then((()=>e.acknowledgeReflow()))}}firstUpdated(e){super.firstUpdated(e),this.element.style.setProperty("--ueb-pin-color-rgb",this.element.entity.pinColor().cssText),this.#Oe=this.element.querySelector(".ueb-pin-icon svg")??this.element,this.#Re=this.element.querySelector(".ueb-pin-wrapper")}getLinkLocation(){const e=this.iconElement.getBoundingClientRect(),t=[this.element.isInput()?e.left:e.right+1,(e.top+e.bottom)/2],i=ae.convertLocation(t,this.blueprint.template.gridElement);return this.blueprint.compensateTranslation(i[0],i[1])}getClickableElement(){return this.#Re??this.element}}class ti extends ei{render(){return H`
${this.renderIcon()}
`}}class ii extends Wt{static nodeStyleClasses=[...super.nodeStyleClasses,"ueb-node-style-event"];firstUpdated(e){super.firstUpdated(e),this.element.querySelector(".ueb-node-top").appendChild(this.createDelegatePinElement())}renderTop(){const e=this.renderNodeIcon(),t=this.renderNodeName(),i=this.element.getType()===re.paths.customEvent&&(this.element.entity.CustomFunctionName||this.element.entity.FunctionReference.MemberParent);return H`
${e?H`
${e}
`:R} ${t?H`
${t} ${i?H`
Custom Event
`:R}
`:R}
`}createDelegatePinElement(){const e=ce.getConstructor("ueb-pin").newObject(this.element.getPinEntities().find((e=>!e.isHidden()&&"delegate"===e.PinType.PinCategory)),new ti,this.element);return e.template.isNameRendered=!1,e}createPinElements(){return this.element.getPinEntities().filter((e=>!e.isHidden()&&"delegate"!==e.PinType.PinCategory)).map((e=>ce.getConstructor("ueb-pin").newObject(e,void 0,this.element)))}}class si extends ti{render(){return this.element.isOutput()?super.render():H``}getOppositePin(){const e=this.element.nodeElement.template;return this.element.isOutput()?e.inputPin:e.outputPin}getLinkLocation(){const e=(this.element.isInput()?this.element.nodeElement.template.outputPin.template:this).iconElement.getBoundingClientRect(),t=[this.element.isInput()?e.left:e.right+1,(e.top+e.bottom)/2],i=ae.convertLocation(t,this.blueprint.template.gridElement);return this.blueprint.compensateTranslation(i[0],i[1])}}class ni extends Wt{static#Ge=new Set;#ze=null;#_e;get inputPin(){return this.#_e}#Fe;get outputPin(){return this.#Fe}initialize(e){super.initialize(e),this.element.classList.add("ueb-node-style-minimal")}findDirectionaPin(e){if(e.nodeElement.getType()!==re.paths.knot||ni.#Ge.has(e))return ni.#Ge.clear(),!0;ni.#Ge.add(e);for(let t of e.getLinks().map((e=>this.blueprint.getPin(e))))if(this.findDirectionaPin(t))return!0;return!1}render(){return H`
`}setupPins(){this.element.getPinElements().forEach((e=>this.element.querySelector(".ueb-node-border").appendChild(e)))}getPinElements(e){return e.querySelectorAll("ueb-pin")}createPinElements(){const e=this.element.getPinEntities().filter((e=>!e.isHidden())),t=e[e[0].isInput()?0:1],i=e[e[0].isOutput()?0:1],s=ce.getConstructor("ueb-pin");return[this.#_e=s.newObject(t,new si,this.element),this.#Fe=s.newObject(i,new si,this.element)]}linksChanged(){}}class ri extends Wt{static nodeStyleClasses=["ueb-node-style-metasound"]}class ai extends qt{initialize(e){super.initialize(e);const t=e.getType();t===re.paths.variableGet||t===re.paths.self?(this.element.classList.add("ueb-node-style-getter"),this.displayName=""):t===re.paths.variableSet&&this.element.classList.add("ueb-node-style-setter")}setupPins(){super.setupPins();let e=this.element.getPinElements().find((e=>!e.entity.isHidden()&&!e.entity.isExecution()));this.element.style.setProperty("--ueb-node-color",e.getColor().cssText)}}function oi(e){if(e.getClass()===re.paths.callFunction||e.getClass()===re.paths.commutativeAssociativeBinaryOperator||e.getClass()===re.paths.callArrayFunction){const t=e.FunctionReference?.MemberParent?.path??"",i=e.FunctionReference?.MemberName;if(i&&(t===re.paths.kismetMathLibrary||t===re.paths.kismetArrayLibrary)){if(i.startsWith("Conv_"))return Qt;if(i.startsWith("Add_")||i.startsWith("And_")||i.startsWith("Boolean")||i.startsWith("Cross_")||i.startsWith("Dot_")||i.startsWith("Not_")||i.startsWith("Or_")||i.startsWith("Percent_")||i.startsWith("Xor_"))return Jt;switch(i){case"Abs":case"Array_Add":case"Array_AddUnique":case"Array_Identical":case"BMax":case"BMin":case"CrossProduct2D":case"DotProduct2D":case"Exp":case"FMax":case"FMin":case"GetPI":case"Max":case"MaxInt64":case"Min":case"MinInt64":case"Sqrt":case"Square":case"Vector4_CrossProduct3":case"Vector4_DotProduct":case"Vector4_DotProduct3":case"Acos":case"Asin":case"Cos":case"DegAcos":case"DegCos":case"DegSin":case"DegTan":case"Sin":case"Tan":return Jt}}if(t===re.paths.blueprintSetLibrary)return Jt;if(t===re.paths.blueprintMapLibrary)return Jt}switch(e.getClass()){case re.paths.comment:case re.paths.materialGraphNodeComment:return Yt;case re.paths.createDelegate:return Wt;case re.paths.metasoundEditorGraphExternalNode:return"Add"==e.ClassName?.Name?Zt:ri;case re.paths.niagaraNodeOp:if(["Boolean::LogicEq","Boolean::LogicNEq","Numeric::Abs","Numeric::Add","Numeric::Mul"].includes(e.OpName))return Jt;break;case re.paths.promotableOperator:return Jt;case re.paths.knot:return ni;case re.paths.literal:case re.paths.self:case re.paths.variableGet:case re.paths.variableSet:return ai}return e.isEvent()?ii:Wt}class li{static#je=new Map;static registerSerializer(e,t){li.#je.set(e,t)}static getSerializer(e){return li.#je.get(e)}}class ui extends Ot{static properties={...super.properties,selected:{type:Boolean,attribute:"data-selected",reflect:!0,converter:ae.booleanConverter}};dragHandler=e=>this.addLocation(...e.detail.value);constructor(){super(),this.selected=!1,this.listeningDrag=!1}setup(){super.setup(),this.setSelected(this.selected)}cleanup(){super.cleanup(),this.blueprint.removeEventListener(re.nodeDragGeneralEventName,this.dragHandler)}setSelected(e=!0){this.selected=e,this.blueprint&&(this.selected?(this.listeningDrag=!0,this.blueprint.addEventListener(re.nodeDragGeneralEventName,this.dragHandler)):(this.blueprint.removeEventListener(re.nodeDragGeneralEventName,this.dragHandler),this.listeningDrag=!1))}}class ci extends ui{static properties={...ui.properties,typePath:{type:String,attribute:"data-type",reflect:!0},nodeTitle:{type:String,attribute:"data-title",reflect:!0},advancedPinDisplay:{type:String,attribute:"data-advanced-display",converter:wt.attributeConverter,reflect:!0},enabledState:{type:String,attribute:"data-enabled-state",reflect:!0},nodeDisplayName:{type:String,attribute:!1},pureFunction:{type:Boolean,converter:ae.booleanConverter,attribute:"data-pure-function",reflect:!0}};static dragEventName=re.nodeDragEventName;static dragGeneralEventName=re.nodeDragGeneralEventName;get blueprint(){return super.blueprint}set blueprint(e){super.blueprint=e,this.#Ue.forEach((t=>t.blueprint=e))}#We;get nodeNameElement(){return this.#We}set nodeNameElement(e){this.#We=e}#Ue=[];boundComments=[];#Ke=!1;#Ye=e=>{this.selected||this.#Ke||(this.#Ke=!0,this.requestUpdate(),this.updateComplete.then((()=>this.#Ke=!1)),this.addLocation(...e.detail.value))};static fromSerializedObject(e){e=e.trim();let t=li.getSerializer(Pt).read(e);return ci.newObject(t)}static newObject(e=new Pt,t=new(oi(e))){const i=new ci;return i.initialize(e,t),i}#Xe(e){for(let t of this.getPinElements())for(let i of t.getLinks())this.blueprint.getPin(i).redirectLink(t,new at({objectName:e,pinGuid:t.entity.PinId}))}initialize(e=new Pt,t=new(oi(e))){this.typePath=e.getType(),this.nodeTitle=e.getObjectName(),this.advancedPinDisplay=e.AdvancedPinDisplay?.toString(),this.enabledState=e.EnabledState,this.nodeDisplayName=Oe(e),this.pureFunction=e.bIsPureFunc,this.dragLinkObjects=[],super.initialize(e,t),this.#Ue=this.template.createPinElements(),super.setLocation(this.entity.getNodePosX(),this.entity.getNodePosY()),this.entity.NodeWidth&&this.entity.NodeHeight?(this.sizeX=this.entity.NodeWidth.value,this.sizeY=this.entity.NodeHeight.value):this.updateComplete.then((()=>this.computeSizes())),e.listenAttribute("Name",(t=>{this.nodeTitle=e.Name,this.nodeDisplayName=Oe(e),this.#Xe(t)}))}async getUpdateComplete(){let e=await super.getUpdateComplete();for(const t of this.getPinElements())e&&=await t.updateComplete;return e}bindToComment(e){e==this||this.boundComments.includes(e)||(e.addEventListener(re.nodeDragEventName,this.#Ye),this.boundComments.push(e))}unbindFromComment(e){const t=this.boundComments.indexOf(e);t>=0&&(e.removeEventListener(re.nodeDragEventName,this.#Ye),this.boundComments[t]=this.boundComments[this.boundComments.length-1],this.boundComments.pop())}isInsideComment(e){return this.topBoundary()>=e.topBoundary()&&this.rightBoundary()<=e.rightBoundary()&&this.bottomBoundary()<=e.bottomBoundary()&&this.leftBoundary()>=e.leftBoundary()}getType(){return this.entity.getType()}getNodeName(){return this.entity.getObjectName()}computeNodeDisplayName(){this.nodeDisplayName=Oe(this.entity)}setNodeWidth(e){this.entity.setNodeWidth(e),this.sizeX=e,this.acknowledgeReflow()}setNodeHeight(e){this.entity.setNodeHeight(e),this.sizeY=e,this.acknowledgeReflow()}sanitizeLinks(e=[]){this.getPinElements().forEach((t=>t.sanitizeLinks(e)))}getPinElements(){return this.#Ue}getPinEntities(){return this.entity.getPinEntities()}setLocation(e=0,t=0,i=!0){this.entity.setNodePosX(e),this.entity.setNodePosY(t),super.setLocation(e,t,i)}acknowledgeReflow(){this.requestUpdate(),this.updateComplete.then((()=>this.computeSizes()));let e=new CustomEvent(re.nodeReflowEventName);this.dispatchEvent(e)}setShowAdvancedPinDisplay(e){this.entity.AdvancedPinDisplay=new wt(e?"Shown":"Hidden"),this.advancedPinDisplay=this.entity.AdvancedPinDisplay}toggleShowAdvancedPinDisplay(){this.setShowAdvancedPinDisplay("Shown"!=this.entity.AdvancedPinDisplay?.toString())}}class hi extends Pt{#qe=new Map;#Ze=[];get objectEntities(){return this.#Ze}getHomonymObjectEntity(e){const t=e.getObjectName(!1);return this.#Ze.find((e=>e.getObjectName()==t))}takeFreeName(e){e=e.replace(/_\d+$/,"");const t=(this.#qe.get(e)??-1)+1;return this.#qe.set(e,t),re.nodeTitle(e,t)}addObjectEntity(e){if(!this.#Ze.includes(e)){this.#Ze.push(e);const[t,i]=e.getNameAndCounter();return this.#qe.set(t,Math.max(this.#qe.get(t)??0,i)),!0}return!1}removeObjectEntity(e){const t=this.#Ze.indexOf(e);if(t>=0){const e=this.#Ze.pop();return te.OriginalChangeId.value==t.OriginalChangeId.value));if(t.length===this.ScriptVariables.length)return this;const i=t.concat(t).map(((i,s)=>{const n=re.subObjectAttributeNameFromReference(i.ScriptVariable,s>=t.length);return[n,this[n]??e[n]]}));return i.push(...Object.entries(this).filter((([e,t])=>!e.startsWith(re.subObjectAttributeNamePrefix)&&"ExportedNodes"!==e))),new hi(Object.fromEntries(i))}}class pi{static same=e=>e;static notWrapped=(e,t)=>t;static bracketsWrapped=(e,t)=>`(${t})`;constructor(e,t=((e,t)=>t),i=",",s=!1,n="=",r=pi.same){this.entityType=e,this.wrap=t,this.attributeSeparator=i,this.trailingSeparator=s,this.attributeValueConjunctionSign=n,this.attributeKeyPrinter=r}read(e){return this.doRead(e.trim())}write(e,t=!1){return this.doWrite(e,t)}doRead(e){const t=Ie.grammarFor(void 0,this.entityType).run(e);if(!t.status)throw new Error(this.entityType?`Error when trying to parse the entity ${this.entityType.prototype.constructor.name}`:"Error when trying to parse null");return t.value}doWrite(e,t=!1,i="",s=this.wrap,n=this.attributeSeparator,r=this.trailingSeparator,a=this.attributeValueConjunctionSign,o=this.attributeKeyPrinter){let l="";const u=e._keys??Object.keys(e);let c=!0;for(const s of u){const r=e[s];if(void 0!==r&&this.showProperty(e,s)){let u=e instanceof Array?`(${s})`:s;Ae.getAttribute(e,s,"quoted")&&(u=`"${u}"`);const h=Ae.getAttribute(e,s,"serialized");if(c?c=!1:l+=n,Ae.getAttribute(e,s,"inlined")){l+=this.doWrite(r,t,i,pi.notWrapped,n,!1,a,Ae.getAttribute(e,s,"type")instanceof Array?e=>o(`${u}${e}`):e=>o(`${u}.${e}`));continue}const p=o(u),d=n.includes("\n")?i:"";l+=(p.length?d+p+this.attributeValueConjunctionSign:"")+(h?`"${this.doWriteValue(r,!0,i)}"`:this.doWriteValue(r,t,i))}}return r&&l.length&&(l+=n),s(e,l)}doWriteValue(e,t,i=""){const s=ae.getType(e),n=li.getSerializer(s);if(!n)throw new Error(`Unknown value type "${s.name}", a serializer must be registered in the SerializerFactory class, check initializeSerializerFactory.js`);return n.doWrite(e,t,i)}showProperty(e,t){if(e instanceof Le){if(Ae.getAttribute(e,t,"ignored"))return!1;if(Ae.getAttribute(e,t,"silent")){let i=Ae.getAttribute(e,t,"default");if(i instanceof Function&&(i=i(e)),ae.equals(e[t],i))return!1}}return!0}}class di extends pi{constructor(e=Pt){super(e,void 0,"\n",!0,void 0,pi.same)}showProperty(e,t){switch(t){case"Class":case"Name":case"Archetype":case"ExportPath":case"CustomProperties":return!1}return super.showProperty(e,t)}write(e,t=!1){return this.doWrite(e,t)+"\n"}doRead(e){return Ie.grammarFor(void 0,this.entityType).parse(e)}readMultiple(e){return Pt.getMultipleObjectsGrammar().parse(e)}doWrite(e,t,i="",s=this.wrap,n=this.attributeSeparator,r=this.trailingSeparator,a=this.attributeValueConjunctionSign,o=this.attributeKeyPrinter){const l=i+re.indentation;if(!(e instanceof Pt))return super.doWrite(e,t,i,s,n,r,a,(t=>e[t]instanceof Pt?"":o(t)));return i+"Begin Object"+(e.Class?.type||e.Class?.path?` Class=${this.doWriteValue(e.Class,t)}`:"")+(e.Name?` Name=${this.doWriteValue(e.Name,t)}`:"")+(e.Archetype?` Archetype=${this.doWriteValue(e.Archetype,t)}`:"")+(e.ExportPath?.type||e.ExportPath?.path?` ExportPath=${this.doWriteValue(e.ExportPath,t)}`:"")+"\n"+super.doWrite(e,t,l,s,n,!0,a,(t=>e[t]instanceof Pt?"":o(t)))+(Ae.getAttribute(e,"CustomProperties","ignored")?"":e.getCustomproperties().map((e=>l+o("CustomProperties ")+li.getSerializer(ft).doWrite(e,t)+this.attributeSeparator)).join(""))+i+"End Object"}}class mi extends At{static#Qe=new di;#Je;constructor(e,t,i={}){i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,super(e,t,i);let s=this;this.#Je=()=>s.copied()}listenEvents(){window.addEventListener("copy",this.#Je)}unlistenEvents(){window.removeEventListener("copy",this.#Je)}getSerializedText(){const e=this.blueprint.getNodes(!0).map((e=>e.entity)),t=e.filter((e=>e.isExported)).map((e=>mi.#Qe.write(e,!1))),i=e.filter((e=>!e.isExported)).map((e=>mi.#Qe.write(e,!1)));return t.length&&(this.blueprint.entity.ExportedNodes=btoa(t.join("")),i.splice(0,0,mi.#Qe.write(this.blueprint.entity,!1)),delete this.blueprint.entity.ExportedNodes),i.join("")}copied(){const e=this.getSerializedText();return navigator.clipboard.writeText(e),e}}class gi extends At{static#Qe=new di;#et;constructor(e,t,i={}){i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,super(e,t,i);let s=this;this.#et=()=>s.cut()}listenEvents(){window.addEventListener("cut",this.#et)}unlistenEvents(){window.removeEventListener("cut",this.#et)}getSerializedText(){return this.blueprint.getNodes(!0).map((e=>gi.#Qe.write(e.entity,!1))).join("")}cut(){this.blueprint.template.getCopyInputObject().copied(),this.blueprint.removeGraphElement(...this.blueprint.getNodes(!0))}}class bi extends At{static#Qe=new di;#tt;constructor(e,t,i={}){i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,super(e,t,i);let s=this;this.#tt=e=>s.pasted(e.clipboardData.getData("Text"))}listenEvents(){window.addEventListener("paste",this.#tt)}unlistenEvents(){window.removeEventListener("paste",this.#tt)}pasted(e){let t=0,i=0,s=0,n=bi.#Qe.readMultiple(e).map((e=>{let n=ce.getConstructor("ueb-node").newObject(e);return t+=n.locationY,i+=n.locationX,++s,n}));t/=s,i/=s,n.length>0&&this.blueprint.unselectAll();let r=this.blueprint.mousePosition;return n.forEach((e=>{e.addLocation(r[0]-i,r[1]-t),e.snapToGrid(),e.setSelected(!0)})),this.blueprint.addGraphElement(...n),n}}class vi extends Tt{static#U=e=>{};#it=0;get variation(){return this.#it}#st=e=>{this.enablerKey&&!this.enablerActivated||(e.preventDefault(),this.#it=e.deltaY,this.setLocationFromEvent(e),this.wheel())};#nt=e=>e.preventDefault();constructor(e,t,i={},s=vi.#U){i.listenOnFocus=!0,i.strictTarget??=!1,super(e,t,i),this.strictTarget=i.strictTarget,this.onWheel=s}listenEvents(){this.movementSpace.addEventListener("wheel",this.#st,!1),this.movementSpace.parentElement?.addEventListener("wheel",this.#nt)}unlistenEvents(){this.movementSpace.removeEventListener("wheel",this.#st,!1),this.movementSpace.parentElement?.removeEventListener("wheel",this.#nt)}wheel(){this.onWheel(this)}}class fi extends vi{#rt=0;#at=!1;get enableZoonIn(){return this.#at}set enableZoonIn(e){e!=this.#at&&(this.#at=e)}wheel(){if(this.#rt+=-this.variation,Math.abs(this.#rt)0||(e+=Math.sign(this.#rt),this.blueprint.setZoom(e,this.location),this.#rt=0)}}class yi extends Mt{#ot;constructor(e,t,i={}){i.activationKeys=ue.enableZoomIn,super(e,t,i)}fire(){this.#ot=this.blueprint.template.getZoomInputObject(),this.#ot.enableZoonIn=!0}unfire(){this.#ot.enableZoonIn=!1}}class wi extends Rt{startDrag(){this.blueprint.scrolling=!0}dragTo(e,t){this.blueprint.scrollDelta(-t[0],-t[1])}endDrag(){this.blueprint.scrolling=!1}}class Si extends Tt{#lt=null;#ut=e=>{e.preventDefault(),this.setLocationFromEvent(e),this.blueprint.mousePosition=[...this.location]};#ct=e=>{this.#lt||(e.preventDefault(),this.#lt=e.detail.tracker,this.unlistenMouseMove())};#ht=e=>{this.#lt==e.detail.tracker&&(e.preventDefault(),this.#lt=null,this.listenMouseMove())};constructor(e,t,i={}){i.listenOnFocus=!0,super(e,t,i)}listenMouseMove(){this.target.addEventListener("mousemove",this.#ut)}unlistenMouseMove(){this.target.removeEventListener("mousemove",this.#ut)}listenEvents(){this.listenMouseMove(),this.blueprint.addEventListener(re.trackingMouseEventName.begin,this.#ct),this.blueprint.addEventListener(re.trackingMouseEventName.end,this.#ht)}unlistenEvents(){this.unlistenMouseMove(),this.blueprint.removeEventListener(re.trackingMouseEventName.begin,this.#ct),this.blueprint.removeEventListener(re.trackingMouseEventName.end,this.#ht)}}class Ei extends Rt{constructor(e,t,i={}){i.scrollGraphEdge??=!0,super(e,t,i),this.selectorElement=this.blueprint.template.selectorElement}startDrag(){this.selectorElement.beginSelect(this.clickedPosition)}dragTo(e,t){this.selectorElement.selectTo(e)}endDrag(){this.started&&this.selectorElement.endSelect()}unclicked(){this.started||this.blueprint.unselectAll()}}class Ci extends At{#pt=e=>this.clickedSomewhere(e.target);constructor(e,t,i={}){i.listenOnFocus=!0,super(e,t,i),this.blueprint.focus&&document.addEventListener("click",this.#pt)}clickedSomewhere(e){e.closest("ueb-blueprint")||this.blueprint.setFocused(!1)}listenEvents(){document.addEventListener("click",this.#pt)}unlistenEvents(){document.removeEventListener("click",this.#pt)}}class Ni extends Dt{static styleVariables={"--ueb-font-size":`${re.fontSize}`,"--ueb-grid-axis-line-color":`${re.gridAxisLineColor}`,"--ueb-grid-expand":`${re.expandGridSize}px`,"--ueb-grid-line-color":`${re.gridLineColor}`,"--ueb-grid-line-width":`${re.gridLineWidth}px`,"--ueb-grid-set-line-color":`${re.gridSetLineColor}`,"--ueb-grid-set":`${re.gridSet}`,"--ueb-grid-size":`${re.gridSize}px`,"--ueb-link-min-width":`${re.linkMinWidth}`,"--ueb-node-radius":`${re.nodeRadius}px`};#dt=new ResizeObserver((e=>{const t=e.find((e=>e.target===this.viewportElement))?.devicePixelContentBoxSize?.[0];t&&(this.viewportSize[0]=t.inlineSize,this.viewportSize[1]=t.blockSize)}));#mt;#gt;#ot;headerElement;overlayElement;viewportElement;selectorElement;gridElement;linksContainerElement;nodesContainerElement;viewportSize=[0,0];initialize(e){super.initialize(e),this.element.style.cssText=Object.entries(Ni.styleVariables).map((([e,t])=>`${e}:${t};`)).join("");const t=this.element.querySelector(":scope > template")?.content.textContent;t&&(this.element.requestUpdate(),this.element.updateComplete.then((()=>{this.blueprint.mousePosition=[Math.round(this.viewportSize[0]/2),Math.round(this.viewportSize[1]/2)],this.getPasteInputObject().pasted(t),this.blueprint.unselectAll()})))}setup(){super.setup(),this.#dt.observe(this.viewportElement,{box:"device-pixel-content-box"});const e=this.viewportElement.getBoundingClientRect();this.viewportSize[0]=e.width,this.viewportSize[1]=e.height,this.blueprint.nodes.length>0&&(this.blueprint.requestUpdate(),this.blueprint.updateComplete.then((()=>this.centerContentInViewport())))}cleanup(){super.cleanup(),this.#dt.unobserve(this.viewportElement)}createInputObjects(){const e=this.element.getGridDOMElement();return this.#mt=new mi(e,this.blueprint),this.#gt=new bi(e,this.blueprint),this.#ot=new fi(e,this.blueprint),[...super.createInputObjects(),this.#mt,this.#gt,this.#ot,new gi(e,this.blueprint),new Mt(e,this.blueprint,{activationKeys:ue.duplicateNodes},(()=>this.blueprint.template.getPasteInputObject().pasted(this.blueprint.template.getCopyInputObject().copied()))),new Mt(e,this.blueprint,{activationKeys:ue.deleteNodes},(()=>this.blueprint.removeGraphElement(...this.blueprint.getNodes(!0)))),new Mt(e,this.blueprint,{activationKeys:ue.selectAllNodes},(()=>this.blueprint.selectAll())),new Ei(e,this.blueprint,{clickButton:re.mouseClickButton,exitAnyButton:!0,moveEverywhere:!0}),new wi(e,this.blueprint,{clickButton:re.mouseRightClickButton,exitAnyButton:!1,moveEverywhere:!0}),new Ci(e,this.blueprint),new Si(e,this.blueprint),new yi(e,this.blueprint)]}render(){return H`
Zoom ${0==this.blueprint.zoom?"1:1":(this.blueprint.zoom>0?"+":"")+this.blueprint.zoom}
`}firstUpdated(e){super.firstUpdated(e),this.headerElement=this.blueprint.querySelector(".ueb-viewport-header"),this.overlayElement=this.blueprint.querySelector(".ueb-viewport-overlay"),this.viewportElement=this.blueprint.querySelector(".ueb-viewport-body"),this.selectorElement=this.blueprint.querySelector("ueb-selector"),this.gridElement=this.viewportElement.querySelector(".ueb-grid"),this.linksContainerElement=this.blueprint.querySelector("[data-links]"),this.linksContainerElement.append(...this.blueprint.getLinks()),this.nodesContainerElement=this.blueprint.querySelector("[data-nodes]"),this.nodesContainerElement.append(...this.blueprint.getNodes()),this.viewportElement.scroll(re.expandGridSize,re.expandGridSize)}willUpdate(e){super.willUpdate(e),this.headerElement&&e.has("zoom")&&(this.headerElement.classList.add("ueb-zoom-changed"),this.headerElement.addEventListener("animationend",(()=>this.headerElement.classList.remove("ueb-zoom-changed"))))}updated(e){if(super.updated(e),(e.has("scrollX")||e.has("scrollY"))&&this.viewportElement.scroll(this.blueprint.scrollX,this.blueprint.scrollY),e.has("zoom")){this.blueprint.style.setProperty("--ueb-scale",this.blueprint.getScale());const t=e.get("zoom"),i=Math.min(t,this.blueprint.zoom),s=Math.max(t,this.blueprint.zoom),n=ae.range(i,s),r=e=>`ueb-zoom-${e}`;te<0)).map(r)),this.blueprint.classList.add(...n.filter((e=>e>0)).map(r))):(this.blueprint.classList.remove(...n.filter((e=>e>0)).map(r)),this.blueprint.classList.add(...n.filter((e=>e<0)).map(r)))}}getCommentNodes(e=!1){return this.blueprint.querySelectorAll(`ueb-node[data-type="${re.paths.comment}"]${e?'[data-selected="true"]':""}, ueb-node[data-type="${re.paths.materialGraphNodeComment}"]${e?'[data-selected="true"]':""}`)}getPin(e){return this.blueprint.querySelector(`ueb-node[data-title="${e.objectName}"] ueb-pin[data-id="${e.pinGuid}"]`)}getCopyInputObject(){return this.#mt}getPasteInputObject(){return this.#gt}getZoomInputObject(){return this.#ot}isPointVisible(e,t){return!1}gridTopVisibilityBoundary(){return this.blueprint.scaleCorrect(this.blueprint.scrollY)-this.blueprint.translateY}gridRightVisibilityBoundary(){return this.gridLeftVisibilityBoundary()+this.blueprint.scaleCorrect(this.viewportSize[0])}gridBottomVisibilityBoundary(){return this.gridTopVisibilityBoundary()+this.blueprint.scaleCorrect(this.viewportSize[1])}gridLeftVisibilityBoundary(){return this.blueprint.scaleCorrect(this.blueprint.scrollX)-this.blueprint.translateX}centerViewport(e=0,t=0,i=!0){const s=this.gridLeftVisibilityBoundary()+this.blueprint.scaleCorrect(this.viewportSize[0]/2),n=this.gridTopVisibilityBoundary()+this.blueprint.scaleCorrect(this.viewportSize[1]/2);this.blueprint.scrollDelta(this.blueprint.scaleCorrectReverse(e-s),this.blueprint.scaleCorrectReverse(t-n),i)}centerContentInViewport(e=!0){let t=0,i=0,s=Number.MAX_SAFE_INTEGER,n=Number.MIN_SAFE_INTEGER,r=Number.MAX_SAFE_INTEGER,a=Number.MIN_SAFE_INTEGER;const o=this.blueprint.getNodes();for(const e of o)t+=e.leftBoundary()+e.rightBoundary(),i+=e.topBoundary()+e.bottomBoundary(),s=Math.min(s,e.leftBoundary()),n=Math.max(n,e.rightBoundary()),r=Math.min(r,e.topBoundary()),a=Math.max(a,e.bottomBoundary());t=Math.round(n-s<=this.viewportSize[0]?(n+s)/2:t/(2*o.length)),i=Math.round(a-r<=this.viewportSize[1]?(a+r)/2:i/(2*o.length)),this.centerViewport(t,i,e)}}class xi extends oe{static properties={selecting:{type:Boolean,attribute:"data-selecting",reflect:!0,converter:ae.booleanConverter},scrolling:{type:Boolean,attribute:"data-scrolling",reflect:!0,converter:ae.booleanConverter},focused:{type:Boolean,attribute:"data-focused",reflect:!0,converter:ae.booleanConverter},zoom:{type:Number,attribute:"data-zoom",reflect:!0},scrollX:{type:Number,attribute:!1},scrollY:{type:Number,attribute:!1},additionalX:{type:Number,attribute:!1},additionalY:{type:Number,attribute:!1},translateX:{type:Number,attribute:!1},translateY:{type:Number,attribute:!1}};static nodeBoundariesSupplier=e=>({primaryInf:e.leftBoundary(!0),primarySup:e.rightBoundary(!0),secondaryInf:e.topBoundary(!0),secondarySup:e.bottomBoundary(!0)});static nodeSelectToggleFunction=(e,t)=>{e.setSelected(t)};#bt=0;#vt=0;nodes=[];links=[];nodesNames=new Map;mousePosition=[0,0];waitingExpandUpdate=!1;constructor(){super(),this.selecting=!1,this.scrolling=!1,this.focused=!1,this.zoom=0,this.scrollX=re.expandGridSize,this.scrollY=re.expandGridSize,this.translateX=re.expandGridSize,this.translateY=re.expandGridSize,super.initialize(new hi,new Ni)}initialize(){}getGridDOMElement(){return this.template.gridElement}getScroll(){return[this.scrollX,this.scrollY]}setScroll(e,t){this.scrollX=e,this.scrollY=t}scrollDelta(e=0,t=0,i=!1,s=re.smoothScrollTime){if(i){let i=[0,0];this.#bt&&cancelAnimationFrame(this.#bt),this.#vt&&cancelAnimationFrame(this.#vt),ae.animate(0,e,s,(e=>{this.scrollDelta(e-i[0],0,!1),i[0]=e}),(e=>this.#bt=e)),ae.animate(0,t,s,(e=>{this.scrollDelta(0,e-i[1],!1),i[1]=e}),(e=>this.#vt=e))}else{const i=[2*re.expandGridSize,2*re.expandGridSize];let s=this.getScroll(),n=[s[0]+e,s[1]+t],r=[0,0];for(let e=0;e<2;++e)n[e]i[e]-re.gridExpandThreshold*re.expandGridSize&&(r[e]=1);0==r[0]&&0==r[1]||this.seamlessExpand(r[0],r[1]),s=this.getScroll(),n=[s[0]+e,s[1]+t],this.setScroll(n[0],n[1])}}scrollCenter(e=!1){const t=this.getScroll(),i=[this.translateX-t[0],this.translateY-t[1]],s=this.getViewportSize().map((e=>e/2)),n=[i[0]-s[0],i[1]-s[1]];this.scrollDelta(n[0],n[1],e)}getViewportSize(){return[this.template.viewportElement.clientWidth,this.template.viewportElement.clientHeight]}getScrollMax(){return[this.template.viewportElement.scrollWidth-this.template.viewportElement.clientWidth,this.template.viewportElement.scrollHeight-this.template.viewportElement.clientHeight]}snapToGrid(e,t){return ae.snapToGrid(e,t,re.gridSize)}seamlessExpand(e,t){e=Math.round(e),t=Math.round(t);let i=this.getScale();[e,t]=[-e*re.expandGridSize,-t*re.expandGridSize],0!=e&&(this.scrollX+=e,e/=i),0!=t&&(this.scrollY+=t,t/=i),this.translateX+=e,this.translateY+=t}progressiveSnapToGrid(e){return re.expandGridSize*Math.round(e/re.expandGridSize+.5*Math.sign(e))}getZoom(){return this.zoom}setZoom(e,t){if((e=ae.clamp(e,re.minZoom,re.maxZoom))==this.zoom)return;let i=this.getScale();if(this.zoom=e,t){t[0]+=this.translateX,t[1]+=this.translateY;let e=this.getScale()/i,s=[e*t[0],e*t[1]];this.scrollDelta((s[0]-t[0])*i,(s[1]-t[1])*i)}}getScale(){return re.scale[this.getZoom()]}scaleCorrect(e){return e/this.getScale()}scaleCorrectReverse(e){return e*this.getScale()}compensateTranslation(e,t){return[e-=this.translateX,t-=this.translateY]}getNodes(e=!1,[t,i,s,n]=[Number.MIN_SAFE_INTEGER,Number.MAX_SAFE_INTEGER,Number.MAX_SAFE_INTEGER,Number.MIN_SAFE_INTEGER]){let r=this.nodes;return e&&(r=r.filter((e=>e.selected))),(t>Number.MIN_SAFE_INTEGER||iNumber.MIN_SAFE_INTEGER)&&(r=r.filter((e=>e.topBoundary()>=t&&e.rightBoundary()<=i&&e.bottomBoundary()<=s&&e.leftBoundary()>=n))),r}getCommentNodes(e=!1){let t=[...this.template.getCommentNodes(e)];return 0===t.length&&(t=this.nodes.filter((t=>t.getType()===re.paths.comment&&(!e||t.selected)))),t}getPin(e){let t=this.template.getPin(e);return t&&t.nodeElement.getNodeName()==e.objectName.toString()||(t=[...this.nodes.find((t=>e.objectName.toString()==t.getNodeName()))?.getPinElements()??[]].find((t=>e.pinGuid.toString()==t.getPinId().toString()))),t}getLinks(e=null,t=null){if(null==e!=(null==t)){const i=e??t;return this.links.filter((e=>e.source==i||e.destination==i))}return null!=e&&null!=t?this.links.filter((i=>i.source==e&&i.destination==t||i.source==t&&i.destination==e)):this.links}getLink(e,t,i=!1){return this.links.find((s=>s.source==e&&s.destination==t||!i&&s.source==t&&s.destination==e))}selectAll(){this.getNodes().forEach((e=>xi.nodeSelectToggleFunction(e,!0)))}unselectAll(){this.getNodes().forEach((e=>xi.nodeSelectToggleFunction(e,!1)))}addGraphElement(...e){const t=e=>{const i=e.currentTarget;i.removeEventListener(re.removeEventName,t);const[s,n]=i instanceof ci?[this.nodes,i.entity]:i instanceof Ht?[this.links]:null,r=s?.indexOf(i);if(r>=0){const e=s.pop();re.entity._exported=!0));continue}const e=i.entity.getObjectName(),s=this.entity.getHomonymObjectEntity(i.entity);s&&(s.Name=this.entity.takeFreeName(e)),this.nodes.push(i),this.entity.addObjectEntity(i.entity),i.addEventListener(re.removeEventName,t),this.template.nodesContainerElement?.appendChild(i)}else i instanceof Ht&&!this.links.includes(i)&&(this.links.push(i),i.addEventListener(re.removeEventName,t),this.template.linksContainerElement&&!this.template.linksContainerElement.contains(i)&&this.template.linksContainerElement.appendChild(i));e.filter((e=>e instanceof ci)).forEach((t=>t.sanitizeLinks(e))),e.filter((e=>e instanceof ci&&e.getType()==re.paths.comment)).forEach((e=>e.updateComplete.then((()=>e.template.manageNodesBind()))))}removeGraphElement(...e){for(let t of e){if(t.closest("ueb-blueprint")!==this)return;t.remove()}}setFocused(e=!0){if(this.focused==e)return;let t=new CustomEvent(e?re.focusEventName.begin:re.focusEventName.end);this.focused=e,this.focused||this.unselectAll(),this.dispatchEvent(t)}acknowledgeEditText(e){const t=new CustomEvent(e?re.editTextEventName.begin:re.editTextEventName.end);this.dispatchEvent(t)}}customElements.define("ueb-blueprint",xi);class Pi extends Ft{#ft;get locationChangeCallback(){return this.#ft}set locationChangeCallback(e){this.#ft=e}movementSpace;movementSpaceSize=[0,0];firstUpdated(e){super.firstUpdated(e),this.movementSpace=this.element.parentElement}setup(){super.setup();const e=this.movementSpace.getBoundingClientRect();this.movementSpaceSize=[e.width,e.height]}createDraggableObject(){return new Gt(this.element,this.blueprint,{draggableElement:this.movementSpace,ignoreTranslateCompensate:!0,moveEverywhere:!0,movementSpace:this.movementSpace,repositionOnClick:!0,stepSize:1})}adjustLocation(e,t){return this.locationChangeCallback?.(e,t),[e,t]}}class ki extends Pi{adjustLocation(e,t){const i=Math.round(this.movementSpaceSize[0]/2);e-=i,t=-(t-i);let[s,n]=ae.getPolarCoordinates(e,t);return s=Math.min(s,i),[e,t]=ae.getCartesianCoordinates(s,n),this.locationChangeCallback?.(e/i,t/i),[e=Math.round(e+i),t=Math.round(-t+i)]}}class Ai extends Ot{windowElement;setup(){super.setup(),this.windowElement=this.closest("ueb-window")}setLocation(e,t){super.setLocation(...this.template.adjustLocation(e,t))}}class Li extends Ai{constructor(){super(),super.initialize({},new ki)}static newObject(){return new Li}initialize(){}}class Mi extends Pi{adjustLocation(e,t){return e=ae.clamp(e,0,this.movementSpaceSize[0]),t=ae.clamp(t,0,this.movementSpaceSize[1]),this.locationChangeCallback?.(e/this.movementSpaceSize[0],1-t/this.movementSpaceSize[1]),[e,t]}}class Ti extends Ai{constructor(){super(),super.initialize({},new Mi)}static newObject(){return new Ti}initialize(){}}class Ii extends Rt{constructor(e,t,i={}){i.consumeEvent=!0,super(e,t,i)}}class $i extends Dt{#yt;#wt;#St=e=>this.element.selectedOption=e.target.selectedOptions[0].value;render(){return H` `}firstUpdated(e){super.firstUpdated(e),this.#yt=this.element.querySelector("select:first-child"),this.#wt=this.element.querySelector("select:last-child");const t=new Event("input",{bubbles:!0});this.#yt.dispatchEvent(t)}updated(e){super.updated(e);const t=this.#wt.getBoundingClientRect();this.element.style.setProperty("--ueb-dropdown-width",t.width+"px")}createInputObjects(){return[...super.createInputObjects(),new Ii(this.element,this.blueprint)]}setSelectedValue(e){this.element.querySelector(`option[value="${e}"]`).defaultSelected=!0}getSelectedValue(){return this.#yt.value}}class Di extends oe{static properties={...super.properties,options:{type:Object},selectedOption:{type:String}};constructor(){super(),super.initialize({},new $i),this.options=[],this.selectedOption=""}static newObject(e){return new Di}initialize(){}getValue(){return this.template.getSelectedValue()}}class Bi extends Dt{#Et=()=>{this.blueprint.acknowledgeEditText(!0),this.element.selectOnFocus&&getSelection().selectAllChildren(this.element)};#Ct=()=>{this.blueprint.acknowledgeEditText(!1),getSelection().removeAllRanges()};#Nt=e=>e.target.querySelectorAll("br").forEach((e=>e.remove()));#xt=e=>{"Enter"!=e.code||e.shiftKey||e.target.blur()};initialize(e){super.initialize(e),this.element.classList.add("ueb-pin-input-content"),this.element.setAttribute("role","textbox"),this.element.contentEditable="true"}firstUpdated(e){super.firstUpdated(e);const t=new Event("input",{bubbles:!0});this.element.dispatchEvent(t)}createInputObjects(){return[...super.createInputObjects(),new Ii(this.element,this.blueprint)]}setup(){super.setup(),this.element.addEventListener("focus",this.#Et),this.element.addEventListener("focusout",this.#Ct),this.element.singleLine&&this.element.addEventListener("input",this.#Nt),this.element.blurOnEnter&&this.element.addEventListener("keydown",this.#xt)}cleanup(){super.cleanup(),this.element.removeEventListener("focus",this.#Et),this.element.removeEventListener("focusout",this.#Ct),this.element.removeEventListener("input",this.#Nt),this.element.removeEventListener("keydown",this.#xt)}}class Vi extends oe{static properties={...super.properties,singleLine:{type:Boolean,attribute:"data-single-line",converter:ae.booleanConverter,reflect:!0},selectOnFocus:{type:Boolean,attribute:"data-select-focus",converter:ae.booleanConverter,reflect:!0},blurOnEnter:{type:Boolean,attribute:"data-blur-enter",converter:ae.booleanConverter,reflect:!0}};constructor(){super(),this.singleLine=!1,this.selectOnFocus=!0,this.blurOnEnter=!0,super.initialize({},new Bi)}static newObject(){return new Vi}initialize(){}}class Hi extends ei{#Pt;#kt=()=>this.element.setDefaultValue(this.#Pt.checked);firstUpdated(e){super.firstUpdated(e),this.#Pt=this.element.querySelector(".ueb-pin-input")}setup(){super.setup(),this.#Pt?.addEventListener("change",this.#kt)}cleanup(){super.cleanup(),this.#Pt?.removeEventListener("change",this.#kt)}createInputObjects(){return[...super.createInputObjects(),new Ii(this.#Pt,this.blueprint)]}renderInput(){return H``}}class Oi extends ei{static singleLineInput=!1;static selectOnFocus=!0;static saveEachInputChange=!1;#At;get inputWrapper(){return this.#At}#Lt;static stringFromInputToUE(e){return e.replace(/(?=\n\s*)\n$/,"")}static stringFromUEToInput(e){return e.replaceAll(/(?:\r|(?<=(?:^|[^\\])(?:\\\\)*)\\r)(?=\n)/g,"").replace(/(?<=\n\s*)$/,"\n")}#Mt=()=>this.setInputs(this.getInputs(),!0);#Tt=e=>this.#It(e.target);#It(e){const t=this.blueprint.scaleCorrect(this.#At.getBoundingClientRect().width)+this.nameWidth,i=this.element.classList.contains("ueb-pin-input-wrap");!i&&t>re.pinInputWrapWidth?this.element.classList.add("ueb-pin-input-wrap"):i&&t<=re.pinInputWrapWidth&&this.element.classList.remove("ueb-pin-input-wrap")}firstUpdated(e){super.firstUpdated(e);this.constructor.canWrapInput&&this.isInputRendered()&&(this.element.addEventListener("input",this.#Tt),this.nameWidth=this.blueprint.scaleCorrect(this.element.querySelector(".ueb-pin-name")?.getBoundingClientRect().width??0)),this.#At=this.element.querySelector(".ueb-pin-input-wrapper"),this.#Lt=[...this.element.querySelectorAll("ueb-input")]}setup(){super.setup();const e=this.constructor;e.saveEachInputChange?this.element.addEventListener("input",this.#Mt):this.element.addEventListener("focusout",this.#Mt),e.canWrapInput&&this.isInputRendered()&&(this.element.addEventListener("input",this.#Tt),this.element.nodeElement.addEventListener(re.nodeReflowEventName,this.#Tt))}cleanup(){super.cleanup(),this.element.nodeElement.removeEventListener(re.nodeReflowEventName,this.#Tt),this.element.removeEventListener("input",this.#Tt),this.element.removeEventListener("input",this.#Mt),this.element.removeEventListener("focusout",this.#Mt)}getInput(){return this.getInputs().reduce(((e,t)=>e+t),"")}getInputs(){return this.#Lt.map((e=>ae.clearHTMLWhitespace(e.innerHTML)))}setInputs(e=[],t=!0){this.#Lt.forEach(this.constructor.singleLineInput?(t,i)=>t.innerText=e[i]:(t,i)=>t.innerText=e[i].replaceAll("\n","")),t&&this.setDefaultValue(e.map((e=>Oi.stringFromInputToUE(e))),e),this.element.requestUpdate(),this.element.nodeElement.acknowledgeReflow()}setDefaultValue(e=[],t=e){this.element.setDefaultValue(e.join(""))}renderInput(){const e=this.constructor,t=e.singleLineInput,i=e.selectOnFocus;return H`
`}}class Ri extends ei{renderIcon(){return Be.execPin}renderName(){let e=this.element.entity.PinName;if(this.element.entity.PinFriendlyName)e=this.element.entity.PinFriendlyName.toString();else if("execute"===e||"then"===e)return H``;return H`${this.element.getPinDisplayName()}`}}class Gi extends Oi{static singleLineInput=!0;setInputs(e=[],t=!1){if(e&&0!=e.length||(e=[this.getInput()]),super.setInputs(e,!1),t){let i=[];for(const s of e){let e=parseFloat(s);isNaN(e)&&(e=0,t=!1),i.push(e)}this.setDefaultValue(i,e)}}setDefaultValue(e=[],t){this.element.setDefaultValue(e[0]),this.element.requestUpdate()}}class zi extends Gi{setDefaultValue(e=[],t){this.element.setDefaultValue(new Ke(e[0])),this.element.requestUpdate()}renderInput(){return H`
`}} /** * @license * Copyright 2017 Google LLC * SPDX-License-Identifier: BSD-3-Clause - */const Hi=1;class Di{constructor(e){}get _$AU(){return this._$AM._$AU}_$AT(e,t,i){this._$Ct=e,this._$AM=t,this._$Ci=i}_$AS(e,t){return this.update(e,t)}update(e,t){return this.render(...t)}} + */const _i=1;class Fi{constructor(e){}get _$AU(){return this._$AM._$AU}_$AT(e,t,i){this._$Ct=e,this._$AM=t,this._$Ci=i}_$AS(e,t){return this.update(e,t)}update(e,t){return this.render(...t)}} /** * @license * Copyright 2018 Google LLC * SPDX-License-Identifier: BSD-3-Clause - */const Gi="important",Ri=" !"+Gi,zi=(e=>(...t)=>({_$litDirective$:e,values:t}))(class extends Di{constructor(e){var t;if(super(e),e.type!==Hi||"style"!==e.name||(null===(t=e.strings)||void 0===t?void 0:t.length)>2)throw Error("The `styleMap` directive must be used in the `style` attribute and must be the only part in the attribute.")}render(e){return Object.keys(e).reduce(((t,i)=>{const r=e[i];return null==r?t:t+`${i=i.includes("-")?i:i.replace(/(?:^(webkit|moz|ms|o)|)(?=[A-Z])/g,"-$&").toLowerCase()}:${r};`}),"")}update(e,[t]){const{style:i}=e.element;if(void 0===this.ht){this.ht=new Set;for(const e in t)this.ht.add(e);return this.render(t)}this.ht.forEach((e=>{null==t[e]&&(this.ht.delete(e),e.includes("-")?i.removeProperty(e):i[e]="")}));for(const e in t){const r=t[e];if(null!=r){this.ht.add(e);const t="string"==typeof r&&r.endsWith(Ri);e.includes("-")||t?i.setProperty(e,t?r.slice(0,-11):r,t?Gi:""):i[e]=r}}return D}});class _i extends Rt{toggleAdvancedDisplayHandler;getDraggableElement(){return this.element.querySelector(".ueb-window-top")}createDraggableObject(){return new Ot(this.element,this.blueprint,{draggableElement:this.getDraggableElement(),ignoreScale:!0,ignoreTranslateCompensate:!1,movementSpace:this.blueprint,stepSize:1})}setup(){const e=this.blueprint.template.gridLeftVisibilityBoundary(),t=this.blueprint.template.gridTopVisibilityBoundary();this.element.locationX=this.blueprint.scaleCorrectReverse(this.blueprint.mousePosition[0]-e),this.element.locationY=this.blueprint.scaleCorrectReverse(this.blueprint.mousePosition[1]-t),this.element.updateComplete.then((()=>{const e=this.blueprint.getBoundingClientRect();this.element.locationX+this.element.sizeX>e.width&&(this.element.locationX=e.width-this.element.sizeX),this.element.locationX=Math.max(0,this.element.locationX),this.element.locationY+this.element.sizeY>e.height&&(this.element.locationY=e.height-this.element.sizeY),this.element.locationY=Math.max(0,this.element.locationY)}))}render(){return H`
${this.renderWindowName()}
${De.close}
${this.renderContent()}
`}renderWindowName(){return H`Window`}renderContent(){return H``}apply(){this.element.dispatchEvent(new CustomEvent(ne.windowApplyEventName)),this.element.remove()}cancel(){this.element.dispatchEvent(new CustomEvent(ne.windowCancelEventName)),this.element.remove()}}class Fi extends _i{#Et;#Ct;#Nt;#xt;#Pt;#kt;#Tt;#At;#Lt;#Mt;#It=e=>{const t=ue.clearHTMLWhitespace(e.target.innerHTML),i=parseInt(t,16);isNaN(i)||(this.color.setFromRGBANumber(i),this.element.requestUpdate())};#Bt=e=>{const t=ue.clearHTMLWhitespace(e.target.innerHTML),i=parseInt(t,16);isNaN(i)||(this.color.setFromSRGBANumber(i),this.element.requestUpdate())};#Vt=e=>t=>{"Enter"==t.code&&(t.preventDefault(),e(t))};#$t=new He;get color(){return this.#$t}set color(e){e.toNumber()!=this.color?.toNumber()&&(this.element.requestUpdate("color",this.#$t),this.#$t=e)}#Ot=new He;get fullColor(){return this.#Ot}#Ht;get initialColor(){return this.#Ht}#Dt=new He;#Gt(e,t,i=!1){const r=this.color.toRGBAString(),s=`${r.substring(0,2*e)}${t}${r.substring(2+2*e)}`;return i?`${s.substring(0,6)}FF`:s}initialize(e){super.initialize(e),this.#Ht=this.element.windowOptions.getPinColor(),this.color.setFromHSVA(this.initialColor.H.value,this.initialColor.S.value,this.initialColor.V.value,this.initialColor.A.value),this.fullColor.setFromHSVA(this.color.H.value,1,1,1)}firstUpdated(e){this.#Et=this.element.querySelector(".ueb-color-picker-wheel ueb-color-handler"),this.#Ct=this.element.querySelector(".ueb-color-picker-saturation ueb-ui-slider"),this.#Nt=this.element.querySelector(".ueb-color-picker-value ueb-ui-slider"),this.#xt=this.element.querySelector(".ueb-color-picker-r ueb-ui-slider"),this.#Pt=this.element.querySelector(".ueb-color-picker-g ueb-ui-slider"),this.#kt=this.element.querySelector(".ueb-color-picker-b ueb-ui-slider"),this.#Tt=this.element.querySelector(".ueb-color-picker-a ueb-ui-slider"),this.#At=this.element.querySelector(".ueb-color-picker-h ueb-ui-slider"),this.#Lt=this.element.querySelector(".ueb-color-picker-s ueb-ui-slider"),this.#Mt=this.element.querySelector(".ueb-color-picker-v ueb-ui-slider"),this.#Et.template.locationChangeCallback=(e,t)=>{this.color.setFromWheelLocation(e,t,this.color.V.value,this.color.A.value),this.fullColor.setFromHSVA(this.color.H.value,1,1,1),this.element.requestUpdate()},this.#Ct.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,t,this.color.V.value,this.color.A.value),this.element.requestUpdate()},this.#Nt.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,this.color.S.value,t,this.color.A.value),this.element.requestUpdate()},this.#xt.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(e,this.color.G.value,this.color.B.value,this.color.A.value),this.element.requestUpdate()},this.#Pt.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(this.color.R.value,e,this.color.B.value,this.color.A.value),this.element.requestUpdate()},this.#kt.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(this.color.R.value,this.color.G.value,e,this.color.A.value),this.element.requestUpdate()},this.#Tt.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(this.color.R.value,this.color.G.value,this.color.B.value,e),this.element.requestUpdate()},this.#At.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(e,this.color.S.value,this.color.V.value,this.color.A.value),this.element.requestUpdate()},this.#Lt.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,e,this.color.V.value,this.color.A.value),this.element.requestUpdate()},this.#Mt.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,this.color.S.value,e,this.color.A.value),this.element.requestUpdate()}}renderSlider(e){let t="",i=0,r="";const s=e=>`linear-gradient(to right, #${this.#Gt(e,"00",!0)}, #${this.#Gt(e,"ff",!0)})`;switch(e){case 0:t="r",i=this.color.R.value,r=s(e);break;case 1:t="g",i=this.color.G.value,r=s(e);break;case 2:t="b",i=this.color.B.value,r=s(e);break;case 3:t="a",i=this.color.A.value,r=`${ne.alphaPattern}, ${s(e)}`;break;case 4:t="h",i=360*this.color.H.value,r="linear-gradient(to right, #f00 0%, #ff0 16.666%, #0f0 33.333%, #0ff 50%, #00f 66.666%, #f0f 83.333%, #f00 100%)";break;case 5:t="s",i=this.color.S.value,r=`linear-gradient(to right,#${this.#Dt.setFromHSVA(this.color.H.value,0,this.color.V.value,1),this.#Dt.toRGBAString()},#${this.#Dt.setFromHSVA(this.color.H.value,1,this.color.V.value,1),this.#Dt.toRGBAString()})`;break;case 6:t="v",i=this.color.V.value,r=`linear-gradient(to right, #000, #${this.fullColor.toRGBAString()})`}return r=`background: ${r};`,H`
${t.toUpperCase()}
`}renderContent(){const e=2*this.color.H.value*Math.PI,t={"--ueb-color-r":this.color.R.toString(),"--ueb-color-g":this.color.G.toString(),"--ueb-color-b":this.color.B.toString(),"--ueb-color-a":this.color.A.toString(),"--ueb-color-h":this.color.H.toString(),"--ueb-color-s":this.color.S.toString(),"--ueb-color-v":this.color.V.toString(),"--ueb-color-wheel-x":100*(this.color.S.value*Math.cos(e)*.5+.5)+"%","--ueb-color-wheel-y":100*(this.color.S.value*Math.sin(e)*.5+.5)+"%"},i=this.color.toRGBAString(),r=this.color.toSRGBAString(),s=this.fullColor.toRGBAString();return H`
Old
New
Advanced
${this.renderSlider(0)} ${this.renderSlider(1)} ${this.renderSlider(2)} ${this.renderSlider(3)}
${this.renderSlider(4)} ${this.renderSlider(5)} ${this.renderSlider(6)}
Hex Linear
Hex sRGB
${ne.windowApplyButtonText}
${ne.windowCancelButtonText}
`}renderWindowName(){return H`${ne.colorWindowName}`}}class ji extends $i{#Rt(){return ue.printNumber(this.element.getDefaultValue()?.X??0)}#zt(){return ue.printNumber(this.element.getDefaultValue()?.Y??0)}setDefaultValue(e,t){const i=this.element.getDefaultValue(!0);if(!(i instanceof lt))throw new TypeError("Expected DefaultValue to be a Vector2DEntity");i.X=e[0],i.Y=e[1],this.element.requestUpdate("DefaultValue",i)}renderInput(){return H`
X
Y
`}}class Wi extends $i{#Rt(){return ue.printNumber(this.element.getDefaultValue()?.X??0)}#zt(){return ue.printNumber(this.element.getDefaultValue()?.Y??0)}#_t(){return ue.printNumber(this.element.getDefaultValue()?.Z??0)}setDefaultValue(e,t){const i=this.element.getDefaultValue(!0);if(!(i instanceof gt))throw new TypeError("Expected DefaultValue to be a VectorEntity");i.X=e[0],i.Y=e[1],i.Z=e[2],this.element.requestUpdate("DefaultValue",i)}renderInput(){return H`
X
Y
Z
`}}const Ui={[ne.paths.linearColor]:class extends Zt{#Ft;#jt=e=>{e.preventDefault(),this.blueprint.setFocused(!0),this.#Ft=me.getConstructor("ueb-window").newObject({type:new Fi,windowOptions:{getPinColor:()=>this.element.defaultValue,setPinColor:e=>this.element.setDefaultValue(e)}}),this.blueprint.append(this.#Ft);const t=()=>{this.element.setDefaultValue(this.#Ft.template.color)},i=()=>{this.#Ft.removeEventListener(ne.windowApplyEventName,t),this.#Ft.removeEventListener(ne.windowCloseEventName,i),this.#Ft=null};this.#Ft.addEventListener(ne.windowApplyEventName,t),this.#Ft.addEventListener(ne.windowCloseEventName,i)};renderInput(){return H``}},[ne.paths.niagaraBool]:Ii,[ne.paths.niagaraPosition]:Wi,[ne.paths.rotator]:class extends $i{#Wt(){return ue.printNumber(this.element.getDefaultValue()?.R??0)}#Ut(){return ue.printNumber(this.element.getDefaultValue()?.P??0)}#zt(){return ue.printNumber(this.element.getDefaultValue()?.Y??0)}setDefaultValue(e=[],t=e){const i=this.element.getDefaultValue(!0);if(!(i instanceof ut))throw new TypeError("Expected DefaultValue to be a RotatorEntity");i.R=e[0],i.P=e[1],i.Y=e[2],this.element.requestUpdate("DefaultValue",i)}renderInput(){return H`
X
Y
Z
`}},[ne.paths.vector]:Wi,[ne.paths.vector2D]:ji,[ne.paths.vector3f]:Wi,[ne.paths.vector4f]:class extends $i{#Rt(){return ue.printNumber(this.element.getDefaultValue()?.X??0)}#zt(){return ue.printNumber(this.element.getDefaultValue()?.Y??0)}#_t(){return ue.printNumber(this.element.getDefaultValue()?.Z??0)}#Kt(){return ue.printNumber(this.element.getDefaultValue()?.W??0)}setDefaultValue(e,t){const i=this.element.getDefaultValue(!0);if(!(i instanceof dt))throw new TypeError("Expected DefaultValue to be a Vector4DEntity");i.X=e[0],i.Y=e[1],i.Z=e[2],i.W=e[3],this.element.requestUpdate("DefaultValue",i)}renderInput(){return H`
X
Y
Z
W
`}},bool:Ii,byte:Oi,enum:class extends Bi{static saveEachInputChange=!0;#Yt;#Xt=[];setup(){super.setup();const e=this.element.nodeElement.entity.EnumEntries;this.#Xt=e?.map((e=>(""===e&&(e="None"),[e,this.element.nodeElement.getPinEntities().find((t=>e===t.PinName))?.PinFriendlyName.toString()??e])))??ne.CommonEnums[this.element.entity.getSubCategory()]?.map((e=>e instanceof Array?e:[e,ue.formatStringName(e)]))??[];const t=this.element.getDefaultValue().toString();this.#Xt.find((([e,i])=>e===t))||this.#Xt.push([t,ue.formatStringName(t)]),this.element.requestUpdate()}renderInput(){return this.element.nodeElement.entity,H``}firstUpdated(e){super.firstUpdated(e),this.#Yt=this.element.querySelector("ueb-dropdown")}getInputs(){return[this.#Yt.getValue()]}},int:Oi,int64:class extends $i{setDefaultValue(e=[],t){this.element.setDefaultValue(new st(e[0])),this.element.requestUpdate()}renderInput(){return H`
`}},MUTABLE_REFERENCE:class extends Zt{renderIcon(){return De.referencePin}},name:class extends Bi{static singleLineInput=!0},rg:ji,real:class extends $i{setDefaultValue(e=[],t=e){this.element.setDefaultValue(e[0])}renderInput(){return H`
`}},string:class extends Bi{}};function Ki(e){return"Array"===e.PinType.ContainerType?.toString()?Zt:e.PinType.bIsReference&&!e.PinType.bIsConst?Ui.MUTABLE_REFERENCE:"exec"===e.getType()?Vi:(e.isInput()?Ui[e.getType()]:Zt)??Zt}class Yi extends he{static properties={pinId:{type:Fe,converter:{fromAttribute:(e,t)=>e?Fe.grammar.parse(e):null,toAttribute:(e,t)=>e?.toString()},attribute:"data-id",reflect:!0},pinType:{type:String,attribute:"data-type",reflect:!0},advancedView:{type:String,attribute:"data-advanced-view",reflect:!0},color:{type:He,converter:{fromAttribute:(e,t)=>e?He.getLinearColorFromAnyFormat().parse(e):null,toAttribute:(e,t)=>e?ue.printLinearColor(e):null},attribute:"data-color",reflect:!0},defaultValue:{type:String,attribute:!1},isLinked:{type:Boolean,converter:ue.booleanConverter,attribute:"data-linked",reflect:!0},pinDirection:{type:String,attribute:"data-direction",reflect:!0},connectable:{type:Boolean,converter:ue.booleanConverter,attribute:"data-connectable",reflect:!0}};nodeElement;static newObject(e=new vt,t=new(Ki(e)),i=void 0){const r=new Yi;return r.initialize(e,t,i),r}initialize(e=new vt,t=new(Ki(e)),i=void 0){this.nodeElement=i,this.advancedView=e.bAdvancedView,this.isLinked=!1,this.connectable=!e.bNotConnectable,super.initialize(e,t),this.pinType=this.entity.getType(),this.defaultValue=this.entity.getDefaultValue(),this.color=Yi.properties.color.converter.fromAttribute(this.getColor().toString()),this.pinDirection=e.isInput()?"input":e.isOutput()?"output":"hidden"}setup(){super.setup(),this.nodeElement=this.closest("ueb-node")}createPinReference(){return new at({objectName:this.nodeElement.getNodeName(),pinGuid:this.getPinId()})}getPinId(){return this.entity.PinId}getPinName(){return this.entity.PinName}getPinDisplayName(){return this.entity.pinTitle()}getColor(){return this.entity.pinColor()}isInput(){return this.entity.isInput()}isOutput(){return this.entity.isOutput()}getLinkLocation(){return this.template.getLinkLocation()}getNodeElement(){return this.nodeElement}getLinks(){return this.entity.LinkedTo??[]}getDefaultValue(e=!1){return this.defaultValue=this.entity.getDefaultValue(e)}setDefaultValue(e){this.entity.DefaultValue=e,this.defaultValue=e,this.entity.recomputesNodeTitleOnChange&&this.nodeElement?.computeNodeDisplayName()}sanitizeLinks(e=[]){this.entity.LinkedTo=this.entity.LinkedTo?.filter((t=>{let i=this.blueprint.getPin(t);if(i){if(e.length&&!e.includes(i.nodeElement))return!1;let t=this.blueprint.getLink(this,i);t||(t=me.getConstructor("ueb-link").newObject(this,i),this.blueprint.addGraphElement(t))}return i})),this.isLinked=this.entity.isLinked()}linkTo(e){const t=this.createPinReference();!this.isLinked||!this.isOutput()||"exec"!==this.pinType&&"exec"!==e.pinType||this.getLinks().some((e=>t.equals(e)))||this.unlinkFromAll(),this.entity.linkTo(e.getNodeElement().getNodeName(),e.entity)&&(this.isLinked=this.entity.isLinked(),this.nodeElement?.template.linksChanged(),this.entity.recomputesNodeTitleOnChange&&this.nodeElement?.computeNodeDisplayName())}unlinkFrom(e,t=!0){this.entity.unlinkFrom(e.getNodeElement().getNodeName(),e.entity)&&(this.isLinked=this.entity.isLinked(),this.nodeElement?.template.linksChanged(),t&&this.blueprint.getLink(this,e)?.remove(),this.entity.recomputesNodeTitleOnChange&&this.nodeElement?.computeNodeDisplayName())}unlinkFromAll(){const e=this.getLinks().length;this.getLinks().map((e=>this.blueprint.getPin(e))).forEach((e=>this.unlinkFrom(e))),e&&this.nodeElement?.template.linksChanged()}redirectLink(e,t){const i=this.getLinks().findIndex((t=>t.objectName.toString()==e.getNodeElement().getNodeName()&&t.pinGuid.valueOf()==e.entity.PinId.valueOf()));return i>=0&&(this.entity.LinkedTo[i]=t,!0)}}class Xi{constructor(e=(e=>e),t=null){this.array=new Uint32Array(t),this.comparisonValueSupplier=e,this.length=0,this.currentPosition=0}get(e){return e>=0&&e=0&&this.currentPosition=0&&this.currentPosition0?this.get(this.currentPosition-1):null}getPrevValue(){return this.currentPosition>0?this.comparisonValueSupplier(this.get(this.currentPosition-1)):Number.MIN_SAFE_INTEGER}shiftLeft(e,t=1){this.array.set(this.array.subarray(e+t),e)}shiftRight(e,t=1){this.array.set(this.array.subarray(e,-t),e+t)}}class Zi{constructor(e,t,i,r){this.initialPosition=e,this.finalPosition=e,this.metadata=new Array(t.length),this.primaryOrder=new Xi((e=>this.metadata[e].primaryBoundary)),this.secondaryOrder=new Xi((e=>this.metadata[e].secondaryBoundary)),this.selectFunc=r,this.rectangles=t,this.primaryOrder.reserve(this.rectangles.length),this.secondaryOrder.reserve(this.rectangles.length),t.forEach(((e,t)=>{let s={primaryBoundary:this.initialPosition[0],secondaryBoundary:this.initialPosition[1],rectangle:t,onSecondaryAxis:!1};this.metadata[t]=s,r(e,!1);const n=i(e);this.initialPosition[1]{if(this.metadata[i].onSecondaryAxis)this.selectFunc(this.rectangles[i],r);else if(r){this.secondaryOrder.insert(i,e[1]);const r=this.metadata[i].secondaryBoundary;Math.sign(e[1]-r)==t[1]&&Math.sign(r-this.initialPosition[1])==t[1]&&this.selectFunc(this.rectangles[i],!0)}else this.selectFunc(this.rectangles[i],!1),this.secondaryOrder.remove(i);this.computeBoundaries(),this.selectTo(e)};e[0]this.boundaries.primaryN.v&&e[0]this.boundaries.primaryP.v&&(++this.primaryOrder.currentPosition,i(this.boundaries.primaryP.i,this.initialPosition[0]{this.selectFunc(this.rectangles[t],i),this.computeBoundaries(),this.selectTo(e)};e[1]this.boundaries.secondaryN.v&&e[1]this.boundaries.secondaryP.v&&(++this.secondaryOrder.currentPosition,r(this.boundaries.secondaryP.i,this.initialPosition[1]Ji.#Zt[e],toAttribute:(e,t)=>Object.entries(Ji.#Zt).find((([t,i])=>e.constructor===i))?.[0]}}};static newObject(e={},t=e.type??new _i){const i=new Ji;return i.initialize(e,t),i}initialize(e={},t=e.type??new _i){e.windowOptions??={},this.type=e.type,this.windowOptions=e.windowOptions,super.initialize(e,t)}computeSizes(){const e=this.getBoundingClientRect();this.sizeX=e.width,this.sizeY=e.height}cleanup(){super.cleanup(),this.acknowledgeClose()}acknowledgeClose(){let e=new CustomEvent(ne.windowCloseEventName);this.dispatchEvent(e)}}class er extends Ve{static attributes={...super.attributes,TerminalCategory:oe.createType(String),TerminalSubCategory:oe.createType(String),bTerminalIsConst:oe.createType(Boolean),bTerminalIsWeakPointer:oe.createType(Boolean),bTerminalIsUObjectWrapper:oe.createType(Boolean)};constructor(e){super(e),this.TerminalCategory,this.TerminalSubCategory,this.bTerminalIsConst,this.bTerminalIsWeakPointer,this.bTerminalIsUObjectWrapper}}class tr extends Ve{static grammar=this.createGrammar();static createGrammar(){return Me.seq(Me.reg(new RegExp(`(${$e.Regex.Path.source}|${$e.Regex.Symbol.source}\\s*)?\\(\\s*`),1),Me.seq($e.attributeName,$e.equalSeparation).map((([e,t])=>e)).chain((e=>$e.unknownValue.map((t=>i=>i[e]=t)))).sepBy($e.commaSeparation),Me.reg(/\s*(?:,\s*)?\)/)).map((([e,t,i])=>{e??="";let r={};return e.length&&(r.lookbehind=e),t.forEach((e=>e(r))),new this(r)}))}constructor(e){super(e,!0)}}class ir extends oi{#qt;constructor(e,t){super(t),this.#qt=e}doWrite(e,t,i=""){return this.#qt(e,t)}}class rr extends oi{constructor(e,t=!0){super(e),t&&(this.wrap=(e,t)=>ue.escapeString(t))}doWrite(e,t,i=""){return t||e.constructor!==String?this.wrap(e,e.toString()):`"${this.wrap(e,e.toString())}"`}}$e.unknownValue=Me.alt($e.boolean,Fe.grammar,Me.str("None").map((()=>new je({type:"None"}))),$e.null,$e.number,je.fullReferenceGrammar,$e.string,it.grammar,tt.grammar,rt.grammar,at.grammar,dt.grammar,gt.grammar,ut.grammar,He.grammar,lt.grammar,tr.grammar,Qe.grammar,$e.grammarFor(void 0,[at]),$e.grammarFor(void 0,[new ce(Number,String,Qe)]),Me.lazy((()=>$e.grammarFor(void 0,[void 0])))),Be.registerSerializer(null,new ir(((e,t)=>"()"),null)),Be.registerSerializer(Array,new ir(((e,t)=>`(${e.map((e=>Be.getSerializer(ue.getType(e)).write(e,t))).join(",")})`),Array)),Be.registerSerializer(BigInt,new rr(BigInt)),Be.registerSerializer(ai,new li(ai)),Be.registerSerializer(Boolean,new ir(((e,t)=>e?t?"true":"True":t?"false":"False"),Boolean)),Be.registerSerializer(qe,new rr(qe)),Be.registerSerializer(Oe,new rr(Oe)),Be.registerSerializer(et,new rr(et)),Be.registerSerializer(Je,new rr(Je)),Be.registerSerializer(rt,new ir(((e,t)=>e.getLookbehind()+"("+e.value.map((e=>Be.getSerializer(ue.getType(e)).write(e,t))).join(", ")+")"),rt)),Be.registerSerializer(We,new oi(We,oi.bracketsWrapped)),Be.registerSerializer(Fe,new rr(Fe)),Be.registerSerializer(Ue,new rr(Ue)),Be.registerSerializer(st,new rr(st)),Be.registerSerializer(Ke,new rr(Ke)),Be.registerSerializer(tt,new oi(tt,((e,t)=>`${e.getLookbehind()}(${t})`),", ",!1,"",(()=>""))),Be.registerSerializer(xt,new oi(xt,oi.bracketsWrapped)),Be.registerSerializer(He,new oi(He,oi.bracketsWrapped)),Be.registerSerializer(it,new oi(it,((e,t)=>`${e.getLookbehind()}(${t})`),", ",!1,"",(()=>""))),Be.registerSerializer(Ye,new oi(Ye,oi.bracketsWrapped)),Be.registerSerializer(le,new ir(((e,t)=>Be.getSerializer(e.getTargetType()).write(e.get(),t)),le)),Be.registerSerializer(Number,new rr(Number)),Be.registerSerializer(Et,new li),Be.registerSerializer(je,new rr(je,!1)),Be.registerSerializer(nt,new rr(nt)),Be.registerSerializer(vt,new oi(vt,((e,t)=>`${e.getLookbehind()} (${t})`),",",!0)),Be.registerSerializer(at,new oi(at,void 0," ",!1,"",(()=>""))),Be.registerSerializer(ot,new oi(ot)),Be.registerSerializer(er,new oi(er,oi.bracketsWrapped)),Be.registerSerializer(ct,new ir(((e,t)=>`X=${e.X} Y=${e.Y}`),ct)),Be.registerSerializer(ut,new oi(ut,oi.bracketsWrapped)),Be.registerSerializer(yt,new oi(yt,oi.bracketsWrapped)),Be.registerSerializer(String,new ir(((e,t)=>t?ue.escapeString(e):`"${ue.escapeString(e)}"`),String)),Be.registerSerializer(ht,new ir(((e,t)=>`${e.P}, ${e.Y}, ${e.R}`),ht)),Be.registerSerializer(pt,new ir(((e,t)=>`${e.X}, ${e.Y}`),pt)),Be.registerSerializer(bt,new ir(((e,t)=>`${e.X}, ${e.Y}, ${e.Z}`),bt)),Be.registerSerializer(mt,new ir(((e,t)=>`${e.X}, ${e.Y}, ${e.Z}, ${e.W}`),mt)),Be.registerSerializer(Qe,new rr(Qe)),Be.registerSerializer(tr,new oi(tr,((e,t)=>`${e.getLookbehind()??""}(${t})`))),Be.registerSerializer(wt,new oi(wt,oi.bracketsWrapped)),Be.registerSerializer(lt,new oi(lt,oi.bracketsWrapped)),Be.registerSerializer(gt,new oi(gt,oi.bracketsWrapped)),Be.registerSerializer(dt,new oi(dt,oi.bracketsWrapped)),function(){const e=(e,t)=>{customElements.define(e,t),me.registerElement(e,t)};e("ueb-color-handler",Ni),e("ueb-dropdown",Ai),e("ueb-input",Mi),e("ueb-link",Bt),e("ueb-node",ni),e("ueb-pin",Yi),e("ueb-selector",Qi),e("ueb-ui-slider",Pi),e("ueb-window",Ji)}();export{wi as Blueprint,ne as Configuration,Bt as LinkElement,ni as NodeElement,ue as Utility}; + */const ji="important",Ui=" !"+ji,Wi=(e=>(...t)=>({_$litDirective$:e,values:t}))(class extends Fi{constructor(e){var t;if(super(e),e.type!==_i||"style"!==e.name||(null===(t=e.strings)||void 0===t?void 0:t.length)>2)throw Error("The `styleMap` directive must be used in the `style` attribute and must be the only part in the attribute.")}render(e){return Object.keys(e).reduce(((t,i)=>{const s=e[i];return null==s?t:t+`${i=i.includes("-")?i:i.replace(/(?:^(webkit|moz|ms|o)|)(?=[A-Z])/g,"-$&").toLowerCase()}:${s};`}),"")}update(e,[t]){const{style:i}=e.element;if(void 0===this.ht){this.ht=new Set;for(const e in t)this.ht.add(e);return this.render(t)}this.ht.forEach((e=>{null==t[e]&&(this.ht.delete(e),e.includes("-")?i.removeProperty(e):i[e]="")}));for(const e in t){const s=t[e];if(null!=s){this.ht.add(e);const t="string"==typeof s&&s.endsWith(Ui);e.includes("-")||t?i.setProperty(e,t?s.slice(0,-11):s,t?ji:""):i[e]=s}}return O}});class Ki extends jt{toggleAdvancedDisplayHandler;getDraggableElement(){return this.element.querySelector(".ueb-window-top")}createDraggableObject(){return new Gt(this.element,this.blueprint,{draggableElement:this.getDraggableElement(),ignoreScale:!0,ignoreTranslateCompensate:!1,movementSpace:this.blueprint,stepSize:1})}setup(){const e=this.blueprint.template.gridLeftVisibilityBoundary(),t=this.blueprint.template.gridTopVisibilityBoundary();this.element.locationX=this.blueprint.scaleCorrectReverse(this.blueprint.mousePosition[0]-e),this.element.locationY=this.blueprint.scaleCorrectReverse(this.blueprint.mousePosition[1]-t),this.element.updateComplete.then((()=>{const e=this.blueprint.getBoundingClientRect();this.element.locationX+this.element.sizeX>e.width&&(this.element.locationX=e.width-this.element.sizeX),this.element.locationX=Math.max(0,this.element.locationX),this.element.locationY+this.element.sizeY>e.height&&(this.element.locationY=e.height-this.element.sizeY),this.element.locationY=Math.max(0,this.element.locationY)}))}render(){return H`
${this.renderWindowName()}
${Be.close}
${this.renderContent()}
`}renderWindowName(){return H`Window`}renderContent(){return H``}apply(){this.element.dispatchEvent(new CustomEvent(re.windowApplyEventName)),this.element.remove()}cancel(){this.element.dispatchEvent(new CustomEvent(re.windowCancelEventName)),this.element.remove()}}class Yi extends Ki{#$t;#Dt;#Bt;#Vt;#Ht;#Ot;#Rt;#Gt;#zt;#_t;#Ft=e=>{const t=ae.clearHTMLWhitespace(e.target.innerHTML),i=parseInt(t,16);isNaN(i)||(this.color.setFromRGBANumber(i),this.element.requestUpdate())};#jt=e=>{const t=ae.clearHTMLWhitespace(e.target.innerHTML),i=parseInt(t,16);isNaN(i)||(this.color.setFromSRGBANumber(i),this.element.requestUpdate())};#Ut=e=>t=>{"Enter"==t.code&&(t.preventDefault(),e(t))};#Wt=new De;get color(){return this.#Wt}set color(e){e.toNumber()!=this.color?.toNumber()&&(this.element.requestUpdate("color",this.#Wt),this.#Wt=e)}#Kt=new De;get fullColor(){return this.#Kt}#Yt;get initialColor(){return this.#Yt}#Xt=new De;#qt(e,t,i=!1){const s=this.color.toRGBAString(),n=`${s.substring(0,2*e)}${t}${s.substring(2+2*e)}`;return i?`${n.substring(0,6)}FF`:n}initialize(e){super.initialize(e),this.#Yt=this.element.windowOptions.getPinColor(),this.color.setFromHSVA(this.initialColor.H.value,this.initialColor.S.value,this.initialColor.V.value,this.initialColor.A.value),this.fullColor.setFromHSVA(this.color.H.value,1,1,1)}firstUpdated(e){this.#$t=this.element.querySelector(".ueb-color-picker-wheel ueb-color-handler"),this.#Dt=this.element.querySelector(".ueb-color-picker-saturation ueb-ui-slider"),this.#Bt=this.element.querySelector(".ueb-color-picker-value ueb-ui-slider"),this.#Vt=this.element.querySelector(".ueb-color-picker-r ueb-ui-slider"),this.#Ht=this.element.querySelector(".ueb-color-picker-g ueb-ui-slider"),this.#Ot=this.element.querySelector(".ueb-color-picker-b ueb-ui-slider"),this.#Rt=this.element.querySelector(".ueb-color-picker-a ueb-ui-slider"),this.#Gt=this.element.querySelector(".ueb-color-picker-h ueb-ui-slider"),this.#zt=this.element.querySelector(".ueb-color-picker-s ueb-ui-slider"),this.#_t=this.element.querySelector(".ueb-color-picker-v ueb-ui-slider"),this.#$t.template.locationChangeCallback=(e,t)=>{this.color.setFromWheelLocation(e,t,this.color.V.value,this.color.A.value),this.fullColor.setFromHSVA(this.color.H.value,1,1,1),this.element.requestUpdate()},this.#Dt.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,t,this.color.V.value,this.color.A.value),this.element.requestUpdate()},this.#Bt.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,this.color.S.value,t,this.color.A.value),this.element.requestUpdate()},this.#Vt.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(e,this.color.G.value,this.color.B.value,this.color.A.value),this.element.requestUpdate()},this.#Ht.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(this.color.R.value,e,this.color.B.value,this.color.A.value),this.element.requestUpdate()},this.#Ot.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(this.color.R.value,this.color.G.value,e,this.color.A.value),this.element.requestUpdate()},this.#Rt.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(this.color.R.value,this.color.G.value,this.color.B.value,e),this.element.requestUpdate()},this.#Gt.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(e,this.color.S.value,this.color.V.value,this.color.A.value),this.element.requestUpdate()},this.#zt.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,e,this.color.V.value,this.color.A.value),this.element.requestUpdate()},this.#_t.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,this.color.S.value,e,this.color.A.value),this.element.requestUpdate()}}renderSlider(e){let t="",i=0,s="";const n=e=>`linear-gradient(to right, #${this.#qt(e,"00",!0)}, #${this.#qt(e,"ff",!0)})`;switch(e){case 0:t="r",i=this.color.R.value,s=n(e);break;case 1:t="g",i=this.color.G.value,s=n(e);break;case 2:t="b",i=this.color.B.value,s=n(e);break;case 3:t="a",i=this.color.A.value,s=`${re.alphaPattern}, ${n(e)}`;break;case 4:t="h",i=360*this.color.H.value,s="linear-gradient(to right, #f00 0%, #ff0 16.666%, #0f0 33.333%, #0ff 50%, #00f 66.666%, #f0f 83.333%, #f00 100%)";break;case 5:t="s",i=this.color.S.value,s=`linear-gradient(to right,#${this.#Xt.setFromHSVA(this.color.H.value,0,this.color.V.value,1),this.#Xt.toRGBAString()},#${this.#Xt.setFromHSVA(this.color.H.value,1,this.color.V.value,1),this.#Xt.toRGBAString()})`;break;case 6:t="v",i=this.color.V.value,s=`linear-gradient(to right, #000, #${this.fullColor.toRGBAString()})`}return s=`background: ${s};`,H`
${t.toUpperCase()}
`}renderContent(){const e=2*this.color.H.value*Math.PI,t={"--ueb-color-r":this.color.R.toString(),"--ueb-color-g":this.color.G.toString(),"--ueb-color-b":this.color.B.toString(),"--ueb-color-a":this.color.A.toString(),"--ueb-color-h":this.color.H.toString(),"--ueb-color-s":this.color.S.toString(),"--ueb-color-v":this.color.V.toString(),"--ueb-color-wheel-x":100*(this.color.S.value*Math.cos(e)*.5+.5)+"%","--ueb-color-wheel-y":100*(this.color.S.value*Math.sin(e)*.5+.5)+"%"},i=this.color.toRGBAString(),s=this.color.toSRGBAString(),n=this.fullColor.toRGBAString();return H`
Old
New
Advanced
${this.renderSlider(0)} ${this.renderSlider(1)} ${this.renderSlider(2)} ${this.renderSlider(3)}
${this.renderSlider(4)} ${this.renderSlider(5)} ${this.renderSlider(6)}
Hex Linear
Hex sRGB
${re.windowApplyButtonText}
${re.windowCancelButtonText}
`}renderWindowName(){return H`${re.colorWindowName}`}}class Xi extends Gi{#Zt(){return ae.printNumber(this.element.getDefaultValue()?.X??0)}#Qt(){return ae.printNumber(this.element.getDefaultValue()?.Y??0)}setDefaultValue(e,t){const i=this.element.getDefaultValue(!0);if(!(i instanceof ut))throw new TypeError("Expected DefaultValue to be a Vector2DEntity");i.X=e[0],i.Y=e[1],this.element.requestUpdate("DefaultValue",i)}renderInput(){return H`
X
Y
`}}class qi extends Gi{#Zt(){return ae.printNumber(this.element.getDefaultValue()?.X??0)}#Qt(){return ae.printNumber(this.element.getDefaultValue()?.Y??0)}#Jt(){return ae.printNumber(this.element.getDefaultValue()?.Z??0)}setDefaultValue(e,t){const i=this.element.getDefaultValue(!0);if(!(i instanceof bt))throw new TypeError("Expected DefaultValue to be a VectorEntity");i.X=e[0],i.Y=e[1],i.Z=e[2],this.element.requestUpdate("DefaultValue",i)}renderInput(){return H`
X
Y
Z
`}}const Zi={[re.paths.linearColor]:class extends ei{#ei;#ti=e=>{e.preventDefault(),this.blueprint.setFocused(!0),this.#ei=ce.getConstructor("ueb-window").newObject({type:new Yi,windowOptions:{getPinColor:()=>this.element.defaultValue,setPinColor:e=>this.element.setDefaultValue(e)}}),this.blueprint.append(this.#ei);const t=()=>{this.element.setDefaultValue(this.#ei.template.color)},i=()=>{this.#ei.removeEventListener(re.windowApplyEventName,t),this.#ei.removeEventListener(re.windowCloseEventName,i),this.#ei=null};this.#ei.addEventListener(re.windowApplyEventName,t),this.#ei.addEventListener(re.windowCloseEventName,i)};renderInput(){return H``}},[re.paths.niagaraBool]:Hi,[re.paths.niagaraPosition]:qi,[re.paths.rotator]:class extends Gi{#ii(){return ae.printNumber(this.element.getDefaultValue()?.R??0)}#si(){return ae.printNumber(this.element.getDefaultValue()?.P??0)}#Qt(){return ae.printNumber(this.element.getDefaultValue()?.Y??0)}setDefaultValue(e=[],t=e){const i=this.element.getDefaultValue(!0);if(!(i instanceof ht))throw new TypeError("Expected DefaultValue to be a RotatorEntity");i.R=e[0],i.P=e[1],i.Y=e[2],this.element.requestUpdate("DefaultValue",i)}renderInput(){return H`
X
Y
Z
`}},[re.paths.vector]:qi,[re.paths.vector2D]:Xi,[re.paths.vector3f]:qi,[re.paths.vector4f]:class extends Gi{#Zt(){return ae.printNumber(this.element.getDefaultValue()?.X??0)}#Qt(){return ae.printNumber(this.element.getDefaultValue()?.Y??0)}#Jt(){return ae.printNumber(this.element.getDefaultValue()?.Z??0)}#ni(){return ae.printNumber(this.element.getDefaultValue()?.W??0)}setDefaultValue(e,t){const i=this.element.getDefaultValue(!0);if(!(i instanceof mt))throw new TypeError("Expected DefaultValue to be a Vector4DEntity");i.X=e[0],i.Y=e[1],i.Z=e[2],i.W=e[3],this.element.requestUpdate("DefaultValue",i)}renderInput(){return H`
X
Y
Z
W
`}},bool:Hi,byte:zi,enum:class extends Oi{static saveEachInputChange=!0;#ri;#ai=[];setup(){super.setup();const e=this.element.nodeElement.entity.EnumEntries;this.#ai=e?.map((e=>(""===e&&(e="None"),[e,this.element.nodeElement.getPinEntities().find((t=>e===t.PinName))?.PinFriendlyName.toString()??e])))??re.CommonEnums[this.element.entity.getSubCategory()]?.map((e=>e instanceof Array?e:[e,ae.formatStringName(e)]))??[];const t=this.element.getDefaultValue().toString();this.#ai.find((([e,i])=>e===t))||this.#ai.push([t,ae.formatStringName(t)]),this.element.requestUpdate()}renderInput(){return this.element.nodeElement.entity,H``}firstUpdated(e){super.firstUpdated(e),this.#ri=this.element.querySelector("ueb-dropdown")}getInputs(){return[this.#ri.getValue()]}},int:zi,int64:class extends Gi{setDefaultValue(e=[],t){this.element.setDefaultValue(new st(e[0])),this.element.requestUpdate()}renderInput(){return H`
`}},MUTABLE_REFERENCE:class extends ei{renderIcon(){return Be.referencePin}},name:class extends Oi{static singleLineInput=!0},rg:Xi,real:class extends Gi{setDefaultValue(e=[],t=e){this.element.setDefaultValue(e[0])}renderInput(){return H`
`}},string:class extends Oi{}};function Qi(e){return"Array"===e.PinType.ContainerType?.toString()?ei:e.PinType.bIsReference&&!e.PinType.bIsConst?Zi.MUTABLE_REFERENCE:"exec"===e.getType()?Ri:(e.isInput()?Zi[e.getType()]:ei)??ei}class Ji extends oe{static properties={pinId:{type:Ge,converter:{fromAttribute:(e,t)=>e?Ge.grammar.parse(e):null,toAttribute:(e,t)=>e?.toString()},attribute:"data-id",reflect:!0},pinType:{type:String,attribute:"data-type",reflect:!0},advancedView:{type:String,attribute:"data-advanced-view",reflect:!0},color:{type:De,converter:{fromAttribute:(e,t)=>e?De.getLinearColorFromAnyFormat().parse(e):null,toAttribute:(e,t)=>e?ae.printLinearColor(e):null},attribute:"data-color",reflect:!0},defaultValue:{type:String,attribute:!1},isLinked:{type:Boolean,converter:ae.booleanConverter,attribute:"data-linked",reflect:!0},pinDirection:{type:String,attribute:"data-direction",reflect:!0},connectable:{type:Boolean,converter:ae.booleanConverter,attribute:"data-connectable",reflect:!0}};nodeElement;static newObject(e=new ft,t=new(Qi(e)),i=void 0){const s=new Ji;return s.initialize(e,t,i),s}initialize(e=new ft,t=new(Qi(e)),i=void 0){this.nodeElement=i,this.advancedView=e.bAdvancedView,this.isLinked=!1,this.connectable=!e.bNotConnectable,super.initialize(e,t),this.pinType=this.entity.getType(),this.defaultValue=this.entity.getDefaultValue(),this.color=Ji.properties.color.converter.fromAttribute(this.getColor().toString()),this.pinDirection=e.isInput()?"input":e.isOutput()?"output":"hidden"}setup(){super.setup(),this.nodeElement=this.closest("ueb-node")}createPinReference(){return new at({objectName:this.nodeElement.getNodeName(),pinGuid:this.getPinId()})}getPinId(){return this.entity.PinId}getPinName(){return this.entity.PinName}getPinDisplayName(){return this.entity.pinTitle()}getColor(){return this.entity.pinColor()}isInput(){return this.entity.isInput()}isOutput(){return this.entity.isOutput()}getLinkLocation(){return this.template.getLinkLocation()}getNodeElement(){return this.nodeElement}getLinks(){return this.entity.LinkedTo??[]}getDefaultValue(e=!1){return this.defaultValue=this.entity.getDefaultValue(e)}setDefaultValue(e){this.entity.DefaultValue=e,this.defaultValue=e,this.entity.recomputesNodeTitleOnChange&&this.nodeElement?.computeNodeDisplayName()}sanitizeLinks(e=[]){this.entity.LinkedTo=this.entity.LinkedTo?.filter((t=>{let i=this.blueprint.getPin(t);if(i){if(e.length&&!e.includes(i.nodeElement))return!1;let t=this.blueprint.getLink(this,i);t||(t=ce.getConstructor("ueb-link").newObject(this,i),this.blueprint.addGraphElement(t))}return i})),this.isLinked=this.entity.isLinked()}linkTo(e){const t=this.createPinReference();!this.isLinked||!this.isOutput()||"exec"!==this.pinType&&"exec"!==e.pinType||this.getLinks().some((e=>t.equals(e)))||this.unlinkFromAll(),this.entity.linkTo(e.getNodeElement().getNodeName(),e.entity)&&(this.isLinked=this.entity.isLinked(),this.nodeElement?.template.linksChanged(),this.entity.recomputesNodeTitleOnChange&&this.nodeElement?.computeNodeDisplayName())}unlinkFrom(e,t=!0){this.entity.unlinkFrom(e.getNodeElement().getNodeName(),e.entity)&&(this.isLinked=this.entity.isLinked(),this.nodeElement?.template.linksChanged(),t&&this.blueprint.getLink(this,e)?.remove(),this.entity.recomputesNodeTitleOnChange&&this.nodeElement?.computeNodeDisplayName())}unlinkFromAll(){const e=this.getLinks().length;this.getLinks().map((e=>this.blueprint.getPin(e))).forEach((e=>this.unlinkFrom(e))),e&&this.nodeElement?.template.linksChanged()}redirectLink(e,t){const i=this.getLinks().findIndex((t=>t.objectName.toString()==e.getNodeElement().getNodeName()&&t.pinGuid.valueOf()==e.entity.PinId.valueOf()));return i>=0&&(this.entity.LinkedTo[i]=t,!0)}}class es{constructor(e=(e=>e),t=null){this.array=new Uint32Array(t),this.comparisonValueSupplier=e,this.length=0,this.currentPosition=0}get(e){return e>=0&&e=0&&this.currentPosition=0&&this.currentPosition0?this.get(this.currentPosition-1):null}getPrevValue(){return this.currentPosition>0?this.comparisonValueSupplier(this.get(this.currentPosition-1)):Number.MIN_SAFE_INTEGER}shiftLeft(e,t=1){this.array.set(this.array.subarray(e+t),e)}shiftRight(e,t=1){this.array.set(this.array.subarray(e,-t),e+t)}}class ts{constructor(e,t,i,s){this.initialPosition=e,this.finalPosition=e,this.metadata=new Array(t.length),this.primaryOrder=new es((e=>this.metadata[e].primaryBoundary)),this.secondaryOrder=new es((e=>this.metadata[e].secondaryBoundary)),this.selectFunc=s,this.rectangles=t,this.primaryOrder.reserve(this.rectangles.length),this.secondaryOrder.reserve(this.rectangles.length),t.forEach(((e,t)=>{let n={primaryBoundary:this.initialPosition[0],secondaryBoundary:this.initialPosition[1],rectangle:t,onSecondaryAxis:!1};this.metadata[t]=n,s(e,!1);const r=i(e);this.initialPosition[1]{if(this.metadata[i].onSecondaryAxis)this.selectFunc(this.rectangles[i],s);else if(s){this.secondaryOrder.insert(i,e[1]);const s=this.metadata[i].secondaryBoundary;Math.sign(e[1]-s)==t[1]&&Math.sign(s-this.initialPosition[1])==t[1]&&this.selectFunc(this.rectangles[i],!0)}else this.selectFunc(this.rectangles[i],!1),this.secondaryOrder.remove(i);this.computeBoundaries(),this.selectTo(e)};e[0]this.boundaries.primaryN.v&&e[0]this.boundaries.primaryP.v&&(++this.primaryOrder.currentPosition,i(this.boundaries.primaryP.i,this.initialPosition[0]{this.selectFunc(this.rectangles[t],i),this.computeBoundaries(),this.selectTo(e)};e[1]this.boundaries.secondaryN.v&&e[1]this.boundaries.secondaryP.v&&(++this.secondaryOrder.currentPosition,s(this.boundaries.secondaryP.i,this.initialPosition[1]ns.#oi[e],toAttribute:(e,t)=>Object.entries(ns.#oi).find((([t,i])=>e.constructor===i))?.[0]}}};static newObject(e={},t=e.type??new Ki){const i=new ns;return i.initialize(e,t),i}initialize(e={},t=e.type??new Ki){e.windowOptions??={},this.type=e.type,this.windowOptions=e.windowOptions,super.initialize(e,t)}computeSizes(){const e=this.getBoundingClientRect();this.sizeX=e.width,this.sizeY=e.height}cleanup(){super.cleanup(),this.acknowledgeClose()}acknowledgeClose(){let e=new CustomEvent(re.windowCloseEventName);this.dispatchEvent(e)}}class rs extends Le{static attributes={...super.attributes,TerminalCategory:tt,TerminalSubCategory:tt,bTerminalIsConst:Ue,bTerminalIsWeakPointer:Ue,bTerminalIsUObjectWrapper:Ue};constructor(e){super(e),this.TerminalCategory,this.TerminalSubCategory,this.bTerminalIsConst,this.bTerminalIsWeakPointer,this.bTerminalIsUObjectWrapper}}class as extends Le{static grammar=ke.seq(ke.reg(new RegExp(`(${Ie.Regex.Path.source}|${Ie.Regex.Symbol.source}\\s*)?\\(\\s*`),1),ke.seq(Ie.attributeName,Ie.equalSeparation).map((([e,t])=>e)).chain((e=>Ie.unknownValue.map((t=>i=>i[e]=t)))).sepBy(Ie.commaSeparation),ke.reg(/\s*(?:,\s*)?\)/)).map((([e,t,i])=>{e??="";let s={};return e.length&&(s.lookbehind=e),t.forEach((e=>e(s))),new this(s)}));constructor(e={}){super(e)}}class os extends pi{#li;constructor(e,t){super(t),this.#li=e}doWrite(e,t,i=""){return this.#li(e,t)}}class ls extends pi{constructor(e,t=!0){super(e),t&&(this.wrap=(e,t)=>ae.escapeString(t))}doWrite(e,t,i=""){return t||e.constructor!==String?this.wrap(e,e.toString()):`"${this.wrap(e,e.toString())}"`}}Ie.unknownValue=ke.alt(Ue.grammar,Ge.grammar,ke.str("None").map((()=>nt.createNoneInstance())),Ie.null,We.grammar,nt.fullReferenceGrammar,tt.grammar,et.grammar,Je.grammar,it.grammar,at.grammar,mt.grammar,bt.grammar,ht.grammar,De.grammar,ut.grammar,as.grammar,qe.grammar,je.of(at).grammar,je.of(Fe.accepting(We,tt,qe)).grammar,ke.lazy((()=>je.createGrammar(Ie.unknownValue)))),li.registerSerializer(null,new os(((e,t)=>"()"),null)),li.registerSerializer(Array,new os(((e,t)=>`(${e.map((e=>li.getSerializer(ae.getType(e)).write(e,t))).join(",")})`),Array)),li.registerSerializer(BigInt,new ls(BigInt)),li.registerSerializer(hi,new di(hi)),li.registerSerializer(Boolean,new os(((e,t)=>e?t?"true":"True":t?"false":"False"),Boolean)),li.registerSerializer(Ye,new ls(Ye)),li.registerSerializer($e,new ls($e)),li.registerSerializer(Qe,new ls(Qe)),li.registerSerializer(Ze,new ls(Ze)),li.registerSerializer(it,new os(((e,t)=>e.getLookbehind()+"("+e.value.map((e=>li.getSerializer(ae.getType(e)).write(e,t))).join(", ")+")"),it)),li.registerSerializer(ot,new pi(ot,pi.bracketsWrapped)),li.registerSerializer(Ge,new ls(Ge)),li.registerSerializer(wt,new ls(wt)),li.registerSerializer(st,new ls(st)),li.registerSerializer(Ke,new ls(Ke)),li.registerSerializer(Je,new pi(Je,((e,t)=>`${e.getLookbehind()}(${t})`),", ",!1,"",(()=>""))),li.registerSerializer(Lt,new pi(Lt,pi.bracketsWrapped)),li.registerSerializer(De,new pi(De,pi.bracketsWrapped)),li.registerSerializer(et,new pi(et,((e,t)=>`${e.getLookbehind()}(${t})`),", ",!1,"",(()=>""))),li.registerSerializer(St,new pi(St,pi.bracketsWrapped)),li.registeOrSerializer(Me,new os(((e,t)=>li.getSerializer(e.getTargetType()).write(e.get(),t)),Me)),li.registerSerializer(Number,new ls(Number)),li.registerSerializer(Pt,new di),li.registerSerializer(nt,new ls(nt,!1)),li.registerSerializer(rt,new ls(rt)),li.registerSerializer(ft,new pi(ft,((e,t)=>`${e.getLookbehind()} (${t})`),",",!0)),li.registerSerializer(at,new pi(at,void 0," ",!1,"",(()=>""))),li.registerSerializer(lt,new pi(lt)),li.registerSerializer(rs,new pi(rs,pi.bracketsWrapped)),li.registerSerializer(ct,new os(((e,t)=>`X=${e.X} Y=${e.Y}`),ct)),li.registerSerializer(ht,new pi(ht,pi.bracketsWrapped)),li.registerSerializer(Ct,new pi(Ct,pi.bracketsWrapped)),li.registerSerializer(String,new os(((e,t)=>t?ae.escapeString(e):`"${ae.escapeString(e)}"`),String)),li.registerSerializer(pt,new os(((e,t)=>`${e.P}, ${e.Y}, ${e.R}`),pt)),li.registerSerializer(dt,new os(((e,t)=>`${e.X}, ${e.Y}`),dt)),li.registerSerializer(vt,new os(((e,t)=>`${e.X}, ${e.Y}, ${e.Z}`),vt)),li.registerSerializer(gt,new os(((e,t)=>`${e.X}, ${e.Y}, ${e.Z}, ${e.W}`),gt)),li.registerSerializer(qe,new ls(qe)),li.registerSerializer(as,new pi(as,((e,t)=>`${e.getLookbehind()??""}(${t})`))),li.registerSerializer(xt,new pi(xt,pi.bracketsWrapped)),li.registerSerializer(ut,new pi(ut,pi.bracketsWrapped)),li.registerSerializer(bt,new pi(bt,pi.bracketsWrapped)),li.registerSerializer(mt,new pi(mt,pi.bracketsWrapped)),function(){const e=(e,t)=>{customElements.define(e,t),ce.registerElement(e,t)};e("ueb-color-handler",Li),e("ueb-dropdown",Di),e("ueb-input",Vi),e("ueb-link",Ht),e("ueb-node",ci),e("ueb-pin",Ji),e("ueb-selector",ss),e("ueb-ui-slider",Ti),e("ueb-window",ns)}();export{xi as Blueprint,re as Configuration,Ht as LinkElement,ci as NodeElement,ae as Utility}; diff --git a/js/Blueprint.js b/js/Blueprint.js index 5f386ce..8b0df39 100755 --- a/js/Blueprint.js +++ b/js/Blueprint.js @@ -413,7 +413,7 @@ export default class Blueprint extends IElement { this.entity = this.entity.mergeWith(element.entity) const additionalSerialization = atob(element.entity.ExportedNodes) this.template.getPasteInputObject().pasted(additionalSerialization) - .forEach(node => node.entity.isExported = true) + .forEach(node => node.entity._exported = true) continue } const name = element.entity.getObjectName() diff --git a/js/Utility.js b/js/Utility.js index 44519d8..129e5e1 100755 --- a/js/Utility.js +++ b/js/Utility.js @@ -1,7 +1,4 @@ -import ComputedType from "./entity/ComputedType.js" import Configuration from "./Configuration.js" -import MirroredEntity from "./entity/MirroredEntity.js" -import Union from "./entity/Union.js" export default class Utility { @@ -243,38 +240,6 @@ export default class Utility { return (acceptNull && value === null) || value instanceof type || value?.constructor === type } - /** @param {Attribute} value */ - static sanitize(value, targetType = /** @type {AttributeTypeDescription } */(value?.constructor)) { - if (targetType instanceof Array) { - targetType = targetType[0] - } - if (targetType instanceof ComputedType) { - return value // The type is computed, can't say anything about it - } - if (targetType instanceof Union) { - let type = targetType.values.find(t => Utility.isValueOfType(value, t, false)) - if (!type) { - type = targetType.values[0] - } - targetType = type - } - if (targetType instanceof MirroredEntity) { - if (value instanceof MirroredEntity) { - return value - } - return Utility.sanitize(value, targetType.getTargetType()) - } - if (targetType && !Utility.isValueOfType(value, targetType, true)) { - value = targetType === BigInt - ? BigInt(/** @type {Number} */(value)) - : new /** @type {EntityConstructor} */(targetType)(value) - } - if (value instanceof Boolean || value instanceof Number || value instanceof String) { - value = /** @type {TerminalAttribute} */(value.valueOf()) // Get the relative primitive value - } - return value - } - /** * @param {Number} x * @param {Number} y diff --git a/js/entity/AlternativesEntity.js b/js/entity/AlternativesEntity.js new file mode 100644 index 0000000..5ab7893 --- /dev/null +++ b/js/entity/AlternativesEntity.js @@ -0,0 +1,29 @@ +import P from "parsernostrum" +import Grammar from "../serialization/Grammar.js" +import IEntity from "./IEntity.js" + +export default class AlternativesEntity extends IEntity { + + /** @type {(typeof IEntity)[]} */ + static alternatives = [] + + static createGrammar() { + return this.alternatives + .map(entity => entity.grammar) + .reduce((acc, cur) => !cur || cur === Grammar.unknownValue || acc === Grammar.unknownValue + ? Grammar.unknownValue + : P.alt(acc, cur) + ) + } + + /** + * @template {(typeof IEntity)[]} Types + * @param {Types} types + */ + static accepting(...types) { + const result = /** @type {typeof AlternativesEntity & { alternatives: Types }} */(this.asUniqueClass()) + result.alternatives = types + result.grammar = result.createGrammar() + return result + } +} diff --git a/js/entity/ArrayEntity.js b/js/entity/ArrayEntity.js new file mode 100644 index 0000000..963268c --- /dev/null +++ b/js/entity/ArrayEntity.js @@ -0,0 +1,41 @@ +import P from "parsernostrum" +import Grammar from "../serialization/Grammar.js" +import IEntity from "./IEntity.js" + +/** @template {typeof IEntity} T */ +export default class ArrayEntity extends IEntity { + + /** @type {typeof IEntity} */ + static type + + /** @param {InstanceType[]} values */ + constructor(values = []) { + super() + this.values = values + } + + static createGrammar(elementGrammar = this.type.grammar) { + return this.inlined + ? elementGrammar + : P.seq( + P.reg(/\(\s*/), + elementGrammar.sepBy(Grammar.commaSeparation).opt(), + P.reg(/\s*(?:,\s*)?\)/), + ).map(([_0, values, _3]) => new this(values instanceof Array ? values : [])) + } + + /** + * @template {typeof IEntity} T + * @param {NonNullable} type + */ + static of(type) { + const result = /** @type {(typeof ArrayEntity) & { type: T }} */(this.asUniqueClass()) + result.type = type + this.grammar = result.createGrammar() + return result + } + + valueOf() { + return this.values + } +} diff --git a/js/entity/BooleanEntity.js b/js/entity/BooleanEntity.js new file mode 100755 index 0000000..b9044d7 --- /dev/null +++ b/js/entity/BooleanEntity.js @@ -0,0 +1,20 @@ +import P from "parsernostrum" +import IEntity from "./IEntity.js" + +export default class BooleanEntity extends IEntity { + + static grammar = P.regArray(/(true)|false/i).map(v => v[1] ? new this(true) : new this(false)) + + constructor(value = false) { + super() + this.value = value + } + + valueOf() { + return this.value + } + + toString() { + return this.value.toString() + } +} diff --git a/js/entity/ByteEntity.js b/js/entity/ByteEntity.js index 1660d21..dded75d 100755 --- a/js/entity/ByteEntity.js +++ b/js/entity/ByteEntity.js @@ -1,23 +1,13 @@ -import Parsernostrum from "parsernostrum" -import AttributeInfo from "./AttributeInfo.js" +import P from "parsernostrum" import IntegerEntity from "./IntegerEntity.js" export default class ByteEntity extends IntegerEntity { - static attributes = { - ...super.attributes, - value: new AttributeInfo({ - ...super.attributes.value, - predicate: v => v % 1 == 0 && v >= 0 && v < 1 << 8, - }), - } - static grammar = this.createGrammar() + static grammar = P.numberByte.map(v => new this(v)) - static createGrammar() { - return Parsernostrum.numberByte.map(v => new this(v)) - } - - constructor(values = 0) { - super(values) + set value(value) { + if (value % 1 == 0 && value >= 0 && value < 1 << 8) { + super.value = value + } } } diff --git a/js/entity/ColorChannelEntity.js b/js/entity/ColorChannelEntity.js index e58d5f3..7bbfe7e 100644 --- a/js/entity/ColorChannelEntity.js +++ b/js/entity/ColorChannelEntity.js @@ -1,28 +1,13 @@ -import Parsernostrum from "parsernostrum" -import AttributeInfo from "./AttributeInfo.js" +import P from "parsernostrum" import IEntity from "./IEntity.js" export default class ColorChannelEntity extends IEntity { - static attributes = { - ...super.attributes, - value: AttributeInfo.createValue(0), - } - static grammar = this.createGrammar() + static grammar = P.number.map(v => new this(v)) - static createGrammar() { - return Parsernostrum.number.map(value => new this(value)) - } - - constructor(values = 0) { - if (values.constructor !== Object) { - // @ts-expect-error - values = { - value: values, - } - } - super(values) - /** @type {Number} */ this.value + constructor(value = 0) { + super() + this.value = value } valueOf() { diff --git a/js/entity/ComputedType.js b/js/entity/ComputedType.js deleted file mode 100644 index 0d7807a..0000000 --- a/js/entity/ComputedType.js +++ /dev/null @@ -1,14 +0,0 @@ -export default class ComputedType { - - #f - - /** @param {Function} f */ - constructor(f) { - this.#f = f - } - - /** @param {IEntity} entity */ - compute(entity) { - return this.#f(entity) - } -} diff --git a/js/entity/ComputedTypeEntity.js b/js/entity/ComputedTypeEntity.js new file mode 100644 index 0000000..089a2dc --- /dev/null +++ b/js/entity/ComputedTypeEntity.js @@ -0,0 +1,22 @@ +import IEntity from "./IEntity.js" + +export default class ComputedTypeEntity extends IEntity { + + /** @type {(entity: IEntity) => typeof IEntity} */ + static f + + /** + * @template {typeof ComputedTypeEntity.f} T + * @param {T} producer + */ + static from(producer) { + const result = /** @type {(typeof ComputedTypeEntity) & { f: T }} */(this.asUniqueClass()) + result.f = producer + return result + } + + /** @param {IEntity} entity */ + compute(entity) { + return /** @type {typeof ComputedTypeEntity} */(this.Self()).f(entity) + } +} diff --git a/js/entity/EnumDisplayValueEntity.js b/js/entity/EnumDisplayValueEntity.js index 76d6031..8d2084f 100755 --- a/js/entity/EnumDisplayValueEntity.js +++ b/js/entity/EnumDisplayValueEntity.js @@ -1,12 +1,8 @@ -import Parsernostrum from "parsernostrum" +import P from "parsernostrum" import Grammar from "../serialization/Grammar.js" import EnumEntity from "./EnumEntity.js" export default class EnumDisplayValueEntity extends EnumEntity { - static grammar = this.createGrammar() - - static createGrammar() { - return Parsernostrum.reg(Grammar.Regex.InsideString).map(v => new this(v)) - } + static grammar = P.reg(Grammar.Regex.InsideString).map(v => new this(v)) } diff --git a/js/entity/EnumEntity.js b/js/entity/EnumEntity.js index 798f7ed..d5d0824 100755 --- a/js/entity/EnumEntity.js +++ b/js/entity/EnumEntity.js @@ -3,9 +3,5 @@ import SymbolEntity from "./SymbolEntity.js" export default class EnumEntity extends SymbolEntity { - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.symbol.map(v => new this(v)) - } + static grammar = Grammar.symbol.map(v => new this(v)) } diff --git a/js/entity/FormatTextEntity.js b/js/entity/FormatTextEntity.js index a31fd0a..9ef4197 100644 --- a/js/entity/FormatTextEntity.js +++ b/js/entity/FormatTextEntity.js @@ -1,55 +1,38 @@ -import Parsernostrum from "parsernostrum" -import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" +import P from "parsernostrum" import IEntity from "./IEntity.js" import InvariantTextEntity from "./InvariantTextEntity.js" import LocalizedTextEntity from "./LocalizedTextEntity.js" -import Union from "./Union.js" +import StringEntity from "./StringEntity.js" export default class FormatTextEntity extends IEntity { - static attributes = { - ...super.attributes, - value: new AttributeInfo({ - type: [new Union(String, LocalizedTextEntity, InvariantTextEntity, FormatTextEntity)], - default: [], - }), - lookbehind: /** @type {AttributeInfo>} */(new AttributeInfo({ - ...super.attributes.lookbehind, - default: new Union("LOCGEN_FORMAT_NAMED", "LOCGEN_FORMAT_ORDERED"), - })), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Parsernostrum.seq( - Parsernostrum.reg( - // Resulting regex: /(LOCGEN_FORMAT_NAMED|LOCGEN_FORMAT_ORDERED)\s*/ - new RegExp(`(${this.attributes.lookbehind.default.values.reduce((acc, cur) => acc + "|" + cur)})\\s*`), - 1 - ), - Grammar.grammarFor(this.attributes.value) - ) - .map(([lookbehind, values]) => { - const result = new this({ - value: values, - lookbehind, - }) - return result - }) - } + static lookbehind = ["LOCGEN_FORMAT_NAMED", "LOCGEN_FORMAT_ORDERED"] + static grammar = P.seq( + // Resulting regex: /(LOCGEN_FORMAT_NAMED|LOCGEN_FORMAT_ORDERED)\s*/ + P.reg(new RegExp(String.raw`(${this.lookbehind.reduce((acc, cur) => acc + "|" + cur)})\s*\(\s*)`), 1), + P.alt( + ...[StringEntity, LocalizedTextEntity, InvariantTextEntity, FormatTextEntity].map(type => type.grammar) + ).sepBy(P.reg(/\s*\,\s*/)), + P.reg(/\s*\)/) + ) + .map(([lookbehind, values]) => { + const result = new this(values) + result.lookbehind = lookbehind + return result + }) + /** @param {(StringEntity | LocalizedTextEntity | InvariantTextEntity | FormatTextEntity)[]} values */ constructor(values) { - super(values) - /** @type {(String | LocalizedTextEntity | InvariantTextEntity | FormatTextEntity)[]} */ this.value + super() + this.values = values } toString() { - const pattern = this.value?.[0]?.toString() // The pattern is always the first element of the array + const pattern = this.values?.[0]?.toString() // The pattern is always the first element of the array if (!pattern) { return "" } - const values = this.value.slice(1).map(v => v.toString()) + const values = this.values.slice(1).map(v => v.toString()) return this.lookbehind == "LOCGEN_FORMAT_NAMED" ? pattern.replaceAll(/\{([a-zA-Z]\w*)\}/g, (substring, arg) => { const argLocation = values.indexOf(arg) + 1 diff --git a/js/entity/FunctionReferenceEntity.js b/js/entity/FunctionReferenceEntity.js index e97040f..362e8d0 100755 --- a/js/entity/FunctionReferenceEntity.js +++ b/js/entity/FunctionReferenceEntity.js @@ -1,22 +1,18 @@ import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" import GuidEntity from "./GuidEntity.js" import IEntity from "./IEntity.js" import ObjectReferenceEntity from "./ObjectReferenceEntity.js" +import StringEntity from "./StringEntity.js" export default class FunctionReferenceEntity extends IEntity { static attributes = { ...super.attributes, - MemberParent: AttributeInfo.createType(ObjectReferenceEntity), - MemberName: AttributeInfo.createType(String), - MemberGuid: AttributeInfo.createType(GuidEntity), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.createEntityGrammar(this) + MemberParent: ObjectReferenceEntity, + MemberName: StringEntity, + MemberGuid: GuidEntity, } + static grammar = Grammar.createEntityGrammar(this) constructor(values) { super(values) diff --git a/js/entity/GuidEntity.js b/js/entity/GuidEntity.js index 06b312f..8b23f2a 100755 --- a/js/entity/GuidEntity.js +++ b/js/entity/GuidEntity.js @@ -1,6 +1,5 @@ -import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" import IEntity from "./IEntity.js" +import P from "parsernostrum" var crypto if (typeof window === "undefined") { @@ -11,39 +10,21 @@ if (typeof window === "undefined") { export default class GuidEntity extends IEntity { - static attributes = { - ...super.attributes, - value: AttributeInfo.createValue(""), - } - static grammar = this.createGrammar() + static grammar = P.reg(/[0-9a-fA-F]{32}/).map(v => new this(v)) - static createGrammar() { - return Grammar.guid.map(v => new this(v)) - } - - static generateGuid(random = true) { + static generateGuid() { let values = new Uint32Array(4) - if (random === true) { - crypto.getRandomValues(values) - } + crypto.getRandomValues(values) let guid = "" values.forEach(n => { guid += ("0".repeat(8) + n.toString(16).toUpperCase()).slice(-8) }) - return new GuidEntity({ value: guid }) + return guid } - constructor(values) { - if (!values) { - values = GuidEntity.generateGuid().value - } - if (values.constructor !== Object) { - values = { - value: values, - } - } - super(values) - /** @type {String} */ this.value + constructor(value = GuidEntity.generateGuid()) { + super() + this.value = value } valueOf() { diff --git a/js/entity/IEntity.js b/js/entity/IEntity.js index e1e7d0d..95ab97e 100644 --- a/js/entity/IEntity.js +++ b/js/entity/IEntity.js @@ -1,169 +1,165 @@ -import Configuration from "../Configuration.js" +import P from "parsernostrum" import Utility from "../Utility.js" -import Serializable from "../serialization/Serializable.js" -import SerializerFactory from "../serialization/SerializerFactory.js" -import AttributeInfo from "./AttributeInfo.js" -import ComputedType from "./ComputedType.js" -import MirroredEntity from "./MirroredEntity.js" -import Union from "./Union.js" /** @abstract */ -export default class IEntity extends Serializable { +export default class IEntity { - /** @type {{ [attribute: String]: AttributeInfo }} */ - static attributes = { - attributes: new AttributeInfo({ - ignored: true, - }), - lookbehind: new AttributeInfo({ - default: /** @type {String | Union} */(""), - ignored: true, - uninitialized: true, - }), + /** @type {(v: String) => String} */ + static same = v => v + + /** @type {(entity: Attribute, serialized: String) => String} */ + static notWrapped = (entity, serialized) => serialized + + /** @type {(entity: Attribute, serialized: String) => String} */ + static bracketsWrapped = (entity, serialized) => `(${serialized})` + + static wrap = this.notWrapped + + static attributeSeparator = "," + + static trailingSeparator = false + + /** @type {(k: String) => String} */ + static printKey = k => k + + /** @type {P} */ + static grammar = P.failure() + + /** @type {{ [key: String]: typeof IEntity }} */ + static attributes = {} + + /** @type {String | String[]} */ + static lookbehind = "" + + /** @type {typeof IEntity.lookbehind} */ + #lookbehind = this.Self().lookbehind + get lookbehind() { + return this.#lookbehind + } + set lookbehind(value) { + throw this.#lookbehind = value } /** @type {String[]} */ - #_keys - get _keys() { - return this.#_keys + #keys + get keys() { + return this.#keys ?? Object.keys(this.Self().attributes) } - set _keys(keys) { - this.#_keys = keys + set keys(value) { + this.#keys = [... new Set(value)] } - constructor(values = {}, suppressWarns = false) { - super() - const Self = /** @type {typeof IEntity} */(this.constructor) - /** @type {AttributeDeclarations?} */ this.attributes - /** @type {String} */ this.lookbehind - const valuesKeys = Object.keys(values) - const attributesKeys = values.attributes - ? Utility.mergeArrays(Object.keys(values.attributes), Object.keys(Self.attributes)) - : Object.keys(Self.attributes) - const allAttributesKeys = Utility.mergeArrays(valuesKeys, attributesKeys) - for (const key of allAttributesKeys) { - let value = values[key] - if (!suppressWarns && !(key in values)) { - if (!(key in Self.attributes) && !key.startsWith(Configuration.subObjectAttributeNamePrefix)) { - const typeName = value instanceof Array ? `[${value[0]?.constructor.name}]` : value.constructor.name - console.warn( - `UEBlueprint: Attribute ${key} (of type ${typeName}) in the serialized data is not defined in ${Self.name}.attributes` - ) - } - } - if (!(key in Self.attributes)) { - // Remember attributeName can come from the values and be not defined in the attributes. - // In that case just assign it and skip the rest. - this[key] = value + /** @type {(type: typeof IEntity) => InstanceType} */ + static default + static nullable = false + static ignored = false // Never serialize or deserialize + static serialized = false // Value is written and read as string + static expected = false // Must be there + static inlined = false // The key is a subobject or array and printed as inlined (A.B=123, A(0)=123) + static quoted = false // Key is serialized with quotes + static silent = false // Do not serialize if default + static uninitialized = false // Do not initialize with default + + constructor(values = {}) { + const keys = Utility.mergeArrays(Object.keys(values.attributes), Object.keys(this.Self().attributes)) + for (const key of keys) { + if (values[key] !== undefined) { + this[key] = values[key] continue } - Self.attributes.lookbehind - const predicate = AttributeInfo.getAttribute(values, key, "predicate", Self) - const assignAttribute = !predicate - ? v => this[key] = v - : v => { - Object.defineProperties(this, { - ["#" + key]: { - writable: true, - enumerable: false, - }, - [key]: { - enumerable: true, - get() { - return this["#" + key] - }, - set(v) { - if (!predicate(v)) { - console.warn( - `UEBlueprint: Tried to assign attribute ${key} to ${Self.name} not satisfying the predicate` - ) - return - } - this["#" + key] = v - } - }, - }) - this[key] = v - } - - let defaultValue = AttributeInfo.getAttribute(values, key, "default", Self) - if (defaultValue instanceof Function) { - defaultValue = defaultValue(this) - } - let defaultType = AttributeInfo.getAttribute(values, key, "type", Self) - if (defaultType instanceof ComputedType) { - defaultType = defaultType.compute(this) - } - if (defaultType instanceof Array) { - defaultType = Array - } - if (defaultType === undefined) { - defaultType = Utility.getType(defaultValue) - } - - if (value !== undefined) { - // Remember value can still be null - if ( - value?.constructor === String - && AttributeInfo.getAttribute(values, key, "serialized", Self) - && defaultType !== String - ) { - try { - value = SerializerFactory - .getSerializer(defaultType) - .read(/** @type {String} */(value)) - } catch (e) { - assignAttribute(value) - continue - } - } - assignAttribute(Utility.sanitize(value, /** @type {AttributeConstructor} */(defaultType))) - continue // We have a value, need nothing more - } - if (defaultValue !== undefined && !AttributeInfo.getAttribute(values, key, "uninitialized", Self)) { - assignAttribute(defaultValue) + const attribute = this.Self().attributes[key] + if (attribute.default !== undefined) { + this[key] = attribute.default(attribute) + continue } } } - /** @param {AttributeTypeDescription} attributeType */ - static defaultValueProviderFromType(attributeType) { - if (attributeType === Boolean) { - return false - } else if (attributeType === Number) { - return 0 - } else if (attributeType === BigInt) { - return 0n - } else if (attributeType === String) { - return "" - } else if (attributeType === Array || attributeType instanceof Array) { - return () => [] - } else if (attributeType instanceof Union) { - return this.defaultValueProviderFromType(attributeType.values[0]) - } else if (attributeType instanceof MirroredEntity) { - return () => new MirroredEntity(attributeType.type, attributeType.getter) - } else if (attributeType instanceof ComputedType) { - return undefined - } else { - return () => new /** @type {AnyConstructor} */(attributeType)() + /** @param {String} key */ + showProperty(key) { + /** @type {IEntity} */ + let value = this[key] + const Self = value.Self() + if (Self.silent && Self.default !== undefined) { + if (Self["#default"] === undefined) { + Self["#default"] = Self.default(Self) + } + const defaultValue = Self["#default"] + return !value.equals(defaultValue) } + return true } /** - * @template {new (...args: any) => any} C - * @param {C} type - * @returns {value is InstanceType} + * @protected + * @template {typeof IEntity} T + * @this {T} + * @returns {T} */ - static isValueOfType(value, type) { - return value != null && (value instanceof type || value.constructor === type) + static asUniqueClass() { + if (this.name.length) { + // @ts-expect-error + return class extends this { } + } + return this } - static defineAttributes(object, attributes) { - Object.defineProperty(object, "attributes", { - writable: true, - configurable: false, - }) - object.attributes = attributes + /** + * @template {typeof IEntity} T + * @this {T} + */ + static withDefault(value = /** @type {(type: T) => InstanceType} */(type => new type())) { + const result = this.asUniqueClass() + result.default = value + return result + } + + /** + * @template {typeof IEntity} T + * @this {T} + */ + static flagNullable(value = true) { + const result = this.asUniqueClass() + result.nullable = value + return result + } + + /** + * @template {typeof IEntity} T + * @this {T} + */ + static flagSerialized(value = true) { + const result = this.asUniqueClass() + result.serialized = value + return result + } + + /** + * @template {typeof IEntity} T + * @this {T} + */ + static flagInlined(value = true) { + const result = this.asUniqueClass() + result.inlined = value + return result + } + + /** + * @template {typeof IEntity} T + * @this {T} + */ + static flagSilent(value = true) { + const result = this.asUniqueClass() + result.silent = value + return result + } + + /** + * @template {typeof IEntity} T + * @this {InstanceType} + */ + Self() { + return /** @type {T} */(this.constructor) } /** @@ -193,27 +189,16 @@ export default class IEntity extends Serializable { return this["#" + attribute] }, set(v) { - if (v == this["#" + attribute]) { - return + if (v != this["#" + attribute]) { + callback(v) + this["#" + attribute] = v } - callback(v) - this["#" + attribute] = v - } + }, }, }) } } - getLookbehind() { - let lookbehind = this.lookbehind ?? AttributeInfo.getAttribute(this, "lookbehind", "default") - lookbehind = lookbehind instanceof Union ? lookbehind.values[0] : lookbehind - return lookbehind - } - - unexpectedKeys() { - return Object.keys(this).length - Object.keys(/** @type {typeof IEntity} */(this.constructor).attributes).length - } - /** @param {IEntity} other */ equals(other) { const thisKeys = Object.keys(this) @@ -221,13 +206,53 @@ export default class IEntity extends Serializable { if (thisKeys.length != otherKeys.length) { return false } - for (const key of thisKeys) { - if (this[key] instanceof IEntity && !this[key].equals(other[key])) { - return false - } else if (!Utility.equals(this[key], other[key])) { + for (let i = 0; i < thisKeys.length; ++i) { + if (!(this[thisKeys[i]] instanceof IEntity && this[thisKeys[i]].equals(other[otherKeys[i]]))) { return false } } return true } + + toString( + insideString = false, + indentation = "", + printKey = this.Self().printKey, + ) { + const Self = this.Self() + let result = "" + let first = true + for (const key of this.keys) { + /** @type {IEntity} */ + const value = this[key] + if (value === undefined || !this.showProperty(key)) { + continue + } + if (first) { + first = false + } else { + result += Self.attributeSeparator + } + if (Self.inlined) { + result += value.toString(insideString, indentation, k => printKey(`${key}.${k}`)) + continue + } + let keyValue = printKey(key) + if (keyValue.length) { + if (Self.quoted) { + keyValue = `"${keyValue}"` + } + result += Self.attributeSeparator.includes("\n") ? indentation : "" + } + let serialization = value.toString(insideString, indentation, printKey) + if (Self.serialized) { + serialization = `"${serialization.replaceAll(/(?<=(?:[^\\]|^)(?:\\\\)*?)"/, '\\"')}"` + } + result += serialization + } + if (Self.trailingSeparator && result.length) { + result += Self.attributeSeparator + } + return Self.wrap(this, result) + } } diff --git a/js/entity/IdentifierEntity.js b/js/entity/IdentifierEntity.js index f4a1fbe..bfe4577 100644 --- a/js/entity/IdentifierEntity.js +++ b/js/entity/IdentifierEntity.js @@ -1,31 +1,18 @@ import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" import IEntity from "./IEntity.js" export default class IdentifierEntity extends IEntity { - static attributes = { - ...super.attributes, - value: AttributeInfo.createValue(""), - } static attributeConverter = { fromAttribute: (value, type) => new IdentifierEntity(value), toAttribute: (value, type) => value.toString() } - static grammar = this.createGrammar() + static grammar = Grammar.symbol.map(v => new this(v)) - static createGrammar() { - return Grammar.symbol.map(v => new this(v)) - } - - constructor(values) { - if (values.constructor !== Object) { - values = { - value: values, - } - } - super(values) - /** @type {String} */ this.value + /** @param {String} value */ + constructor(value) { + super() + this.value = value } valueOf() { @@ -33,6 +20,6 @@ export default class IdentifierEntity extends IEntity { } toString() { - return this.value + return this.value.toString() } } diff --git a/js/entity/Integer64Entity.js b/js/entity/Integer64Entity.js index fa4bc03..1b7c454 100755 --- a/js/entity/Integer64Entity.js +++ b/js/entity/Integer64Entity.js @@ -1,34 +1,25 @@ -import Parsernostrum from "parsernostrum" -import AttributeInfo from "./AttributeInfo.js" +import P from "parsernostrum" import IEntity from "./IEntity.js" export default class Integer64Entity extends IEntity { - static attributes = { - ...super.attributes, - value: new AttributeInfo({ - default: 0n, - predicate: v => v >= -(1n << 63n) && v < 1n << 63n, - }), - } - static grammar = this.createGrammar() + static grammar = P.numberBigInteger.map(v => new this(v)) - static createGrammar() { - return Parsernostrum.numberBigInteger.map(v => new this(v)) + /** @type {bigint} */ + #value + get value() { + return this.#value + } + set value(value) { + if (value >= -(1n << 63n) && value < 1n << 63n) { + this.#value = value + } } - /** @param {BigInt | Number | Object} values */ - constructor(values = 0) { - if (values.constructor !== Object) { - values = { - value: values, - } - } - if (values.value === -0) { - values.value = 0n - } - super(values) - /** @type {BigInt} */ this.value + /** @param {bigint | Number} value */ + constructor(value = 0n) { + super() + this.value = BigInt(value) } valueOf() { diff --git a/js/entity/IntegerEntity.js b/js/entity/IntegerEntity.js index bfbab45..0073cc8 100755 --- a/js/entity/IntegerEntity.js +++ b/js/entity/IntegerEntity.js @@ -1,42 +1,15 @@ -import Parsernostrum from "parsernostrum" -import AttributeInfo from "./AttributeInfo.js" -import IEntity from "./IEntity.js" +import P from "parsernostrum" +import NumberEntity from "./NumberEntity.js" -export default class IntegerEntity extends IEntity { +// @ts-expect-error +export default class IntegerEntity extends NumberEntity { - static attributes = { - ...super.attributes, - value: new AttributeInfo({ - default: 0, - predicate: v => v % 1 == 0 && v > 1 << 31 && v < -(1 << 31), - }), - } - static grammar = this.createGrammar() + static grammar = P.numberInteger.map(v => new this(v)) - static createGrammar() { - return Parsernostrum.numberInteger.map(v => new this(v)) - } - - /** @param {Number | Object} values */ - constructor(values = 0) { - if (values.constructor !== Object) { - values = { - value: values, - } + set value(value) { + if (value >= -(1 << 31) && value < 1 << 31) { + value = Math.floor(value) + super.value = value } - values.value = Math.floor(values.value) - if (values.value === -0) { - values.value = 0 - } - super(values) - /** @type {Number} */ this.value - } - - valueOf() { - return this.value - } - - toString() { - return this.value.toString() } } diff --git a/js/entity/InvariantTextEntity.js b/js/entity/InvariantTextEntity.js index 809eee4..445fef5 100644 --- a/js/entity/InvariantTextEntity.js +++ b/js/entity/InvariantTextEntity.js @@ -1,41 +1,22 @@ -import Parsernostrum from "parsernostrum" -import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" +import P from "parsernostrum" import IEntity from "./IEntity.js" export default class InvariantTextEntity extends IEntity { - static attributes = { - ...super.attributes, - value: AttributeInfo.createValue(""), - lookbehind: new AttributeInfo({ - ...super.attributes.lookbehind, - default: "INVTEXT", - }), - } - static grammar = this.createGrammar() + static lookbehind = "INVTEXT" - static createGrammar() { - return Parsernostrum.alt( - Parsernostrum.seq( - Parsernostrum.reg(new RegExp(`${this.attributes.lookbehind.default}\\s*\\(`)), - Grammar.grammarFor(this.attributes.value), - Parsernostrum.reg(/\s*\)/) - ) - .map(([_0, value, _2]) => value), - Parsernostrum.reg(new RegExp(this.attributes.lookbehind.default)) // InvariantTextEntity can not have arguments - .map(() => "") - ).map(value => new this(value)) - } + static grammar = P.alt( + P.seq( + P.reg(new RegExp(`${this.lookbehind}\\s*\\(`)), + P.doubleQuotedString, + P.reg(/\s*\)/) + ).map(([_0, value, _2]) => new this(value)), + P.reg(new RegExp(this.lookbehind)).map(() => new this()) // InvariantTextEntity can not have arguments + ).map(value => new this(value)) - constructor(values) { - if (values.constructor !== Object) { - values = { - value: values, - } - } - super(values) - /** @type {String} */ this.value + constructor(value = "") { + super() + this.value = value } toString() { diff --git a/js/entity/KeyBindingEntity.js b/js/entity/KeyBindingEntity.js index 6ae25f9..3302167 100644 --- a/js/entity/KeyBindingEntity.js +++ b/js/entity/KeyBindingEntity.js @@ -1,33 +1,32 @@ -import Parsernostrum from "parsernostrum" +import P from "parsernostrum" import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" +import BooleanEntity from "./BooleanEntity.js" import IEntity from "./IEntity.js" import IdentifierEntity from "./IdentifierEntity.js" +import StringEntity from "./StringEntity.js" export default class KeyBindingEntity extends IEntity { static attributes = { ...super.attributes, - ActionName: AttributeInfo.createValue(""), - bShift: AttributeInfo.createValue(false), - bCtrl: AttributeInfo.createValue(false), - bAlt: AttributeInfo.createValue(false), - bCmd: AttributeInfo.createValue(false), - Key: AttributeInfo.createType(IdentifierEntity), + ActionName: StringEntity, + bShift: BooleanEntity, + bCtrl: BooleanEntity, + bAlt: BooleanEntity, + bCmd: BooleanEntity, + Key: IdentifierEntity, } - static grammar = this.createGrammar() + static grammar = P.alt( + IdentifierEntity.grammar.map(identifier => { + const result = new this() + result.Key = identifier + return result + }), + Grammar.createEntityGrammar(this) + ) - static createGrammar() { - return Parsernostrum.alt( - IdentifierEntity.grammar.map(identifier => new this({ - Key: identifier - })), - Grammar.createEntityGrammar(this) - ) - } - - constructor(values = {}) { - super(values, true) + constructor() { + super() /** @type {String} */ this.ActionName /** @type {Boolean} */ this.bShift /** @type {Boolean} */ this.bCtrl diff --git a/js/entity/LinearColorEntity.js b/js/entity/LinearColorEntity.js index 03cb146..e56641f 100644 --- a/js/entity/LinearColorEntity.js +++ b/js/entity/LinearColorEntity.js @@ -1,8 +1,7 @@ import { css } from "lit" -import Parsernostrum from "parsernostrum" +import P from "parsernostrum" import Utility from "../Utility.js" import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" import ColorChannelEntity from "./ColorChannelEntity.js" import IEntity from "./IEntity.js" @@ -10,42 +9,36 @@ export default class LinearColorEntity extends IEntity { static attributes = { ...super.attributes, - R: new AttributeInfo({ - type: ColorChannelEntity, - default: () => new ColorChannelEntity(), - expected: true, - }), - G: new AttributeInfo({ - type: ColorChannelEntity, - default: () => new ColorChannelEntity(), - expected: true, - }), - B: new AttributeInfo({ - type: ColorChannelEntity, - default: () => new ColorChannelEntity(), - expected: true, - }), - A: new AttributeInfo({ - type: ColorChannelEntity, - default: () => new ColorChannelEntity(1), - }), - H: new AttributeInfo({ - type: ColorChannelEntity, - default: () => new ColorChannelEntity(), - ignored: true, - }), - S: new AttributeInfo({ - type: ColorChannelEntity, - default: () => new ColorChannelEntity(), - ignored: true, - }), - V: new AttributeInfo({ - type: ColorChannelEntity, - default: () => new ColorChannelEntity(), - ignored: true, - }), + R: ColorChannelEntity.withDefault(), + G: ColorChannelEntity.withDefault(), + B: ColorChannelEntity.withDefault(), + A: ColorChannelEntity.withDefault(type => new type(1)), + } + static grammar = Grammar.createEntityGrammar(this, false) + + #H = new ColorChannelEntity() + get H() { + return this.#H + } + set H(value) { + this.#H = value + } + + #S = new ColorChannelEntity() + get S() { + return this.#H + } + set S(value) { + this.#H = value + } + + #V = new ColorChannelEntity() + get V() { + return this.#H + } + set V(value) { + this.#H = value } - static grammar = this.createGrammar() /** @param {Number} x */ static linearToSRGB(x) { @@ -81,16 +74,13 @@ export default class LinearColorEntity extends IEntity { }) } - static createGrammar() { - return Grammar.createEntityGrammar(this, false) - } - static getLinearColorFromHexGrammar() { - return Parsernostrum.regArray(new RegExp( - "#(" + Grammar.Regex.HexDigit.source + "{2})" - + "(" + Grammar.Regex.HexDigit.source + "{2})" - + "(" + Grammar.Regex.HexDigit.source + "{2})" - + "(" + Grammar.Regex.HexDigit.source + "{2})?" + const hexDigit = /[0-9a-fA-F]/ + return P.regArray(new RegExp( + "#(" + hexDigit.source + "{2})" + + "(" + hexDigit.source + "{2})" + + "(" + hexDigit.source + "{2})" + + "(" + hexDigit.source + "{2})?" )).map(([m, R, G, B, A]) => new this({ R: parseInt(R, 16) / 255, G: parseInt(G, 16) / 255, @@ -100,12 +90,12 @@ export default class LinearColorEntity extends IEntity { } static getLinearColorRGBListGrammar() { - return Parsernostrum.seq( - Parsernostrum.numberByte, + return P.seq( + P.numberByte, Grammar.commaSeparation, - Parsernostrum.numberByte, + P.numberByte, Grammar.commaSeparation, - Parsernostrum.numberByte, + P.numberByte, ).map(([R, _1, G, _3, B]) => new this({ R: R / 255, G: G / 255, @@ -115,23 +105,23 @@ export default class LinearColorEntity extends IEntity { } static getLinearColorRGBGrammar() { - return Parsernostrum.seq( - Parsernostrum.reg(/rgb\s*\(\s*/), + return P.seq( + P.reg(/rgb\s*\(\s*/), this.getLinearColorRGBListGrammar(), - Parsernostrum.reg(/\s*\)/) + P.reg(/\s*\)/) ).map(([_0, linearColor, _2]) => linearColor) } static getLinearColorRGBAGrammar() { - return Parsernostrum.seq( - Parsernostrum.reg(/rgba\s*\(\s*/), + return P.seq( + P.reg(/rgba\s*\(\s*/), this.getLinearColorRGBListGrammar(), - Parsernostrum.reg(/\s*\)/) + P.reg(/\s*\)/) ).map(([_0, linearColor, _2]) => linearColor) } static getLinearColorFromAnyFormat() { - return Parsernostrum.alt( + return P.alt( this.getLinearColorFromHexGrammar(), this.getLinearColorRGBAGrammar(), this.getLinearColorRGBGrammar(), @@ -140,6 +130,7 @@ export default class LinearColorEntity extends IEntity { } constructor(values) { + super(values) if (values instanceof Array) { values = { R: values[0] ?? 0, @@ -148,14 +139,10 @@ export default class LinearColorEntity extends IEntity { A: values[3] ?? 1, } } - super(values) /** @type {ColorChannelEntity} */ this.R /** @type {ColorChannelEntity} */ this.G /** @type {ColorChannelEntity} */ this.B /** @type {ColorChannelEntity} */ this.A - /** @type {ColorChannelEntity} */ this.H - /** @type {ColorChannelEntity} */ this.S - /** @type {ColorChannelEntity} */ this.V this.#updateHSV() } diff --git a/js/entity/LocalizedTextEntity.js b/js/entity/LocalizedTextEntity.js index c9cd0ac..6f5d28f 100755 --- a/js/entity/LocalizedTextEntity.js +++ b/js/entity/LocalizedTextEntity.js @@ -1,44 +1,55 @@ -import Parsernostrum from "parsernostrum" +import P from "parsernostrum" import Utility from "../Utility.js" import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" import IEntity from "./IEntity.js" export default class LocalizedTextEntity extends IEntity { - static attributes = { - ...super.attributes, - namespace: AttributeInfo.createValue(""), - key: AttributeInfo.createValue(""), - value: AttributeInfo.createValue(""), - lookbehind: new AttributeInfo({ - ...super.attributes.lookbehind, - default: "NSLOCTEXT", - }), - } - static grammar = this.createGrammar() + static lookbehind = "NSLOCTEXT" + static grammar = P.regArray(new RegExp( + String.raw`${this.attributes.lookbehind.default}\s*\(` + + String.raw`\s*"(${Grammar.Regex.InsideString.source})"\s*,` + + String.raw`\s*"(${Grammar.Regex.InsideString.source})"\s*,` + + String.raw`\s*"(${Grammar.Regex.InsideString.source})"\s*` + + String.raw`(?:,\s+)?` + + String.raw`\)`, + "m" + )).map(matchResult => new this( + Utility.unescapeString(matchResult[1]), + Utility.unescapeString(matchResult[2]), + Utility.unescapeString(matchResult[3]), + )) - static createGrammar() { - return Parsernostrum.regArray(new RegExp( - String.raw`${this.attributes.lookbehind.default}\s*\(` - + String.raw`\s*"(${Grammar.Regex.InsideString.source})"\s*,` - + String.raw`\s*"(${Grammar.Regex.InsideString.source})"\s*,` - + String.raw`\s*"(${Grammar.Regex.InsideString.source})"\s*` - + String.raw`(?:,\s+)?` - + String.raw`\)`, - "m" - )).map(matchResult => new this({ - namespace: Utility.unescapeString(matchResult[1]), - key: Utility.unescapeString(matchResult[2]), - value: Utility.unescapeString(matchResult[3]), - })) + #namespace + get namespace() { + return this.#namespace + } + set namespace(value) { + this.#namespace = value } - constructor(values) { - super(values) - /** @type {String} */ this.namespace - /** @type {String} */ this.key - /** @type {String} */ this.value + #key + get key() { + return this.#key + } + set key(value) { + this.#key = value + } + + #value + get value() { + return this.#value + } + set value(value) { + this.#value = value + } + + + constructor(namespace = "", key = "", value = "") { + super() + this.namespace = namespace + this.key = key + this.value = value } toString() { diff --git a/js/entity/MacroGraphReferenceEntity.js b/js/entity/MacroGraphReferenceEntity.js index 38f920d..10095f6 100755 --- a/js/entity/MacroGraphReferenceEntity.js +++ b/js/entity/MacroGraphReferenceEntity.js @@ -1,5 +1,4 @@ import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" import GuidEntity from "./GuidEntity.js" import IEntity from "./IEntity.js" import ObjectReferenceEntity from "./ObjectReferenceEntity.js" @@ -8,24 +7,11 @@ export default class MacroGraphReferenceEntity extends IEntity { static attributes = { ...super.attributes, - MacroGraph: new AttributeInfo({ - type: ObjectReferenceEntity, - default: () => new ObjectReferenceEntity(), - }), - GraphBlueprint: new AttributeInfo({ - type: ObjectReferenceEntity, - default: () => new ObjectReferenceEntity(), - }), - GraphGuid: new AttributeInfo({ - type: GuidEntity, - default: () => new GuidEntity(), - }), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.createEntityGrammar(this) + MacroGraph: ObjectReferenceEntity, + GraphBlueprint: ObjectReferenceEntity, + GraphGuid: GuidEntity, } + static grammar = Grammar.createEntityGrammar(this) constructor(values) { super(values) diff --git a/js/entity/MirroredEntity.js b/js/entity/MirroredEntity.js index 8bf71d2..7a628a2 100644 --- a/js/entity/MirroredEntity.js +++ b/js/entity/MirroredEntity.js @@ -1,36 +1,38 @@ -import AttributeInfo from "./AttributeInfo.js" +import IEntity from "./IEntity.js" -/** @template {Attribute} T */ -export default class MirroredEntity { +/** @template {typeof IEntity} T */ +export default class MirroredEntity extends IEntity { - static attributes = { - type: new AttributeInfo({ - ignored: true, - }), - getter: new AttributeInfo({ - ignored: true, - }), - } + /** @type {typeof IEntity} */ + static type - /** - * @param {ConstructorType} type - * @param {() => T} getter - */ - constructor(type, getter = null) { - this.type = type + /** @param {() => T} getter */ + constructor(getter = null) { + super() this.getter = getter } - get() { - return this.getter() + /** + * @template {typeof IEntity} T + * @param {T} type + */ + static of(type) { + const result = this.asUniqueClass() + result.type = type + result.grammar = result.getTargetType().grammar.map(v => new this()) + return result } - /** @returns {AttributeConstructor} */ - getTargetType() { + /** @returns {typeof IEntity} */ + static getTargetType() { const result = this.type - if (result instanceof MirroredEntity) { - return result.getTargetType() + if (result.prototype instanceof MirroredEntity) { + return /** @type {typeof MirroredEntity} */(result).getTargetType() } return result } + + toString() { + return this.getter().toString() + } } diff --git a/js/entity/NaturalNumberEntity.js b/js/entity/NaturalNumberEntity.js index a53a6b9..d0376b7 100755 --- a/js/entity/NaturalNumberEntity.js +++ b/js/entity/NaturalNumberEntity.js @@ -1,17 +1,17 @@ -import IntegerEntity from "./IntegerEntity.js" -import Parsernostrum from "parsernostrum" +import P from "parsernostrum" import Utility from "../Utility.js" +import IntegerEntity from "./IntegerEntity.js" export default class NaturalNumberEntity extends IntegerEntity { - static grammar = this.createGrammar() + static grammar = P.numberNatural.map(v => new this(v)) - static createGrammar() { - return Parsernostrum.numberNatural.map(v => new this(v)) + set value(value) { + value = Math.round(Utility.clamp(this.value, 0)) + super.value = value } - constructor(values = 0) { - super(values) - this.value = Math.round(Utility.clamp(this.value, 0)) + constructor(value = 0) { + super(value) } } diff --git a/js/entity/NumberEntity.js b/js/entity/NumberEntity.js new file mode 100755 index 0000000..ec020b1 --- /dev/null +++ b/js/entity/NumberEntity.js @@ -0,0 +1,36 @@ +import P from "parsernostrum" +import IEntity from "./IEntity.js" + +export default class NumberEntity extends IEntity { + + static grammar = P.regArray( + new RegExp(`(${P.number.getParser().parser.regexp.source})|(\\+?inf)|(-inf)`) + ).map(([_0, n, plusInf, minusInf]) => new this( + n ? Number(n) : plusInf ? Number.POSITIVE_INFINITY : Number.NEGATIVE_INFINITY + )) + + /** @type {Number} */ + #value + get value() { + return this.#value + } + set value(value) { + if (value === -0) { + value = 0 + } + this.#value = value + } + + constructor(value = 0) { + super() + this.value = value + } + + valueOf() { + return this.value + } + + toString() { + return this.value.toString() + } +} diff --git a/js/entity/ObjectEntity.js b/js/entity/ObjectEntity.js index c7aa8d7..5a0a181 100755 --- a/js/entity/ObjectEntity.js +++ b/js/entity/ObjectEntity.js @@ -1,10 +1,14 @@ -import Parsernostrum from "parsernostrum" +import P from "parsernostrum" import Configuration from "../Configuration.js" import Utility from "../Utility.js" import nodeColor from "../decoding/nodeColor.js" import nodeIcon from "../decoding/nodeIcon.js" +import nodeVariadic from "../decoding/nodeVariadic.js" import Grammar from "../serialization/Grammar.js" +import AlternativesEntity from "./AlternativesEntity.js" +import ArrayEntity from "./ArrayEntity.js" import AttributeInfo from "./AttributeInfo.js" +import BooleanEntity from "./BooleanEntity.js" import FunctionReferenceEntity from "./FunctionReferenceEntity.js" import GuidEntity from "./GuidEntity.js" import IEntity from "./IEntity.js" @@ -13,160 +17,134 @@ import IntegerEntity from "./IntegerEntity.js" import LinearColorEntity from "./LinearColorEntity.js" import MacroGraphReferenceEntity from "./MacroGraphReferenceEntity.js" import MirroredEntity from "./MirroredEntity.js" +import NaturalNumberEntity from "./NaturalNumberEntity.js" import ObjectReferenceEntity from "./ObjectReferenceEntity.js" import PinEntity from "./PinEntity.js" import ScriptVariableEntity from "./ScriptVariableEntity.js" +import StringEntity from "./StringEntity.js" import SymbolEntity from "./SymbolEntity.js" -import Union from "./Union.js" import UnknownPinEntity from "./UnknownPinEntity.js" import VariableReferenceEntity from "./VariableReferenceEntity.js" -import nodeVariadic from "../decoding/nodeVariadic.js" export default class ObjectEntity extends IEntity { + #_exported = false + get _exported() { + return this.#_exported + } + set _exported(value) { + this.#_exported = value + } + static attributes = { ...super.attributes, - isExported: new AttributeInfo({ - type: Boolean, - ignored: true, - }), - Class: AttributeInfo.createType(ObjectReferenceEntity), - Name: AttributeInfo.createType(String), - Archetype: AttributeInfo.createType(ObjectReferenceEntity), - ExportPath: AttributeInfo.createType(ObjectReferenceEntity), - ObjectRef: AttributeInfo.createType(ObjectReferenceEntity), - BlueprintElementType: AttributeInfo.createType(ObjectReferenceEntity), - BlueprintElementInstance: AttributeInfo.createType(ObjectReferenceEntity), - PinTags: new AttributeInfo({ - type: [null], - inlined: true, - }), - PinNames: new AttributeInfo({ - type: [String], - inlined: true, - }), - AxisKey: AttributeInfo.createType(SymbolEntity), - InputAxisKey: AttributeInfo.createType(SymbolEntity), - InputName: AttributeInfo.createType(String), - InputType: AttributeInfo.createType(SymbolEntity), - NumAdditionalInputs: AttributeInfo.createType(Number), - bIsPureFunc: AttributeInfo.createType(Boolean), - bIsConstFunc: AttributeInfo.createType(Boolean), - bIsCaseSensitive: AttributeInfo.createType(Boolean), - VariableReference: AttributeInfo.createType(VariableReferenceEntity), - SelfContextInfo: AttributeInfo.createType(SymbolEntity), - DelegatePropertyName: AttributeInfo.createType(String), - DelegateOwnerClass: AttributeInfo.createType(ObjectReferenceEntity), - ComponentPropertyName: AttributeInfo.createType(String), - EventReference: AttributeInfo.createType(FunctionReferenceEntity), - FunctionReference: AttributeInfo.createType(FunctionReferenceEntity), - FunctionScript: AttributeInfo.createType(ObjectReferenceEntity), - CustomFunctionName: AttributeInfo.createType(String), - TargetType: AttributeInfo.createType(ObjectReferenceEntity), - MacroGraphReference: AttributeInfo.createType(MacroGraphReferenceEntity), - Enum: AttributeInfo.createType(ObjectReferenceEntity), - EnumEntries: new AttributeInfo({ - type: [String], - inlined: true, - }), - InputKey: AttributeInfo.createType(SymbolEntity), - OpName: AttributeInfo.createType(String), - CachedChangeId: AttributeInfo.createType(GuidEntity), - FunctionDisplayName: AttributeInfo.createType(String), - AddedPins: new AttributeInfo({ - type: [UnknownPinEntity], - default: () => [], - inlined: true, - silent: true, - }), - ChangeId: AttributeInfo.createType(GuidEntity), - MaterialFunction: AttributeInfo.createType(ObjectReferenceEntity), - bOverrideFunction: AttributeInfo.createType(Boolean), - bInternalEvent: AttributeInfo.createType(Boolean), - bConsumeInput: AttributeInfo.createType(Boolean), - bExecuteWhenPaused: AttributeInfo.createType(Boolean), - bOverrideParentBinding: AttributeInfo.createType(Boolean), - bControl: AttributeInfo.createType(Boolean), - bAlt: AttributeInfo.createType(Boolean), - bShift: AttributeInfo.createType(Boolean), - bCommand: AttributeInfo.createType(Boolean), - CommentColor: AttributeInfo.createType(LinearColorEntity), - bCommentBubbleVisible_InDetailsPanel: AttributeInfo.createType(Boolean), - bColorCommentBubble: AttributeInfo.createType(Boolean), - ProxyFactoryFunctionName: AttributeInfo.createType(String), - ProxyFactoryClass: AttributeInfo.createType(ObjectReferenceEntity), - ProxyClass: AttributeInfo.createType(ObjectReferenceEntity), - StructType: AttributeInfo.createType(ObjectReferenceEntity), - MaterialExpression: AttributeInfo.createType(ObjectReferenceEntity), - MaterialExpressionComment: AttributeInfo.createType(ObjectReferenceEntity), - MoveMode: AttributeInfo.createType(SymbolEntity), - TimelineName: AttributeInfo.createType(String), - TimelineGuid: AttributeInfo.createType(GuidEntity), - SizeX: AttributeInfo.createType(new MirroredEntity(IntegerEntity)), - SizeY: AttributeInfo.createType(new MirroredEntity(IntegerEntity)), - Text: AttributeInfo.createType(new MirroredEntity(String)), - MaterialExpressionEditorX: AttributeInfo.createType(new MirroredEntity(IntegerEntity)), - MaterialExpressionEditorY: AttributeInfo.createType(new MirroredEntity(IntegerEntity)), - NodeTitle: AttributeInfo.createType(String), - NodeTitleColor: AttributeInfo.createType(LinearColorEntity), - PositionX: AttributeInfo.createType(new MirroredEntity(IntegerEntity)), - PositionY: AttributeInfo.createType(new MirroredEntity(IntegerEntity)), - SettingsInterface: AttributeInfo.createType(ObjectReferenceEntity), - PCGNode: AttributeInfo.createType(ObjectReferenceEntity), - HiGenGridSize: AttributeInfo.createType(SymbolEntity), - Operation: AttributeInfo.createType(SymbolEntity), - NodePosX: AttributeInfo.createType(IntegerEntity), - NodePosY: AttributeInfo.createType(IntegerEntity), - NodeHeight: AttributeInfo.createType(IntegerEntity), - NodeWidth: AttributeInfo.createType(IntegerEntity), - Graph: AttributeInfo.createType(ObjectReferenceEntity), - SubgraphInstance: AttributeInfo.createType(String), - InputPins: new AttributeInfo({ - type: [ObjectReferenceEntity], - inlined: true, - }), - OutputPins: new AttributeInfo({ - type: [ObjectReferenceEntity], - inlined: true, - }), - bExposeToLibrary: AttributeInfo.createType(Boolean), - bCanRenameNode: AttributeInfo.createType(Boolean), - bCommentBubblePinned: AttributeInfo.createType(Boolean), - bCommentBubbleVisible: AttributeInfo.createType(Boolean), - NodeComment: AttributeInfo.createType(String), - AdvancedPinDisplay: AttributeInfo.createType(IdentifierEntity), - DelegateReference: AttributeInfo.createType(VariableReferenceEntity), - EnabledState: AttributeInfo.createType(IdentifierEntity), - NodeGuid: AttributeInfo.createType(GuidEntity), - ErrorType: AttributeInfo.createType(IntegerEntity), - ErrorMsg: AttributeInfo.createType(String), - ScriptVariables: new AttributeInfo({ - type: [ScriptVariableEntity], - inlined: true, - }), - Node: AttributeInfo.createType(new MirroredEntity(ObjectReferenceEntity)), - ExportedNodes: AttributeInfo.createType(String), - CustomProperties: AttributeInfo.createType([new Union(PinEntity, UnknownPinEntity)]), + Class: ObjectReferenceEntity, + Name: StringEntity, + Archetype: ObjectReferenceEntity, + ExportPath: ObjectReferenceEntity, + ObjectRef: ObjectReferenceEntity, + BlueprintElementType: ObjectReferenceEntity, + BlueprintElementInstance: ObjectReferenceEntity, + PinNames: ArrayEntity.of(StringEntity).flagInlined(), + AxisKey: SymbolEntity, + InputAxisKey: SymbolEntity, + InputName: StringEntity, + InputType: SymbolEntity, + NumAdditionalInputs: NaturalNumberEntity, + bIsPureFunc: BooleanEntity, + bIsConstFunc: BooleanEntity, + bIsCaseSensitive: BooleanEntity, + VariableReference: VariableReferenceEntity, + SelfContextInfo: SymbolEntity, + DelegatePropertyName: StringEntity, + DelegateOwnerClass: ObjectReferenceEntity, + ComponentPropertyName: StringEntity, + EventReference: FunctionReferenceEntity, + FunctionReference: FunctionReferenceEntity, + FunctionScript: ObjectReferenceEntity, + CustomFunctionName: StringEntity, + TargetType: ObjectReferenceEntity, + MacroGraphReference: MacroGraphReferenceEntity, + Enum: ObjectReferenceEntity, + EnumEntries: ArrayEntity.of(StringEntity).flagInlined(), + InputKey: SymbolEntity, + OpName: StringEntity, + CachedChangeId: GuidEntity, + FunctionDisplayName: StringEntity, + AddedPins: ArrayEntity.of(UnknownPinEntity).withDefault().flagInlined().flagSilent(), + ChangeId: GuidEntity, + MaterialFunction: ObjectReferenceEntity, + bOverrideFunction: BooleanEntity, + bInternalEvent: BooleanEntity, + bConsumeInput: BooleanEntity, + bExecuteWhenPaused: BooleanEntity, + bOverrideParentBinding: BooleanEntity, + bControl: BooleanEntity, + bAlt: BooleanEntity, + bShift: BooleanEntity, + bCommand: BooleanEntity, + CommentColor: LinearColorEntity, + bCommentBubbleVisible_InDetailsPanel: BooleanEntity, + bColorCommentBubble: BooleanEntity, + ProxyFactoryFunctionName: StringEntity, + ProxyFactoryClass: ObjectReferenceEntity, + ProxyClass: ObjectReferenceEntity, + StructType: ObjectReferenceEntity, + MaterialExpression: ObjectReferenceEntity, + MaterialExpressionComment: ObjectReferenceEntity, + MoveMode: SymbolEntity, + TimelineName: StringEntity, + TimelineGuid: GuidEntity, + SizeX: MirroredEntity.of(IntegerEntity), + SizeY: MirroredEntity.of(IntegerEntity), + Text: MirroredEntity.of(StringEntity), + MaterialExpressionEditorX: MirroredEntity.of(IntegerEntity), + MaterialExpressionEditorY: MirroredEntity.of(IntegerEntity), + NodeTitle: StringEntity, + NodeTitleColor: LinearColorEntity, + PositionX: MirroredEntity.of(IntegerEntity), + PositionY: MirroredEntity.of(IntegerEntity), + SettingsInterface: ObjectReferenceEntity, + PCGNode: ObjectReferenceEntity, + HiGenGridSize: SymbolEntity, + Operation: SymbolEntity, + NodePosX: IntegerEntity, + NodePosY: IntegerEntity, + NodeHeight: IntegerEntity, + NodeWidth: IntegerEntity, + Graph: ObjectReferenceEntity, + SubgraphInstance: StringEntity, + InputPins: ArrayEntity.of(ObjectReferenceEntity).flagInlined(), + OutputPins: ArrayEntity.of(ObjectReferenceEntity).flagInlined(), + bExposeToLibrary: BooleanEntity, + bCanRenameNode: BooleanEntity, + bCommentBubblePinned: BooleanEntity, + bCommentBubbleVisible: BooleanEntity, + NodeComment: StringEntity, + AdvancedPinDisplay: IdentifierEntity, + DelegateReference: VariableReferenceEntity, + EnabledState: IdentifierEntity, + NodeGuid: GuidEntity, + ErrorType: IntegerEntity, + ErrorMsg: StringEntity, + ScriptVariables: ArrayEntity.of(ScriptVariableEntity), + Node: MirroredEntity.of(ObjectReferenceEntity), + ExportedNodes: StringEntity, + CustomProperties: ArrayEntity.of(AlternativesEntity.accepting(PinEntity, UnknownPinEntity)), } - static nameRegex = /^(\w+?)(?:_(\d+))?$/ - static customPropertyGrammar = Parsernostrum.seq( - Parsernostrum.reg(/CustomProperties\s+/), - Grammar.grammarFor( - undefined, - this.attributes.CustomProperties.type[0] - ), + static #nameRegex = /^(\w+?)(?:_(\d+))?$/ + static customPropertyGrammar = P.seq( + P.reg(/CustomProperties\s+/), + this.attributes.CustomProperties.type.grammar, ).map(([_0, pin]) => values => { - if (!values.CustomProperties) { - values.CustomProperties = [] - } - values.CustomProperties.push(pin) + (values.CustomProperties ??= []).push(pin) }) - static inlinedArrayEntryGrammar = Parsernostrum.seq( - Parsernostrum.alt( + static inlinedArrayEntryGrammar = P.seq( + P.alt( Grammar.symbolQuoted.map(v => [v, true]), Grammar.symbol.map(v => [v, false]), ), - Parsernostrum.reg( + P.reg( new RegExp(`\\s*\\(\\s*(\\d+)\\s*\\)\\s*\\=\\s*`), 1 ).map(Number) @@ -192,21 +170,21 @@ export default class ObjectEntity extends IEntity { static grammar = this.createGrammar() static createSubObjectGrammar() { - return Parsernostrum.lazy(() => this.grammar) + return P.lazy(() => this.grammar) .map(object => values => values[Configuration.subObjectAttributeNameFromEntity(object)] = object ) } static createGrammar() { - return Parsernostrum.seq( - Parsernostrum.reg(/Begin +Object/), - Parsernostrum.seq( - Parsernostrum.whitespace, - Parsernostrum.alt( + return P.seq( + P.reg(/Begin +Object/), + P.seq( + P.whitespace, + P.alt( this.createSubObjectGrammar(), this.customPropertyGrammar, - Grammar.createAttributeGrammar(this, Parsernostrum.reg(Grammar.Regex.MultipleWordsSymbols)), + Grammar.createAttributeGrammar(this, P.reg(Grammar.Regex.MultipleWordsSymbols)), Grammar.createAttributeGrammar(this, Grammar.attributeNameQuoted, undefined, (obj, k, v) => Utility.objectSet(obj, ["attributes", ...k, "quoted"], true) ), @@ -215,7 +193,7 @@ export default class ObjectEntity extends IEntity { ) .map(([_0, entry]) => entry) .many(), - Parsernostrum.reg(/\s+End +Object/), + P.reg(/\s+End +Object/), ) .map(([_0, attributes, _2]) => { const values = {} @@ -225,16 +203,16 @@ export default class ObjectEntity extends IEntity { } static getMultipleObjectsGrammar() { - return Parsernostrum.seq( - Parsernostrum.whitespaceOpt, + return P.seq( + P.whitespaceOpt, this.grammar, - Parsernostrum.seq( - Parsernostrum.whitespace, + P.seq( + P.whitespace, this.grammar, ) .map(([_0, object]) => object) .many(), - Parsernostrum.whitespaceOpt + P.whitespaceOpt ) .map(([_0, first, remaining, _4]) => [first, ...remaining]) } @@ -242,7 +220,7 @@ export default class ObjectEntity extends IEntity { /** @type {String} */ #class - constructor(values = {}, suppressWarns = false) { + constructor(values = {}) { if ("NodePosX" in values !== "NodePosY" in values) { const entries = Object.entries(values) const [key, position] = "NodePosX" in values @@ -252,13 +230,7 @@ export default class ObjectEntity extends IEntity { entries.splice(position, 0, entry) values = Object.fromEntries(entries) } - super(values, suppressWarns) - - // Attributes not assigned a strong type in attributes because the names are too generic - /** @type {Number | MirroredEntity} */ this.R - /** @type {Number | MirroredEntity} */ this.G - /** @type {Number | MirroredEntity} */ this.B - /** @type {Number | MirroredEntity} */ this.A + super(values) // Attributes /** @type {(PinEntity | UnknownPinEntity)[]} */ this.CustomProperties @@ -359,19 +331,19 @@ export default class ObjectEntity extends IEntity { this.getPinEntities().find(pin => pin.PinName === pinName && (pin.recomputesNodeTitleOnChange = true)) ) const attribute = {} - obj.R = new MirroredEntity(Boolean, () => rgbaPins[0].DefaultValue) - obj.G = new MirroredEntity(Boolean, () => rgbaPins[1].DefaultValue) - obj.B = new MirroredEntity(Boolean, () => rgbaPins[2].DefaultValue) - obj.A = new MirroredEntity(Boolean, () => rgbaPins[3].DefaultValue) - Utility.objectSet(obj, ["attributes", "R", "default"], false) - Utility.objectSet(obj, ["attributes", "R", "silent"], true) - Utility.objectSet(obj, ["attributes", "G", "default"], false) - Utility.objectSet(obj, ["attributes", "G", "silent"], true) - Utility.objectSet(obj, ["attributes", "B", "default"], false) - Utility.objectSet(obj, ["attributes", "B", "silent"], true) - Utility.objectSet(obj, ["attributes", "A", "default"], false) - Utility.objectSet(obj, ["attributes", "A", "silent"], true) - obj._keys = [...Configuration.rgba, ...Object.keys(obj).filter(k => !Configuration.rgba.includes(k))] + obj.R = new ( + MirroredEntity.of(BooleanEntity).withDefault().flagSilent() + )(() => rgbaPins[0].DefaultValue) + obj.G = new ( + MirroredEntity.of(BooleanEntity).withDefault().flagSilent() + )(() => rgbaPins[1].DefaultValue) + obj.B = new ( + MirroredEntity.of(BooleanEntity).withDefault().flagSilent() + )(() => rgbaPins[2].DefaultValue) + obj.A = new ( + MirroredEntity.of(BooleanEntity).withDefault().flagSilent() + )(() => rgbaPins[3].DefaultValue) + obj.keys = [...Configuration.rgba, ...super.keys.filter(k => !Configuration.rgba.includes(k))] } } /** @type {ObjectEntity} */ @@ -388,10 +360,10 @@ export default class ObjectEntity extends IEntity { nodeRef.type === this.PCGNode.type && nodeRef.path === `${this.Name}.${this.PCGNode.path}` ) { - obj.Node.getter = () => new ObjectReferenceEntity({ - type: this.PCGNode.type, - path: `${this.Name}.${this.PCGNode.path}`, - }) + obj.Node.getter = () => new ObjectReferenceEntity( + this.PCGNode.type, + `${this.Name}.${this.PCGNode.path}`, + ) } } } @@ -446,7 +418,7 @@ export default class ObjectEntity extends IEntity { /** @returns {[String, Number]} */ getNameAndCounter() { - const result = this.getObjectName().match(ObjectEntity.nameRegex) + const result = this.getObjectName().match(ObjectEntity.#nameRegex) let name = "" let counter = null return result diff --git a/js/entity/ObjectReferenceEntity.js b/js/entity/ObjectReferenceEntity.js index 213d074..e8164c5 100755 --- a/js/entity/ObjectReferenceEntity.js +++ b/js/entity/ObjectReferenceEntity.js @@ -1,73 +1,71 @@ -import Parsernostrum from "parsernostrum" +import P from "parsernostrum" import Utility from "../Utility.js" import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" import IEntity from "./IEntity.js" export default class ObjectReferenceEntity extends IEntity { - static attributes = { - ...super.attributes, - type: new AttributeInfo({ - default: "", - serialized: true, - }), - path: new AttributeInfo({ - default: "", - serialized: true, - }), - _full: new AttributeInfo({ - ignored: true, - }), - } - static quoted = Parsernostrum.regArray(new RegExp( + static #quotedParser = P.regArray(new RegExp( `'"(${Grammar.Regex.InsideString.source})"'` + "|" + `'(${Grammar.Regex.InsideSingleQuotedString.source})'` )).map(([_0, a, b]) => a ?? b) - static path = this.quoted.getParser().parser.regexp.source + "|" + Grammar.Regex.Path.source - static typeReference = Parsernostrum.reg( + static typeReference = P.reg( new RegExp(Grammar.Regex.Path.source + "|" + Grammar.symbol.getParser().regexp.source) ) - static fullReferenceGrammar = Parsernostrum.regArray( + static fullReferenceGrammar = P.regArray( new RegExp( "(" + this.typeReference.getParser().regexp.source + ")" - + "(?:" + this.quoted.getParser().parser.regexp.source + ")" + + "(?:" + this.#quotedParser.getParser().parser.regexp.source + ")" ) - ).map(([_full, type, ...path]) => new this({ type, path: path.find(v => v), _full })) - static fullReferenceSerializedGrammar = Parsernostrum.regArray( + ).map(([full, type, ...path]) => new this(type, path.find(v => v), full)) + static fullReferenceSerializedGrammar = P.regArray( new RegExp( '"(' + Grammar.Regex.InsideString.source + "?)" + "(?:'(" + Grammar.Regex.InsideSingleQuotedString.source + `?)')?"` ) - ).map(([_full, type, path]) => new this({ type, path, _full })) - static typeReferenceGrammar = this.typeReference.map(v => new this({ type: v, path: "", _full: v })) - static grammar = this.createGrammar() + ).map(([full, type, path]) => new this(type, path, full)) + static typeReferenceGrammar = this.typeReference.map(v => new this(v, "", v)) + static grammar = P.alt( + this.fullReferenceSerializedGrammar, + this.fullReferenceGrammar, + this.typeReferenceGrammar, + ) - constructor(values = {}) { - if (values.constructor === String) { - values = { - path: values - } - } - super(values) - if (!values._full || values._full.length === 0) { - this._full = `"${this.type + (this.path ? (`'${this.path}'`) : "")}"` - } - /** @type {String} */ this.type - /** @type {String} */ this.path + #type + get type() { + return this.#type + } + set type(value) { + this.#type = value } - static createGrammar() { - return Parsernostrum.alt( - this.fullReferenceSerializedGrammar, - this.fullReferenceGrammar, - this.typeReferenceGrammar, - ) + #path + get path() { + return this.#path + } + set path(value) { + this.#path = value + } + + #full + get full() { + return this.#full + } + set full(value) { + this.#full = value + } + + + constructor(type = "None", path = "", full = null) { + super() + this.#type = type + this.#path = path + this.#full = full ?? `"${this.type + (this.path ? (`'${this.path}'`) : "")}"` } static createNoneInstance() { - return new ObjectReferenceEntity({ type: "None", path: "" }) + return new ObjectReferenceEntity("None") } getName(dropCounter = false) { @@ -75,6 +73,6 @@ export default class ObjectReferenceEntity extends IEntity { } toString() { - return this._full + return this.full } } diff --git a/js/entity/PathSymbolEntity.js b/js/entity/PathSymbolEntity.js index df60e30..573ef8a 100755 --- a/js/entity/PathSymbolEntity.js +++ b/js/entity/PathSymbolEntity.js @@ -1,29 +1,13 @@ import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" import IEntity from "./IEntity.js" export default class PathSymbolEntity extends IEntity { - static attributes = { - ...super.attributes, - value: new AttributeInfo({ - default: "", - }), - } - static grammar = this.createGrammar() + static grammar = Grammar.symbol.map(v => new this(v)) - static createGrammar() { - return Grammar.symbol.map(v => new this(v)) - } - - constructor(values) { - if (values.constructor !== Object) { - values = { - value: values, - } - } - super(values) - /** @type {String} */ this.value + constructor(value = "") { + super() + this.value = value } valueOf() { @@ -31,6 +15,6 @@ export default class PathSymbolEntity extends IEntity { } toString() { - return this.value + return this.value.toString() } } diff --git a/js/entity/PinEntity.js b/js/entity/PinEntity.js index 54c3b88..d8dbe3f 100755 --- a/js/entity/PinEntity.js +++ b/js/entity/PinEntity.js @@ -2,9 +2,11 @@ import Configuration from "../Configuration.js" import pinColor from "../decoding/pinColor.js" import pinTitle from "../decoding/pinTitle.js" import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" +import AlternativesEntity from "./AlternativesEntity.js" +import ArrayEntity from "./ArrayEntity.js" +import BooleanEntity from "./BooleanEntity.js" import ByteEntity from "./ByteEntity.js" -import ComputedType from "./ComputedType.js" +import ComputedTypeEntity from "./ComputedTypeEntity.js" import EnumDisplayValueEntity from "./EnumDisplayValueEntity.js" import EnumEntity from "./EnumEntity.js" import FormatTextEntity from "./FormatTextEntity.js" @@ -15,6 +17,7 @@ import IntegerEntity from "./IntegerEntity.js" import InvariantTextEntity from "./InvariantTextEntity.js" import LinearColorEntity from "./LinearColorEntity.js" import LocalizedTextEntity from "./LocalizedTextEntity.js" +import NumberEntity from "./NumberEntity.js" import ObjectReferenceEntity from "./ObjectReferenceEntity.js" import PinReferenceEntity from "./PinReferenceEntity.js" import PinTypeEntity from "./PinTypeEntity.js" @@ -24,7 +27,7 @@ import SimpleSerializationRotatorEntity from "./SimpleSerializationRotatorEntity import SimpleSerializationVector2DEntity from "./SimpleSerializationVector2DEntity.js" import SimpleSerializationVector4DEntity from "./SimpleSerializationVector4DEntity.js" import SimpleSerializationVectorEntity from "./SimpleSerializationVectorEntity.js" -import Union from "./Union.js" +import StringEntity from "./StringEntity.js" import Vector2DEntity from "./Vector2DEntity.js" import Vector4DEntity from "./Vector4DEntity.js" import VectorEntity from "./VectorEntity.js" @@ -32,21 +35,22 @@ import VectorEntity from "./VectorEntity.js" /** @template {TerminalAttribute} T */ export default class PinEntity extends IEntity { + static lookbehind = "INVTEXT" static #typeEntityMap = { [Configuration.paths.linearColor]: LinearColorEntity, [Configuration.paths.rotator]: RotatorEntity, [Configuration.paths.vector]: VectorEntity, [Configuration.paths.vector2D]: Vector2DEntity, [Configuration.paths.vector4f]: Vector4DEntity, - "bool": Boolean, + "bool": BooleanEntity, "byte": ByteEntity, "enum": EnumEntity, - "exec": String, + "exec": StringEntity, "int": IntegerEntity, "int64": Integer64Entity, - "name": String, - "real": Number, - "string": String, + "name": StringEntity, + "real": NumberEntity, + "string": StringEntity, } static #alternativeTypeEntityMap = { "enum": EnumDisplayValueEntity, @@ -59,51 +63,36 @@ export default class PinEntity extends IEntity { } static attributes = { ...super.attributes, - lookbehind: new AttributeInfo({ - default: "Pin", - ignored: true, - }), - objectEntity: new AttributeInfo({ - ignored: true, - }), - pinIndex: new AttributeInfo({ - type: Number, - ignored: true, - }), - PinId: new AttributeInfo({ - type: GuidEntity, - default: () => new GuidEntity() - }), - PinName: AttributeInfo.createValue(""), - PinFriendlyName: AttributeInfo.createType(new Union(LocalizedTextEntity, FormatTextEntity, InvariantTextEntity, String)), - PinToolTip: AttributeInfo.createType(String), - Direction: AttributeInfo.createType(String), - PinType: new AttributeInfo({ - type: PinTypeEntity, - default: () => new PinTypeEntity(), - inlined: true, - }), - LinkedTo: AttributeInfo.createType([PinReferenceEntity]), - SubPins: AttributeInfo.createType([PinReferenceEntity]), - ParentPin: AttributeInfo.createType(PinReferenceEntity), - DefaultValue: new AttributeInfo({ - type: new ComputedType( + PinId: GuidEntity.withDefault(), + PinName: StringEntity.withDefault(), + PinFriendlyName: AlternativesEntity.accepting( + LocalizedTextEntity, + FormatTextEntity, + InvariantTextEntity, + StringEntity + ), + PinToolTip: StringEntity, + Direction: StringEntity, + PinType: PinTypeEntity.withDefault().flagInlined(), + LinkedTo: ArrayEntity.of(PinReferenceEntity), + SubPins: ArrayEntity.of(PinReferenceEntity), + ParentPin: PinReferenceEntity, + DefaultValue: + ComputedTypeEntity.from( /** @param {PinEntity} pinEntity */ - pinEntity => pinEntity.getEntityType(true) ?? String - ), - serialized: true, - }), - AutogeneratedDefaultValue: AttributeInfo.createType(String), - DefaultObject: AttributeInfo.createType(ObjectReferenceEntity), - PersistentGuid: AttributeInfo.createType(GuidEntity), - bHidden: AttributeInfo.createValue(false), - bNotConnectable: AttributeInfo.createValue(false), - bDefaultValueIsReadOnly: AttributeInfo.createValue(false), - bDefaultValueIsIgnored: AttributeInfo.createValue(false), - bAdvancedView: AttributeInfo.createValue(false), - bOrphanedPin: AttributeInfo.createValue(false), + pinEntity => pinEntity.getEntityType(true) ?? StringEntity + ).flagSerialized(), + AutogeneratedDefaultValue: StringEntity, + DefaultObject: ObjectReferenceEntity, + PersistentGuid: GuidEntity, + bHidden: BooleanEntity.withDefault(), + bNotConnectable: BooleanEntity.withDefault(), + bDefaultValueIsReadOnly: BooleanEntity.withDefault(), + bDefaultValueIsIgnored: BooleanEntity.withDefault(), + bAdvancedView: BooleanEntity.withDefault(), + bOrphanedPin: BooleanEntity.withDefault(), } - static grammar = this.createGrammar() + static grammar = Grammar.createEntityGrammar(this) #recomputesNodeTitleOnChange = false set recomputesNodeTitleOnChange(value) { @@ -113,12 +102,24 @@ export default class PinEntity extends IEntity { return this.#recomputesNodeTitleOnChange } - static createGrammar() { - return Grammar.createEntityGrammar(this) + #objectEntity + get objectEntity() { + return this.#objectEntity + } + set objectEntity(value) { + this.#objectEntity = value } - constructor(values = {}, suppressWarns = false) { - super(values, suppressWarns) + #pinIndex + get pinIndex() { + return this.#pinIndex + } + set pinIndex(value) { + this.#pinIndex = value + } + + constructor(values = {}) { + super(values) /** @type {ObjectEntity} */ this.objectEntity /** @type {Number} */ this.pinIndex /** @type {GuidEntity} */ this.PinId @@ -142,7 +143,7 @@ export default class PinEntity extends IEntity { /** @param {ObjectEntity} objectEntity */ static fromLegacyObject(objectEntity) { - return new PinEntity(objectEntity, true) + return new PinEntity(objectEntity) } getType() { diff --git a/js/entity/PinReferenceEntity.js b/js/entity/PinReferenceEntity.js index b6dc6ca..b3e9764 100755 --- a/js/entity/PinReferenceEntity.js +++ b/js/entity/PinReferenceEntity.js @@ -1,34 +1,23 @@ -import Parsernostrum from "parsernostrum" +import P from "parsernostrum" import GuidEntity from "./GuidEntity.js" import IEntity from "./IEntity.js" import PathSymbolEntity from "./PathSymbolEntity.js" -import AttributeInfo from "./AttributeInfo.js" export default class PinReferenceEntity extends IEntity { - static attributes = { - ...super.attributes, - objectName: AttributeInfo.createType(PathSymbolEntity), - pinGuid: AttributeInfo.createType(GuidEntity), - } - static grammar = this.createGrammar() + static grammar = P.seq( + PathSymbolEntity.grammar, + P.whitespace, + GuidEntity.grammar + ).map(([objectName, _1, pinGuid]) => new this(objectName, pinGuid)) - static createGrammar() { - return Parsernostrum.seq( - PathSymbolEntity.grammar, - Parsernostrum.whitespace, - GuidEntity.grammar - ).map( - ([objectName, _1, pinGuid]) => new this({ - objectName: objectName, - pinGuid: pinGuid, - }) - ) - } - - constructor(values) { - super(values) - /** @type {PathSymbolEntity} */ this.objectName - /** @type {GuidEntity} */ this.pinGuid + /** + * @param {PathSymbolEntity} objectName + * @param {GuidEntity} pinGuid + */ + constructor(objectName = null, pinGuid = null) { + super() + this.objectName = objectName + this.pinGuid = pinGuid } } diff --git a/js/entity/PinTypeEntity.js b/js/entity/PinTypeEntity.js index 0227342..c94ed78 100755 --- a/js/entity/PinTypeEntity.js +++ b/js/entity/PinTypeEntity.js @@ -1,43 +1,31 @@ import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" +import BooleanEntity from "./BooleanEntity.js" import FunctionReferenceEntity from "./FunctionReferenceEntity.js" import IEntity from "./IEntity.js" import ObjectReferenceEntity from "./ObjectReferenceEntity.js" import PathSymbolEntity from "./PathSymbolEntity.js" +import StringEntity from "./StringEntity.js" export default class PinTypeEntity extends IEntity { static attributes = { ...super.attributes, - PinCategory: AttributeInfo.createValue(""), - PinSubCategory: AttributeInfo.createValue(""), - PinSubCategoryObject: new AttributeInfo({ - type: ObjectReferenceEntity, - default: () => ObjectReferenceEntity.createNoneInstance(), - }), - PinSubCategoryMemberReference: new AttributeInfo({ - type: FunctionReferenceEntity, - default: null, - }), - PinValueType: new AttributeInfo({ - type: PinTypeEntity, - default: null, - }), - ContainerType: AttributeInfo.createType(PathSymbolEntity), - bIsReference: AttributeInfo.createValue(false), - bIsConst: AttributeInfo.createValue(false), - bIsWeakPointer: AttributeInfo.createValue(false), - bIsUObjectWrapper: AttributeInfo.createValue(false), - bSerializeAsSinglePrecisionFloat: AttributeInfo.createValue(false), + PinCategory: StringEntity.withDefault(), + PinSubCategory: StringEntity.withDefault(), + PinSubCategoryObject: ObjectReferenceEntity.withDefault(), + PinSubCategoryMemberReference: FunctionReferenceEntity.withDefault(type => null), + PinValueType: PinTypeEntity.withDefault(), + ContainerType: PathSymbolEntity, + bIsReference: BooleanEntity.withDefault(), + bIsConst: BooleanEntity.withDefault(), + bIsWeakPointer: BooleanEntity.withDefault(), + bIsUObjectWrapper: BooleanEntity.withDefault(), + bSerializeAsSinglePrecisionFloat: BooleanEntity.withDefault(), } - static grammar = this.createGrammar() + static grammar = Grammar.createEntityGrammar(this) - static createGrammar() { - return Grammar.createEntityGrammar(this) - } - - constructor(values = {}, suppressWarns = false) { - super(values, suppressWarns) + constructor(values = {}) { + super(values) /** @type {String} */ this.PinCategory /** @type {String} */ this.PinSubCategory /** @type {ObjectReferenceEntity} */ this.PinSubCategoryObject @@ -54,16 +42,10 @@ export default class PinTypeEntity extends IEntity { /** @param {PinTypeEntity} other */ copyTypeFrom(other) { - this.PinCategory = other.PinCategory - this.PinSubCategory = other.PinSubCategory - this.PinSubCategoryObject = other.PinSubCategoryObject - this.PinSubCategoryMemberReference = other.PinSubCategoryMemberReference - this.PinValueType = other.PinValueType - this.ContainerType = other.ContainerType - this.bIsReference = other.bIsReference - this.bIsConst = other.bIsConst - this.bIsWeakPointer = other.bIsWeakPointer - this.bIsUObjectWrapper = other.bIsUObjectWrapper - this.bSerializeAsSinglePrecisionFloat = other.bSerializeAsSinglePrecisionFloat + for (const key of this.keys) { + if (other[key] !== undefined) { + this[key] = other[key] + } + } } } diff --git a/js/entity/RBSerializationVector2DEntity.js b/js/entity/RBSerializationVector2DEntity.js index 7c9176d..aa42f6d 100644 --- a/js/entity/RBSerializationVector2DEntity.js +++ b/js/entity/RBSerializationVector2DEntity.js @@ -1,21 +1,17 @@ -import Parsernostrum from "parsernostrum" +import P from "parsernostrum" import Vector2DEntity from "./Vector2DEntity.js" export default class RBSerializationVector2DEntity extends Vector2DEntity { - static grammar = this.createGrammar() - - static createGrammar() { - return Parsernostrum.alt( - Parsernostrum.regArray(new RegExp( - /X\s*=\s*/.source + "(?" + Parsernostrum.number.getParser().parser.regexp.source + ")" - + "\\s+" - + /Y\s*=\s*/.source + "(?" + Parsernostrum.number.getParser().parser.regexp.source + ")" - )).map(({ groups: { x, y } }) => new this({ - X: Number(x), - Y: Number(y), - })), - Vector2DEntity.grammar - ) - } + static grammar = P.alt( + P.regArray(new RegExp( + /X\s*=\s*/.source + "(?" + P.number.getParser().parser.regexp.source + ")" + + "\\s+" + + /Y\s*=\s*/.source + "(?" + P.number.getParser().parser.regexp.source + ")" + )).map(({ groups: { x, y } }) => new this({ + X: Number(x), + Y: Number(y), + })), + Vector2DEntity.grammar + ) } diff --git a/js/entity/RotatorEntity.js b/js/entity/RotatorEntity.js index 36746d5..3a9b995 100644 --- a/js/entity/RotatorEntity.js +++ b/js/entity/RotatorEntity.js @@ -1,35 +1,22 @@ import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" import IEntity from "./IEntity.js" +import NumberEntity from "./NumberEntity.js" export default class RotatorEntity extends IEntity { static attributes = { ...super.attributes, - R: new AttributeInfo({ - default: 0, - expected: true, - }), - P: new AttributeInfo({ - default: 0, - expected: true, - }), - Y: new AttributeInfo({ - default: 0, - expected: true, - }), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.createEntityGrammar(this, false) + R: NumberEntity.withDefault(), + P: NumberEntity.withDefault(), + Y: NumberEntity.withDefault(), } + static grammar = Grammar.createEntityGrammar(this, false) constructor(values) { super(values) - /** @type {Number} */ this.R - /** @type {Number} */ this.P - /** @type {Number} */ this.Y + /** @type {NumberEntity} */ this.R + /** @type {NumberEntity} */ this.P + /** @type {NumberEntity} */ this.Y } getRoll() { diff --git a/js/entity/ScriptVariableEntity.js b/js/entity/ScriptVariableEntity.js index a94c152..a6aeeec 100644 --- a/js/entity/ScriptVariableEntity.js +++ b/js/entity/ScriptVariableEntity.js @@ -1,5 +1,4 @@ import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" import GuidEntity from "./GuidEntity.js" import IEntity from "./IEntity.js" import ObjectReferenceEntity from "./ObjectReferenceEntity.js" @@ -8,17 +7,13 @@ export default class ScriptVariableEntity extends IEntity { static attributes = { ...super.attributes, - ScriptVariable: AttributeInfo.createType(ObjectReferenceEntity), - OriginalChangeId: AttributeInfo.createType(GuidEntity), + ScriptVariable: ObjectReferenceEntity, + OriginalChangeId: GuidEntity, } - static grammar = this.createGrammar() + static grammar = Grammar.createEntityGrammar(this) - static createGrammar() { - return Grammar.createEntityGrammar(this) - } - - constructor(values = {}, suppressWarns = false) { - super(values, suppressWarns) + constructor(values = {}) { + super(values) /** @type {ObjectReferenceEntity} */ this.ScriptVariable /** @type {GuidEntity} */ this.OriginalChangeId } diff --git a/js/entity/SimpleSerializationRotatorEntity.js b/js/entity/SimpleSerializationRotatorEntity.js index 34ae923..006482a 100644 --- a/js/entity/SimpleSerializationRotatorEntity.js +++ b/js/entity/SimpleSerializationRotatorEntity.js @@ -1,25 +1,20 @@ -import Parsernostrum from "parsernostrum" +import P from "parsernostrum" import RotatorEntity from "./RotatorEntity.js" export default class SimpleSerializationRotatorEntity extends RotatorEntity { - static grammar = this.createGrammar() - - static createGrammar() { - const number = Parsernostrum.number.getParser().parser.regexp.source - return Parsernostrum.alt( - Parsernostrum.regArray(new RegExp( - "(" + number + ")" - + "\\s*,\\s*" - + "(" + number + ")" - + "\\s*,\\s*" - + "(" + number + ")" - )).map(([_, p, y, r]) => new this({ - R: Number(r), - P: Number(p), - Y: Number(y), - })), - RotatorEntity.grammar - ) - } + static grammar = P.alt( + P.regArray(new RegExp( + `(${P.number.getParser().parser.regexp.source})` + + String.raw`\s*,\s*` + + `(${P.number.getParser().parser.regexp.source})` + + String.raw`\s*,\s*` + + `(${P.number.getParser().parser.regexp.source})` + )).map(([_, p, y, r]) => new this({ + R: Number(r), + P: Number(p), + Y: Number(y), + })), + RotatorEntity.grammar + ) } diff --git a/js/entity/SimpleSerializationVector2DEntity.js b/js/entity/SimpleSerializationVector2DEntity.js index 6b9cdd0..0d4f333 100644 --- a/js/entity/SimpleSerializationVector2DEntity.js +++ b/js/entity/SimpleSerializationVector2DEntity.js @@ -1,22 +1,17 @@ -import Parsernostrum from "parsernostrum" +import P from "parsernostrum" import Vector2DEntity from "./Vector2DEntity.js" export default class SimpleSerializationVector2DEntity extends Vector2DEntity { - static grammar = this.createGrammar() - - static createGrammar() { - const number = Parsernostrum.number.getParser().parser.regexp.source - return Parsernostrum.alt( - Parsernostrum.regArray(new RegExp( - "(" + number + ")" - + "\\s*,\\s*" - + "(" + number + ")" - )).map(([_, x, y]) => new this({ - X: Number(x), - Y: Number(y), - })), - Vector2DEntity.grammar - ) - } + static grammar = P.alt( + P.regArray(new RegExp( + `(${P.number.getParser().parser.regexp.source})` + + String.raw`\s*,\s*` + + `(${P.number.getParser().parser.regexp.source})` + )).map(([_, x, y]) => new this({ + X: Number(x), + Y: Number(y), + })), + Vector2DEntity.grammar + ) } diff --git a/js/entity/SimpleSerializationVector4DEntity.js b/js/entity/SimpleSerializationVector4DEntity.js index 9261426..79f721b 100644 --- a/js/entity/SimpleSerializationVector4DEntity.js +++ b/js/entity/SimpleSerializationVector4DEntity.js @@ -1,4 +1,4 @@ -import Parsernostrum from "parsernostrum" +import P from "parsernostrum" import Vector4DEntity from "./Vector4DEntity.js" export default class SimpleSerializationVector4DEntity extends Vector4DEntity { @@ -6,16 +6,16 @@ export default class SimpleSerializationVector4DEntity extends Vector4DEntity { static grammar = this.createGrammar() static createGrammar() { - const number = Parsernostrum.number.getParser().parser.regexp.source - return Parsernostrum.alt( - Parsernostrum.regArray(new RegExp( - "(" + number + ")" - + "\\s*,\\s*" - + "(" + number + ")" - + "\\s*,\\s*" - + "(" + number + ")" - + "\\s*,\\s*" - + "(" + number + ")" + const number = P.number.getParser().parser.regexp.source + return P.alt( + P.regArray(new RegExp( + `(${P.number.getParser().parser.regexp.source})` + + String.raw`\s*,\s*` + + `(${P.number.getParser().parser.regexp.source})` + + String.raw`\s*,\s*` + + `(${P.number.getParser().parser.regexp.source})` + + String.raw`\s*,\s*` + + `(${P.number.getParser().parser.regexp.source})` )) .map(([_0, x, y, z, w]) => new this({ X: Number(x), diff --git a/js/entity/SimpleSerializationVectorEntity.js b/js/entity/SimpleSerializationVectorEntity.js index 0642df3..8c737f5 100644 --- a/js/entity/SimpleSerializationVectorEntity.js +++ b/js/entity/SimpleSerializationVectorEntity.js @@ -1,26 +1,21 @@ -import Parsernostrum from "parsernostrum" +import P from "parsernostrum" import VectorEntity from "./VectorEntity.js" export default class SimpleSerializationVectorEntity extends VectorEntity { - static grammar = this.createGrammar() - - static createGrammar() { - const number = Parsernostrum.number.getParser().parser.regexp.source - return Parsernostrum.alt( - Parsernostrum.regArray(new RegExp( - "(" + number + ")" - + "\\s*,\\s*" - + "(" + number + ")" - + "\\s*,\\s*" - + "(" + number + ")" - )) - .map(([_0, x, y, z]) => new this({ - X: Number(x), - Y: Number(y), - Z: Number(z), - })), - VectorEntity.grammar - ) - } + static grammar = P.alt( + P.regArray(new RegExp( + `(${P.number.getParser().parser.regexp.source})` + + String.raw`\s*,\s*` + + `(${P.number.getParser().parser.regexp.source})` + + String.raw`\s*,\s*` + + `(${P.number.getParser().parser.regexp.source})` + )) + .map(([_0, x, y, z]) => new this({ + X: Number(x), + Y: Number(y), + Z: Number(z), + })), + VectorEntity.grammar + ) } diff --git a/js/entity/StringEntity.js b/js/entity/StringEntity.js new file mode 100755 index 0000000..fbf7e54 --- /dev/null +++ b/js/entity/StringEntity.js @@ -0,0 +1,22 @@ +import P from "parsernostrum" +import IEntity from "./IEntity.js" +import Utility from "../Utility.js" + +export default class StringEntity extends IEntity { + + static grammar = P.doubleQuotedString.map(insideString => Utility.unescapeString(insideString)) + + /** @param {String} value */ + constructor(value = "") { + super() + this.value = value + } + + valueOf() { + return this.value + } + + toString() { + return this.value.toString() + } +} diff --git a/js/entity/SymbolEntity.js b/js/entity/SymbolEntity.js index fc0fd7e..7986b25 100644 --- a/js/entity/SymbolEntity.js +++ b/js/entity/SymbolEntity.js @@ -1,28 +1,14 @@ import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" import IEntity from "./IEntity.js" export default class SymbolEntity extends IEntity { - static attributes = { - ...super.attributes, - value: AttributeInfo.createValue(""), - } - static grammar = this.createGrammar() + static grammar = Grammar.symbol.map(v => new this(v)) - static createGrammar() { - return Grammar.symbol.map(v => new this(v)) - } - - /** @param {String | Object} values */ - constructor(values) { - if (values.constructor !== Object) { - values = { - value: values, - } - } - super(values) - /** @type {String} */ this.value + /** @param {String} value */ + constructor(value = "") { + super() + this.value = value } valueOf() { diff --git a/js/entity/TerminalTypeEntity.js b/js/entity/TerminalTypeEntity.js index ce206e9..da2b819 100644 --- a/js/entity/TerminalTypeEntity.js +++ b/js/entity/TerminalTypeEntity.js @@ -1,15 +1,16 @@ -import AttributeInfo from "./AttributeInfo.js" +import BooleanEntity from "./BooleanEntity.js" import IEntity from "./IEntity.js" +import StringEntity from "./StringEntity.js" export default class TerminalTypeEntity extends IEntity { static attributes = { ...super.attributes, - TerminalCategory: AttributeInfo.createType(String), - TerminalSubCategory: AttributeInfo.createType(String), - bTerminalIsConst: AttributeInfo.createType(Boolean), - bTerminalIsWeakPointer: AttributeInfo.createType(Boolean), - bTerminalIsUObjectWrapper: AttributeInfo.createType(Boolean), + TerminalCategory: StringEntity, + TerminalSubCategory: StringEntity, + bTerminalIsConst: BooleanEntity, + bTerminalIsWeakPointer: BooleanEntity, + bTerminalIsUObjectWrapper: BooleanEntity, } constructor(values) { diff --git a/js/entity/Union.js b/js/entity/Union.js deleted file mode 100644 index 67db27b..0000000 --- a/js/entity/Union.js +++ /dev/null @@ -1,14 +0,0 @@ -/** @template {any[]} T */ -export default class Union { - - /** @type {T} */ - #values - get values() { - return this.#values - } - - /** @param {T} values */ - constructor(...values) { - this.#values = values - } -} diff --git a/js/entity/UnknownKeysEntity.js b/js/entity/UnknownKeysEntity.js index d1de1b7..0545822 100644 --- a/js/entity/UnknownKeysEntity.js +++ b/js/entity/UnknownKeysEntity.js @@ -1,40 +1,32 @@ -import Parsernostrum from "parsernostrum" +import P from "parsernostrum" import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" import IEntity from "./IEntity.js" export default class UnknownKeysEntity extends IEntity { - static grammar = this.createGrammar() - - static createGrammar() { - return Parsernostrum.seq( - // Lookbehind - Parsernostrum.reg( - new RegExp(`(${Grammar.Regex.Path.source}|${Grammar.Regex.Symbol.source}\\s*)?\\(\\s*`), - 1 - ), - Parsernostrum.seq(Grammar.attributeName, Grammar.equalSeparation).map(([attribute, equal]) => attribute) - .chain(attributeName => - Grammar.unknownValue.map(attributeValue => - values => values[attributeName] = attributeValue - ) + static grammar = P.seq( + // Lookbehind + P.reg(new RegExp(`(${Grammar.Regex.Path.source}|${Grammar.Regex.Symbol.source}\\s*)?\\(\\s*`), 1), + P.seq(Grammar.attributeName, Grammar.equalSeparation).map(([attribute, equal]) => attribute) + .chain(attributeName => + Grammar.unknownValue.map(attributeValue => + values => values[attributeName] = attributeValue ) - .sepBy(Grammar.commaSeparation), - Parsernostrum.reg(/\s*(?:,\s*)?\)/), - ).map(([lookbehind, attributes, _2]) => { - lookbehind ??= "" - let values = {} - if (lookbehind.length) { - values.lookbehind = lookbehind - } - attributes.forEach(attributeSetter => attributeSetter(values)) - return new this(values) - }) - } + ) + .sepBy(Grammar.commaSeparation), + P.reg(/\s*(?:,\s*)?\)/), + ).map(([lookbehind, attributes, _2]) => { + lookbehind ??= "" + let values = {} + if (lookbehind.length) { + values.lookbehind = lookbehind + } + attributes.forEach(attributeSetter => attributeSetter(values)) + return new this(values) + }) - constructor(values) { - super(values, true) + constructor(values = {}) { + super(values) } } diff --git a/js/entity/UnknownPinEntity.js b/js/entity/UnknownPinEntity.js index 1f49d2c..105221f 100755 --- a/js/entity/UnknownPinEntity.js +++ b/js/entity/UnknownPinEntity.js @@ -1,31 +1,20 @@ +import P from "parsernostrum" import Grammar from "../serialization/Grammar.js" -import Parsernostrum from "parsernostrum" import PinEntity from "./PinEntity.js" export default class UnknownPinEntity extends PinEntity { - static grammar = this.createGrammar() - - static createGrammar() { - return Parsernostrum.seq( - Parsernostrum.reg( - new RegExp(`(${Grammar.Regex.Symbol.source})\\s*\\(\\s*`), - 1 - ), - Grammar.createAttributeGrammar(this).sepBy(Grammar.commaSeparation), - Parsernostrum.reg(/\s*(?:,\s*)?\)/) - ).map(([lookbehind, attributes, _2]) => { - lookbehind ??= "" - let values = {} - if (lookbehind.length) { - values.lookbehind = lookbehind - } - attributes.forEach(attributeSetter => attributeSetter(values)) - return new this(values) - }) - } - - constructor(values = {}) { - super(values, true) - } + static grammar = P.seq( + P.reg(new RegExp(`(${Grammar.Regex.Symbol.source})\\s*\\(\\s*`), 1), + Grammar.createAttributeGrammar(this).sepBy(Grammar.commaSeparation), + P.reg(/\s*(?:,\s*)?\)/) + ).map(([lookbehind, attributes, _2]) => { + lookbehind ??= "" + let values = {} + if (lookbehind.length) { + values.lookbehind = lookbehind + } + attributes.forEach(attributeSetter => attributeSetter(values)) + return new this(values) + }) } diff --git a/js/entity/VariableReferenceEntity.js b/js/entity/VariableReferenceEntity.js index 03dd0bc..cb25bb5 100755 --- a/js/entity/VariableReferenceEntity.js +++ b/js/entity/VariableReferenceEntity.js @@ -1,22 +1,19 @@ import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" +import BooleanEntity from "./BooleanEntity.js" import GuidEntity from "./GuidEntity.js" import IEntity from "./IEntity.js" +import StringEntity from "./StringEntity.js" export default class VariableReferenceEntity extends IEntity { static attributes = { ...super.attributes, - MemberScope: AttributeInfo.createType(String), - MemberName: AttributeInfo.createValue(""), - MemberGuid: AttributeInfo.createType(GuidEntity), - bSelfContext: AttributeInfo.createType(Boolean), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.createEntityGrammar(this) + MemberScope: StringEntity, + MemberName: StringEntity.withDefault(), + MemberGuid: GuidEntity, + bSelfContext: BooleanEntity, } + static grammar = Grammar.createEntityGrammar(this) constructor(values) { super(values) diff --git a/js/entity/Vector2DEntity.js b/js/entity/Vector2DEntity.js index 89ac06d..288a2e0 100644 --- a/js/entity/Vector2DEntity.js +++ b/js/entity/Vector2DEntity.js @@ -1,34 +1,24 @@ import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" import IEntity from "./IEntity.js" +import NumberEntity from "./NumberEntity.js" export default class Vector2DEntity extends IEntity { static attributes = { ...super.attributes, - X: new AttributeInfo({ - default: 0, - expected: true, - }), - Y: new AttributeInfo({ - default: 0, - expected: true, - }), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.createEntityGrammar(this, false) + X: NumberEntity.withDefault(), + Y: NumberEntity.withDefault(), } + static grammar = Grammar.createEntityGrammar(this, false) constructor(values) { super(values) - /** @type {Number} */ this.X - /** @type {Number} */ this.Y + /** @type {NumberEntity} */ this.X + /** @type {NumberEntity} */ this.Y } /** @returns {[Number, Number]} */ toArray() { - return [this.X, this.Y] + return [this.X.valueOf(), this.Y.valueOf()] } } diff --git a/js/entity/Vector4DEntity.js b/js/entity/Vector4DEntity.js index 6fa899f..0cda8e0 100644 --- a/js/entity/Vector4DEntity.js +++ b/js/entity/Vector4DEntity.js @@ -1,44 +1,28 @@ import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" import IEntity from "./IEntity.js" +import NumberEntity from "./NumberEntity.js" export default class Vector4DEntity extends IEntity { static attributes = { ...super.attributes, - X: new AttributeInfo({ - default: 0, - expected: true, - }), - Y: new AttributeInfo({ - default: 0, - expected: true, - }), - Z: new AttributeInfo({ - default: 0, - expected: true, - }), - W: new AttributeInfo({ - default: 0, - expected: true, - }), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.createEntityGrammar(Vector4DEntity, false) + X: NumberEntity.withDefault(), + Y: NumberEntity.withDefault(), + Z: NumberEntity.withDefault(), + W: NumberEntity.withDefault(), } + static grammar = Grammar.createEntityGrammar(Vector4DEntity, false) constructor(values) { super(values) - /** @type {Number} */ this.X - /** @type {Number} */ this.Y - /** @type {Number} */ this.Z - /** @type {Number} */ this.W + /** @type {NumberEntity} */ this.X + /** @type {NumberEntity} */ this.Y + /** @type {NumberEntity} */ this.Z + /** @type {NumberEntity} */ this.W } /** @returns {[Number, Number, Number, Number]} */ toArray() { - return [this.X, this.Y, this.Z, this.W] + return [this.X.valueOf(), this.Y.valueOf(), this.Z.valueOf(), this.W.valueOf()] } } diff --git a/js/entity/VectorEntity.js b/js/entity/VectorEntity.js index 8be55f9..e01a9b2 100644 --- a/js/entity/VectorEntity.js +++ b/js/entity/VectorEntity.js @@ -1,39 +1,26 @@ import Grammar from "../serialization/Grammar.js" -import AttributeInfo from "./AttributeInfo.js" import IEntity from "./IEntity.js" +import NumberEntity from "./NumberEntity.js" export default class VectorEntity extends IEntity { static attributes = { ...super.attributes, - X: new AttributeInfo({ - default: 0, - expected: true, - }), - Y: new AttributeInfo({ - default: 0, - expected: true, - }), - Z: new AttributeInfo({ - default: 0, - expected: true, - }), - } - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.createEntityGrammar(VectorEntity, false) + X: NumberEntity.withDefault(), + Y: NumberEntity.withDefault(), + Z: NumberEntity.withDefault(), } + static grammar = Grammar.createEntityGrammar(VectorEntity, false) constructor(values) { super(values) - /** @type {Number} */ this.X - /** @type {Number} */ this.Y - /** @type {Number} */ this.Z + /** @type {NumberEntity} */ this.X + /** @type {NumberEntity} */ this.Y + /** @type {NumberEntity} */ this.Z } /** @returns {[Number, Number, Number]} */ toArray() { - return [this.X, this.Y, this.Z] + return [this.X.valueOf(), this.Y.valueOf(), this.Z.valueOf()] } } diff --git a/js/entity/objects/KnotEntity.js b/js/entity/objects/KnotEntity.js index b159691..a45e0c0 100644 --- a/js/entity/objects/KnotEntity.js +++ b/js/entity/objects/KnotEntity.js @@ -14,20 +14,18 @@ export default class KnotEntity extends ObjectEntity { values.Name = "K2Node_Knot" const inputPinEntity = new PinEntity( { PinName: "InputPin" }, - true ) const outputPinEntity = new PinEntity( { PinName: "OutputPin", Direction: "EGPD_Output", }, - true ) if (pinReferenceForType) { inputPinEntity.copyTypeFrom(pinReferenceForType) outputPinEntity.copyTypeFrom(pinReferenceForType) } values["CustomProperties"] = [inputPinEntity, outputPinEntity] - super(values, true) + super(values) } } diff --git a/js/serialization/Grammar.js b/js/serialization/Grammar.js index abc5263..1485d95 100755 --- a/js/serialization/Grammar.js +++ b/js/serialization/Grammar.js @@ -4,7 +4,6 @@ import Utility from "../Utility.js" import AttributeInfo from "../entity/AttributeInfo.js" import IEntity from "../entity/IEntity.js" import MirroredEntity from "../entity/MirroredEntity.js" -import Union from "../entity/Union.js" import Serializable from "./Serializable.js" export default class Grammar { @@ -36,7 +35,6 @@ export default class Grammar { static null = Parsernostrum.reg(/\(\s*\)/).map(() => null) static true = Parsernostrum.reg(/true/i).map(() => true) static false = Parsernostrum.reg(/false/i).map(() => false) - static boolean = Parsernostrum.regArray(/(true)|false/i).map(v => v[1] ? true : false) static number = Parsernostrum.regArray( new RegExp(`(${Parsernostrum.number.getParser().parser.regexp.source})|(\\+?inf)|(-inf)`) ).map(([_0, n, plusInf, minusInf]) => n ? Number(n) : plusInf ? Number.POSITIVE_INFINITY : Number.NEGATIVE_INFINITY) diff --git a/js/serialization/Serializable.js b/js/serialization/Serializable.js index 6da54c4..5a6b777 100644 --- a/js/serialization/Serializable.js +++ b/js/serialization/Serializable.js @@ -2,10 +2,6 @@ import Parsernostrum from "parsernostrum" export default class Serializable { - static grammar = this.createGrammar() - - /** @protected */ - static createGrammar() { - return /** @type {Parsernostrum} */(Parsernostrum.failure()) - } + /** @type {Parsernostrum} */ + static grammar = Parsernostrum.failure() } diff --git a/js/serialization/initializeSerializerFactory.js b/js/serialization/initializeSerializerFactory.js index 1f2770e..323fbd0 100755 --- a/js/serialization/initializeSerializerFactory.js +++ b/js/serialization/initializeSerializerFactory.js @@ -32,7 +32,6 @@ import SimpleSerializationVector4DEntity from "../entity/SimpleSerializationVect import SimpleSerializationVectorEntity from "../entity/SimpleSerializationVectorEntity.js" import SymbolEntity from "../entity/SymbolEntity.js" import TerminalTypeEntity from "../entity/TerminalTypeEntity.js" -import Union from "../entity/Union.js" import UnknownKeysEntity from "../entity/UnknownKeysEntity.js" import VariableReferenceEntity from "../entity/VariableReferenceEntity.js" import Vector2DEntity from "../entity/Vector2DEntity.js" @@ -44,17 +43,22 @@ import ObjectSerializer from "./ObjectSerializer.js" import Serializer from "./Serializer.js" import SerializerFactory from "./SerializerFactory.js" import ToStringSerializer from "./ToStringSerializer.js" +import BooleanEntity from "../entity/BooleanEntity.js" +import NumberEntity from "../entity/NumberEntity.js" +import StringEntity from "../entity/StringEntity.js" +import ArrayEntity from "../entity/ArrayEntity.js" +import AlternativesEntity from "../entity/AlternativesEntity.js" Grammar.unknownValue = Parsernostrum.alt( // Remember to keep the order, otherwise parsing might fail - Grammar.boolean, + BooleanEntity.grammar, GuidEntity.grammar, - Parsernostrum.str("None").map(() => new ObjectReferenceEntity({ type: "None" })), + Parsernostrum.str("None").map(() => ObjectReferenceEntity.createNoneInstance()), Grammar.null, - Grammar.number, + NumberEntity.grammar, ObjectReferenceEntity.fullReferenceGrammar, - Grammar.string, + StringEntity.grammar, LocalizedTextEntity.grammar, InvariantTextEntity.grammar, FormatTextEntity.grammar, @@ -66,9 +70,9 @@ Grammar.unknownValue = Vector2DEntity.grammar, UnknownKeysEntity.grammar, SymbolEntity.grammar, - Grammar.grammarFor(undefined, [PinReferenceEntity]), - Grammar.grammarFor(undefined, [new Union(Number, String, SymbolEntity)]), - Parsernostrum.lazy(() => Grammar.grammarFor(undefined, [undefined])), + ArrayEntity.of(PinReferenceEntity).grammar, + ArrayEntity.of(AlternativesEntity.accepting(NumberEntity, StringEntity, SymbolEntity)).grammar, + Parsernostrum.lazy(() => ArrayEntity.createGrammar(Grammar.unknownValue)), ) export default function initializeSerializerFactory() { @@ -202,7 +206,7 @@ export default function initializeSerializerFactory() { new Serializer(MacroGraphReferenceEntity, Serializer.bracketsWrapped) ) - SerializerFactory.registerSerializer( + SerializerFactory.registeOrSerializer( MirroredEntity, new CustomSerializer( (v, insideString) => SerializerFactory.getSerializer(v.getTargetType()).write(v.get(), insideString), diff --git a/tests/entities.spec.js b/tests/entities.spec.js index c4afe83..53e65ca 100644 --- a/tests/entities.spec.js +++ b/tests/entities.spec.js @@ -1,5 +1,6 @@ // @ts-nocheck +import NumberEntity from "../js/entity/NumberEntity.js" import UnknownKeysEntity from "../js/entity/UnknownKeysEntity.js" import Grammar from "../js/serialization/Grammar.js" import ObjectSerializer from "../js/serialization/ObjectSerializer.js" @@ -104,8 +105,8 @@ test("Entity3", () => { ) expect(Object.keys(entity)).toHaveLength(keys.length) expect(Object.keys(entity)).toStrictEqual(keys) - expect(entity.alpha).toBe(32) - expect(entity.bravo).toBe(78) + expect(entity.alpha).toEqual(new NumberEntity(32)) + expect(entity.bravo).toBe(new NumberEntity(78)) expect(entity.charlie).toBe("Charlie") expect(entity.delta).toBeNull() expect(entity.echo).toBe("echo") @@ -116,28 +117,10 @@ test("Entity3", () => { expect(entity.juliett).toStrictEqual(["a", "b", "c", "d", "e"]) expect(entity.kilo).toStrictEqual([true, false, false, true, true]) expect(entity.mike).toBe("Bar") - expect(entity.november).toBe(0) + expect(entity.november).toBe(new NumberEntity()) expect(entity.oscar).toStrictEqual(new Entity1({ a: 8, b: 9 })) expect(entity.papa).toStrictEqual(new Entity1({ a: 12, b: 13 })) - expect(entity.quebec).toBeUndefined() - entity = new Entity3() - entity.quebec = 2 - expect(entity.quebec).toBe(2) - entity["quebec"] = 7 - expect(entity.quebec).toBe(7) - entity.quebec = 1 - expect(entity.quebec).toBe(1) - entity["quebec"] = 10 - expect(entity.quebec).toBe(10) - entity.quebec = 0 - expect(entity.quebec).toBe(10) - entity["quebec"] = 11 - expect(entity.quebec).toBe(10) - entity.quebec = -1 - expect(entity.quebec).toBe(10) - entity.quebec = 6 - expect(entity.quebec).toBe(6) expect(SerializerFactory.getSerializer(Entity3).write(entity)).toBe(entity3Value) expect(Grammar.getAttribute(Entity3, ["romeo", "b"]).type).toBe(Number) diff --git a/tests/parsing.spec.js b/tests/parsing.spec.js index bedf38a..a92f386 100644 --- a/tests/parsing.spec.js +++ b/tests/parsing.spec.js @@ -478,7 +478,7 @@ test("UnknownKeysValue", () => { expect(parser.parse("(1,2,3,4,5,6,7,8,9)")).toStrictEqual([1, 2, 3, 4, 5, 6, 7, 8, 9]) expect(parser.parse(`( "Hello", "World", )`)).toStrictEqual(["Hello", "World"]) expect(parser.parse(`( "Alpha", 123, Beta, "Gamma", "Delta", 99 )`)) - .toStrictEqual(["Alpha", 123, new SymbolEntity({ value: "Beta" }), "Gamma", "Delta", 99]) + .toStrictEqual(["Alpha", 123, new SymbolEntity("Beta"), "Gamma", "Delta", 99]) }) test("UnknownKeysEntity", () => { diff --git a/tests/resources/Entity1.js b/tests/resources/Entity1.js index eeee542..64b1e7d 100644 --- a/tests/resources/Entity1.js +++ b/tests/resources/Entity1.js @@ -1,17 +1,11 @@ -import AttributeInfo from "../../js/entity/AttributeInfo.js" import IEntity from "../../js/entity/IEntity.js" +import NumberEntity from "../../js/entity/NumberEntity.js" export default class Entity1 extends IEntity { static attributes = { - a: new AttributeInfo({ - type: Number, - default: 8, - }), - b: new AttributeInfo({ - type: Number, - default: 9, - }), + a: NumberEntity.withDefault(type => new type(8)), + b: NumberEntity.withDefault(type => new type(9)), } constructor(values = {}) { diff --git a/tests/resources/Entity2.js b/tests/resources/Entity2.js index fcfa340..beaad2f 100644 --- a/tests/resources/Entity2.js +++ b/tests/resources/Entity2.js @@ -1,21 +1,33 @@ -import AttributeInfo from "../../js/entity/AttributeInfo.js" +import ArrayEntity from "../../js/entity/ArrayEntity.js" +import BooleanEntity from "../../js/entity/BooleanEntity.js" import IEntity from "../../js/entity/IEntity.js" +import NumberEntity from "../../js/entity/NumberEntity.js" +import StringEntity from "../../js/entity/StringEntity.js" import Entity1 from "./Entity1.js" export default class Entity2 extends IEntity { static attributes = { - someNumber: AttributeInfo.createValue(567), - someString: AttributeInfo.createValue("alpha"), - someString2: AttributeInfo.createValue("beta"), - someBoolean: AttributeInfo.createValue(true), - someBoolean2: AttributeInfo.createValue(false), - someObjectString: AttributeInfo.createValue("gamma"), - someArray: AttributeInfo.createValue([400, 500, 600, 700, 800]), - someArray2: AttributeInfo.createValue(() => [400, 500, 600, 700, 800]), - someEntity: new AttributeInfo({ - type: Entity1, - default: new Entity1() - }), + someNumber: NumberEntity.withDefault(type => new type(567)), + someString: StringEntity.withDefault(type => new type("alpha")), + someString2: StringEntity.withDefault(type => new type("beta")), + someBoolean: BooleanEntity.withDefault(type => new type(true)), + someBoolean2: BooleanEntity.withDefault(), + someObjectString: StringEntity.withDefault(type => new type("gamma")), + someArray: ArrayEntity.of(NumberEntity).withDefault(type => new type([ + new NumberEntity(400), + new NumberEntity(500), + new NumberEntity(600), + new NumberEntity(700), + new NumberEntity(800), + ])), + someArray2: ArrayEntity.of(NumberEntity).withDefault(type => new type([ + new NumberEntity(400), + new NumberEntity(500), + new NumberEntity(600), + new NumberEntity(700), + new NumberEntity(800), + ])).flagInlined(), + someEntity: Entity1.withDefault(), } } diff --git a/tests/resources/Entity3.js b/tests/resources/Entity3.js index 2aa95b0..60e0702 100644 --- a/tests/resources/Entity3.js +++ b/tests/resources/Entity3.js @@ -1,74 +1,45 @@ -import AttributeInfo from "../../js/entity/AttributeInfo.js" +import AlternativesEntity from "../../js/entity/AlternativesEntity.js" +import ArrayEntity from "../../js/entity/ArrayEntity.js" +import BooleanEntity from "../../js/entity/BooleanEntity.js" import IEntity from "../../js/entity/IEntity.js" -import Union from "../../js/entity/Union.js" +import NumberEntity from "../../js/entity/NumberEntity.js" +import StringEntity from "../../js/entity/StringEntity.js" import Entity1 from "./Entity1.js" import Entity2 from "./Entity2.js" export default class Entity3 extends IEntity { static attributes = { - alpha: AttributeInfo.createValue(32), - bravo: new AttributeInfo({ - type: Number, - default: 78, - }), - charlie: new AttributeInfo({ - type: String, - default: "Charlie", - }), - delta: new AttributeInfo({ - type: String, - default: null, - }), - echo: AttributeInfo.createValue("echo"), - foxtrot: AttributeInfo.createValue(false), - golf: AttributeInfo.createValue([]), - hotel: new AttributeInfo({ - type: Array, - default: null, - }), - india: new AttributeInfo({ - type: [Number], - default: () => [], - }), - juliett: new AttributeInfo({ - type: [String], - default: ["a", "b", "c", "d", "e"], - }), - kilo: new AttributeInfo({ - type: [Boolean], - default: () => [true, false, false, true, true], - }), - lima: AttributeInfo.createType(String), - mike: new AttributeInfo({ - type: new Union(Number, String, Array), - default: "Bar", - }), - november: new AttributeInfo({ - type: new Union(Number, String, Array), - default: 0, - }), - oscar: new AttributeInfo({ - type: Entity1, - default: () => new Entity1() - }), - papa: new AttributeInfo({ - type: Entity1, - default: () => new Entity1({ a: 12, b: 13 }), - }), - quebec: new AttributeInfo({ - default: 0, // will assign undefined because it does not satisfy the predicate - predicate: v => v >= 1 && v <= 10, - }), - romeo: new AttributeInfo({ - type: Entity1, - default: new Entity1(), - inlined: true, - }), - sierra: new AttributeInfo({ - type: Entity2, - default: new Entity2(), - inlined: true, - }), + alpha: NumberEntity.withDefault(type => new type(32)), + bravo: NumberEntity.withDefault(type => new type(78)), + charlie: StringEntity.withDefault(type => new type("Charlie")), + delta: StringEntity.withDefault(type => null), + echo: StringEntity.withDefault(type => new type("echo")), + foxtrot: BooleanEntity.withDefault(), + golf: ArrayEntity.of(StringEntity).withDefault(), + hotel: ArrayEntity.of(NumberEntity).withDefault(() => null), + india: ArrayEntity.of(NumberEntity).withDefault(), + juliett: ArrayEntity.of(StringEntity).withDefault(type => new type([ + new StringEntity("a"), + new StringEntity("b"), + new StringEntity("c"), + new StringEntity("d"), + new StringEntity("e"), + ])), + kilo: ArrayEntity.of(BooleanEntity).withDefault(type => new type([ + new BooleanEntity(true), + new BooleanEntity(), + new BooleanEntity(), + new BooleanEntity(true), + new BooleanEntity(true), + ])), + lima: StringEntity, + mike: AlternativesEntity.accepting(NumberEntity, StringEntity, ArrayEntity).withDefault(type => new StringEntity("Bar")), + november: AlternativesEntity.accepting(NumberEntity, StringEntity, ArrayEntity).withDefault(type => new NumberEntity(0)), + oscar: Entity1.withDefault(() => new Entity1()), + papa: Entity1.withDefault(() => new Entity1({ a: 12, b: 13 })), + quebec: NumberEntity.withDefault(), // will assign undefined because it does not satisfy the predicate, + romeo: Entity1.withDefault().flagInlined(), + sierra: Entity2.withDefault().flagInlined(), } } diff --git a/tests/resources/IssuesNodes1.js b/tests/resources/IssuesNodes1.js index e20e818..44149ea 100644 --- a/tests/resources/IssuesNodes1.js +++ b/tests/resources/IssuesNodes1.js @@ -44,7 +44,93 @@ export default class IssuesNodes1 extends NodeTests { const relevantPins = (await Promise.all( pins.map(async p => { const innerText = await p.innerText() - // @ts-expect-error + return [Configuration.rgba.includes(innerText), p] + }) + )) + .filter(([flag, value]) => flag) + .map(([flag, value]) => /** @type {Locator} */(value)) + expect(await Promise.all(relevantPins.map(async pin => await pin.innerText()))).toStrictEqual(Configuration.rgba) + for (const p of relevantPins) { + const pinName = await p.innerText() + expect(p.locator('input[type="checkbox"]')).toBeChecked({ checked: pinName === "R" }) + } + await relevantPins[0].locator('input[type="checkbox"]').uncheck() // Uncheck "R" + await relevantPins[2].locator('input[type="checkbox"]').check() // Check "B" + await relevantPins[3].locator('input[type="checkbox"]').check() // Check "A" + await relevantPins[2].locator('input[type="checkbox"]').uncheck() // Uncheck "B" + await relevantPins[2].locator('input[type="checkbox"]').check() // Check "B" + expect(node.locator(".ueb-node-name")).toHaveText("Mask ( B A )") + const resultSerialization = await blueprintPage.blueprintLocator.evaluate(blueprint => { + blueprint.selectAll() + return blueprint.template.getCopyInputObject().getSerializedText() + }) + const expectedSerialization = String.raw` + Begin Object Class=/Script/UnrealEd.MaterialGraphNode Name="MaterialGraphNode_37" ExportPath="/Script/UnrealEd.MaterialGraphNode'/Engine/Transient.NewMaterial:MaterialGraph_0.MaterialGraphNode_37'" + Begin Object Class=/Script/Engine.MaterialExpressionComponentMask Name="MaterialExpressionComponentMask_0" ExportPath="/Script/Engine.MaterialExpressionComponentMask'/Engine/Transient.NewMaterial:MaterialGraph_0.MaterialGraphNode_37.MaterialExpressionComponentMask_0'" + End Object + Begin Object Name="MaterialExpressionComponentMask_0" ExportPath="/Script/Engine.MaterialExpressionComponentMask'/Engine/Transient.NewMaterial:MaterialGraph_0.MaterialGraphNode_37.MaterialExpressionComponentMask_0'" + B=True + A=True + MaterialExpressionEditorX=-544 + MaterialExpressionEditorY=32 + MaterialExpressionGuid=8EFA535CAE3A4DAF9DAE27B200E06EDC + Material="/Script/UnrealEd.PreviewMaterial'/Engine/Transient.NewMaterial'" + End Object + MaterialExpression="/Script/Engine.MaterialExpressionComponentMask'MaterialExpressionComponentMask_0'" + NodePosX=-544 + NodePosY=32 + AdvancedPinDisplay=Shown + NodeGuid=54A40610EEC646A0954F310727D1B888 + CustomProperties Pin (PinId=DC3859AB4C8C12645EEA1AA4E500A637,PinName="Input",PinFriendlyName=NSLOCTEXT("MaterialGraphNode", "Space", " "),PinType.PinCategory="required",PinType.PinSubCategory="",PinType.PinSubCategoryObject=None,PinType.PinSubCategoryMemberReference=(),PinType.PinValueType=(),PinType.ContainerType=None,PinType.bIsReference=False,PinType.bIsConst=False,PinType.bIsWeakPointer=False,PinType.bIsUObjectWrapper=False,PinType.bSerializeAsSinglePrecisionFloat=False,PersistentGuid=00000000000000000000000000000000,bHidden=False,bNotConnectable=False,bDefaultValueIsReadOnly=False,bDefaultValueIsIgnored=False,bAdvancedView=False,bOrphanedPin=False,) + CustomProperties Pin (PinId=D5C8F4DF4AFE5EEB605ED382CD5744DE,PinName="R",PinType.PinCategory="optional",PinType.PinSubCategory="bool",PinType.PinSubCategoryObject=None,PinType.PinSubCategoryMemberReference=(),PinType.PinValueType=(),PinType.ContainerType=None,PinType.bIsReference=False,PinType.bIsConst=False,PinType.bIsWeakPointer=False,PinType.bIsUObjectWrapper=False,PinType.bSerializeAsSinglePrecisionFloat=False,DefaultValue="false",PersistentGuid=00000000000000000000000000000000,bHidden=False,bNotConnectable=True,bDefaultValueIsReadOnly=False,bDefaultValueIsIgnored=False,bAdvancedView=True,bOrphanedPin=False,) + CustomProperties Pin (PinId=7E43455B4D2232C4E99BB098631CAFCE,PinName="G",PinType.PinCategory="optional",PinType.PinSubCategory="bool",PinType.PinSubCategoryObject=None,PinType.PinSubCategoryMemberReference=(),PinType.PinValueType=(),PinType.ContainerType=None,PinType.bIsReference=False,PinType.bIsConst=False,PinType.bIsWeakPointer=False,PinType.bIsUObjectWrapper=False,PinType.bSerializeAsSinglePrecisionFloat=False,DefaultValue="false",PersistentGuid=00000000000000000000000000000000,bHidden=False,bNotConnectable=True,bDefaultValueIsReadOnly=False,bDefaultValueIsIgnored=False,bAdvancedView=True,bOrphanedPin=False,) + CustomProperties Pin (PinId=46CEC6754365CB39F9FC39944B40D5C6,PinName="B",PinType.PinCategory="optional",PinType.PinSubCategory="bool",PinType.PinSubCategoryObject=None,PinType.PinSubCategoryMemberReference=(),PinType.PinValueType=(),PinType.ContainerType=None,PinType.bIsReference=False,PinType.bIsConst=False,PinType.bIsWeakPointer=False,PinType.bIsUObjectWrapper=False,PinType.bSerializeAsSinglePrecisionFloat=False,DefaultValue="true",PersistentGuid=00000000000000000000000000000000,bHidden=False,bNotConnectable=True,bDefaultValueIsReadOnly=False,bDefaultValueIsIgnored=False,bAdvancedView=True,bOrphanedPin=False,) + CustomProperties Pin (PinId=F658E76C400B0AF242DFE292C92702C8,PinName="A",PinType.PinCategory="optional",PinType.PinSubCategory="bool",PinType.PinSubCategoryObject=None,PinType.PinSubCategoryMemberReference=(),PinType.PinValueType=(),PinType.ContainerType=None,PinType.bIsReference=False,PinType.bIsConst=False,PinType.bIsWeakPointer=False,PinType.bIsUObjectWrapper=False,PinType.bSerializeAsSinglePrecisionFloat=False,DefaultValue="true",PersistentGuid=00000000000000000000000000000000,bHidden=False,bNotConnectable=True,bDefaultValueIsReadOnly=False,bDefaultValueIsIgnored=False,bAdvancedView=True,bOrphanedPin=False,) + CustomProperties Pin (PinId=2EC8C8234D570AB2A03DB59A1FF65987,PinName="Output",PinFriendlyName=NSLOCTEXT("MaterialGraphNode", "Space", " "),Direction="EGPD_Output",PinType.PinCategory="",PinType.PinSubCategory="",PinType.PinSubCategoryObject=None,PinType.PinSubCategoryMemberReference=(),PinType.PinValueType=(),PinType.ContainerType=None,PinType.bIsReference=False,PinType.bIsConst=False,PinType.bIsWeakPointer=False,PinType.bIsUObjectWrapper=False,PinType.bSerializeAsSinglePrecisionFloat=False,PersistentGuid=00000000000000000000000000000000,bHidden=False,bNotConnectable=False,bDefaultValueIsReadOnly=False,bDefaultValueIsIgnored=False,bAdvancedView=False,bOrphanedPin=False,) + End Object + ` + const words = expectedSerialization + .split("\n") + .map(row => row.match(/\s*("?\w+(\s+\w+)*).+/)?.[1]) + .filter(v => v?.length > 0) + expect(resultSerialization).toMatch(Utility.getFirstWordOrder(words)) + } + }, + { + name: "Issue 21", + title: "Mask ( R )", + value: String.raw` + Begin Object Class=/Script/UnrealEd.MaterialGraphNode Name="MaterialGraphNode_202" ExportPath=/Script/UnrealEd.MaterialGraphNode'/Engine/Transient.卡通:MaterialGraph_0.MaterialGraphNode_202' + Begin Object Class=/Script/Engine.MaterialExpressionSubtract Name="MaterialExpressionSubtract_10" ExportPath=/Script/Engine.MaterialExpressionSubtract'/Engine/Transient.卡通:MaterialGraph_0.MaterialGraphNode_202.MaterialExpressionSubtract_10' + End Object + Begin Object Name="MaterialExpressionSubtract_10" ExportPath=/Script/Engine.MaterialExpressionSubtract'/Engine/Transient.卡通:MaterialGraph_0.MaterialGraphNode_202.MaterialExpressionSubtract_10' + A=(Expression="/Script/Engine.MaterialExpressionSaturate'MaterialGraphNode_237.MaterialExpressionSaturate_3'") + B=(Expression="/Script/Engine.MaterialExpressionSaturate'MaterialGraphNode_201.MaterialExpressionSaturate_7'") + MaterialExpressionEditorX=0 + MaterialExpressionEditorY=0 + MaterialExpressionGuid=7202C13642DA1225C118CF867599387C + Material="/Script/UnrealEd.PreviewMaterial'/Engine/Transient.卡通'" + End Object + MaterialExpression=/Script/Engine.MaterialExpressionSubtract'MaterialExpressionSubtract_10' + NodePosX=0 + NodePosY=0 + NodeGuid=7008F5AC49E8F5BFD4C707819A58C021 + CustomProperties Pin (PinId=86D4DE5E48C71A576ED0519B982907B3,PinName="A",PinType.PinCategory="optional",PinType.PinSubCategory="red",PinType.PinSubCategoryObject=None,PinType.PinSubCategoryMemberReference=(),PinType.PinValueType=(),PinType.ContainerType=None,PinType.bIsReference=False,PinType.bIsConst=False,PinType.bIsWeakPointer=False,PinType.bIsUObjectWrapper=False,PinType.bSerializeAsSinglePrecisionFloat=False,DefaultValue="1",LinkedTo=(),PersistentGuid=00000000000000000000000000000000,bHidden=False,bNotConnectable=False,bDefaultValueIsReadOnly=False,bDefaultValueIsIgnored=False,bAdvancedView=False,bOrphanedPin=False,) + CustomProperties Pin (PinId=5C75E1374E1E7436C72B9FA072875C04,PinName="B",PinType.PinCategory="optional",PinType.PinSubCategory="red",PinType.PinSubCategoryObject=None,PinType.PinSubCategoryMemberReference=(),PinType.PinValueType=(),PinType.ContainerType=None,PinType.bIsReference=False,PinType.bIsConst=False,PinType.bIsWeakPointer=False,PinType.bIsUObjectWrapper=False,PinType.bSerializeAsSinglePrecisionFloat=False,DefaultValue="1",LinkedTo=(),PersistentGuid=00000000000000000000000000000000,bHidden=False,bNotConnectable=False,bDefaultValueIsReadOnly=False,bDefaultValueIsIgnored=False,bAdvancedView=False,bOrphanedPin=False,) + CustomProperties Pin (PinId=528D346A49976B0854764CA755AF2F93,PinName="Output",PinFriendlyName=NSLOCTEXT("MaterialGraphNode", "Space", " "),Direction="EGPD_Output",PinType.PinCategory="",PinType.PinSubCategory="",PinType.PinSubCategoryObject=None,PinType.PinSubCategoryMemberReference=(),PinType.PinValueType=(),PinType.ContainerType=None,PinType.bIsReference=False,PinType.bIsConst=False,PinType.bIsWeakPointer=False,PinType.bIsUObjectWrapper=False,PinType.bSerializeAsSinglePrecisionFloat=False,LinkedTo=(),PersistentGuid=00000000000000000000000000000000,bHidden=False,bNotConnectable=False,bDefaultValueIsReadOnly=False,bDefaultValueIsIgnored=False,bAdvancedView=False,bOrphanedPin=False,) + End Object + `, + size: [7, 14.5], + color: Configuration.nodeColors.green, + icon: null, + pins: 6, + pinNames: Configuration.rgba, + delegate: false, + development: false, + additionalTest: async (node, pins, blueprintPage) => { + const relevantPins = (await Promise.all( + pins.map(async p => { + const innerText = await p.innerText() return [Configuration.rgba.includes(innerText), p] }) )) diff --git a/types.js b/types.js index 37c3911..a729bad 100644 --- a/types.js +++ b/types.js @@ -1,6 +1,6 @@ /** * @template T - * @typedef {new (...args: any) => T} AnyConstructor + * @typedef {abstract new (...args: any) => T} AnyConstructor */ /** * @template {Attribute} T @@ -76,8 +76,6 @@ * ? DescribedType[] * : T extends MirroredEntity * ? DescribedType - * : T extends Union - * ? DescribedTypesFromArray * : T * } DescribedType */ @@ -98,10 +96,6 @@ * (value: T): typeof value.constructor, * }} TypeGetter */ -/** - * @template {any[]} T - * @typedef {import("./js/entity/Union.js").default} Union - */ /** * @typedef {typeof import("./js/Blueprint.js").default} BlueprintConstructor * @typedef {typeof import("./js/element/LinkElement.js").default} LinkElementConstructor @@ -112,6 +106,7 @@ * @typedef {typeof import("./js/entity/ObjectEntity.js").default} ObjectEntityConstructor */ /** + * @typedef {import ("./tests/fixtures/BlueprintFixture.js").default} BlueprintFixture * @typedef {import("./js/Blueprint.js").default} Blueprint * @typedef {import("./js/element/ColorHandlerElement.js").default} ColorHandlerElement * @typedef {import("./js/element/ColorSliderElement.js").default} ColorSliderElement @@ -130,7 +125,7 @@ * @typedef {import("./js/element/WindowElement.js").default} WindowElement * @typedef {import("./js/entity/ByteEntity.js").default} ByteEntity * @typedef {import("./js/entity/ColorChannelEntity.js").default} ColorChannelEntity - * @typedef {import("./js/entity/ComputedType.js").default} ComputedType + * @typedef {import("./js/entity/ComputedTypeEntity.js").default} ComputedTypeEntity * @typedef {import("./js/entity/EnumDisplayValueEntity.js").default} EnumDisplayValueEntity * @typedef {import("./js/entity/EnumEntity.js").default} EnumEntity * @typedef {import("./js/entity/FormatTextEntity.js").default} FormatTextEntity @@ -209,10 +204,10 @@ * @typedef {import("./js/template/SelectorTemplate.js").default} SelectorTemplate * @typedef {import("./js/template/window/ColorPickerWindowTemplate.js").default} ColorPickerWindowTemplate * @typedef {import("./js/template/window/WindowTemplate.js").default} WindowTemplate - * @typedef {import ("./tests/fixtures/BlueprintFixture.js").default} BlueprintFixture * @typedef {import("lit").CSSResult} CSSResult * @typedef {import("lit").PropertyValues} PropertyValues * @typedef {import("lit").TemplateResult} TemplateResult + * @typedef {import("parsernostrum/src/parser/Parser.js").default} Parser */ /** * @template {AttributeConstructor} T