diff --git a/cypress/e2e/entities.cy.js b/cypress/e2e/entities.cy.js new file mode 100644 index 0000000..a36adc5 --- /dev/null +++ b/cypress/e2e/entities.cy.js @@ -0,0 +1,139 @@ +/// + +import ComplexEntity from "../fixtures/ComplexEntity" +import SimpleEntity from "../fixtures/SimpleEntity" +import SimpleObject from "../fixtures/SimpleObject" + +describe("Entity initialization", () => { + before(() => { + expect(SimpleEntity,).to.be.a("function") + expect(ComplexEntity).to.be.a("function") + }) + + context("SimpleEntity", () => { + const entity = new SimpleEntity() + it("has 8 keys", () => expect(Object.keys(entity).length).to.equal(8)) + it("has someNumber equal to 567", () => expect(entity) + .to.have.property("someNumber") + .which.is.a("number") + .and.is.equal(567) + ) + it("has someString equal to alpha", () => expect(entity) + .to.have.property("someString") + .which.is.a("string") + .and.is.equal("alpha") + ) + it("has someString2 equal to beta", () => expect(entity) + .to.have.property("someString2") + .which.is.a("string") + .and.is.equal("beta") + ) + it("has someBoolean true", () => expect(entity) + .to.have.property("someBoolean") + .which.is.a("boolean") + .and.is.true + ) + it("has someBoolean2 false", () => expect(entity) + .to.have.property("someBoolean2") + .which.is.a("boolean") + .and.is.false + ) + it("has someObjectString equal to gamma", () => expect(entity) + .to.have.property("someObjectString") + .which.is.a("string") + .and.is.equal("gamma") + ) + it("has someArray with numbers", () => expect(entity) + .to.have.property("someArray") + .which.is.an("array") + .and.is.deep.equal([400, 500, 600, 700, 800]) + ) + it("has someSet with numbers", () => expect(entity) + .to.have.property("someSet") + .which.is.instanceOf(Set) + .and.is.deep.equal(new Set([10, 20, 30, 40, 50, 60, 70])) + ) + }) + + context("ComplexEntity", () => { + const entity = new ComplexEntity() + it("has 8 keys", () => expect(Object.keys(entity).length).to.equal(8)) + it("has alpha equal to 32", () => expect(entity) + .to.have.property("alpha") + .which.is.a("number") + .and.is.equal(32) + ) + it("has bravo equal to 78", () => expect(entity) + .to.have.property("bravo") + .which.is.a("number") + .and.is.equal(78) + ) + it("has charlie equal to beta", () => expect(entity) + .to.have.property("charlie") + .which.is.a("string") + .and.is.equal("Charlie") + ) + it("has delta null", () => expect(entity) + .to.have.property("delta") + .which.is.null + ) + it("has echo equal to echo", () => expect(entity) + .to.have.property("echo") + .which.is.a("string") + .and.is.equal("echo") + ) + it("has foxtrot false", () => expect(entity) + .to.have.property("foxtrot") + .which.is.a("boolean") + .and.is.false + ) + it("has golf empty array", () => expect(entity) + .to.have.property("golf") + .which.is.an("array") + .and.is.empty + ) + it("has hotel null", () => expect(entity) + .to.have.property("hotel") + .which.is.null + ) + it("has india empty array", () => expect(entity) + .to.have.property("india") + .which.is.an("array") + .and.is.empty + ) + it("has juliett array of strings", () => expect(entity) + .to.have.property("juliett") + .which.is.an("array") + .and.is.deep.equal(["a", "b", "c", "d", "e"]) + ) + it("has kilo array of booleans", () => expect(entity) + .to.have.property("kilo") + .which.is.an("array") + .and.is.deep.equal([true, false, false, true, true]) + ) + it("has lima undefined", () => expect(entity) + .to.have.property("lima") + .which.is.undefined + ) + it("has mike equal to Foo", () => expect(entity) + .to.have.property("mike") + .which.is.a("string") + .and.is.equal("Bar") + ) + it("has november equal to 0", () => expect(entity) + .to.have.property("november") + .which.is.a("number") + .and.is.equal(0) + ) + it("has oscar a SimpleObject", () => expect(entity) + .to.have.property("oscar") + .which.is.instanceOf(SimpleObject) + .and.is.deep.equal({ a: 8, b: 9 }) + ) + it("has papa a SimpleObject", () => expect(entity) + .to.have.property("papa") + .which.is.instanceOf(SimpleObject) + .and.is.deep.equal({ a: 12, b: 13 }) + ) + }) +}) diff --git a/cypress/fixtures/ComplexEntity.js b/cypress/fixtures/ComplexEntity.js new file mode 100644 index 0000000..1ee8760 --- /dev/null +++ b/cypress/fixtures/ComplexEntity.js @@ -0,0 +1,64 @@ +import IEntity from "../../js/entity/IEntity" +import UnionType from "../../js/entity/UnionType" +import SimpleObject from "./SimpleObject" + +export default class ComplexEntity extends IEntity { + + static attributes = { + alpha: 32, + bravo: { + type: Number, + value: 78, + }, + charlie: { + type: String, + value: "Charlie", + }, + delta: { + type: String, + value: null, + }, + echo: "echo", + foxtrot: { + value: false, + }, + golf: { + type: Array, + }, + hotel: { + type: Array, + value: null, + }, + india: { + type: [Number] + }, + juliett: { + type: [String], + value: ["a", "b", "c", "d", "e"], + }, + kilo: { + type: [Boolean], + value: () => [true, false, false, true, true], + }, + lima: { + type: String, + value: "Foo", + showDefault: false, + }, + mike: { + type: new UnionType(Number, String, Array), + value: "Bar", + }, + november: { + type: new UnionType(Number, String, Array), + }, + oscar: { + type: SimpleObject + }, + papa: () => new SimpleObject(12, 13), + } + + static { + this.cleanupAttributes(this.attributes) + } +} diff --git a/cypress/fixtures/SimpleEntity.js b/cypress/fixtures/SimpleEntity.js new file mode 100644 index 0000000..e343465 --- /dev/null +++ b/cypress/fixtures/SimpleEntity.js @@ -0,0 +1,19 @@ +import IEntity from "../../js/entity/IEntity" + +export default class SimpleEntity extends IEntity { + + static attributes = { + someNumber: 567, + someString: "alpha", + someString2: "beta", + someBoolean: true, + someBoolean2: false, + someObjectString: new String("gamma"), + someArray: [400, 500, 600, 700, 800], + someSet: new Set([10, 20, 30, 40, 50, 60, 70]), + } + + static { + this.cleanupAttributes(this.attributes) + } +} diff --git a/cypress/fixtures/SimpleObject.js b/cypress/fixtures/SimpleObject.js new file mode 100644 index 0000000..ff1e2d8 --- /dev/null +++ b/cypress/fixtures/SimpleObject.js @@ -0,0 +1,7 @@ +export default class SimpleObject { + + constructor(a = 8, b = 9) { + this.a = a + this.b = b + } +} diff --git a/cypress/fixtures/example.json b/cypress/fixtures/example.json deleted file mode 100644 index 02e4254..0000000 --- a/cypress/fixtures/example.json +++ /dev/null @@ -1,5 +0,0 @@ -{ - "name": "Using fixtures to represent data", - "email": "hello@cypress.io", - "body": "Fixtures are a great way to mock data for responses to routes" -} diff --git a/dist/ueblueprint.js b/dist/ueblueprint.js index f89709f..96f84db 100755 --- a/dist/ueblueprint.js +++ b/dist/ueblueprint.js @@ -330,23 +330,6 @@ class IInput { } } -/** @typedef {import("./IEntity").default} IEntity */ - -class CalculatedType { - - #f - - /** @param {Function} f */ - constructor(f) { - this.#f = f; - } - - /** @param {IEntity} entity */ - calculate(entity) { - return this.#f(entity) - } -} - class Observable { /** @type {Map} */ @@ -455,12 +438,10 @@ class Observable { /** * @typedef {import("../entity/IEntity").default} IEntity - * @typedef {import("../entity/TypeInitialization").AnyValue} AnyValue - */ -/** - * @template T - * @typedef {import("../entity/TypeInitialization").AnyValueConstructor} AnyValueConstructor + * @typedef {import("../entity/IEntity").AnyValue} AnyValue + * @typedef {import("../entity/IEntity").AnyValueConstructor} AnyValueConstructor */ + /** * @template {AnyValue} T * @typedef {import("./ISerializer").default} ISerializer @@ -468,159 +449,37 @@ class Observable { class SerializerFactory { - /** @type {Map, ISerializer>} */ + /** @type {Map>} */ static #serializers = new Map() static registerSerializer(entity, object) { SerializerFactory.#serializers.set(entity, object); } - /** - * @template {AnyValue} T - * @param {AnyValueConstructor} entity - */ + /** @param {AnyValueConstructor} entity */ static getSerializer(entity) { return SerializerFactory.#serializers.get(entity) } } -/** - * @template T - * @typedef {import("./TypeInitialization").AnyValueConstructor} AnyValueConstructor - */ +/** @typedef {import("./IEntity").AttributeDeclarations} AttributeDeclarations */ -class UnionType { +class SubAttributesDeclaration { - #types - get types() { - return this.#types + /** @param {AttributeDeclarations} attributes */ + constructor(attributes) { + this.attributes = attributes; } - - /** @param {...AnyValueConstructor} types */ - constructor(...types) { - this.#types = types; - } - - getFirstType() { - return this.#types[0] - } -} - -/** - * @typedef {IEntity | String | Number | Boolean | Array} AnyValue - * @typedef {import("./IEntity").default} IEntity - */ -/** - * @template {AnyValue} T - * @typedef {import("./IEntity").IEntityConstructor} IEntityConstructor - */ -/** - * @template {AnyValue} T - * @typedef {IEntityConstructor | StringConstructor | NumberConstructor | BooleanConstructor | ArrayConstructor | UnionType} AnyValueConstructor - */ - -/** @template {AnyValue} T */ -class TypeInitialization { - - /** @type {AnyValueConstructor|AnyValueConstructor[]} */ - #type - get type() { - return this.#type - } - set type(v) { - this.#type = v; - } - - #showDefault = true - get showDefault() { - return this.#showDefault - } - set showDefault(v) { - this.#showDefault = v; - } - - /** @type {T | T[] | String | (() => T) | (() => T[])} */ - #value - get value() { - return this.#value - } - set value(v) { - this.#value = v; - } - - /** @type {Boolean} */ - #serialized - get serialized() { - return this.#serialized - } - set serialized(v) { - this.#serialized = v; - } - - #ignored - get ignored() { - return this.#ignored - } - set ignored(v) { - this.#ignored = v; - } - - static isValueOfType(value, type) { - return value != null && (value instanceof type || value.constructor === type) - } - - static sanitize(value, targetType) { - if (targetType === undefined) { - targetType = value?.constructor; - } - if (targetType instanceof Array) { - let type = targetType.find(t => TypeInitialization.isValueOfType(value, t)); - if (!type) { - type = targetType[0]; - } - targetType = type; - } - if (targetType && !TypeInitialization.isValueOfType(value, targetType)) { - value = new targetType(value); - } - if (value instanceof Boolean || value instanceof Number || value instanceof String) { - value = value.valueOf(); // Get the relative primitive value - } - return value - } - - /** - * @param {AnyValueConstructor|AnyValueConstructor[]} type - * @param {Boolean} showDefault - * @param {T | T[] | String | (() => T) | (() => T[])} value - * @param {Boolean} serialized - */ - constructor(type, showDefault = true, value = undefined, serialized = false, ignored = false) { - if (value === undefined) { - if (type instanceof Array) { - value = []; - } else { - value = () => TypeInitialization.sanitize(new type()); - } - } - this.#type = type; - this.#showDefault = showDefault; - this.#value = value; - this.#serialized = serialized; - this.#ignored = ignored; - } } /** * @typedef {import("./element/IElement").default} IElement + * @typedef {import("./entity/IEntity").AnyValue} AnyValue + * @typedef {import("./entity/IEntity").AnyValueConstructor} AnyValueConstructor + * @typedef {import("./entity/IEntity").AttributeInformation} TypeInformation * @typedef {import("./entity/IEntity").default} IEntity * @typedef {import("./entity/IEntity").EntityConstructor} EntityConstructor * @typedef {import("./entity/LinearColorEntity").default} LinearColorEntity - * @typedef {import("./entity/TypeInitialization").AnyValue} AnyValue - */ -/** - * @template T - * @typedef {import("./entity/TypeInitialization").AnyValueConstructor} AnyValueConstructor */ class Utility { @@ -706,22 +565,16 @@ class Utility { /** * @param {IEntity} entity * @param {String[]} keys - * @param {any} propertyDefinition + * @param {any} attribute * @returns {Boolean} */ static isSerialized( entity, keys, - propertyDefinition = Utility.objectGet(/** @type {EntityConstructor} */(entity.constructor).attributes, keys) + attribute = Utility.objectGet(/** @type {EntityConstructor} */(entity.constructor).attributes, keys) ) { - if (propertyDefinition instanceof CalculatedType) { - return Utility.isSerialized(entity, keys, propertyDefinition.calculate(entity)) - } - if (propertyDefinition instanceof TypeInitialization) { - if (propertyDefinition.serialized) { - return true - } - return Utility.isSerialized(entity, keys, propertyDefinition.type) + if (attribute.constructor === Object) { + return /** @type {TypeInformation} */(attribute).serialized } return false } @@ -732,7 +585,10 @@ class Utility { return undefined } if (!(keys instanceof Array)) { - throw new TypeError("Expected keys to be an array.") + throw new TypeError("UEBlueprint: Expected keys to be an array") + } + if (target instanceof SubAttributesDeclaration) { + target = target.attributes; } if (keys.length == 0 || !(keys[0] in target) || target[keys[0]] === undefined) { return defaultValue @@ -766,9 +622,13 @@ class Utility { return false } + /** + * @param {AnyValue} a + * @param {AnyValue} b + */ static equals(a, b) { - a = TypeInitialization.sanitize(a); - b = TypeInitialization.sanitize(b); + a = Utility.sanitize(a); + b = Utility.sanitize(b); if (a === b) { return true } @@ -777,25 +637,46 @@ class Utility { } } - /** - * @param {AnyValue | AnyValueConstructor} value - * @returns {AnyValueConstructor | AnyValueConstructor[]} + /** + * @param {null | AnyValue | TypeInformation} value + * @returns {AnyValueConstructor} */ static getType(value) { if (value === null) { return null } - if (value instanceof TypeInitialization) { - return Utility.getType(value.type) + // @ts-expect-error + if (value.constructor === Object && value.type instanceof Function) { + // @ts-expect-error + return value.type } - if (value instanceof UnionType) { - return value.types + return /** @type {AnyValueConstructor} */(value?.constructor) + } + + /** + * @param {AnyValue} value + * @param {AnyValueConstructor} type + */ + static isValueOfType(value, type) { + return value === null || (value instanceof type || value.constructor === type) + } + + /** @param {AnyValue} value */ + static sanitize(value, targetType = /** @type {AnyValueConstructor} */(value?.constructor)) { + if (targetType instanceof Array) { + let type = targetType.find(t => Utility.isValueOfType(value, t)); + if (!type) { + type = targetType[0]; + } + targetType = type; } - if (value instanceof Function) { - // value is already a constructor - return value + if (targetType && !Utility.isValueOfType(value, targetType)) { + value = new targetType(value); } - return /** @type {AnyValueConstructor} */(value?.constructor) + if (value instanceof Boolean || value instanceof Number || value instanceof String) { + value = value.valueOf(); // Get the relative primitive value + } + return value } /** @@ -955,17 +836,61 @@ class Utility { }; requestAnimationFrame(doAnimation); } + + /** @param {String} value */ + static warn(value) { + console.warn("UEBlueprint: " + value); + } +} + +/** @typedef {import("./IEntity").AnyValueConstructor} AnyValueConstructor */ + +class UnionType { + + #types + get types() { + return this.#types + } + + /** @param {...AnyValueConstructor} types */ + constructor(...types) { + this.#types = types; + } + + getFirstType() { + return this.#types[0] + } } -/** @typedef {typeof IEntity} EntityConstructor */ /** - * @template {IEntity} T - * @typedef {new (Object) => T} IEntityConstructor + * @typedef {(entity: IEntity) => AnyValue} ValueSupplier + * @typedef {(entity: IEntity) => AnyValueConstructor} TypeSupplier + * @typedef {EntityConstructor | StringConstructor | NumberConstructor | BooleanConstructor | ArrayConstructor} AnyValueConstructor + * @typedef {IEntity | String | Number | Boolean} AnyValue + * @typedef {{ + * [key: String]: AttributeInformation | AnyValue | SubAttributesDeclaration + * }} AttributeDeclarations + * @typedef {typeof IEntity} EntityConstructor + * @typedef {{ + * type?: AnyValueConstructor | AnyValueConstructor[] | UnionType | TypeSupplier, + * value?: AnyValue | ValueSupplier, + * showDefault?: Boolean, + * nullable?: Boolean, + * ignored?: Boolean, + * serialized?: Boolean, + * }} AttributeInformation */ class IEntity extends Observable { + /** @type {AttributeDeclarations} */ static attributes = {} + static defaultAttribute = { + showDefault: true, + nullable: false, + ignored: false, + serialized: false, + } constructor(values = {}, suppressWarns = false) { super(); @@ -976,82 +901,92 @@ class IEntity extends Observable { * @param {String} prefix */ const defineAllAttributes = (target, attributes, values = {}, prefix = "") => { - const valuesPropertyNames = Object.getOwnPropertyNames(values); - for (let attribute of Utility.mergeArrays(Object.getOwnPropertyNames(attributes), valuesPropertyNames)) { - let value = Utility.objectGet(values, [attribute]); - let defaultValue = attributes[attribute]; - let defaultType = Utility.getType(defaultValue); - if (defaultValue instanceof CalculatedType) { - defaultValue = defaultValue.calculate(this); - defaultType = Utility.getType(defaultValue); - } - if (defaultValue != null && defaultValue === defaultType) { - defaultValue = new defaultType(); + const valuesNames = Object.getOwnPropertyNames(values); + for (let attributeName of Utility.mergeArrays(Object.getOwnPropertyNames(attributes), valuesNames)) { + let value = Utility.objectGet(values, [attributeName]); + /** @type {AttributeInformation} */ + let attribute = attributes[attributeName]; + + if (attribute instanceof SubAttributesDeclaration) { + target[attributeName] = {}; + defineAllAttributes( + target[attributeName], + attribute.attributes, + values[attributeName], + attributeName + "." + ); + continue } if (!suppressWarns) { - if (!(attribute in attributes)) { - console.warn( - `Attribute ${prefix}${attribute} in the serialized data is not defined in ${this.constructor.name}.attributes` + if (!(attributeName in attributes)) { + Utility.warn( + `Attribute ${prefix}${attributeName} in the serialized data is not defined in ` + + `${this.constructor.name}.attributes` ); } else if ( - valuesPropertyNames.length > 0 - && !(attribute in values) - && defaultValue !== undefined - && !(defaultValue instanceof TypeInitialization && (!defaultValue.showDefault || defaultValue.ignored)) + valuesNames.length > 0 + && !(attributeName in values) + && !(!attribute.showDefault || attribute.ignored) ) { - console.warn( - `${this.constructor.name} will add attribute ${prefix}${attribute} not defined in the serialized data` + Utility.warn( + `${this.constructor.name} will add attribute ${prefix}${attributeName} not defined in the ` + + "serialized data" ); } } - // Not instanceof because all objects are instenceof Object, exact match needed - // @ts-expect-error - if (defaultType === Object) { - target[attribute] = {}; - defineAllAttributes(target[attribute], attributes[attribute], values[attribute], attribute + "."); - continue + let defaultValue = attribute.value; + let defaultType = attribute.type; + if (attribute.serialized && defaultType instanceof Function) { + // If the attribute is serialized, the type must contain a function providing the type + defaultType = /** @type {TypeSupplier} */(defaultType)(this); + } + if (defaultType instanceof Array) { + defaultType = Array; + } + if (defaultValue instanceof Function) { + defaultValue = defaultValue(this); + } + if (defaultType instanceof UnionType) { + if (defaultValue != undefined) { + defaultType = defaultType.types.find( + type => defaultValue instanceof type || defaultValue.constructor == type + ) ?? defaultType.getFirstType(); + } else { + defaultType = defaultType.getFirstType(); + } + } + if (defaultType === undefined) { + defaultType = Utility.getType(defaultValue); } if (value !== undefined) { // Remember value can still be null - if ( - value?.constructor === String - && defaultValue instanceof TypeInitialization - && defaultValue.serialized - && defaultValue.type !== String - ) { - // @ts-expect-error - value = SerializerFactory.getSerializer(defaultValue.type).deserialize(value); + if (value?.constructor === String && attribute.serialized && defaultType !== String) { + value = SerializerFactory + .getSerializer(defaultType) + .deserialize(/** @type {String} */(value)); } - target[attribute] = TypeInitialization.sanitize(value, Utility.getType(defaultValue)); + target[attributeName] = Utility.sanitize(value, defaultType); continue // We have a value, need nothing more } - - if (defaultValue instanceof TypeInitialization) { - if (!defaultValue.showDefault) { - target[attribute] = undefined; // Declare undefined to preserve the order of attributes - continue - } - if (defaultValue.serialized) { - defaultValue = ""; - } else { - defaultType = defaultValue.type; - defaultValue = defaultValue.value; - if (defaultValue instanceof Function) { - defaultValue = defaultValue(); - } + if (defaultValue === undefined) { + defaultValue = Utility.sanitize(new /** @type {AnyValueConstructor} */(defaultType)()); + } + if (!attribute.showDefault) { + target[attributeName] = undefined; // Declare undefined to preserve the order of attributes + continue + } + if (attribute.serialized) { + if (defaultValue.constructor !== String) { + defaultValue = SerializerFactory.getSerializer(defaultType).deserialize(defaultValue); } } - if (defaultValue instanceof UnionType) { - defaultType = defaultValue.getFirstType(); - defaultValue = TypeInitialization.sanitize(null, defaultType); - } - if (defaultValue instanceof Array) { - defaultValue = []; - } - target[attribute] = TypeInitialization.sanitize(defaultValue, defaultType); + target[attributeName] = Utility.sanitize( + /** @type {AnyValue} */(defaultValue), + /** @type {AnyValueConstructor} */(defaultType) + ); } }; const attributes = /** @type {typeof IEntity} */(this.constructor).attributes; @@ -1064,21 +999,115 @@ class IEntity extends Observable { defineAllAttributes(this, attributes, values); } + /** @param {AttributeDeclarations} attributes */ + static cleanupAttributes(attributes, prefix = "") { + for (const attributeName in attributes) { + if (attributes[attributeName] instanceof SubAttributesDeclaration) { + this.cleanupAttributes( + /** @type {SubAttributesDeclaration} */(attributes[attributeName]).attributes, + prefix + "." + attributeName + ); + continue + } + if (attributes[attributeName].constructor !== Object) { + attributes[attributeName] = { + value: attributes[attributeName], + }; + } + const attribute = /** @type {AttributeInformation} */(attributes[attributeName]); + if (attribute.type === undefined && !(attribute.value instanceof Function)) { + attribute.type = Utility.getType(attribute.value); + } + attributes[attributeName] = { + ...IEntity.defaultAttribute, + ...attribute, + }; + if (attribute.value === undefined && attribute.type === undefined) { + throw new Error( + `UEBlueprint: Expected either "type" or "value" property in ${this.name} attribute ${prefix}` + + attributeName + ) + } + if (attribute.value === null) { + attributes[attributeName].nullable = true; + } + } + } + + static isValueOfType(value, type) { + return value != null && (value instanceof type || value.constructor === type) + } + unexpectedKeys() { // @ts-expect-error return Object.getOwnPropertyNames(this).length - Object.getOwnPropertyNames(this.constructor.attributes).length } } +class IntegerEntity extends IEntity { + + static attributes = { + value: 0, + } + + static { + this.cleanupAttributes(this.attributes); + } + + /** @param {Object | Number | String} value */ + constructor(value = 0) { + super(value); + this.value = Math.round(this.value); + } + + valueOf() { + return this.value + } + + toString() { + return this.value.toString() + } +} + +class ByteEntity extends IntegerEntity { + + static attributes = { + value: 0, + } + + static { + this.cleanupAttributes(this.attributes); + } + + /** @param {Object | Number | String} values */ + constructor(values = 0) { + super(values); + const value = Math.round(this.value); + this.value = value >= 0 && value < 1 << 8 ? value : 0; + } + + valueOf() { + return this.value + } + + toString() { + return this.value.toString() + } +} + class ObjectReferenceEntity extends IEntity { static attributes = { - type: String, - path: String, + type: "", + path: "", + } + + static { + this.cleanupAttributes(this.attributes); } constructor(values = {}) { - if (values.constructor !== Object) { + if (values.constructor === String) { values = { path: values }; @@ -1096,10 +1125,17 @@ class ObjectReferenceEntity extends IEntity { class FunctionReferenceEntity extends IEntity { static attributes = { - MemberParent: new TypeInitialization(ObjectReferenceEntity, false), + MemberParent: { + type: ObjectReferenceEntity, + showDefault: false + }, MemberName: "", } + static { + this.cleanupAttributes(this.attributes); + } + constructor(values) { super(values); /** @type {ObjectReferenceEntity} */ this.MemberParent; @@ -1110,7 +1146,11 @@ class FunctionReferenceEntity extends IEntity { class GuidEntity extends IEntity { static attributes = { - value: String, + value: "", + } + + static { + this.cleanupAttributes(this.attributes); } static generateGuid(random = true) { @@ -1145,7 +1185,11 @@ class GuidEntity extends IEntity { class IdentifierEntity extends IEntity { static attributes = { - value: String, + value: "", + } + + static { + this.cleanupAttributes(this.attributes); } static attributeConverter = { @@ -1167,33 +1211,15 @@ class IdentifierEntity extends IEntity { } } -class IntegerEntity extends IEntity { - - static attributes = { - value: 0, - } - - /** @param {Object | Number | String} values */ - constructor(values = 0) { - super(values); - /** @type {Number} */ - this.value = Math.round(this.value); - } - - valueOf() { - return this.value - } - - toString() { - return this.value.toString() - } -} - class InvariantTextEntity extends IEntity { static lookbehind = "INVTEXT" static attributes = { - value: String, + value: "", + } + + static { + this.cleanupAttributes(this.attributes); } constructor(values) { @@ -1210,7 +1236,13 @@ class KeyBindingEntity extends IEntity { bCtrl: false, bAlt: false, bCmd: false, - Key: IdentifierEntity, + Key: { + type: IdentifierEntity + }, + } + + static { + this.cleanupAttributes(this.attributes); } constructor(values = {}) { @@ -1235,6 +1267,10 @@ class RealUnitEntity extends IEntity { value: 0, } + static { + this.cleanupAttributes(this.attributes); + } + /** @param {Object | Number | String} values */ constructor(values = 0) { super(values); @@ -1253,13 +1289,39 @@ class RealUnitEntity extends IEntity { class LinearColorEntity extends IEntity { static attributes = { - R: RealUnitEntity, - G: RealUnitEntity, - B: RealUnitEntity, - A: new TypeInitialization(RealUnitEntity, true, () => new RealUnitEntity(1), false, false), - H: new TypeInitialization(RealUnitEntity, true, undefined, false, true), - S: new TypeInitialization(RealUnitEntity, true, undefined, false, true), - V: new TypeInitialization(RealUnitEntity, true, undefined, false, true), + R: { + type: RealUnitEntity, + }, + G: { + type: RealUnitEntity, + }, + B: { + type: RealUnitEntity, + }, + A: { + type: RealUnitEntity, + value: () => new RealUnitEntity(1), + showDefault: true, + }, + H: { + type: RealUnitEntity, + showDefault: true, + ignored: true, + }, + S: { + type: RealUnitEntity, + showDefault: true, + ignored: true, + }, + V: { + type: RealUnitEntity, + showDefault: true, + ignored: true, + }, + } + + static { + this.cleanupAttributes(this.attributes); } /** @param {Number} x */ @@ -1462,9 +1524,13 @@ class LocalizedTextEntity extends IEntity { static lookbehind = "NSLOCTEXT" static attributes = { - namespace: String, - key: String, - value: String, + namespace: "", + key: "", + value: "", + } + + static { + this.cleanupAttributes(this.attributes); } constructor(values) { @@ -1482,9 +1548,19 @@ class LocalizedTextEntity extends IEntity { class MacroGraphReferenceEntity extends IEntity { static attributes = { - MacroGraph: ObjectReferenceEntity, - GraphBlueprint: ObjectReferenceEntity, - GraphGuid: GuidEntity, + MacroGraph: { + type: ObjectReferenceEntity, + }, + GraphBlueprint: { + type: ObjectReferenceEntity, + }, + GraphGuid: { + type: GuidEntity, + }, + } + + static { + this.cleanupAttributes(this.attributes); } constructor(values) { @@ -1503,7 +1579,11 @@ class MacroGraphReferenceEntity extends IEntity { class PathSymbolEntity extends IEntity { static attributes = { - value: String, + value: "", + } + + static { + this.cleanupAttributes(this.attributes); } constructor(values) { @@ -1523,8 +1603,16 @@ class PathSymbolEntity extends IEntity { class PinReferenceEntity extends IEntity { static attributes = { - objectName: PathSymbolEntity, - pinGuid: GuidEntity, + objectName: { + type: PathSymbolEntity, + }, + pinGuid: { + type: GuidEntity, + }, + } + + static { + this.cleanupAttributes(this.attributes); } constructor(values) { @@ -1537,9 +1625,19 @@ class PinReferenceEntity extends IEntity { class RotatorEntity extends IEntity { static attributes = { - R: Number, - P: Number, - Y: Number, + R: { + value: 0, + }, + P: { + value: 0, + }, + Y: { + value: 0, + }, + } + + static { + this.cleanupAttributes(this.attributes); } constructor(values) { @@ -1548,6 +1646,18 @@ class RotatorEntity extends IEntity { /** @type {Number} */ this.P; /** @type {Number} */ this.Y; } + + getRoll() { + return this.R + } + + getPitch() { + return this.P + } + + getYaw() { + return this.Y + } } class SimpleSerializationRotatorEntity extends RotatorEntity { @@ -1556,8 +1666,8 @@ class SimpleSerializationRotatorEntity extends RotatorEntity { class Vector2DEntity extends IEntity { static attributes = { - X: Number, - Y: Number, + X: 0, + Y: 0, } constructor(values) { @@ -1573,9 +1683,9 @@ class SimpleSerializationVector2DEntity extends Vector2DEntity { class VectorEntity extends IEntity { static attributes = { - X: Number, - Y: Number, - Z: Number, + X: 0, + Y: 0, + Z: 0, } constructor(values) { @@ -1589,7 +1699,7 @@ class VectorEntity extends IEntity { class SimpleSerializationVectorEntity extends VectorEntity { } -/** @typedef {import("./TypeInitialization").AnyValue} AnyValue */ +/** @typedef {import("./IEntity").AnyValue} AnyValue */ /** @template {AnyValue} T */ class PinEntity extends IEntity { @@ -1613,38 +1723,67 @@ class PinEntity extends IEntity { } static lookbehind = "Pin" static attributes = { - PinId: GuidEntity, + PinId: { + type: GuidEntity, + }, PinName: "", - PinFriendlyName: new TypeInitialization(new UnionType(LocalizedTextEntity, String), false, null), - PinToolTip: new TypeInitialization(String, false, ""), - Direction: new TypeInitialization(String, false, ""), - PinType: { + PinFriendlyName: { + type: new UnionType(LocalizedTextEntity, String), + showDefault: false, + }, + PinToolTip: { + type: String, + showDefault: false, + }, + Direction: { + type: String, + showDefault: false, + }, + PinType: new SubAttributesDeclaration({ PinCategory: "", PinSubCategory: "", - PinSubCategoryObject: ObjectReferenceEntity, - PinSubCategoryMemberReference: null, - PinValueType: null, - ContainerType: ObjectReferenceEntity, + PinSubCategoryObject: { + type: ObjectReferenceEntity, + }, + PinSubCategoryMemberReference: { + type: ObjectReferenceEntity, + value: null, + }, + PinValueType: { + type: String, + value: null, + }, + ContainerType: { + type: ObjectReferenceEntity, + }, bIsReference: false, bIsConst: false, bIsWeakPointer: false, bIsUObjectWrapper: false, bSerializeAsSinglePrecisionFloat: false, + }), + LinkedTo: { + type: [PinReferenceEntity], + showDefault: false, + }, + DefaultValue: { + /** @param {PinEntity} pinEntity */ + type: pinEntity => pinEntity.getEntityType(true) ?? String, + serialized: true, + showDefault: false, + }, + AutogeneratedDefaultValue: { + type: String, + showDefault: false, + }, + DefaultObject: { + type: ObjectReferenceEntity, + showDefault: false, + value: null, + }, + PersistentGuid: { + type: GuidEntity, }, - LinkedTo: new TypeInitialization([PinReferenceEntity], false), - DefaultValue: - new CalculatedType( - /** @param {PinEntity} pinEntity */ - pinEntity => new TypeInitialization( - pinEntity.getEntityType(true) ?? String, - false, - undefined, - true - ) - ), - AutogeneratedDefaultValue: new TypeInitialization(String, false), - DefaultObject: new TypeInitialization(ObjectReferenceEntity, false, null), - PersistentGuid: GuidEntity, bHidden: false, bNotConnectable: false, bDefaultValueIsReadOnly: false, @@ -1653,6 +1792,10 @@ class PinEntity extends IEntity { bOrphanedPin: false, } + static { + this.cleanupAttributes(this.attributes); + } + constructor(values = {}, suppressWarns = false) { super(values, suppressWarns); /** @type {GuidEntity} */ this.PinId; @@ -1807,7 +1950,11 @@ class PinEntity extends IEntity { class SymbolEntity extends IEntity { static attributes = { - value: String + value: "", + } + + static { + this.cleanupAttributes(this.attributes); } constructor(values) { @@ -1819,10 +1966,18 @@ class SymbolEntity extends IEntity { class VariableReferenceEntity extends IEntity { static attributes = { - MemberScope: new TypeInitialization(String, false), - MemberName: String, - MemberGuid: GuidEntity, - bSelfContext: new TypeInitialization(Boolean, false, false) + MemberScope: { + value: "", + showDefault: false, + }, + MemberName: "", + MemberGuid: { + type: GuidEntity, + }, + bSelfContext: { + value: false, + showDefault: false, + }, } constructor(values) { @@ -1836,38 +1991,125 @@ class VariableReferenceEntity extends IEntity { class ObjectEntity extends IEntity { static attributes = { - Class: ObjectReferenceEntity, + Class: { + type: ObjectReferenceEntity, + }, Name: "", - bIsPureFunc: new TypeInitialization(Boolean, false, false), - VariableReference: new TypeInitialization(VariableReferenceEntity, false, null), - SelfContextInfo: new TypeInitialization(SymbolEntity, false, null), - FunctionReference: new TypeInitialization(FunctionReferenceEntity, false, null,), - EventReference: new TypeInitialization(FunctionReferenceEntity, false, null,), - TargetType: new TypeInitialization(ObjectReferenceEntity, false, null), - MacroGraphReference: new TypeInitialization(MacroGraphReferenceEntity, false, null), - Enum: new TypeInitialization(ObjectReferenceEntity, false), - CommentColor: new TypeInitialization(LinearColorEntity, false), - bCommentBubbleVisible_InDetailsPanel: new TypeInitialization(Boolean, false), - bColorCommentBubble: new TypeInitialization(Boolean, false, false), - MoveMode: new TypeInitialization(SymbolEntity, false), - NodePosX: IntegerEntity, - NodePosY: IntegerEntity, - NodeWidth: new TypeInitialization(IntegerEntity, false), - NodeHeight: new TypeInitialization(IntegerEntity, false), - bCommentBubblePinned: new TypeInitialization(Boolean, false), - bCommentBubbleVisible: new TypeInitialization(Boolean, false), - NodeComment: new TypeInitialization(String, false), - AdvancedPinDisplay: new TypeInitialization(IdentifierEntity, false, null), - EnabledState: new TypeInitialization(IdentifierEntity, false, null), - NodeGuid: GuidEntity, - ErrorType: new TypeInitialization(IntegerEntity, false), - ErrorMsg: new TypeInitialization(String, false, ""), - CustomProperties: [PinEntity], + bIsPureFunc: { + value: false, + showDefault: false, + }, + VariableReference: { + type: VariableReferenceEntity, + value: null, + showDefault: false, + }, + SelfContextInfo: { + type: SymbolEntity, + value: null, + showDefault: false, + }, + FunctionReference: { + type: FunctionReferenceEntity, + value: null, + showDefault: false, + }, + EventReference: { + type: FunctionReferenceEntity, + value: null, + showDefault: false, + }, + TargetType: { + type: ObjectReferenceEntity, + value: null, + showDefault: false, + }, + MacroGraphReference: { + type: MacroGraphReferenceEntity, + value: null, + showDefault: false, + }, + Enum: { + type: ObjectReferenceEntity, + showDefault: false, + }, + CommentColor: { + type: LinearColorEntity, + showDefault: false, + }, + bCommentBubbleVisible_InDetailsPanel: { + type: Boolean, + showDefault: false, + }, + bColorCommentBubble: { + type: Boolean, + value: false, + showDefault: false, + }, + MoveMode: { + type: SymbolEntity, + showDefault: false, + }, + NodePosX: { + type: IntegerEntity, + }, + NodePosY: { + type: IntegerEntity, + }, + NodeWidth: { + type: IntegerEntity, + showDefault: false, + }, + NodeHeight: { + type: IntegerEntity, + showDefault: false, + }, + bCommentBubblePinned: { + type: Boolean, + showDefault: false, + }, + bCommentBubbleVisible: { + type: Boolean, + showDefault: false, + }, + NodeComment: { + type: String, + showDefault: false, + }, + AdvancedPinDisplay: { + type: IdentifierEntity, + value: null, + showDefault: false, + }, + EnabledState: { + type: IdentifierEntity, + value: null, + showDefault: false, + }, + NodeGuid: { + type: GuidEntity, + }, + ErrorType: { + type: IntegerEntity, + showDefault: false, + }, + ErrorMsg: { + type: String, + value: "", + showDefault: false, + }, + CustomProperties: { + type: [PinEntity] + }, } static nameRegex = /^(\w+?)(?:_(\d+))?$/ static sequencerScriptingNameRegex = /\/Script\/SequencerScripting\.MovieSceneScripting(.+)Channel/ + static { + this.cleanupAttributes(this.attributes); + } + constructor(values, suppressWarns = false) { super(values, suppressWarns); /** @type {ObjectReferenceEntity} */ this.Class; @@ -1980,7 +2222,12 @@ var Parsimmon = /*@__PURE__*/getDefaultExportFromCjs(parsimmon_umd_min.exports); class UnknownKeysEntity extends IEntity { static attributes = { - lookbehind: new TypeInitialization(String, false, "", false, true) + lookbehind: + { + value: "", + showDefault: false, + ignore: true, + }, } constructor(values) { @@ -1989,31 +2236,10 @@ class UnknownKeysEntity extends IEntity { } } -class ByteEntity extends IntegerEntity { - - static attributes = { - value: 0, - } - - /** @param {Object | Number | String} values */ - constructor(values = 0) { - super(values); - /** @type {Number} */ - const value = Math.round(this.value); - this.value = value >= 0 && value < 1 << 8 ? value : 0; - } - - valueOf() { - return this.value - } - - toString() { - return this.value.toString() - } -} - // @ts-nocheck +/** @typedef {import ("../entity/IEntity").AttributeInformation} AttributeInformation */ + let P = Parsimmon; class Grammar { @@ -2021,30 +2247,35 @@ class Grammar { /* --- Factory --- */ /** @param {Grammar} r */ - static getGrammarForType(r, attributeType, defaultGrammar = r.AttributeAnyValue) { - if (attributeType instanceof TypeInitialization) { - let result = Grammar.getGrammarForType(r, attributeType.type, defaultGrammar); - if (attributeType.serialized && !(attributeType.type instanceof String)) { + static getGrammarForType(r, attribute, defaultGrammar = r.AttributeAnyValue) { + if (attribute.constructor === Object) { + attribute = /** @type {AttributeInformation} */(attribute); + let type = attribute.type; + let result; + if (type instanceof Array) { + result = Grammar.getGrammarForType(r, type[0]) + .trim(P.optWhitespace) + .sepBy(P.string(",")) + .skip(P.regex(/,?\s*/)) + .wrap(P.string("("), P.string(")")); + } else if (type instanceof UnionType) { + result = type.types + .map(v => Grammar.getGrammarForType(r, Utility.getType(v))) + .reduce((accum, cur) => !cur || accum === r.AttributeAnyValue + ? r.AttributeAnyValue + : accum.or(cur)); + } else { + result = Grammar.getGrammarForType(r, type, defaultGrammar); + } + if (attribute.serialized && !(type instanceof String)) { result = result.wrap(P.string('"'), P.string('"')); } + if (attribute.nullable) { + result = result.or(r.Null); + } return result } - switch (Utility.getType(attributeType)) { - case Array: - return P.seqMap( - P.string("("), - attributeType - .map(v => Grammar.getGrammarForType(r, Utility.getType(v))) - .reduce((accum, cur) => !cur || accum === r.AttributeAnyValue - ? r.AttributeAnyValue - : accum.or(cur) - ) - .trim(P.optWhitespace) - .sepBy(P.string(",")) - .skip(P.regex(/,?\s*/)), - P.string(")"), - (_0, grammar, _2) => grammar - ) + switch (attribute) { case Boolean: return r.Boolean case ByteEntity: @@ -2087,12 +2318,6 @@ class Grammar { return r.String case SymbolEntity: return r.Symbol - case UnionType: - return attributeType.types - .map(v => Grammar.getGrammarForType(r, Utility.getType(v))) - .reduce((accum, cur) => !cur || accum === r.AttributeAnyValue - ? r.AttributeAnyValue - : accum.or(cur)) case VariableReferenceEntity: return r.VariableReference case Vector2DEntity: @@ -2130,7 +2355,10 @@ class Grammar { // Once the attribute name is known, look into entityType.attributes to get its type const attributeKey = attributeName.split("."); const attribute = Utility.objectGet(entityType.attributes, attributeKey); - let attributeValueGrammar = Grammar.getGrammarForType(r, attribute, r.AttributeAnyValue); + let attributeValueGrammar = + attribute.constructor === Object && /** @type {AttributeInformation} */(attribute).serialized + ? r.String + : Grammar.getGrammarForType(r, attribute, r.AttributeAnyValue); // Returns a setter function for the attribute return attributeValueGrammar.map(attributeValue => entity => Utility.objectSet(entity, attributeKey, attributeValue, true) @@ -2526,11 +2754,8 @@ class Grammar { /** * @typedef {import("../entity/IEntity").EntityConstructor} EntityConstructor - * @typedef {import("../entity/TypeInitialization").AnyValue} AnyValue - */ -/** - * @template {AnyValue} T - * @typedef {import("../entity/TypeInitialization").AnyValueConstructor} AnyValueConstructor + * @typedef {import("../entity/IEntity").AnyValue} AnyValue + * @typedef {import("../entity/IEntity").AnyValueConstructor} AnyValueConstructor */ /** @template {AnyValue} T */ @@ -2538,7 +2763,7 @@ class ISerializer { static grammar = Parsimmon.createLanguage(new Grammar()) - /** @param {AnyValueConstructor} entityType */ + /** @param {AnyValueConstructor} entityType */ constructor( entityType, attributePrefix = "", @@ -2596,7 +2821,11 @@ class ISerializer { if (!serializer) { throw new Error(`Unknown value type "${type.name}", a serializer must be registered in the SerializerFactory class, check initializeSerializerFactory.js`) } - return serializer.write(entity, value, insideString) + return serializer.write( + value instanceof IEntity ? value : entity, + value, + insideString + ) } /** @@ -2610,13 +2839,12 @@ class ISerializer { let fullKey = key.concat(""); const last = fullKey.length - 1; const attributes = /** @type {EntityConstructor} */(object.constructor).attributes; - const keys = - attributes ? - Utility.mergeArrays( - Object.getOwnPropertyNames(attributes), - Object.getOwnPropertyNames(object) - ) - : Object.getOwnPropertyNames(object); + const keys = attributes + ? Utility.mergeArrays( + Object.getOwnPropertyNames(attributes), + Object.getOwnPropertyNames(object) + ) + : Object.getOwnPropertyNames(object); for (const property of keys) { fullKey[last] = property; const value = object[property]; @@ -2645,10 +2873,9 @@ class ISerializer { } showProperty(entity, object, attributeKey, attributeValue) { - // @ts-expect-error const attributes = /** @type {EntityConstructor} */(this.entityType).attributes; const attribute = Utility.objectGet(attributes, attributeKey); - if (attribute instanceof TypeInitialization) { + if (attribute.constructor === Object) { if (attribute.ignored) { return false } @@ -3091,10 +3318,6 @@ class KeyboardSelectAll extends IKeyboardShortcut { */ class IElement extends s { - /** @type {PropertyDeclarations} */ - static properties = { - } - #nextUpdatedCallbacks = [] /** @type {Blueprint} */ @@ -7881,8 +8104,8 @@ class VectorPinTemplate extends INumericPinTemplate { } /** + * @typedef {import("../entity/IEntity").AnyValue} AnyValue * @typedef {import("../entity/PinReferenceEntity").default} PinReferenceEntity - * @typedef {import("../entity/TypeInitialization").AnyValue} AnyValue * @typedef {import("./LinkElement").LinkElementConstructor} LinkElementConstructor * @typedef {import("./NodeElement").default} NodeElement * @typedef {import("lit").CSSResult} CSSResult @@ -8537,11 +8760,8 @@ function defineElements() { /** * @typedef {import("../entity/IEntity").default} IEntity - * @typedef {import("../entity/TypeInitialization").AnyValue} AnyValue - */ -/** - * @template {AnyValue} T - * @typedef {import("../entity/TypeInitialization").AnyValueConstructor} AnyValueConstructor + * @typedef {import("../entity/IEntity").AnyValue} AnyValue + * @typedef {import("../entity/IEntity").AnyValueConstructor} AnyValueConstructor */ /** @@ -8552,7 +8772,7 @@ class GeneralSerializer extends ISerializer { /** * @param {(value: String, entity: T) => String} wrap - * @param {AnyValueConstructor} entityType + * @param {AnyValueConstructor} entityType */ constructor(wrap, entityType, attributePrefix, attributeSeparator, trailingSeparator, attributeValueConjunctionSign, attributeKeyPrinter) { wrap = wrap ?? (v => `(${v})`); @@ -8569,7 +8789,6 @@ class GeneralSerializer extends ISerializer { let grammar = Grammar.getGrammarForType(ISerializer.grammar, this.entityType); const parseResult = grammar.parse(value); if (!parseResult.status) { - // @ts-expect-error throw new Error(`Error when trying to parse the entity ${this.entityType.prototype.constructor.name}.`) } return parseResult.value @@ -8588,11 +8807,8 @@ class GeneralSerializer extends ISerializer { /** * @typedef {import("../entity/IEntity").default} IEntity - * @typedef {import("../entity/TypeInitialization").AnyValue} AnyValue - */ -/** - * @template {AnyValue} T - * @typedef {import("../entity/TypeInitialization").AnyValueConstructor} AnyValueConstructor + * @typedef {import("../entity/IEntity").AnyValue} AnyValue + * @typedef {import("../entity/IEntity").AnyValueConstructor} AnyValueConstructor */ /** @@ -8605,7 +8821,7 @@ class CustomSerializer extends GeneralSerializer { /** * @param {(v: T, insideString: Boolean) => String} objectWriter - * @param {AnyValueConstructor} entityType + * @param {AnyValueConstructor} entityType */ constructor(objectWriter, entityType) { super(undefined, entityType); @@ -8623,18 +8839,18 @@ class CustomSerializer extends GeneralSerializer { } } -/** @typedef {import("../entity/TypeInitialization").AnyValue} AnyValue */ -/** - * @template {AnyValue} T - * @typedef {import("../entity/TypeInitialization").AnyValueConstructor} AnyValueConstructor +/** + * @typedef {import("../entity/IEntity").AnyValue} AnyValue + * @typedef {import("../entity/IEntity").AnyValueConstructor} AnyValueConstructor */ + /** * @template {AnyValue} T * @extends {GeneralSerializer} */ class ToStringSerializer extends GeneralSerializer { - /** @param {AnyValueConstructor} entityType */ + /** @param {AnyValueConstructor} entityType */ constructor(entityType) { super(undefined, entityType); } diff --git a/dist/ueblueprint.min.js b/dist/ueblueprint.min.js index 4002915..5e32fa9 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(),n=new WeakMap;class s{constructor(e,t,n){if(this._$cssResult$=!0,n!==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=n.get(i)),void 0===e&&((this.o=e=new CSSStyleSheet).replaceSync(this.cssText),t&&n.set(i,e))}return e}toString(){return this.cssText}}const r=(e,...t)=>{const n=1===e.length?e[0]:t.reduce(((t,i,n)=>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[n+1]),e[0]);return new s(n,e,i)},o=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(),n=new WeakMap;class s{constructor(e,t,n){if(this._$cssResult$=!0,n!==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=n.get(i)),void 0===e&&((this.o=e=new CSSStyleSheet).replaceSync(this.cssText),t&&n.set(i,e))}return e}toString(){return this.cssText}}const r=(e,...t)=>{const n=1===e.length?e[0]:t.reduce(((t,i,n)=>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[n+1]),e[0]);return new s(n,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 /** * @license * Copyright 2017 Google LLC * SPDX-License-Identifier: BSD-3-Clause - */;var a;const l=window,u=l.trustedTypes,c=u?u.emptyScript:"",h=l.reactiveElementPolyfillSupport,d={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}},p=(e,t)=>t!==e&&(t==t||e==e),m={attribute:!0,type:String,converter:d,reflect:!1,hasChanged:p};class g extends HTMLElement{constructor(){super(),this._$Ei=new Map,this.isUpdatePending=!1,this.hasUpdated=!1,this._$El=null,this.u()}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 n=this._$Ep(i,t);void 0!==n&&(this._$Ev.set(n,i),e.push(n))})),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,n=this.getPropertyDescriptor(e,i,t);void 0!==n&&Object.defineProperty(this.prototype,e,n)}}static getPropertyDescriptor(e,t,i){return{get(){return this[t]},set(n){const s=this[e];this[t]=n,this.requestUpdate(e,s,i)},configurable:!0,enumerable:!0}}static getPropertyOptions(e){return this.elementProperties.get(e)||m}static finalize(){if(this.hasOwnProperty("finalized"))return!1;this.finalized=!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(o(e))}else void 0!==e&&t.push(o(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}u(){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 n=null!==(i=this.shadowRoot)&&void 0!==i?i:this.attachShadow(this.constructor.shadowRootOptions);return((i,n)=>{t?i.adoptedStyleSheets=n.map((e=>e instanceof CSSStyleSheet?e:e.styleSheet)):n.forEach((t=>{const n=document.createElement("style"),s=e.litNonce;void 0!==s&&n.setAttribute("nonce",s),n.textContent=t.cssText,i.appendChild(n)}))})(n,this.constructor.elementStyles),n}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 n;const s=this.constructor._$Ep(e,i);if(void 0!==s&&!0===i.reflect){const r=(void 0!==(null===(n=i.converter)||void 0===n?void 0:n.toAttribute)?i.converter:d).toAttribute(t,i.type);this._$El=e,null==r?this.removeAttribute(s):this.setAttribute(s,r),this._$El=null}}_$AK(e,t){var i;const n=this.constructor,s=n._$Ev.get(e);if(void 0!==s&&this._$El!==s){const e=n.getPropertyOptions(s),r="function"==typeof e.converter?{fromAttribute:e.converter}:void 0!==(null===(i=e.converter)||void 0===i?void 0:i.fromAttribute)?e.converter:d;this._$El=s,this[s]=r.fromAttribute(t,e.type),this._$El=null}}requestUpdate(e,t,i){let n=!0;void 0!==e&&(((i=i||this.constructor.getPropertyOptions(e)).hasChanged||p)(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))):n=!1),!this.isUpdatePending&&n&&(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,d={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}},p=(e,t)=>t!==e&&(t==t||e==e),m={attribute:!0,type:String,converter:d,reflect:!1,hasChanged:p};class g extends HTMLElement{constructor(){super(),this._$Ei=new Map,this.isUpdatePending=!1,this.hasUpdated=!1,this._$El=null,this.u()}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 n=this._$Ep(i,t);void 0!==n&&(this._$Ev.set(n,i),e.push(n))})),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,n=this.getPropertyDescriptor(e,i,t);void 0!==n&&Object.defineProperty(this.prototype,e,n)}}static getPropertyDescriptor(e,t,i){return{get(){return this[t]},set(n){const s=this[e];this[t]=n,this.requestUpdate(e,s,i)},configurable:!0,enumerable:!0}}static getPropertyOptions(e){return this.elementProperties.get(e)||m}static finalize(){if(this.hasOwnProperty("finalized"))return!1;this.finalized=!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}u(){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 n=null!==(i=this.shadowRoot)&&void 0!==i?i:this.attachShadow(this.constructor.shadowRootOptions);return((i,n)=>{t?i.adoptedStyleSheets=n.map((e=>e instanceof CSSStyleSheet?e:e.styleSheet)):n.forEach((t=>{const n=document.createElement("style"),s=e.litNonce;void 0!==s&&n.setAttribute("nonce",s),n.textContent=t.cssText,i.appendChild(n)}))})(n,this.constructor.elementStyles),n}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 n;const s=this.constructor._$Ep(e,i);if(void 0!==s&&!0===i.reflect){const r=(void 0!==(null===(n=i.converter)||void 0===n?void 0:n.toAttribute)?i.converter:d).toAttribute(t,i.type);this._$El=e,null==r?this.removeAttribute(s):this.setAttribute(s,r),this._$El=null}}_$AK(e,t){var i;const n=this.constructor,s=n._$Ev.get(e);if(void 0!==s&&this._$El!==s){const e=n.getPropertyOptions(s),r="function"==typeof e.converter?{fromAttribute:e.converter}:void 0!==(null===(i=e.converter)||void 0===i?void 0:i.fromAttribute)?e.converter:d;this._$El=s,this[s]=r.fromAttribute(t,e.type),this._$El=null}}requestUpdate(e,t,i){let n=!0;void 0!==e&&(((i=i||this.constructor.getPropertyOptions(e)).hasChanged||p)(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))):n=!1),!this.isUpdatePending&&n&&(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 b;g.finalized=!0,g.elementProperties=new Map,g.elementStyles=[],g.shadowRootOptions={mode:"open"},null==h||h({ReactiveElement:g}),(null!==(a=l.reactiveElementVersions)&&void 0!==a?a:l.reactiveElementVersions=[]).push("1.4.2");const v=window,f=v.trustedTypes,y=f?f.createPolicy("lit-html",{createHTML:e=>e}):void 0,w=`lit$${(Math.random()+"").slice(9)}$`,E="?"+w,S=`<${E}>`,P=document,C=(e="")=>P.createComment(e),k=e=>null===e||"object"!=typeof e&&"function"!=typeof e,x=Array.isArray,N=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,L=/-->/g,T=/>/g,A=RegExp(">|[ \t\n\f\r](?:([^\\s\"'>=/]+)([ \t\n\f\r]*=[ \t\n\f\r]*(?:[^ \t\n\f\r\"'`<>=]|(\"|')|))|$)","g"),M=/'/g,$=/"/g,D=/^(?:script|style|textarea|title)$/i,B=(e=>(t,...i)=>({_$litType$:e,strings:t,values:i}))(1),O=Symbol.for("lit-noChange"),H=Symbol.for("lit-nothing"),z=new WeakMap,I=P.createTreeWalker(P,129,null,!1),R=(e,t)=>{const i=e.length-1,n=[];let s,r=2===t?"":"",o=N;for(let t=0;t"===l[0]?(o=null!=s?s:N,u=-1):void 0===l[1]?u=-2:(u=o.lastIndex-l[2].length,a=l[1],o=void 0===l[3]?A:'"'===l[3]?$:M):o===$||o===M?o=A:o===L||o===T?o=N:(o=A,s=void 0);const h=o===A&&e[t+1].startsWith("/>")?" ":"";r+=o===N?i+S:u>=0?(n.push(a),i.slice(0,u)+"$lit$"+i.slice(u)+w+h):i+w+(-2===u?(n.push(void 0),t):h)}const a=r+(e[i]||"")+(2===t?"":"");if(!Array.isArray(e)||!e.hasOwnProperty("raw"))throw Error("invalid template strings array");return[void 0!==y?y.createHTML(a):a,n]};class V{constructor({strings:e,_$litType$:t},i){let n;this.parts=[];let s=0,r=0;const o=e.length-1,a=this.parts,[l,u]=R(e,t);if(this.el=V.createElement(l,i),I.currentNode=this.el.content,2===t){const e=this.el.content,t=e.firstChild;t.remove(),e.append(...t.childNodes)}for(;null!==(n=I.nextNode())&&a.length0){n.textContent=f?f.emptyScript:"";for(let i=0;ix(e)||"function"==typeof(null==e?void 0:e[Symbol.iterator]))(e)?this.k(e):this.g(e)}O(e,t=this._$AB){return this._$AA.parentNode.insertBefore(e,t)}T(e){this._$AH!==e&&(this._$AR(),this._$AH=this.O(e))}g(e){this._$AH!==H&&k(this._$AH)?this._$AA.nextSibling.data=e:this.T(P.createTextNode(e)),this._$AH=e}$(e){var t;const{values:i,_$litType$:n}=e,s="number"==typeof n?this._$AC(e):(void 0===n.el&&(n.el=V.createElement(n.h,this.options)),n);if((null===(t=this._$AH)||void 0===t?void 0:t._$AD)===s)this._$AH.p(i);else{const e=new G(s,this),t=e.v(this.options);e.p(i),this.T(t),this._$AH=e}}_$AC(e){let t=z.get(e.strings);return void 0===t&&z.set(e.strings,t=new V(e)),t}k(e){x(this._$AH)||(this._$AH=[],this._$AR());const t=this._$AH;let i,n=0;for(const s of e)n===t.length?t.push(i=new F(this.O(C()),this.O(C()),this,this.options)):i=t[n],i._$AI(s),n++;n2||""!==i[0]||""!==i[1]?(this._$AH=Array(i.length-1).fill(new String),this.strings=i):this._$AH=H}get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}_$AI(e,t=this,i,n){const s=this.strings;let r=!1;if(void 0===s)e=_(this,e,t,0),r=!k(e)||e!==this._$AH&&e!==O,r&&(this._$AH=e);else{const n=e;let o,a;for(e=s[0],o=0;oe}):void 0,w=`lit$${(Math.random()+"").slice(9)}$`,E="?"+w,S=`<${E}>`,P=document,C=(e="")=>P.createComment(e),k=e=>null===e||"object"!=typeof e&&"function"!=typeof e,x=Array.isArray,N=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,L=/-->/g,A=/>/g,T=RegExp(">|[ \t\n\f\r](?:([^\\s\"'>=/]+)([ \t\n\f\r]*=[ \t\n\f\r]*(?:[^ \t\n\f\r\"'`<>=]|(\"|')|))|$)","g"),M=/'/g,$=/"/g,D=/^(?:script|style|textarea|title)$/i,B=(e=>(t,...i)=>({_$litType$:e,strings:t,values:i}))(1),O=Symbol.for("lit-noChange"),H=Symbol.for("lit-nothing"),z=new WeakMap,R=P.createTreeWalker(P,129,null,!1),I=(e,t)=>{const i=e.length-1,n=[];let s,r=2===t?"":"",a=N;for(let t=0;t"===l[0]?(a=null!=s?s:N,u=-1):void 0===l[1]?u=-2:(u=a.lastIndex-l[2].length,o=l[1],a=void 0===l[3]?T:'"'===l[3]?$:M):a===$||a===M?a=T:a===L||a===A?a=N:(a=T,s=void 0);const h=a===T&&e[t+1].startsWith("/>")?" ":"";r+=a===N?i+S:u>=0?(n.push(o),i.slice(0,u)+"$lit$"+i.slice(u)+w+h):i+w+(-2===u?(n.push(void 0),t):h)}const o=r+(e[i]||"")+(2===t?"":"");if(!Array.isArray(e)||!e.hasOwnProperty("raw"))throw Error("invalid template strings array");return[void 0!==y?y.createHTML(o):o,n]};class V{constructor({strings:e,_$litType$:t},i){let n;this.parts=[];let s=0,r=0;const a=e.length-1,o=this.parts,[l,u]=I(e,t);if(this.el=V.createElement(l,i),R.currentNode=this.el.content,2===t){const e=this.el.content,t=e.firstChild;t.remove(),e.append(...t.childNodes)}for(;null!==(n=R.nextNode())&&o.length0){n.textContent=f?f.emptyScript:"";for(let i=0;ix(e)||"function"==typeof(null==e?void 0:e[Symbol.iterator]))(e)?this.k(e):this.g(e)}O(e,t=this._$AB){return this._$AA.parentNode.insertBefore(e,t)}T(e){this._$AH!==e&&(this._$AR(),this._$AH=this.O(e))}g(e){this._$AH!==H&&k(this._$AH)?this._$AA.nextSibling.data=e:this.T(P.createTextNode(e)),this._$AH=e}$(e){var t;const{values:i,_$litType$:n}=e,s="number"==typeof n?this._$AC(e):(void 0===n.el&&(n.el=V.createElement(n.h,this.options)),n);if((null===(t=this._$AH)||void 0===t?void 0:t._$AD)===s)this._$AH.p(i);else{const e=new F(s,this),t=e.v(this.options);e.p(i),this.T(t),this._$AH=e}}_$AC(e){let t=z.get(e.strings);return void 0===t&&z.set(e.strings,t=new V(e)),t}k(e){x(this._$AH)||(this._$AH=[],this._$AR());const t=this._$AH;let i,n=0;for(const s of e)n===t.length?t.push(i=new G(this.O(C()),this.O(C()),this,this.options)):i=t[n],i._$AI(s),n++;n2||""!==i[0]||""!==i[1]?(this._$AH=Array(i.length-1).fill(new String),this.strings=i):this._$AH=H}get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}_$AI(e,t=this,i,n){const s=this.strings;let r=!1;if(void 0===s)e=_(this,e,t,0),r=!k(e)||e!==this._$AH&&e!==O,r&&(this._$AH=e);else{const n=e;let a,o;for(e=s[0],a=0;a{var n,s;const r=null!==(n=null==i?void 0:i.renderBefore)&&void 0!==n?n:t;let o=r._$litPart$;if(void 0===o){const e=null!==(s=null==i?void 0:i.renderBefore)&&void 0!==s?s:null;r._$litPart$=o=new F(t.insertBefore(C(),e),e,void 0,null!=i?i:{})}return o._$AI(e),o})(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}}Q.finalized=!0,Q._$litElement$=!0,null===(Z=globalThis.litElementHydrateSupport)||void 0===Z||Z.call(globalThis,{LitElement:Q});const ee=globalThis.litElementPolyfillSupport;null==ee||ee({LitElement:Q}),(null!==(J=globalThis.litElementVersions)&&void 0!==J?J:globalThis.litElementVersions=[]).push("3.2.2");class te{static#e={"/Script/CoreUObject.Rotator":r``,"/Script/CoreUObject.Transform":r``,"/Script/CoreUObject.Vector":r``,"/Script/Engine.Actor":r``,"/Script/Engine.GameStateBase":r``,"/Script/Engine.Pawn":r``,"/Script/Engine.PlayerState":r``,bool:r``,byte:r``,class:r``,default:r``,exec:r``,int:r``,int64:r``,name:r``,real:r``,string:r``,wildcard: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 defaultCommentHeight=96;static defaultCommentWidth=400;static deleteNodesKeyboardKey="Delete";static distanceThreshold=5;static dragEventName="ueb-drag";static dragGeneralEventName="ueb-drag-general";static editTextEventName={begin:"ueb-edit-text-begin",end:"ueb-edit-text-end"};static enableZoomIn=["LeftControl","RightControl"];static expandGridSize=400;static focusEventName={begin:"blueprint-focus",end:"blueprint-unfocus"};static fontSize=r``;static getPinColor(e){if(!e)return te.#e.default;if(te.#e[e.pinType])return te.#e[e.pinType];if("struct"==e.entity.PinType.PinCategory||"object"==e.entity.PinType.PinCategory)switch(e.entity.PinType.PinSubCategoryObject.type){case"ScriptStruct":case"/Script/CoreUObject.ScriptStruct":return r``;default:if(e.entity.PinType.PinSubCategoryObject.getName().endsWith("Actor")||"Target"==e.getPinDisplayName())return te.#e["/Script/Engine.Actor"]}return te.#e.default}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 keysSeparator="+";static linkCurveHeight=15;static linkCurveWidth=80;static linkMinWidth=100;static linkRightSVGPath=(e,t,i)=>{let n=100-e;return`M ${e} 0 C ${t} 0, ${i} 0, 50 50 S ${n-t+e} 100, ${n} 100`};static maxZoom=7;static minZoom=-12;static mouseWheelFactor=.2;static nodeDeleteEventName="ueb-node-delete";static nodeDragGeneralEventName="ueb-node-drag-general";static nodeDragEventName="ueb-node-drag";static nodeName=(e,t)=>`${e}_${t}`;static nodeRadius=8;static nodeReflowEventName="ueb-node-reflow";static nodeType={callFunction:"/Script/BlueprintGraph.K2Node_CallFunction",comment:"/Script/UnrealEd.EdGraphNode_Comment",commutativeAssociativeBinaryOperator:"/Script/BlueprintGraph.K2Node_CommutativeAssociativeBinaryOperator",doN:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:Do N",dynamicCast:"/Script/BlueprintGraph.K2Node_DynamicCast",executionSequence:"/Script/BlueprintGraph.K2Node_ExecutionSequence",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",ifThenElse:"/Script/BlueprintGraph.K2Node_IfThenElse",knot:"/Script/BlueprintGraph.K2Node_Knot",macro:"/Script/BlueprintGraph.K2Node_MacroInstance",makeArray:"/Script/BlueprintGraph.K2Node_MakeArray",makeMap:"/Script/BlueprintGraph.K2Node_MakeMap",pawn:"/Script/Engine.Pawn",reverseForEachLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ReverseForEachLoop",select:"/Script/BlueprintGraph.K2Node_Select",variableGet:"/Script/BlueprintGraph.K2Node_VariableGet",variableSet:"/Script/BlueprintGraph.K2Node_VariableSet",whileLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:WhileLoop"};static selectAllKeyboardKey="(bCtrl=True,Key=A)";static smoothScrollTime=1e3;static trackingMouseEventName={begin:"ueb-tracking-mouse-begin",end:"ueb-tracking-mouse-end"};static windowApplyEventName="ueb-window-apply";static windowCancelEventName="ueb-window-cancel";static windowCloseEventName="ueb-window-close";static ModifierKeys=["Ctrl","Shift","Alt","Meta"];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:"Left",ArrowUp:"Up",ArrowRight:"Right",ArrowDown:"Down",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 ie{#t;get target(){return this.#t}#i;get blueprint(){return this.#i}options;listenHandler=()=>this.listenEvents();unlistenHandler=()=>this.unlistenEvents();constructor(e,t,i={}){i.consumeEvent??=!1,i.listenOnFocus??=!1,i.unlistenOnTextEdit??=!1,this.#t=e,this.#i=t,this.options=i}setup(){this.options.listenOnFocus&&(this.blueprint.addEventListener(te.focusEventName.begin,this.listenHandler),this.blueprint.addEventListener(te.focusEventName.end,this.unlistenHandler)),this.options.unlistenOnTextEdit&&(this.blueprint.addEventListener(te.editTextEventName.begin,this.unlistenHandler),this.blueprint.addEventListener(te.editTextEventName.end,this.listenHandler)),this.blueprint.focused&&this.listenEvents()}cleanup(){this.unlistenEvents(),this.blueprint.removeEventListener(te.focusEventName.begin,this.listenHandler),this.blueprint.removeEventListener(te.focusEventName.end,this.unlistenHandler),this.blueprint.removeEventListener(te.editTextEventName.begin,this.unlistenHandler),this.blueprint.removeEventListener(te.editTextEventName.end,this.listenHandler)}listenEvents(){}unlistenEvents(){}}class ne{#n;constructor(e){this.#n=e}calculate(e){return this.#n(e)}}class se{#s=new Map;subscribe(e,t){let i=this.#s;if(i.has(e)){let n=i.get(e);if(n.includes(t))return!1;n.push(t)}else{let n=!1,s=Object.getOwnPropertyDescriptor(this,e);if(!s&&(n=!0,s=Object.getOwnPropertyDescriptor(Object.getPrototypeOf(this),e)??{},!s))return!1;i.set(e,[t]);const r="value"in s,o="set"in s;if(!r&&!o)throw new Error(`Property ${e} is not a value or a setter`);const a=Symbol.for(e+"Storage"),l=Symbol.for(e+"ValInfo");Object.defineProperties(n?Object.getPrototypeOf(this):this,{[a]:{configurable:!0,enumerable:!1,...r?{value:this[e],writable:!0}:{get:s.get,set:s.set}},[l]:{configurable:!0,enumerable:!1,value:[n,r]},[e]:{configurable:!0,...r&&{get(){return this[a]}},set(t){this[a]=t,i.get(e).forEach((t=>{t(this[e])}))}}})}return!0}unsubscribe(e,t){let i=this.#s.get(e);if(!i?.includes(t))return!1;if(i.splice(i.indexOf(t),1),0==i.length){const t=Symbol.for(e+"Storage"),i=Symbol.for(e+"ValInfo"),n=this[i][0];this[i][1],Object.defineProperty(n?Object.getPrototypeOf(this):this,e,Object.getOwnPropertyDescriptor(n?Object.getPrototypeOf(this):this,t)),delete this[i],delete this[t]}return!0}}class re{static#r=new Map;static registerSerializer(e,t){re.#r.set(e,t)}static getSerializer(e){return re.#r.get(e)}}class oe{#o;get types(){return this.#o}constructor(...e){this.#o=e}getFirstType(){return this.#o[0]}}class ae{#a;get type(){return this.#a}set type(e){this.#a=e}#l=!0;get showDefault(){return this.#l}set showDefault(e){this.#l=e}#u;get value(){return this.#u}set value(e){this.#u=e}#c;get serialized(){return this.#c}set serialized(e){this.#c=e}#h;get ignored(){return this.#h}set ignored(e){this.#h=e}static isValueOfType(e,t){return null!=e&&(e instanceof t||e.constructor===t)}static sanitize(e,t){if(void 0===t&&(t=e?.constructor),t instanceof Array){let i=t.find((t=>ae.isValueOfType(e,t)));i||(i=t[0]),t=i}return t&&!ae.isValueOfType(e,t)&&(e=new t(e)),(e instanceof Boolean||e instanceof Number||e instanceof String)&&(e=e.valueOf()),e}constructor(e,t=!0,i,n=!1,s=!1){void 0===i&&(i=e instanceof Array?[]:()=>ae.sanitize(new e)),this.#a=e,this.#l=t,this.#u=i,this.#c=n,this.#h=s}}class le{static emptyObj={};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 clamp(e,t,i){return Math.min(Math.max(e,t),i)}static getScale(e){const t=e.blueprint?e.blueprint.getScale():getComputedStyle(e).getPropertyValue("--ueb-scale");return""!=t?parseFloat(t):1}static minDecimals(e,t=1){const i=e*10**t;return Math.abs(i%1)>Number.EPSILON?e.toString():e.toFixed(t)}static roundDecimals(e,t=1){const i=10**t;return Math.round(e*i)/i}static approximatelyEqual(e,t){return!(Math.abs(e-t)>Number.EPSILON)}static convertLocation(e,t,i=!1){const n=i?1:1/le.getScale(t),s=t.getBoundingClientRect();return[Math.round((e[0]-s.x)*n),Math.round((e[1]-s.y)*n)]}static isSerialized(e,t,i=le.objectGet(e.constructor.attributes,t)){return i instanceof ne?le.isSerialized(e,t,i.calculate(e)):i instanceof ae&&(!!i.serialized||le.isSerialized(e,t,i.type))}static objectGet(e,t,i){if(void 0!==e){if(!(t instanceof Array))throw new TypeError("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]]:le.objectGet(e[t[0]],t.slice(1),i):i}}static objectSet(e,t,i,n=!1,s=Object){if(!(t instanceof Array))throw new TypeError("Expected keys to be an array.");if(1==t.length){if(n||t[0]in e||void 0===e[t[0]])return e[t[0]]=i,!0}else if(t.length>0)return!n||e[t[0]]instanceof Object||(e[t[0]]=new s),le.objectSet(e[t[0]],t.slice(1),i,n,s);return!1}static equals(e,t){return(e=ae.sanitize(e))===(t=ae.sanitize(t))||(e instanceof Array&&t instanceof Array?e.length==t.length&&!e.find(((e,i)=>!le.equals(e,t[i]))):void 0)}static getType(e){return null===e?null:e instanceof ae?le.getType(e.type):e instanceof oe?e.types:e instanceof Function?e:e?.constructor}static snapToGrid(e,t){return 1===t?e:[t*Math.round(e[0]/t),t*Math.round(e[1]/t)]}static mergeArrays(e=[],t=[]){let i=[];e=[...e],t=[...t];e:for(let n=0;n","\n").replaceAll(/(\)/g,"")}static capitalFirstLetter(e){return 0===e.length?e:e.charAt(0).toLocaleUpperCase()+e.slice(1).toLocaleLowerCase()}static formatStringName(e){return e.trim().replace(/^b/,"").replaceAll(/^K2(?:Node|node)?_|(?<=[a-z])(?=[A-Z])|_|\s+/g," ").split(" ").map((e=>le.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 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 n=Math.atan2(t,e);return i&&n<0&&(n=2*Math.PI+n),[Math.sqrt(e*e+t*t),n]}static getCartesianCoordinates([e,t]){return[e*Math.cos(t),e*Math.sin(t)]}static range(e,t,i=1){return Array.from({length:Math.ceil((t-e)/i)},((t,n)=>e+n*i))}static paste(e,t){const i=new ClipboardEvent("paste",{bubbles:!0,cancelable:!0});i.clipboardData.setData("text",t),e.dispatchEvent(i)}static animate(e,t,i,n,s=(e=>{const t=e**3.5;return t/(t+(1-e)**3.5)})){const r=performance.now(),o=a=>{let l=(a-r)/i;le.approximatelyEqual(l,1)||l>1?l=1:requestAnimationFrame(o);const u=e+(t-e)*s(l);n(u)};requestAnimationFrame(o)}}class ue extends se{static attributes={};constructor(e={},t=!1){super();const i=(e,n,s={},r="")=>{const o=Object.getOwnPropertyNames(s);for(let a of le.mergeArrays(Object.getOwnPropertyNames(n),o)){let l=le.objectGet(s,[a]),u=n[a],c=le.getType(u);if(u instanceof ne&&(u=u.calculate(this),c=le.getType(u)),null!=u&&u===c&&(u=new c),t||(a in n?!(o.length>0)||a in s||void 0===u||u instanceof ae&&(!u.showDefault||u.ignored)||console.warn(`${this.constructor.name} will add attribute ${r}${a} not defined in the serialized data`):console.warn(`Attribute ${r}${a} in the serialized data is not defined in ${this.constructor.name}.attributes`)),c!==Object)if(void 0===l){if(u instanceof ae){if(!u.showDefault){e[a]=void 0;continue}u.serialized?u="":(c=u.type,u=u.value,u instanceof Function&&(u=u()))}u instanceof oe&&(c=u.getFirstType(),u=ae.sanitize(null,c)),u instanceof Array&&(u=[]),e[a]=ae.sanitize(u,c)}else l?.constructor===String&&u instanceof ae&&u.serialized&&u.type!==String&&(l=re.getSerializer(u.type).deserialize(l)),e[a]=ae.sanitize(l,le.getType(u));else e[a]={},i(e[a],n[a],s[a],a+".")}},n=this.constructor.attributes;e.constructor!==Object&&1===Object.getOwnPropertyNames(n).length&&(e={[Object.getOwnPropertyNames(n)[0]]:e}),i(this,n,e)}unexpectedKeys(){return Object.getOwnPropertyNames(this).length-Object.getOwnPropertyNames(this.constructor.attributes).length}}class ce extends ue{static attributes={type:String,path:String};constructor(e={}){e.constructor!==Object&&(e={path:e}),super(e),this.type,this.path}getName(){return this.path.match(/[^\.\/]+$/)?.[0]??""}}class he extends ue{static attributes={MemberParent:new ae(ce,!1),MemberName:""};constructor(e){super(e),this.MemberParent,this.MemberName}}class de extends ue{static attributes={value:String};static generateGuid(e=!0){let t=new Uint32Array(4);!0===e&&crypto.getRandomValues(t);let i="";return t.forEach((e=>{i+=("0".repeat(8)+e.toString(16).toUpperCase()).slice(-8)})),new de({value:i})}constructor(e){e||(e=de.generateGuid().value),super(e),this.value}valueOf(){return this.value}toString(){return this.value}}class pe extends ue{static attributes={value:String};static attributeConverter={fromAttribute:(e,t)=>new pe(e),toAttribute:(e,t)=>e.toString()};constructor(e){super(e),this.value}valueOf(){return this.value}toString(){return this.value}}class me extends ue{static attributes={value:0};constructor(e=0){super(e),this.value=Math.round(this.value)}valueOf(){return this.value}toString(){return this.value.toString()}}class ge extends ue{static lookbehind="INVTEXT";static attributes={value:String};constructor(e){super(e),this.value}}class be extends ue{static attributes={ActionName:"",bShift:!1,bCtrl:!1,bAlt:!1,bCmd:!1,Key:pe};constructor(e={}){e.ActionName=e.ActionName??"",e.bShift=e.bShift??!1,e.bCtrl=e.bCtrl??!1,e.bAlt=e.bAlt??!1,e.bCmd=e.bCmd??!1,super(e),this.ActionName,this.bShift,this.bCtrl,this.bAlt,this.bCmd,this.Key}}class ve extends ue{static attributes={value:0};constructor(e=0){super(e),this.value=le.clamp(this.value,0,1)}valueOf(){return this.value}toString(){return this.value.toFixed(6)}}class fe extends ue{static attributes={R:ve,G:ve,B:ve,A:new ae(ve,!0,(()=>new ve(1)),!1,!1),H:new ae(ve,!0,void 0,!1,!0),S:new ae(ve,!0,void 0,!1,!0),V:new ae(ve,!0,void 0,!1,!0)};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 fe({R:1,G:1,B:1})}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.#d()}#d(){const e=this.R.value,t=this.G.value,i=this.B.value;if(le.approximatelyEqual(e,t)&&le.approximatelyEqual(e,i)&&le.approximatelyEqual(t,i))return this.S.value=0,void(this.V.value=e);const n=Math.max(e,t,i),s=Math.min(e,t,i),r=n-s;let o;switch(n){case s:o=0;break;case e:o=(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.#d()}setFromSRGBANumber(e){this.A.value=(255&e)/255,this.B.value=fe.sRGBtoLinear((e>>8&255)/255),this.G.value=fe.sRGBtoLinear((e>>16&255)/255),this.R.value=fe.sRGBtoLinear((e>>24&255)/255),this.#d()}toString(){return le.printLinearColor(this)}}class ye extends ue{static lookbehind="NSLOCTEXT";static attributes={namespace:String,key:String,value:String};constructor(e){super(e),this.namespace,this.key,this.value}toString(){return le.capitalFirstLetter(this.value)}}class we extends ue{static attributes={MacroGraph:ce,GraphBlueprint:ce,GraphGuid:de};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 Ee extends ue{static attributes={value:String};constructor(e){super(e),this.value}valueOf(){return this.value}toString(){return this.value}}class Se extends ue{static attributes={objectName:Ee,pinGuid:de};constructor(e){super(e),this.objectName,this.pinGuid}}class Pe extends ue{static attributes={R:Number,P:Number,Y:Number};constructor(e){super(e),this.R,this.P,this.Y}}class Ce extends Pe{}class ke extends ue{static attributes={X:Number,Y:Number};constructor(e){super(e),this.X,this.Y}}class xe extends ke{}class Ne extends ue{static attributes={X:Number,Y:Number,Z:Number};constructor(e){super(e),this.X,this.Y,this.Z}}class Le extends Ne{}class Te extends ue{static#p={"/Script/CoreUObject.LinearColor":fe,"/Script/CoreUObject.Rotator":Pe,"/Script/CoreUObject.Vector2D":ke,"/Script/CoreUObject.Vector":Ne,bool:Boolean,exec:String,int:me,name:String,real:Number,string:String};static#m={"/Script/CoreUObject.Vector2D":xe,"/Script/CoreUObject.Vector":Le,"/Script/CoreUObject.Rotator":Ce};static lookbehind="Pin";static attributes={PinId:de,PinName:"",PinFriendlyName:new ae(new oe(ye,String),!1,null),PinToolTip:new ae(String,!1,""),Direction:new ae(String,!1,""),PinType:{PinCategory:"",PinSubCategory:"",PinSubCategoryObject:ce,PinSubCategoryMemberReference:null,PinValueType:null,ContainerType:ce,bIsReference:!1,bIsConst:!1,bIsWeakPointer:!1,bIsUObjectWrapper:!1,bSerializeAsSinglePrecisionFloat:!1},LinkedTo:new ae([Se],!1),DefaultValue:new ne((e=>new ae(e.getEntityType(!0)??String,!1,void 0,!0))),AutogeneratedDefaultValue:new ae(String,!1),DefaultObject:new ae(ce,!1,null),PersistentGuid:de,bHidden:!1,bNotConnectable:!1,bDefaultValueIsReadOnly:!1,bDefaultValueIsIgnored:!1,bAdvancedView:!1,bOrphanedPin:!1};constructor(e={},t=!1){super(e,t),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}getType(){return"struct"==this.PinType.PinCategory||"object"==this.PinType.PinCategory?this.PinType.PinSubCategoryObject.path:this.PinType.PinCategory}getEntityType(e=!1){const t=this.getType(),i=Te.#p[t],n=Te.#m[t];return e&&void 0!==n?n:i}getDisplayName(){let e=null;return this.PinToolTip&&(e=this.PinToolTip.match(/\s*(.+?(?=\n)|.+\S)\s*/))?le.formatStringName(e[1]):le.formatStringName(this.PinName)}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}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){this.LinkedTo;const i=this.LinkedTo?.find((i=>i.objectName.toString()==e&&i.pinGuid.valueOf()==t.PinId.valueOf()));return!i&&((this.LinkedTo??(this.LinkedTo=[])).push(new Se({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&&(1==this.LinkedTo.length?this.LinkedTo=void 0:this.LinkedTo.splice(i,1),!0)}getSubCategory(){return this.PinType.PinSubCategoryObject.path}}class Ae extends ue{static attributes={value:String};constructor(e){super(e),this.value}}class Me extends ue{static attributes={MemberScope:new ae(String,!1),MemberName:String,MemberGuid:de,bSelfContext:new ae(Boolean,!1,!1)};constructor(e){super(e),this.MemberName,this.GuidEntity,this.bSelfContext}}class $e extends ue{static attributes={Class:ce,Name:"",bIsPureFunc:new ae(Boolean,!1,!1),VariableReference:new ae(Me,!1,null),SelfContextInfo:new ae(Ae,!1,null),FunctionReference:new ae(he,!1,null),EventReference:new ae(he,!1,null),TargetType:new ae(ce,!1,null),MacroGraphReference:new ae(we,!1,null),Enum:new ae(ce,!1),CommentColor:new ae(fe,!1),bCommentBubbleVisible_InDetailsPanel:new ae(Boolean,!1),bColorCommentBubble:new ae(Boolean,!1,!1),MoveMode:new ae(Ae,!1),NodePosX:me,NodePosY:me,NodeWidth:new ae(me,!1),NodeHeight:new ae(me,!1),bCommentBubblePinned:new ae(Boolean,!1),bCommentBubbleVisible:new ae(Boolean,!1),NodeComment:new ae(String,!1),AdvancedPinDisplay:new ae(pe,!1,null),EnabledState:new ae(pe,!1,null),NodeGuid:de,ErrorType:new ae(me,!1),ErrorMsg:new ae(String,!1,""),CustomProperties:[Te]};static nameRegex=/^(\w+?)(?:_(\d+))?$/;static sequencerScriptingNameRegex=/\/Script\/SequencerScripting\.MovieSceneScripting(.+)Channel/;constructor(e,t=!1){super(e,t),this.Class,this.Name,this.bIsPureFunc,this.VariableReference,this.FunctionReference,this.EventReference,this.TargetType,this.MacroGraphReference,this.Enum,this.CommentColor,this.bCommentBubbleVisible_InDetailsPanel,this.NodePosX,this.NodePosY,this.NodeWidth,this.NodeHeight,this.bCommentBubblePinned,this.bCommentBubbleVisible,this.NodeComment,this.AdvancedPinDisplay,this.EnabledState,this.NodeGuid,this.ErrorType,this.ErrorMsg,this.CustomProperties}getClass(){return this.Class.path}getType(){let e=this.getClass();return e===te.nodeType.macro?this.MacroGraphReference.MacroGraph.path:e}getObjectName(e=!1){return e?this.getNameAndCounter()[0]:this.Name}getNameAndCounter(){const e=this.getObjectName(!1).match($e.nameRegex);let t="",i=null;return e?(e.length>1&&(t=e[1]),e.length>2&&(i=parseInt(e[2])),[t,i]):["",0]}getCounter(){return this.getNameAndCounter()[1]}getNodeWidth(){return this.NodeWidth??this.getType()==te.nodeType.comment?te.defaultCommentWidth:void 0}setNodeWidth(e){this.NodeWidth||(this.NodeWidth=new me),this.NodeWidth.value=e}getNodeHeight(){return this.NodeHeight??this.getType()==te.nodeType.comment?te.defaultCommentHeight:void 0}setNodeHeight(e){this.NodeHeight||(this.NodeHeight=new me),this.NodeHeight.value=e}}"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self&&self;function De(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}var Be={exports:{}};"undefined"!=typeof self&&self;var Oe=De(Be.exports=function(e){var t={};function i(n){if(t[n])return t[n].exports;var s=t[n]={i:n,l:!1,exports:{}};return e[n].call(s.exports,s,s.exports,i),s.l=!0,s.exports}return i.m=e,i.c=t,i.d=function(e,t,n){i.o(e,t)||Object.defineProperty(e,t,{configurable:!1,enumerable:!0,get:n})},i.r=function(e){Object.defineProperty(e,"__esModule",{value:!0})},i.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return i.d(t,"a",t),t},i.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},i.p="",i(i.s=0)}([function(e,t,i){function n(e){if(!(this instanceof n))return new n(e);this._=e}var s=n.prototype;function r(e,t){for(var i=0;i>7),buf:function(e){var t=o((function(e,t,i,n){return e.concat(i===n.length-1?Buffer.from([t,0]).readUInt16BE(0):n.readUInt16BE(i))}),[],e);return Buffer.from(a((function(e){return(e<<1&65535)>>8}),t))}(i.buf)}})),i}function u(){return"undefined"!=typeof Buffer}function c(){if(!u())throw new Error("Buffer global does not exist; please use webpack if you need to parse Buffers in the browser.")}function h(e){c();var t=o((function(e,t){return e+t}),0,e);if(t%8!=0)throw new Error("The bits ["+e.join(", ")+"] add up to "+t+" which is not an even number of bytes; the total should be divisible by 8");var i,s=t/8,r=(i=function(e){return e>48},o((function(e,t){return e||(i(t)?t:e)}),null,e));if(r)throw new Error(r+" bit range requested exceeds 48 bit (6 byte) Number max.");return new n((function(t,i){var n=s+i;return n>t.length?S(i,s.toString()+" bytes"):E(n,o((function(e,t){var i=l(t,e.buf);return{coll:e.coll.concat(i.v),buf:i.buf}}),{coll:[],buf:t.slice(i,n)},e).coll)}))}function d(e,t){return new n((function(i,n){return c(),n+t>i.length?S(n,t+" bytes for "+e):E(n+t,i.slice(n,n+t))}))}function p(e,t){if("number"!=typeof(i=t)||Math.floor(i)!==i||t<0||t>6)throw new Error(e+" requires integer length in range [0, 6].");var i}function m(e){return p("uintBE",e),d("uintBE("+e+")",e).map((function(t){return t.readUIntBE(0,e)}))}function g(e){return p("uintLE",e),d("uintLE("+e+")",e).map((function(t){return t.readUIntLE(0,e)}))}function b(e){return p("intBE",e),d("intBE("+e+")",e).map((function(t){return t.readIntBE(0,e)}))}function v(e){return p("intLE",e),d("intLE("+e+")",e).map((function(t){return t.readIntLE(0,e)}))}function f(e){return e instanceof n}function y(e){return"[object Array]"==={}.toString.call(e)}function w(e){return u()&&Buffer.isBuffer(e)}function E(e,t){return{status:!0,index:e,value:t,furthest:-1,expected:[]}}function S(e,t){return y(t)||(t=[t]),{status:!1,index:-1,value:null,furthest:e,expected:t}}function P(e,t){if(!t)return e;if(e.furthest>t.furthest)return e;var i=e.furthest===t.furthest?function(e,t){if(function(){if(void 0!==n._supportsSet)return n._supportsSet;var e="undefined"!=typeof Set;return n._supportsSet=e,e}()&&Array.from){for(var i=new Set(e),s=0;s=0;){if(o in i){n=i[o].line,0===r&&(r=i[o].lineStart);break}("\n"===e.charAt(o)||"\r"===e.charAt(o)&&"\n"!==e.charAt(o+1))&&(s++,0===r&&(r=o+1)),o--}var a=n+s,l=t-r;return i[t]={line:a,lineStart:r},{offset:t,line:a+1,column:l+1}}function x(e){if(!f(e))throw new Error("not a parser: "+e)}function N(e,t){return"string"==typeof e?e.charAt(t):e[t]}function L(e){if("number"!=typeof e)throw new Error("not a number: "+e)}function T(e){if("function"!=typeof e)throw new Error("not a function: "+e)}function A(e){if("string"!=typeof e)throw new Error("not a string: "+e)}var M=2,$=3,D=8,B=5*D,O=4*D,H=" ";function z(e,t){return new Array(t+1).join(e)}function I(e,t,i){var n=t-e.length;return n<=0?e:z(i,n)+e}function R(e,t,i,n){return{from:e-t>0?e-t:0,to:e+i>n?n:e+i}}function V(e,t){var i,n,s,r,l,u=t.index,c=u.offset,h=1;if(c===e.length)return"Got the end of the input";if(w(e)){var d=c-c%D,p=c-d,m=R(d,B,O+D,e.length),g=a((function(e){return a((function(e){return I(e.toString(16),2,"0")}),e)}),function(e,t){var i=e.length,n=[],s=0;if(i<=t)return[e.slice()];for(var r=0;r=4&&(i+=1),h=2,s=a((function(e){return e.length<=4?e.join(" "):e.slice(0,4).join(" ")+" "+e.slice(4).join(" ")}),g),(l=(8*(r.to>0?r.to-1:r.to)).toString(16).length)<2&&(l=2)}else{var b=e.split(/\r\n|[\n\r\u2028\u2029]/);i=u.column-1,n=u.line-1,r=R(n,M,$,b.length),s=b.slice(r.from,r.to),l=r.to.toString().length}var v=n-r.from;return w(e)&&(l=(8*(r.to>0?r.to-1:r.to)).toString(16).length)<2&&(l=2),o((function(t,n,s){var o,a=s===v,u=a?"> ":H;return o=w(e)?I((8*(r.from+s)).toString(16),l,"0"):I((r.from+s+1).toString(),l," "),[].concat(t,[u+o+" | "+n],a?[H+z(" ",l)+" | "+I("",i," ")+z("^",h)]:[])}),[],s).join("\n")}function _(e,t){return["\n","-- PARSING FAILED "+z("-",50),"\n\n",V(e,t),"\n\n",(i=t.expected,1===i.length?"Expected:\n\n"+i[0]:"Expected one of the following: \n\n"+i.join(", ")),"\n"].join("");var i}function G(e){return void 0!==e.flags?e.flags:[e.global?"g":"",e.ignoreCase?"i":"",e.multiline?"m":"",e.unicode?"u":"",e.sticky?"y":""].join("")}function F(){for(var e=[].slice.call(arguments),t=e.length,i=0;i=2?L(t):t=0;var i=function(e){return RegExp("^(?:"+e.source+")",G(e))}(e),s=""+e;return n((function(e,n){var r=i.exec(e.slice(n));if(r){if(0<=t&&t<=r.length){var o=r[0],a=r[t];return E(n+o.length,a)}return S(n,"valid match group (0 to "+r.length+") in "+s)}return S(n,s)}))}function K(e){return n((function(t,i){return E(i,e)}))}function Z(e){return n((function(t,i){return S(i,e)}))}function J(e){if(f(e))return n((function(t,i){var n=e._(t,i);return n.index=i,n.value="",n}));if("string"==typeof e)return J(Y(e));if(e instanceof RegExp)return J(q(e));throw new Error("not a string, regexp, or parser: "+e)}function Q(e){return x(e),n((function(t,i){var n=e._(t,i),s=t.slice(i,n.index);return n.status?S(i,'not "'+s+'"'):E(i,null)}))}function ee(e){return T(e),n((function(t,i){var n=N(t,i);return i=e.length?S(t,"any character/byte"):E(t+1,N(e,t))})),re=n((function(e,t){return E(e.length,e.slice(t))})),oe=n((function(e,t){return t=0})).desc(t)},n.optWhitespace=he,n.Parser=n,n.range=function(e,t){return ee((function(i){return e<=i&&i<=t})).desc(e+"-"+t)},n.regex=q,n.regexp=q,n.sepBy=X,n.sepBy1=W,n.seq=F,n.seqMap=j,n.seqObj=function(){for(var e,t={},i=0,s=(e=arguments,Array.prototype.slice.call(e)),r=s.length,o=0;o255)throw new Error("Value specified to byte constructor ("+e+"=0x"+e.toString(16)+") is larger in value than a single byte.");var t=(e>15?"0x":"0x0")+e.toString(16);return n((function(i,n){var s=N(i,n);return s===e?E(n+1,s):S(n,t)}))},buffer:function(e){return d("buffer",e).map((function(e){return Buffer.from(e)}))},encodedString:function(e,t){return d("string",t).map((function(t){return t.toString(e)}))},uintBE:m,uint8BE:m(1),uint16BE:m(2),uint32BE:m(4),uintLE:g,uint8LE:g(1),uint16LE:g(2),uint32LE:g(4),intBE:b,int8BE:b(1),int16BE:b(2),int32BE:b(4),intLE:v,int8LE:v(1),int16LE:v(2),int32LE:v(4),floatBE:d("floatBE",4).map((function(e){return e.readFloatBE(0)})),floatLE:d("floatLE",4).map((function(e){return e.readFloatLE(0)})),doubleBE:d("doubleBE",8).map((function(e){return e.readDoubleBE(0)})),doubleLE:d("doubleLE",8).map((function(e){return e.readDoubleLE(0)}))},e.exports=n}]));class He extends ue{static attributes={lookbehind:new ae(String,!1,"",!1,!0)};constructor(e){super(e),this.lookbehind}}class ze extends me{static attributes={value:0};constructor(e=0){super(e);const t=Math.round(this.value);this.value=t>=0&&t<256?t:0}valueOf(){return this.value}toString(){return this.value.toString()}}let Ie=Oe;class Re{static getGrammarForType(e,t,i=e.AttributeAnyValue){if(t instanceof ae){let n=Re.getGrammarForType(e,t.type,i);return!t.serialized||t.type instanceof String||(n=n.wrap(Ie.string('"'),Ie.string('"'))),n}switch(le.getType(t)){case Array:return Ie.seqMap(Ie.string("("),t.map((t=>Re.getGrammarForType(e,le.getType(t)))).reduce(((t,i)=>i&&t!==e.AttributeAnyValue?t.or(i):e.AttributeAnyValue)).trim(Ie.optWhitespace).sepBy(Ie.string(",")).skip(Ie.regex(/,?\s*/)),Ie.string(")"),((e,t,i)=>t));case Boolean:return e.Boolean;case ze:return e.Byte;case he:return e.FunctionReference;case de:return e.Guid;case pe:return e.Identifier;case me:return e.Integer;case ge:return e.InvariantText;case fe:return e.LinearColor;case ye:return e.LocalizedText;case we:return e.MacroGraphReference;case Number:return e.Number;case ce:return e.ObjectReference;case Te:return e.Pin;case Se:return e.PinReference;case ve:return e.RealUnit;case Pe:return e.Rotator;case Ce:return e.SimpleSerializationRotator;case xe:return e.SimpleSerializationVector2D;case Le:return e.SimpleSerializationVector;case String:return e.String;case Ae:return e.Symbol;case oe:return t.types.map((t=>Re.getGrammarForType(e,le.getType(t)))).reduce(((t,i)=>i&&t!==e.AttributeAnyValue?t.or(i):e.AttributeAnyValue));case Me:return e.VariableReference;case ke:return e.Vector2D;case Ne:return e.Vector;default:return i}}static ReferencePath=(e,t)=>Ie.alt(t,Ie.seq(Ie.string("/"),t.map((e=>e.toString())).sepBy1(Ie.string(".")).tieWith(".").sepBy1(Ie.string(":")).tieWith(":")).tie().atLeast(2).tie());static createAttributeGrammar=(e,t,i=Ie.string("=").trim(Ie.optWhitespace))=>e.AttributeName.skip(i).chain((i=>{const n=i.split("."),s=le.objectGet(t.attributes,n);return Re.getGrammarForType(e,s,e.AttributeAnyValue).map((e=>t=>le.objectSet(t,n,e,!0)))}));static createEntityGrammar=(e,t,i=!1)=>Ie.seqMap(t.lookbehind?Ie.seq(Ie.string(t.lookbehind),Ie.optWhitespace,Ie.string("(")):Ie.string("("),Re.createAttributeGrammar(e,t).trim(Ie.optWhitespace).sepBy(Ie.string(",")).skip(Ie.regex(/,?/).then(Ie.optWhitespace)),Ie.string(")"),((e,t,i)=>{let n={};return t.forEach((e=>e(n))),n})).chain((e=>{if(i){let i=0,n=0;for(const s in e)i+=s in t.attributes?0:1,++n;if(i+.5>Math.sqrt(n))return Ie.fail()}return Ie.succeed().map((()=>new t(e)))}));InlineWhitespace=e=>Ie.regex(/[^\S\n]+/).desc("single line whitespace");InlineOptWhitespace=e=>Ie.regex(/[^\S\n]*/).desc("single line optional whitespace");MultilineWhitespace=e=>Ie.regex(/[^\S\n]*\n\s*/).desc("whitespace with at least a newline");Null=e=>Ie.seq(Ie.string("("),e.InlineOptWhitespace,Ie.string(")")).map((()=>null)).desc("null: ()");Boolean=e=>Ie.alt(Ie.string("True"),Ie.string("true"),Ie.string("False"),Ie.string("false")).map((e=>"true"===e.toLocaleLowerCase())).desc("either True or False");HexDigit=e=>Ie.regex(/[0-9a-fA-f]/).desc("hexadecimal digit");Number=e=>Ie.regex(/[-\+]?[0-9]+(?:\.[0-9]+)?/).map(Number).desc("a number");RealNumber=e=>Ie.regex(/[-\+]?[0-9]+\.[0-9]+/).map(Number).desc("a number written as real");RealUnit=e=>Ie.regex(/\+?[0-9]+(?:\.[0-9]+)?/).map(Number).assert((e=>e>=0&&e<=1)).desc("a number between 0 and 1");NaturalNumber=e=>Ie.regex(/0|[1-9]\d*/).map(Number).desc("a natural number");ColorNumber=e=>e.NaturalNumber.assert((e=>0<=e&&e<256),"the color must be between 0 and 256 excluded");Word=e=>Ie.regex(/[a-zA-Z_]+/).desc("a word");String=e=>Ie.regex(/(?:[^"\\]|\\.)*/).wrap(Ie.string('"'),Ie.string('"')).map(le.unescapeString).desc('string (with possibility to escape the quote using ")');AttributeName=e=>e.Word.sepBy1(Ie.string(".")).tieWith(".").desc("dot-separated words");None=e=>Ie.string("None").map((()=>new ce({type:"None",path:""}))).desc("none");Integer=e=>Ie.regex(/[\-\+]?[0-9]+/).map((e=>new me(e))).desc("an integer");Byte=e=>Ie.regex(/\+?[0-9]+/).map((e=>parseInt(e))).assert((e=>e>=0&&e<256)).map((e=>new ze(e))).desc("a Byte");Guid=e=>e.HexDigit.times(32).tie().map((e=>new de({value:e}))).desc("32 digit hexadecimal value");Identifier=e=>Ie.regex(/\w+/).map((e=>new pe(e)));PathSymbol=e=>Ie.regex(/[0-9\w]+/).map((e=>new Ee({value:e})));PathSymbolOptSpaces=e=>Ie.regex(/[0-9\w]+(?: [0-9\w]+)+|[0-9\w]+/).map((e=>new Ee({value:e})));Symbol=e=>Ie.regex(/\w+/).map((e=>new Ae({value:e})));ObjectReference=e=>Ie.alt(e.None,...[Re.ReferencePath(e,e.PathSymbolOptSpaces).map((e=>new ce({type:"",path:e})))].flatMap((e=>[e.wrap(Ie.string('"'),Ie.string('"')),e.wrap(Ie.string("'\""),Ie.string("\"'"))])),Ie.seqMap(Re.ReferencePath(e,e.PathSymbolOptSpaces),Ie.optWhitespace,Ie.alt(...[Re.ReferencePath(e,e.PathSymbolOptSpaces)].flatMap((e=>[e.wrap(Ie.string('"'),Ie.string('"')),e.wrap(Ie.string("'\""),Ie.string("\"'"))]))),((e,t,i)=>new ce({type:e,path:i}))),Re.ReferencePath(e,e.PathSymbol).map((e=>new ce({type:"",path:e}))),e.Word.map((e=>new ce({type:e,path:""}))));LocalizedText=e=>Ie.seqMap(Ie.string(ye.lookbehind).skip(Ie.optWhitespace).skip(Ie.string("(")),e.String.trim(Ie.optWhitespace),Ie.string(","),e.String.trim(Ie.optWhitespace),Ie.string(","),e.String.trim(Ie.optWhitespace),Ie.string(")"),((e,t,i,n,s,r,o)=>new ye({namespace:t,key:n,value:r})));InvariantText=e=>e.String.trim(Ie.optWhitespace).wrap(Ie.string(ge.lookbehind).skip(Ie.optWhitespace).skip(Ie.string("(")),Ie.string(")")).map((e=>new ge({value:e})));AttributeAnyValue=e=>Ie.alt(e.Boolean,e.Guid,e.None,e.Null,e.Number,e.String,e.LocalizedText,e.InvariantText,e.PinReference,Re.createEntityGrammar(e,Ne,!0),Re.createEntityGrammar(e,fe,!0),Re.createEntityGrammar(e,ke,!0),e.UnknownKeys,e.ObjectReference,e.Symbol);PinReference=e=>Ie.seqMap(e.PathSymbol,Ie.whitespace,e.Guid,((e,t,i)=>new Se({objectName:e,pinGuid:i})));Vector2D=e=>Re.createEntityGrammar(e,ke);Vector=e=>Re.createEntityGrammar(e,Ne);Rotator=e=>Re.createEntityGrammar(e,Pe);SimpleSerializationRotator=e=>Ie.seqMap(e.Number,Ie.string(",").trim(Ie.optWhitespace),e.Number,Ie.string(",").trim(Ie.optWhitespace),e.Number,((e,t,i,n,s)=>new Ce({R:s,P:e,Y:i})));SimpleSerializationVector2D=e=>Ie.seqMap(e.Number,Ie.string(",").trim(Ie.optWhitespace),e.Number,((e,t,i)=>new xe({X:e,Y:i})));SimpleSerializationVector=e=>Ie.seqMap(e.Number,Ie.string(",").trim(Ie.optWhitespace),e.Number,Ie.string(",").trim(Ie.optWhitespace),e.Number,((e,t,i,n,s)=>new Le({X:e,Y:i,Z:s})));LinearColor=e=>Re.createEntityGrammar(e,fe);FunctionReference=e=>Re.createEntityGrammar(e,he);VariableReference=e=>Re.createEntityGrammar(e,Me);MacroGraphReference=e=>Re.createEntityGrammar(e,we);KeyBinding=e=>Ie.alt(e.Identifier.map((e=>new be({Key:e}))),Re.createEntityGrammar(e,be));Pin=e=>Re.createEntityGrammar(e,Te);CustomProperties=e=>Ie.string("CustomProperties").then(Ie.whitespace).then(e.Pin).map((e=>t=>{let i=le.objectGet(t,["CustomProperties"],[]);i.push(e),le.objectSet(t,["CustomProperties"],i,!0)}));Object=e=>Ie.seqMap(Ie.seq(Ie.string("Begin"),Ie.whitespace,Ie.string("Object"),Ie.whitespace),Ie.alt(e.CustomProperties,Re.createAttributeGrammar(e,$e)).sepBy1(Ie.whitespace),Ie.seq(e.MultilineWhitespace,Ie.string("End"),Ie.whitespace,Ie.string("Object")),((e,t,i)=>{let n={};return t.forEach((e=>e(n))),new $e(n)}));MultipleObject=e=>e.Object.sepBy1(Ie.whitespace).trim(Ie.optWhitespace);LinearColorFromHex=e=>Ie.string("#").then(e.HexDigit.times(2).tie().times(3,4)).trim(Ie.optWhitespace).map((([e,t,i,n])=>new fe({R:parseInt(e,16)/255,G:parseInt(t,16)/255,B:parseInt(i,16)/255,A:n?parseInt(n,16)/255:1})));LinearColorFromRGBList=e=>Ie.seqMap(e.ColorNumber,Ie.string(",").skip(Ie.optWhitespace),e.ColorNumber,Ie.string(",").skip(Ie.optWhitespace),e.ColorNumber.map(Number),((e,t,i,n,s)=>new fe({R:e/255,G:i/255,B:s/255,A:1})));LinearColorFromRGB=e=>Ie.string("rgb").then(e.LinearColorFromRGBList.wrap(Ie.regex(/\(\s*/),Ie.regex(/\s*\)/)));LinearColorFromRGBA=e=>Ie.string("rgba").then(Ie.seqMap(e.ColorNumber,Ie.string(",").skip(Ie.optWhitespace),e.ColorNumber,Ie.string(",").skip(Ie.optWhitespace),e.ColorNumber.map(Number),Ie.string(",").skip(Ie.optWhitespace),Ie.regex(/0?\.\d+|[01]/).map(Number),((e,t,i,n,s,r,o)=>new fe({R:e/255,G:i/255,B:s/255,A:o}))).wrap(Ie.regex(/\(\s*/),Ie.regex(/\s*\)/)));LinearColorFromAnyColor=e=>Ie.alt(e.LinearColorFromRGBList,e.LinearColorFromHex,e.LinearColorFromRGB,e.LinearColorFromRGBA);UnknownKeys=e=>Ie.seqMap(Ie.regex(/\w*\s*/).skip(Ie.string("(")),Ie.seqMap(e.AttributeName,Ie.string("=").trim(Ie.optWhitespace),e.AttributeAnyValue,((e,t,i)=>t=>le.objectSet(t,e.split("."),i,!0))).trim(Ie.optWhitespace).sepBy(Ie.string(",")).skip(Ie.regex(/,?/).then(Ie.optWhitespace)),Ie.string(")"),((e,t,i)=>{let n={};t.forEach((e=>e(n)));let s=new He(n);return e&&(s.lookbehind=e),s}))}class Ve{static grammar=Oe.createLanguage(new Re);constructor(e,t="",i=",",n=!1,s="=",r=(e=>e.join("."))){this.entityType=e,this.attributePrefix=t,this.attributeSeparator=i,this.trailingSeparator=n,this.attributeValueConjunctionSign=s,this.attributeKeyPrinter=r}deserialize(e){return this.read(e)}serialize(e,t=!1,i=e){return this.write(i,e,t)}read(e){throw new Error("Not implemented")}write(e,t,i){throw new Error("Not implemented")}writeValue(e,t,i,n){const s=le.getType(t),r=re.getSerializer(s);if(!r)throw new Error(`Unknown value type "${s.name}", a serializer must be registered in the SerializerFactory class, check initializeSerializerFactory.js`);return r.write(e,t,n)}subWrite(e,t,i,n){let s="",r=t.concat("");const o=r.length-1,a=i.constructor.attributes,l=a?le.mergeArrays(Object.getOwnPropertyNames(a),Object.getOwnPropertyNames(i)):Object.getOwnPropertyNames(i);for(const t of l){r[o]=t;const a=i[t];if(a?.constructor===Object)s+=(s.length?this.attributeSeparator:"")+this.subWrite(e,r,a,n);else if(void 0!==a&&this.showProperty(e,i,r,a)){const t=le.isSerialized(e,r);s+=(s.length?this.attributeSeparator:"")+this.attributePrefix+this.attributeKeyPrinter(r)+this.attributeValueConjunctionSign+(t?`"${this.writeValue(e,a,r,!0)}"`:this.writeValue(e,a,r,n))}}return this.trailingSeparator&&s.length&&1===r.length&&(s+=this.attributeSeparator),s}showProperty(e,t,i,n){const s=this.entityType.attributes,r=le.objectGet(s,i);return!(r instanceof ae)||!r.ignored&&(!le.equals(r.value,n)||r.showDefault)}}class _e extends Ve{constructor(){super($e," ","\n",!1)}showProperty(e,t,i,n){switch(i.toString()){case"Class":case"Name":case"CustomProperties":return!1}return super.showProperty(e,t,i,n)}read(e){const t=Ve.grammar.Object.parse(e);if(!t.status)throw new Error("Error when trying to parse the object.");return t.value}readMultiple(e){const t=Ve.grammar.MultipleObject.parse(e);if(!t.status)throw new Error("Error when trying to parse the object.");return t.value}write(e,t,i){return`Begin Object Class=${t.Class.path} Name=${this.writeValue(e,t.Name,["Name"],i)}\n${this.subWrite(e,[],t,i)+t.CustomProperties.map((e=>this.attributeSeparator+this.attributePrefix+"CustomProperties "+re.getSerializer(Te).serialize(e))).join("")}\nEnd Object\n`}}class Ge extends ie{static#g=new _e;#b;constructor(e,t,i={}){i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,super(e,t,i);let n=this;this.#b=e=>n.copied()}listenEvents(){window.addEventListener("copy",this.#b)}unlistenEvents(){window.removeEventListener("copy",this.#b)}getSerializedText(){return this.blueprint.getNodes(!0).map((e=>Ge.#g.serialize(e.entity,!1))).join("")}copied(){const e=this.getSerializedText();navigator.clipboard.writeText(e)}}class Fe{element;get blueprint(){return this.element.blueprint}#v=[];get inputObjects(){return this.#v}initialize(e){this.element=e}createInputObjects(){return[]}setup(){this.#v.forEach((e=>e.setup()))}cleanup(){this.#v.forEach((e=>e.cleanup()))}willUpdate(e){}update(e){}render(){return B``}firstUpdated(e){}updated(e){}inputSetup(){this.#v=this.createInputObjects()}}class je extends ie{#f;constructor(e,t,i={}){i.activateAnyKey??=!1,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 be)return e;if(e.constructor===String){const t=Ve.grammar.KeyBinding.parse(e);if(t.status)return t.value}throw new Error("Unexpected key value")})),super(e,t,i),this.#f=this.options.activationKeys??[];let n=this;this.keyDownHandler=e=>{(this.options.activateAnyKey||n.#f.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&&te.Keys[t.Key]==e.code)))&&(i.consumeEvent&&(e.preventDefault(),e.stopImmediatePropagation()),n.fire(),document.removeEventListener("keydown",n.keyDownHandler),document.addEventListener("keyup",n.keyUpHandler))},this.keyUpHandler=e=>{(this.options.activateAnyKey||n.#f.some((t=>t.bShift&&"Shift"==e.key||t.bCtrl&&"Control"==e.key||t.bAlt&&"Alt"==e.key||t.bCmd&&"Meta"==e.key||te.Keys[t.Key]==e.code)))&&(i.consumeEvent&&e.stopImmediatePropagation(),n.unfire(),document.removeEventListener("keyup",this.keyUpHandler),document.addEventListener("keydown",this.keyDownHandler))}}listenEvents(){document.addEventListener("keydown",this.keyDownHandler)}unlistenEvents(){document.removeEventListener("keydown",this.keyDownHandler)}fire(){}unfire(){}}class Ue extends je{constructor(e,t,i={}){i.activationKeys=te.deleteNodesKeyboardKey,super(e,t,i)}fire(){this.blueprint.removeGraphElement(...this.blueprint.getNodes(!0))}}class Xe extends ie{constructor(e,t,i={}){i.ignoreTranslateCompensate??=!1,i.ignoreScale??=!1,i.movementSpace??=t.getGridDOMElement()??document.documentElement,super(e,t,i),this.movementSpace=i.movementSpace}locationFromEvent(e){const t=le.convertLocation([e.clientX,e.clientY],this.movementSpace,this.options.ignoreScale);return this.options.ignoreTranslateCompensate?t:this.blueprint.compensateTranslation(t)}}class We extends Xe{#y=e=>{e.preventDefault();const t=this.locationFromEvent(e);this.wheel(Math.sign(e.deltaY*te.mouseWheelFactor),t)};#w=e=>e.preventDefault();constructor(e,t,i={}){i.listenOnFocus=!0,i.strictTarget??=!1,super(e,t,i),this.strictTarget=i.strictTarget}listenEvents(){this.movementSpace.addEventListener("wheel",this.#y,!1),this.movementSpace.parentElement?.addEventListener("wheel",this.#w)}unlistenEvents(){this.movementSpace.removeEventListener("wheel",this.#y,!1),this.movementSpace.parentElement?.removeEventListener("wheel",this.#w)}wheel(e,t){}}class Ye extends We{#E=!1;get enableZoonIn(){return this.#E}set enableZoonIn(e){(e=Boolean(e))!=this.#E&&(this.#E=e)}wheel(e,t){let i=this.blueprint.getZoom();e=-e,!this.enableZoonIn&&0==i&&e>0||(i+=e,this.blueprint.setZoom(i,t))}}class qe extends je{#S;constructor(e,t,i={}){i.activationKeys=te.enableZoomIn,super(e,t,i)}fire(){this.#S=this.blueprint.getInputObject(Ye),this.#S.enableZoonIn=!0}unfire(){this.#S.enableZoonIn=!1}}class Ke extends je{constructor(e,t,i={}){i.activationKeys=te.selectAllKeyboardKey,super(e,t,i)}fire(){this.blueprint.selectAll()}}class Ze extends Q{static properties={};#P=[];#i;get blueprint(){return this.#i}set blueprint(e){this.#i=e}#C;get entity(){return this.#C}set entity(e){this.#C=e}#k;get template(){return this.#k}isInitialized=!1;isSetup=!1;inputObjects=[];initialize(e,t){this.requestUpdate(),this.#C=e,this.#k=t,this.#k.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()))}createRenderRoot(){return this}shouldUpdate(e){return this.isInitialized&&this.isConnected}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);for(const t of this.#P)t(e);this.#P=[]}addNextUpdatedCallbacks(e,t=!1){this.#P.push(e),t&&this.requestUpdate()}isSameGraph(e){return this.blueprint&&this.blueprint==e?.blueprint}getInputObject(e){return this.template.inputObjects.find((t=>t.constructor==e))}}class Je extends Ze{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=te.dragEventName;static dragGeneralEventName=te.dragGeneralEventName;constructor(){super(),this.locationX=0,this.locationY=0,this.sizeX=0,this.sizeY=0}computeSizes(){const e=1/this.blueprint.getScale(),t=this.getBoundingClientRect();this.sizeX=t.width*e,this.sizeY=t.height*e}firstUpdated(e){super.firstUpdated(e),this.computeSizes()}setLocation([e,t],i=!0){const n=[e-this.locationX,t-this.locationY];if(this.locationX=e,this.locationY=t,this.blueprint&&i){const e=new CustomEvent(this.constructor.dragEventName,{detail:{value: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=le.snapToGrid([this.locationX,this.locationY],te.gridSize);this.locationX==e[0]&&this.locationY==e[1]||this.setLocation(e)}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 Qe extends Xe{#x=e=>{if(this.blueprint.setFocused(!0),e.button===this.options.clickButton)this.options.strictTarget&&e.target!=e.currentTarget||(this.options.consumeEvent&&e.stopImmediatePropagation(),this.#N.addEventListener("mousemove",this.#L),document.addEventListener("mouseup",this.#T),this.clickedPosition=this.locationFromEvent(e),this.blueprint.mousePosition[0]=this.clickedPosition[0],this.blueprint.mousePosition[1]=this.clickedPosition[1],this.target instanceof Je&&(this.clickedOffset=[this.clickedPosition[0]-this.target.locationX,this.clickedPosition[1]-this.target.locationY]),this.clicked(this.clickedPosition));else this.options.exitAnyButton||this.#T(e)};#L=e=>{this.options.consumeEvent&&e.stopImmediatePropagation(),this.#N.removeEventListener("mousemove",this.#L),this.#N.addEventListener("mousemove",this.#A);const t=this.getEvent(te.trackingMouseEventName.begin);this.#M=0==this.target.dispatchEvent(t);const i=this.locationFromEvent(e);this.lastLocation=le.snapToGrid(this.clickedPosition,this.stepSize),this.startDrag(i),this.started=!0};#A=e=>{this.options.consumeEvent&&e.stopImmediatePropagation();const t=this.locationFromEvent(e),i=[e.movementX,e.movementY];this.dragTo(t,i),this.#M&&(this.blueprint.mousePosition=this.locationFromEvent(e))};#T=e=>{if(!this.options.exitAnyButton||e.button==this.options.clickButton){if(this.options.consumeEvent&&e.stopImmediatePropagation(),this.#N.removeEventListener("mousemove",this.#L),this.#N.removeEventListener("mousemove",this.#A),document.removeEventListener("mouseup",this.#T),this.started&&this.endDrag(),this.unclicked(),this.#M){const e=this.getEvent(te.trackingMouseEventName.end);this.target.dispatchEvent(e),this.#M=!1}this.started=!1}};#M=!1;#N;#$;clickedOffset=[0,0];clickedPosition=[0,0];lastLocation=[0,0];started=!1;stepSize=1;constructor(e,t,i={}){i.clickButton??=0,i.consumeEvent??=!0,i.draggableElement??=e,i.exitAnyButton??=!0,i.moveEverywhere??=!1,i.movementSpace??=t?.getGridDOMElement(),i.repositionOnClick??=!1,i.strictTarget??=!1,super(e,t,i),this.stepSize=parseInt(i?.stepSize??te.gridSize),this.#N=this.options.moveEverywhere?document.documentElement:this.movementSpace,this.#$=this.options.draggableElement,this.listenEvents()}listenEvents(){super.listenEvents(),this.#$.addEventListener("mousedown",this.#x),2==this.options.clickButton&&this.#$.addEventListener("contextmenu",(e=>e.preventDefault()))}unlistenEvents(){super.unlistenEvents(),this.#$.removeEventListener("mousedown",this.#x)}getEvent(e){return new CustomEvent(e,{detail:{tracker:this},bubbles:!0,cancelable:!0})}clicked(e){}startDrag(e){}dragTo(e,t){}endDrag(){}unclicked(e){}}class et extends Qe{startDrag(){this.blueprint.scrolling=!0}dragTo(e,t){this.blueprint.scrollDelta([-t[0],-t[1]])}endDrag(){this.blueprint.scrolling=!1}}class tt extends Xe{#D=null;#B;#O;#H;constructor(e,t,i={}){i.listenOnFocus=!0,super(e,t,i);let n=this;this.#B=e=>{e.preventDefault(),n.blueprint.mousePosition=n.locationFromEvent(e)},this.#O=e=>{n.#D||(e.preventDefault(),this.#D=e.detail.tracker,n.unlistenMouseMove())},this.#H=e=>{n.#D==e.detail.tracker&&(e.preventDefault(),n.#D=null,n.listenMouseMove())}}listenMouseMove(){this.target.addEventListener("mousemove",this.#B)}unlistenMouseMove(){this.target.removeEventListener("mousemove",this.#B)}listenEvents(){this.listenMouseMove(),this.blueprint.addEventListener(te.trackingMouseEventName.begin,this.#O),this.blueprint.addEventListener(te.trackingMouseEventName.end,this.#H)}unlistenEvents(){this.unlistenMouseMove(),this.blueprint.removeEventListener(te.trackingMouseEventName.begin,this.#O),this.blueprint.removeEventListener(te.trackingMouseEventName.end,this.#H)}}class it{static#z=new Map;static registerElement(e,t){it.#z.set(e,t)}static getConstructor(e){return it.#z.get(e)}}class nt extends ie{static#g=new _e;#I;constructor(e,t,i={}){i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,super(e,t,i);let n=this;this.#I=e=>n.pasted(e.clipboardData.getData("Text"))}listenEvents(){window.addEventListener("paste",this.#I)}unlistenEvents(){window.removeEventListener("paste",this.#I)}pasted(e){let t=0,i=0,n=0,s=nt.#g.readMultiple(e).map((e=>{let s=it.getConstructor("ueb-node").newObject(e);return t+=s.locationY,i+=s.locationX,++n,s}));t/=n,i/=n,s.length>0&&this.blueprint.unselectAll();let r=this.blueprint.mousePosition;return s.forEach((e=>{const n=[r[0]-i,r[1]-t];e.addLocation(n),e.snapToGrid(),e.setSelected(!0)})),this.blueprint.addGraphElement(...s),!0}}class st extends Qe{constructor(e,t,i){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 rt extends ie{#R;constructor(e,t,i={}){i.listenOnFocus=!0,super(e,t,i);let n=this;this.#R=e=>n.clickedSomewhere(e.target),this.blueprint.focus&&document.addEventListener("click",this.#R)}clickedSomewhere(e){e.closest("ueb-blueprint")||this.blueprint.setFocused(!1)}listenEvents(){document.addEventListener("click",this.#R)}unlistenEvents(){document.removeEventListener("click",this.#R)}}class ot extends Fe{static styleVariables={"--ueb-font-size":`${te.fontSize}`,"--ueb-grid-axis-line-color":`${te.gridAxisLineColor}`,"--ueb-grid-expand":`${te.expandGridSize}px`,"--ueb-grid-line-color":`${te.gridLineColor}`,"--ueb-grid-line-width":`${te.gridLineWidth}px`,"--ueb-grid-set-line-color":`${te.gridSetLineColor}`,"--ueb-grid-set":`${te.gridSet}`,"--ueb-grid-size":`${te.gridSize}px`,"--ueb-link-min-width":`${te.linkMinWidth}`,"--ueb-node-radius":`${te.nodeRadius}px`};#V=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)}));headerElement;overlayElement;viewportElement;selectorElement;gridElement;linksContainerElement;nodesContainerElement;viewportSize=[0,0];initialize(e){super.initialize(e),this.element.style.cssText=Object.entries(ot.styleVariables).map((([e,t])=>`${e}:${t};`)).join("")}setup(){super.setup(),this.#V.observe(this.viewportElement,{box:"device-pixel-content-box"});const e=this.viewportElement.getBoundingClientRect();this.viewportSize[0]=e.width,this.viewportSize[1]=e.height}cleanup(){super.cleanup(),this.#V.unobserve(this.viewportElement)}createInputObjects(){return[...super.createInputObjects(),new Ge(this.element.getGridDOMElement(),this.element),new nt(this.element.getGridDOMElement(),this.element),new Ue(this.element.getGridDOMElement(),this.element),new Ke(this.element.getGridDOMElement(),this.element),new Ye(this.element.getGridDOMElement(),this.element),new st(this.element.getGridDOMElement(),this.element,{clickButton:0,exitAnyButton:!0,moveEverywhere:!0}),new et(this.element.getGridDOMElement(),this.element,{clickButton:2,exitAnyButton:!1,moveEverywhere:!0}),new rt(this.element.getGridDOMElement(),this.element),new tt(this.element.getGridDOMElement(),this.element),new qe(this.element.getGridDOMElement(),this.element)]}render(){return B`
Zoom ${0==this.element.zoom?"1:1":(this.element.zoom>0?"+":"")+this.element.zoom}
`}firstUpdated(e){super.firstUpdated(e),this.headerElement=this.element.querySelector(".ueb-viewport-header"),this.overlayElement=this.element.querySelector(".ueb-viewport-overlay"),this.viewportElement=this.element.querySelector(".ueb-viewport-body"),this.selectorElement=this.element.querySelector("ueb-selector"),this.gridElement=this.viewportElement.querySelector(".ueb-grid"),this.linksContainerElement=this.element.querySelector("[data-links]"),this.linksContainerElement.append(...this.element.getLinks()),this.nodesContainerElement=this.element.querySelector("[data-nodes]"),this.nodesContainerElement.append(...this.element.getNodes()),this.viewportElement.scroll(te.expandGridSize,te.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.element.scrollX,this.element.scrollY),e.has("zoom")){const t=e.get("zoom"),i=Math.min(t,this.element.zoom),n=Math.max(t,this.element.zoom),s=le.range(i,n),r=e=>`ueb-zoom-${e}`;te<0)).map(r)),this.element.classList.add(...s.filter((e=>e>0)).map(r))):(this.element.classList.remove(...s.filter((e=>e>0)).map(r)),this.element.classList.add(...s.filter((e=>e<0)).map(r)))}}getCommentNodes(e=!1){return this.element.querySelectorAll(`ueb-node[data-type="${te.nodeType.comment}"]${e?'[data-selected="true"]':""}`)}getPin(e){return this.element.querySelector(`ueb-node[data-name="${e.objectName}"] ueb-pin[data-id="${e.pinGuid}"]`)}isPointVisible(e,t){return!1}gridTopVisibilityBoundary(){return this.blueprint.scrollY-this.blueprint.translateY}gridRightVisibilityBoundary(){return this.gridLeftVisibilityBoundary()+this.viewportSize[0]}gridBottomVisibilityBoundary(){return this.gridTopVisibilityBoundary()+this.viewportSize[1]}gridLeftVisibilityBoundary(){return this.blueprint.scrollX-this.blueprint.translateX}}class at extends Ze{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 lt extends Fe{update(e){super.update(e);const[t,i,n,s]=[Math.round(this.element.fromX),Math.round(this.element.fromY),Math.round(this.element.toX),Math.round(this.element.toY)],[r,o,a,l]=[Math.min(t,n),Math.min(i,s),Math.abs(t-n),Math.abs(i-s)];(e.has("fromX")||e.has("toX"))&&(this.element.style.left=`${r}px`,this.element.style.width=`${a}px`),(e.has("fromY")||e.has("toY"))&&(this.element.style.top=`${o}px`,this.element.style.height=`${l}px`)}}class ut extends $e{constructor(e={},t){super(e,!0),this.Class=new ce("/Script/BlueprintGraph.K2Node_Knot"),this.Name="K2Node_Knot";const i=new Te({PinName:"InputPin"},!0),n=new Te({PinName:"OutputPin",Direction:"EGPD_Output"},!0);t&&(i.copyTypeFrom(t),n.copyTypeFrom(t)),this.CustomProperties=[i,n]}}class ct extends Xe{static ignoreDbClick=e=>{};#_=e=>{this.options.strictTarget&&e.target!==e.currentTarget||(this.options.consumeEvent&&e.stopImmediatePropagation(),this.clickedPosition=this.locationFromEvent(e),this.blueprint.mousePosition[0]=this.clickedPosition[0],this.blueprint.mousePosition[1]=this.clickedPosition[1],this.dbclicked(this.clickedPosition))};#G;get onDbClick(){return this.#G}set onDbClick(e){this.#G=e}clickedPosition=[0,0];constructor(e,t,i={},n=ct.ignoreDbClick){i.consumeEvent??=!0,i.strictTarget??=!1,super(e,t,i),this.#G=n,this.listenEvents()}listenEvents(){this.target.addEventListener("dblclick",this.#_)}unlistenEvents(){this.target.removeEventListener("dblclick",this.#_)}dbclicked(e){this.onDbClick(e)}}class ht extends lt{static decreasingValue(e,t){const i=-e*t[0]**2,n=t[1]-i/t[0];return e=>i/e+n}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]),n=e[1]-i*e[0];return s=>st[0]?t[1]:i*s+n}static c1DecreasingValue=ht.decreasingValue(-.15,[100,15]);static c2DecreasingValue=ht.decreasingValue(-.06,[500,130]);static c2Clamped=ht.clampedLine([0,100],[200,30]);#F=e=>{const t=new ut({},this.element.sourcePin.entity),i=it.getConstructor("ueb-node").newObject(t);i.setLocation(this.blueprint.snapToGrid(e)),this.blueprint.addGraphElement(i);const n=it.getConstructor("ueb-link").newObject(i.template.outputPin,this.element.destinationPin);this.element.destinationPin=i.template.inputPin,this.blueprint.addGraphElement(n)};createInputObjects(){return[...super.createInputObjects(),new ct(this.element.querySelector(".ueb-link-area"),this.blueprint,void 0,(e=>this.#F(e)))]}willUpdate(e){super.willUpdate(e);const t=this.element.sourcePin,i=this.element.destinationPin;if(e.has("fromX")||e.has("toX")){const e=t?.nodeElement.getType()==te.nodeType.knot,n=i?.nodeElement.getType()==te.nodeType.knot;!e||i&&!n||(t?.isInput()&&this.element.toX>this.element.fromX+te.distanceThreshold?this.element.sourcePin=t.nodeElement.template.outputPin:t?.isOutput()&&this.element.toXthis.element.fromX-te.distanceThreshold&&(this.element.destinationPin=i.nodeElement.template.inputPin))}const n=Math.max(Math.abs(this.element.fromX-this.element.toX),1);Math.max(Math.abs(this.element.fromY-this.element.toY),1);const s=Math.max(n,te.linkMinWidth),r=n/s,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(){const e=`ueb-id-${Math.floor(1e12*Math.random())}`;return B` ${this.element.linkMessageIcon||this.element.linkMessageText?B``:H}`}}class dt{static branchNode=B``;static breakStruct=B``;static cast=B``;static close=B``;static correct=B``;static doN=B``;static execPin=B``;static expandIcon=B``;static forEachLoop=B``;static functionSymbol=B``;static genericPin=B``;static loop=B``;static macro=B``;static makeArray=B``;static makeMap=B``;static makeStruct=B``;static referencePin=B``;static reject=B``;static select=B``;static sequence=B``}class pt extends at{static properties={...super.properties,source:{type:String,reflect:!0},destination:{type:String,reflect:!0},dragging:{type:Boolean,attribute:"data-dragging",converter:le.booleanConverter,reflect:!0},originatesFromInput:{type:Boolean,attribute:!1},svgPathD:{type:String,attribute:!1},linkMessageIcon:{type:String,attribute:!1},linkMessageText:{type:String,attribute:!1}};#j;get sourcePin(){return this.#j}set sourcePin(e){this.#U(e,!1)}#X;get destinationPin(){return this.#X}set destinationPin(e){this.#U(e,!0)}#W=()=>this.remove();#Y=e=>this.addSourceLocation(e.detail.value);#q=e=>this.addDestinationLocation(e.detail.value);#K=e=>this.setSourceLocation();#Z=e=>this.setDestinationLocation();linkMessageIcon=H;linkMessageText=H;pathElement;constructor(){super(),this.source=null,this.destination=null,this.dragging=!1,this.originatesFromInput=!1,this.startPercentage=0,this.svgPathD="",this.startPixels=0}static newObject(e,t){const i=new pt;return i.initialize(e,t),i}initialize(e,t){super.initialize({},new ht),e&&(this.sourcePin=e,t||(this.toX=this.fromX,this.toY=this.fromY)),t&&(this.destinationPin=t,e||(this.fromX=this.toX,this.fromY=this.toY)),this.#J()}#U(e,t){const i=()=>t?this.destinationPin:this.sourcePin;if(i()!=e){if(i()){const e=i().getNodeElement();e.removeEventListener(te.nodeDeleteEventName,this.#W),e.removeEventListener(te.nodeDragEventName,t?this.#q:this.#Y),e.removeEventListener(te.nodeReflowEventName,t?this.#Z:this.#K),this.#Q()}if(t?this.#X=e:this.#j=e,i()){const e=i().getNodeElement();e.addEventListener(te.nodeDeleteEventName,this.#W),e.addEventListener(te.nodeDragEventName,t?this.#q:this.#Y),e.addEventListener(te.nodeReflowEventName,t?this.#Z:this.#K),t?this.setDestinationLocation():(this.setSourceLocation(),this.originatesFromInput=this.sourcePin.isInput()),this.#J()}}}#J(){this.sourcePin&&this.destinationPin&&(this.sourcePin.linkTo(this.destinationPin),this.destinationPin.linkTo(this.sourcePin))}#Q(){this.sourcePin&&this.destinationPin&&(this.sourcePin.unlinkFrom(this.destinationPin),this.destinationPin.unlinkFrom(this.sourcePin))}cleanup(){super.cleanup(),this.#Q(),this.sourcePin=null,this.destinationPin=null}setSourceLocation(e=null){if(null==e){const t=this;if(!this.hasUpdated||!this.sourcePin.hasUpdated)return void Promise.all([this.updateComplete,this.sourcePin.updateComplete]).then((()=>t.setSourceLocation()));e=this.sourcePin.template.getLinkLocation()}const[t,i]=e;this.fromX=t,this.fromY=i}setDestinationLocation(e=null){if(null==e){const t=this;if(!this.hasUpdated||!this.destinationPin.hasUpdated)return void Promise.all([this.updateComplete,this.destinationPin.updateComplete]).then((()=>t.setDestinationLocation()));e=this.destinationPin.template.getLinkLocation()}this.toX=e[0],this.toY=e[1]}startDragging(){this.dragging=!0}finishDragging(){this.dragging=!1}removeMessage(){this.linkMessageIcon="",this.linkMessageText=""}setMessageConvertType(){this.linkMessageIcon="ueb-icon-conver-type",this.linkMessageText=`Convert ${this.sourcePin.pinType} to ${this.destinationPin.pinType}.`}setMessageCorrect(){this.linkMessageIcon=dt.correct,this.linkMessageText=H}setMessageReplace(){this.linkMessageIcon=dt.correct,this.linkMessageText=H}setMessageDirectionsIncompatible(){this.linkMessageIcon=dt.reject,this.linkMessageText=B`Directions are not compatbile.`}setMessagePlaceNode(){this.linkMessageIcon="ueb-icon-place-node",this.linkMessageText=B`Place a new node.`}setMessageReplaceLink(){this.linkMessageIcon=dt.correct,this.linkMessageText=B`Replace existing input connections.`}setMessageSameNode(){this.linkMessageIcon=dt.reject,this.linkMessageText=B`Both are on the same node.`}setMEssagetypesIncompatible(){this.linkMessageIcon=dt.reject,this.linkMessageText=B`${this.sourcePin.pinType} is not compatible with ${this.destinationPin.pinType}.`}}class mt extends Qe{clicked(e){this.options.repositionOnClick&&(this.target.setLocation(this.stepSize>1?le.snapToGrid(e,this.stepSize):e),this.clickedOffset=[0,0])}dragTo(e,t){const i=[this.target.locationX??this.lastLocation[0],this.target.locationY??this.lastLocation[1]],[n,s]=this.stepSize>1?[le.snapToGrid(e,this.stepSize),le.snapToGrid(i,this.stepSize)]:[e,i];0==(t=[n[0]-this.lastLocation[0],n[1]-this.lastLocation[1]])[0]&&0==t[1]||(t[0]+=s[0]-i[0],t[1]+=s[1]-i[1],this.dragAction(n,t),this.lastLocation=n)}dragAction(e,t){this.target.setLocation([e[0]-this.clickedOffset[0],e[1]-this.clickedOffset[1]])}}class gt extends mt{#ee;#te;#ie;#ne;constructor(e,t,i={}){super(e,t,i),i.onClicked&&(this.#ee=i.onClicked),i.onStartDrag&&(this.#te=i.onStartDrag),i.onDrag&&(this.#ie=i.onDrag),i.onEndDrag&&(this.#ne=i.onEndDrag)}clicked(){super.clicked(),this.#ee?.()}startDrag(){super.startDrag(),this.#te?.()}dragAction(e,t){this.#ie?.(e,t)}endDrag(){super.endDrag(),this.#ne?.()}}class bt extends Fe{getDraggableElement(){return this.element}createDraggableObject(){return new mt(this.element,this.blueprint,{draggableElement:this.getDraggableElement()})}createInputObjects(){return[...super.createInputObjects(),this.createDraggableObject()]}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 n=Math.max((t+i)/2,e);const s=this.topBoundary()-this.blueprint.template.gridTopVisibilityBoundary(),r=this.blueprint.template.gridBottomVisibilityBoundary()-this.bottomBoundary();const o=[t-n,s-Math.max((s+r)/2,e)];this.blueprint.scrollDelta(o,!0)}}class vt extends bt{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 ft extends mt{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 yt extends vt{getDraggableElement(){return this.element}createDraggableObject(){return new ft(this.element,this.blueprint,{draggableElement:this.getDraggableElement()})}firstUpdated(e){super.firstUpdated(e),this.element.selected&&!this.element.listeningDrag&&this.element.setSelected(!0)}}class wt extends yt{static#se={[te.nodeType.doN]:dt.doN,[te.nodeType.dynamicCast]:dt.cast,[te.nodeType.executionSequence]:dt.sequence,[te.nodeType.forEachElementInEnum]:dt.loop,[te.nodeType.forEachLoop]:dt.forEachLoop,[te.nodeType.forEachLoopWithBreak]:dt.forEachLoop,[te.nodeType.forLoop]:dt.loop,[te.nodeType.forLoopWithBreak]:dt.loop,[te.nodeType.ifThenElse]:dt.branchNode,[te.nodeType.makeArray]:dt.makeArray,[te.nodeType.makeMap]:dt.makeMap,[te.nodeType.select]:dt.select,[te.nodeType.whileLoop]:dt.loop,default:dt.functionSymbol};#re=!1;toggleAdvancedDisplayHandler=()=>{this.element.toggleShowAdvancedPinDisplay(),this.element.addNextUpdatedCallbacks((()=>this.element.acknowledgeReflow()),!0)};initialize(e){super.initialize(e),this.element.style.setProperty("--ueb-node-color",this.getColor().cssText)}getColor(){const e=r``,t=r``;switch(this.element.entity.getClass()){case te.nodeType.callFunction:return this.element.entity.bIsPureFunc?t:e;case te.nodeType.makeArray:case te.nodeType.makeMap:case te.nodeType.select:return t;case te.nodeType.macro:case te.nodeType.executionSequence:case te.nodeType.dynamicCast:return r``}return e}render(){const e=this.renderNodeIcon(),t=this.renderNodeName();return B`
${e?B`
${e}
`:H} ${t?B`
${t} ${this.#re&&this.element.entity.FunctionReference.MemberParent?B`
Target is ${le.formatStringName(this.element.entity.FunctionReference.MemberParent.getName())}
`:H}
`:H}
${"DevelopmentOnly"==this.element.enabledState?.toString()?B`
Development Only
`:H} ${this.element.advancedPinDisplay?B`
${dt.expandIcon}
`:H}
`}renderNodeIcon(){let e=wt.#se[this.element.getType()];return e||(this.element.getNodeDisplayName().startsWith("Break")?dt.breakStruct:this.element.entity.getClass()===te.nodeType.macro?dt.macro:wt.#se.default)}renderNodeName(){return this.element.getNodeDisplayName()}firstUpdated(e){super.firstUpdated(e),this.setupPins(),this.element.updateComplete.then((()=>this.element.acknowledgeReflow()))}setupPins(){const e=this.element.querySelector(".ueb-node-inputs"),t=this.element.querySelector(".ueb-node-outputs");this.element.nodeNameElement=this.element.querySelector(".ueb-node-name-text"),this.element.getPinElements().forEach((i=>{i.isInput()?e.appendChild(i):i.isOutput()&&t.appendChild(i)}))}createPinElements(){return this.element.getPinEntities().filter((e=>!e.isHidden())).map((e=>(this.#re||"Target"!=e.getDisplayName()||(this.#re=!0),it.getConstructor("ueb-pin").newObject(e,void 0,this.element))))}getPinElements(e){return e.querySelectorAll("ueb-pin")}linksChanged(){}}class Et extends wt{#oe=document.createElement("div");#ae=document.createElement("div");#le=document.createElement("div");#ue=document.createElement("div");#ce=document.createElement("div");#he=document.createElement("div");#de=document.createElement("div");#pe=document.createElement("div");initialize(e){super.initialize(e),this.element.classList.add("ueb-resizeable"),this.#oe.classList.add("ueb-resizeable-top"),this.#ae.classList.add("ueb-resizeable-right"),this.#le.classList.add("ueb-resizeable-bottom"),this.#ue.classList.add("ueb-resizeable-left"),this.#ce.classList.add("ueb-resizeable-top-right"),this.#he.classList.add("ueb-resizeable-bottom-right"),this.#de.classList.add("ueb-resizeable-bottom-left"),this.#pe.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.#oe,this.#ae,this.#le,this.#ue,this.#ce,this.#he,this.#de,this.#pe)}createInputObjects(){return[...super.createInputObjects(),new gt(this.#oe,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 gt(this.#ae,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.rightBoundary(),this.setSizeX(this.element.sizeX+t[0])},onEndDrag:()=>this.endResize()}),new gt(this.#le,this.blueprint,{onDrag:(e,t)=>{t[1]=e[1]-this.element.bottomBoundary(),this.setSizeY(this.element.sizeY+t[1])},onEndDrag:()=>this.endResize()}),new gt(this.#ue,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 gt(this.#ce,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 gt(this.#he,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 gt(this.#de,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 gt(this.#pe,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 St extends Et{#me=fe.getWhite();#ge=0;initialize(e){e.entity.CommentColor&&(this.#me.setFromRGBANumber(e.entity.CommentColor.toNumber()),this.#me.setFromHSVA(this.#me.H.value,this.#me.S.value,.67*Math.pow(this.#me.V.value,.45))),e.classList.add("ueb-node-style-comment","ueb-node-resizeable"),e.sizeX=25*te.gridSize,e.sizeY=6*te.gridSize,super.initialize(e)}getColor(){return r`${Math.round(255*this.#me.R.value)}${Math.round(255*this.#me.G.value)}${Math.round(255*this.#me.B.value)}`}getDraggableElement(){return this.element.querySelector(".ueb-node-top")}render(){return B`
${this.element.entity.NodeComment}
`}firstUpdated(e){super.firstUpdated(e);const t=this.getDraggableElement().getBoundingClientRect();this.#ge=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))>=te.gridSet*te.gridSize&&(this.element.setNodeWidth(e),!0)}setSizeY(e){return(e=Math.round(e))>=3*te.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.#ge:super.bottomBoundary()}leftBoundary(e=!1){return this.element.locationX}}class Pt extends Je{static properties={...super.properties,selected:{type:Boolean,attribute:"data-selected",reflect:!0,converter:le.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(te.nodeDragGeneralEventName,this.dragHandler)}setSelected(e=!0){this.selected=e,this.blueprint&&(this.selected?(this.listeningDrag=!0,this.blueprint.addEventListener(te.nodeDragGeneralEventName,this.dragHandler)):(this.blueprint.removeEventListener(te.nodeDragGeneralEventName,this.dragHandler),this.listeningDrag=!1))}}class Ct extends Qe{#be;#ve=null;#fe=e=>{if(!this.enteredPin){this.linkValid=!1,this.enteredPin=e.target;const t=this.link.sourcePin??this.target,i=this.enteredPin;t.nodeElement.getType()==te.nodeType.knot||i.nodeElement.getType()==te.nodeType.knot?(this.link.setMessageCorrect(),this.linkValid=!0):t.getNodeElement()==i.getNodeElement()?this.link.setMessageSameNode():t.isOutput()==i.isOutput()||t.isOutput()==i.isOutput()?this.link.setMessageDirectionsIncompatible():this.blueprint.getLinks([t,i]).length?(this.link.setMessageReplaceLink(),this.linkValid=!0):(this.link.setMessageCorrect(),this.linkValid=!0)}};#ye=e=>{this.enteredPin==e.target&&(this.enteredPin=null,this.linkValid=!1,this.link?.setMessagePlaceNode())};link;enteredPin;linkValid=!1;startDrag(e){this.target.nodeElement.getType()==te.nodeType.knot&&(this.#ve=this.target),this.link=it.getConstructor("ueb-link").newObject(this.target,null),this.blueprint.template.linksContainerElement.prepend(this.link),this.link.setMessagePlaceNode(),this.#be=this.blueprint.querySelectorAll("ueb-pin"),this.#be.forEach((e=>{if(e!=this.target){const t=e.template.getClickableElement();t.addEventListener("mouseenter",this.#fe),t.addEventListener("mouseleave",this.#ye)}})),this.link.startDragging(),this.link.setDestinationLocation(e)}dragTo(e,t){this.link.setDestinationLocation(e)}endDrag(){if(this.#be.forEach((e=>{e.removeEventListener("mouseenter",this.#fe),e.removeEventListener("mouseleave",this.#ye)})),this.enteredPin&&this.linkValid){if(this.#ve){const e=this.#ve!==this.link.sourcePin?this.link.sourcePin:this.enteredPin;if(this.#ve.isInput()&&e.isInput()||this.#ve.isOutput()&&e.isOutput()){const e=this.#ve.isInput()?this.#ve.nodeElement.template.outputPin:this.#ve.nodeElement.template.inputPin;this.#ve===this.link.sourcePin?this.link.sourcePin=e:this.enteredPin=e}}this.blueprint.addGraphElement(this.link),this.link.destinationPin=this.enteredPin,this.link.removeMessage(),this.link.finishDragging()}else this.link.finishDragging(),this.link.remove();this.enteredPin=null,this.link=null,this.#be=null}}class kt extends wt{#we=!1;#Ee=!1;#Se="";initialize(e){super.initialize(e),this.element.classList.add("ueb-node-style-glass"),this.#Se=this.element.getNodeDisplayName()}render(){return B`
${this.#Se?B`
${this.#Se}
`:H}
${this.#we?B`
`:H} ${this.#Ee?B`
`:H}
`}createPinElements(){return this.element.getPinEntities().filter((e=>!e.isHidden())).map((e=>{this.#we||=e.isInput(),this.#Ee||=e.isOutput();return it.getConstructor("ueb-pin").newObject(e,void 0,this.element)}))}}class xt extends kt{initialize(e){super.initialize(e),this.element.classList.add("ueb-node-style-conversion")}}class Nt extends kt{initialize(e){super.initialize(e),this.element.classList.add("ueb-node-style-operation")}}class Lt extends Fe{#Pe;get iconElement(){return this.#Pe}isNameRendered=!0;setup(){super.setup(),this.element.nodeElement=this.element.closest("ueb-node");const e=this.element.nodeElement.template;(e instanceof xt||e instanceof Nt)&&(this.isNameRendered=!1,this.element.requestUpdate())}createInputObjects(){return[new Ct(this.getClickableElement(),this.blueprint,{moveEverywhere:!0})]}render(){const e=B`
${this.renderIcon()}
`,t=B`
${this.isNameRendered?this.renderName():H} ${this.element.isInput()&&!this.element.entity.bDefaultValueIsIgnored?this.renderInput():B``}
`;return B`
${this.element.isInput()?B`${e}${t}`:B`${t}${e}`}
`}renderIcon(){return dt.genericPin}renderName(){return B`${this.element.getPinDisplayName()}`}renderInput(){return B``}updated(e){if(super.updated(e),this.element.isInput()&&e.has("isLinked")){const e=this.element.nodeElement;e.addNextUpdatedCallbacks((()=>e.acknowledgeReflow())),e.requestUpdate()}}firstUpdated(e){super.firstUpdated(e),this.element.style.setProperty("--ueb-pin-color-rgb",te.getPinColor(this.element).cssText),this.#Pe=this.element.querySelector(".ueb-pin-icon svg")??this.element}getLinkLocation(){const e=this.iconElement.getBoundingClientRect(),t=le.convertLocation([(e.left+e.right)/2,(e.top+e.bottom)/2],this.blueprint.template.gridElement);return this.blueprint.compensateTranslation(t)}getClickableElement(){return this.element}}class Tt extends Lt{render(){return this.element.isOutput()?B`
${this.renderIcon()}
`:B``}getLinkLocation(){const e=(this.element.isInput()?this.element.nodeElement.template.outputPin.template:this).iconElement.getBoundingClientRect(),t=le.convertLocation([this.element.isInput()?e.left+1:e.right+2,(e.top+e.bottom)/2],this.blueprint.template.gridElement);return this.blueprint.compensateTranslation(t)}}class At extends wt{static#Ce=new Set;#ke=null;#xe;get inputPin(){return this.#xe}#Ne;get outputPin(){return this.#Ne}initialize(e){super.initialize(e),this.element.classList.add("ueb-node-style-minimal")}findDirectionaPin(e){if(e.nodeElement.getType()!==te.nodeType.knot||At.#Ce.has(e))return At.#Ce.clear(),!0;At.#Ce.add(e);for(let t of e.getLinks().map((e=>this.blueprint.getPin(e))))if(this.findDirectionaPin(t))return!0;return!1}render(){return B`
`}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],n=it.getConstructor("ueb-pin");return[this.#xe=n.newObject(t,new Tt,this.element),this.#Ne=n.newObject(i,new Tt,this.element)]}linksChanged(){}}class Mt extends kt{initialize(e){super.initialize(e),e.getType()===te.nodeType.variableGet?this.element.classList.add("ueb-node-style-getter"):e.getType()===te.nodeType.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)}}class $t extends Pt{static#Le={};static properties={...Pt.properties,typePath:{type:String,attribute:"data-type",reflect:!0},nodeName:{type:String,attribute:"data-name",reflect:!0},advancedPinDisplay:{type:String,attribute:"data-advanced-display",converter:pe.attributeConverter,reflect:!0},enabledState:{type:String,attribute:"data-enabled-state",reflect:!0},nodeDisplayName:{type:String,attribute:!1},pureFunction:{type:Boolean,converter:le.booleanConverter,attribute:"data-pure-function",reflect:!0}};static dragEventName=te.nodeDragEventName;static dragGeneralEventName=te.nodeDragGeneralEventName;get blueprint(){return super.blueprint}set blueprint(e){super.blueprint=e,this.#Te.forEach((t=>t.blueprint=e))}#Ae;get nodeNameElement(){return this.#Ae}set nodeNameElement(e){this.#Ae=e}#Te=[];boundComments=[];#Me=!1;#$e=e=>{this.selected||this.#Me||(this.#Me=!0,this.addNextUpdatedCallbacks((()=>this.#Me=!1)),this.addLocation(e.detail.value))};static getTypeTemplate(e){if((e.getClass()===te.nodeType.callFunction||e.getClass()===te.nodeType.commutativeAssociativeBinaryOperator)&&"/Script/Engine.KismetMathLibrary"===e.FunctionReference.MemberParent.path){if(e.FunctionReference.MemberName?.startsWith("Conv_"))return xt;if(e.FunctionReference.MemberName?.startsWith("Percent_"))return Nt;switch(e.FunctionReference.MemberName){case"Abs":case"BMax":case"BMin":case"Exp":case"FMax":case"FMin":case"Max":case"MaxInt64":case"Min":case"MinInt64":return Nt}}switch(e.getClass()){case te.nodeType.comment:return St;case te.nodeType.knot:return At;case te.nodeType.variableGet:case te.nodeType.variableSet:return Mt}return wt}static fromSerializedObject(e){e=e.trim();let t=re.getSerializer($e).deserialize(e);return $t.newObject(t)}static newObject(e=new $e,t=new($t.getTypeTemplate(e))){const i=new $t;return i.initialize(e,t),i}initialize(e=new $e,t=new($t.getTypeTemplate(e))){super.initialize(e,t),this.#Te=this.template.createPinElements(),this.typePath=this.entity.getType(),this.nodeName=this.entity.getObjectName(),this.advancedPinDisplay=this.entity.AdvancedPinDisplay?.toString(),this.enabledState=this.entity.EnabledState,this.nodeDisplayName=this.getNodeDisplayName(),this.pureFunction=this.entity.bIsPureFunc,this.dragLinkObjects=[],super.setLocation([this.entity.NodePosX.value,this.entity.NodePosY.value]),this.entity.subscribe("AdvancedPinDisplay",(e=>this.advancedPinDisplay=e)),this.entity.subscribe("Name",(e=>this.nodeName=e)),this.entity.NodeWidth&&this.entity.NodeHeight?(this.sizeX=this.entity.NodeWidth.value,this.sizeY=this.entity.NodeHeight.value):this.updateComplete.then((()=>this.computeSizes()))}getUpdateComplete(){return Promise.all([super.getUpdateComplete(),...this.getPinElements().map((e=>e.updateComplete))]).then((()=>!0))}bindToComment(e){e==this||this.boundComments.includes(e)||(e.addEventListener(te.nodeDragEventName,this.#$e),this.boundComments.push(e))}unbindFromComment(e){const t=this.boundComments.indexOf(e);t>=0&&(e.removeEventListener(te.nodeDragEventName,this.#$e),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()}cleanup(){super.cleanup(),this.acknowledgeDelete()}getType(){return this.entity.getType()}getNodeName(){return this.entity.getObjectName()}getNodeDisplayName(){switch(this.getType()){case te.nodeType.callFunction:case te.nodeType.commutativeAssociativeBinaryOperator:if("AddKey"==this.entity.FunctionReference.MemberName){let e=this.entity.FunctionReference.MemberParent.path.match($e.sequencerScriptingNameRegex);if(e)return`Add Key (${le.formatStringName(e[1])})`}let e=this.entity.FunctionReference.MemberName;if("/Script/Engine.KismetMathLibrary"==this.entity.FunctionReference.MemberParent.path){if(e.startsWith("Conv_"))return"";if(e.startsWith("Percent_"))return"%";const t=e.match(/[BF]([A-Z]\w+)/);switch(t&&(e=t[1]),e){case"Abs":return"ABS";case"Exp":return"e";case"Max":case"MaxInt64":return"MAX";case"Min":case"MinInt64":return"MIN"}}return le.formatStringName(e);case te.nodeType.dynamicCast:return`Cast To ${this.entity.TargetType.getName()}`;case te.nodeType.executionSequence:return"Sequence";case te.nodeType.ifThenElse:return"Branch";case te.nodeType.forEachElementInEnum:return`For Each ${this.entity.Enum.getName()}`;case te.nodeType.forEachLoopWithBreak:return"For Each Loop with Break";case te.nodeType.variableGet:return"";case te.nodeType.variableSet:return"SET";default:return this.entity.getClass()===te.nodeType.macro?le.formatStringName(this.entity.MacroGraphReference.getMacroName()):le.formatStringName(this.entity.getNameAndCounter()[0])}}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)))}rename(e){if(this.entity.Name==e)return!1;for(let t of this.getPinElements())for(let i of t.getLinks())this.blueprint.getPin(i).redirectLink(t,new Se({objectName:e,pinGuid:t.entity.PinId}));this.entity.Name=e}getPinElements(){return this.#Te}getPinEntities(){return this.entity.CustomProperties.filter((e=>e instanceof Te))}setLocation(e=[0,0],t=!0){this.entity.NodePosX.value=e[0],this.entity.NodePosY.value=e[1],super.setLocation(e,t)}acknowledgeDelete(){let e=new CustomEvent(te.nodeDeleteEventName);this.dispatchEvent(e)}acknowledgeReflow(){this.addNextUpdatedCallbacks((()=>this.computeSizes()),!0);let e=new CustomEvent(te.nodeReflowEventName);this.dispatchEvent(e)}setShowAdvancedPinDisplay(e){this.entity.AdvancedPinDisplay=new pe(e?"Shown":"Hidden")}toggleShowAdvancedPinDisplay(){this.setShowAdvancedPinDisplay("Shown"!=this.entity.AdvancedPinDisplay?.toString())}}class Dt extends Ze{static properties={selecting:{type:Boolean,attribute:"data-selecting",reflect:!0,converter:le.booleanConverter},scrolling:{type:Boolean,attribute:"data-scrolling",reflect:!0,converter:le.booleanConverter},focused:{type:Boolean,attribute:"data-focused",reflect:!0,converter:le.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)};#De=!1;#Be=new Map;nodes=[];links=[];mousePosition=[0,0];waitingExpandUpdate=!1;constructor(){super(),this.selecting=!1,this.scrolling=!1,this.focused=!1,this.zoom=0,this.scrollX=te.expandGridSize,this.scrollY=te.expandGridSize,this.translateX=te.expandGridSize,this.translateY=te.expandGridSize,super.initialize({},new ot)}initialize(){}getGridDOMElement(){return this.template.gridElement}getScroll(){return[this.scrollX,this.scrollY]}setScroll([e,t]){this.scrollX=e,this.scrollY=t}scrollDelta(e,t=!1){if(t){let t=[0,0];le.animate(0,e[0],te.smoothScrollTime,(e=>{this.scrollDelta([e-t[0],0],!1),t[0]=e})),le.animate(0,e[1],te.smoothScrollTime,(e=>{this.scrollDelta([0,e-t[1]],!1),t[1]=e}))}else{const t=[2*te.expandGridSize,2*te.expandGridSize];let i=this.getScroll(),n=[i[0]+e[0],i[1]+e[1]],s=[0,0];for(let e=0;e<2;++e)n[e]t[e]-te.gridExpandThreshold*te.expandGridSize&&(s[e]=1);0==s[0]&&0==s[1]||this.seamlessExpand(s),i=this.getScroll(),n=[i[0]+e[0],i[1]+e[1]],this.setScroll(n)}}scrollCenter(){const e=this.getScroll(),t=[this.translateX-e[0],this.translateY-e[1]],i=this.getViewportSize().map((e=>e/2)),n=[t[0]-i[0],t[1]-i[1]];this.scrollDelta(n,!0)}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){return le.snapToGrid(e,te.gridSize)}seamlessExpand([e,t]){e=Math.round(e),t=Math.round(t);let i=this.getScale();[e,t]=[-e*te.expandGridSize,-t*te.expandGridSize],0!=e&&(this.scrollX+=e,e/=i),0!=t&&(this.scrollY+=t,t/=i),this.translateX+=e,this.translateY+=t}progressiveSnapToGrid(e){return te.expandGridSize*Math.round(e/te.expandGridSize+.5*Math.sign(e))}getZoom(){return this.zoom}setZoom(e,t){if((e=le.clamp(e,te.minZoom,te.maxZoom))==this.zoom)return;let i=this.getScale();this.zoom=e,t&&requestAnimationFrame((e=>{t[0]+=this.translateX,t[1]+=this.translateY;let n=this.getScale()/i,s=[n*t[0],n*t[1]];this.scrollDelta([(s[0]-t[0])*i,(s[1]-t[1])*i])}))}getScale(){return parseFloat(getComputedStyle(this.template.gridElement).getPropertyValue("--ueb-scale"))}compensateTranslation([e,t]){return[e-=this.translateX,t-=this.translateY]}getNodes(e=!1,[t,i,n,s]=[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()<=n&&e.leftBoundary()>=s))),r}getCommentNodes(e=!1){let t=[...this.template.getCommentNodes(e)];return 0===t.length&&(t=this.nodes.filter((t=>t.getType()===te.nodeType.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,t]=[]){if(null==e!=t==null){const i=e??t;return this.links.filter((e=>e.sourcePin==i||e.destinationPin==i))}return null!=e&&null!=t?this.links.filter((i=>i.sourcePin==e&&i.destinationPin==t||i.sourcePin==t&&i.destinationPin==e)):this.links}getLink(e,t,i=!1){return this.links.find((n=>n.sourcePin==e&&n.destinationPin==t||i&&n.sourcePin==t&&n.destinationPin==e))}selectAll(){this.getNodes().forEach((e=>Dt.nodeSelectToggleFunction(e,!0)))}unselectAll(){this.getNodes().forEach((e=>Dt.nodeSelectToggleFunction(e,!1)))}addGraphElement(...e){for(let t of e)if(t.blueprint=this,t instanceof $t&&!this.nodes.includes(t)){const e=t.entity.getObjectName(),i=this.nodes.find((t=>t.entity.getObjectName()==e));if(i){let e=i.entity.getObjectName(!0);this.#Be[e]=this.#Be[e]??-1;do{++this.#Be[e]}while(this.nodes.find((t=>t.entity.getObjectName()==te.nodeName(e,this.#Be[e]))));i.rename(te.nodeName(e,this.#Be[e]))}this.nodes.push(t),this.template.nodesContainerElement?.appendChild(t)}else t instanceof pt&&!this.links.includes(t)&&(this.links.push(t),this.template.linksContainerElement&&!this.template.linksContainerElement.contains(t)&&this.template.linksContainerElement.appendChild(t));e.filter((e=>e instanceof $t)).forEach((t=>t.sanitizeLinks(e))),e.filter((e=>e instanceof $t&&e.getType()==te.nodeType.comment)).forEach((e=>e.updateComplete.then((()=>e.template.manageNodesBind()))))}removeGraphElement(...e){for(let t of e)if(t.closest("ueb-blueprint")==this){t.remove();let e=t instanceof $t?this.nodes:t instanceof pt?this.links:null;e?.splice(e.findIndex((e=>e===t)),1)}}setFocused(e=!0){if(this.focused==e)return;let t=new CustomEvent(e?te.focusEventName.begin:te.focusEventName.end);this.focused=e,this.focused||this.unselectAll(),this.dispatchEvent(t)}acknowledgeEditText(e){const t=new CustomEvent(e?te.editTextEventName.begin:te.editTextEventName.end);this.dispatchEvent(t)}}customElements.define("ueb-blueprint",Dt);class Bt extends bt{#Oe;get locationChangeCallback(){return this.#Oe}set locationChangeCallback(e){this.#Oe=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 mt(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 Ot extends Bt{adjustLocation([e,t]){const i=Math.round(this.movementSpaceSize[0]/2);e-=i,t=-(t-i);let[n,s]=le.getPolarCoordinates([e,t]);return n=Math.min(n,i),[e,t]=le.getCartesianCoordinates([n,s]),this.locationChangeCallback?.(e/i,t/i),[e=Math.round(e+i),t=Math.round(-t+i)]}}class Ht extends Je{windowElement;setup(){super.setup(),this.windowElement=this.closest("ueb-window")}setLocation([e,t]){super.setLocation(this.template.adjustLocation([e,t]))}}class zt extends Ht{constructor(){super(),super.initialize({},new Ot)}static newObject(){return new zt}initialize(){}}class It extends Bt{adjustLocation([e,t]){return e=le.clamp(e,0,this.movementSpaceSize[0]),t=le.clamp(t,0,this.movementSpaceSize[1]),this.locationChangeCallback?.(e/this.movementSpaceSize[0],1-t/this.movementSpaceSize[1]),[e,t]}}class Rt extends Ht{constructor(){super(),super.initialize({},new It)}static newObject(){return new Rt}initialize(){}}class Vt extends Fe{#He=()=>{this.blueprint.acknowledgeEditText(!0),this.element.selectOnFocus&&getSelection().selectAllChildren(this.element)};#ze=()=>{this.blueprint.acknowledgeEditText(!1),document.getSelection()?.removeAllRanges()};#Ie=e=>e.target.querySelectorAll("br").forEach((e=>e.remove()));#Re=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"}setup(){super.setup(),this.element.addEventListener("focus",this.#He),this.element.addEventListener("focusout",this.#ze),this.element.singleLine&&this.element.addEventListener("input",this.#Ie),this.element.blurOnEnter&&this.element.addEventListener("keydown",this.#Re)}cleanup(){super.cleanup(),this.element.removeEventListener("focus",this.#He),this.element.removeEventListener("focusout",this.#ze),this.element.removeEventListener("input",this.#Ie),this.element.removeEventListener("keydown",this.#Re)}}class _t extends Ze{static properties={...super.properties,singleLine:{type:Boolean,attribute:"data-single-line",converter:le.booleanConverter,reflect:!0},selectOnFocus:{type:Boolean,attribute:"data-select-focus",converter:le.booleanConverter,reflect:!0},blurOnEnter:{type:Boolean,attribute:"data-blur-enter",converter:le.booleanConverter,reflect:!0}};constructor(){super(),this.singleLine=!1,this.selectOnFocus=!0,this.blurOnEnter=!0,super.initialize({},new Vt)}static newObject(){return new _t}initialize(){}}class Gt extends Qe{constructor(e,t,i={}){i.consumeEvent=!0,super(e,t,i)}}class Ft extends Lt{#Ve;#_e=e=>this.element.setDefaultValue(this.#Ve.checked);firstUpdated(e){super.firstUpdated(e),this.#Ve=this.element.querySelector(".ueb-pin-input")}setup(){super.setup(),this.#Ve?.addEventListener("change",this.#_e)}cleanup(){super.cleanup(),this.#Ve?.removeEventListener("change",this.#_e)}createInputObjects(){return[...super.createInputObjects(),new Gt(this.#Ve,this.blueprint)]}renderInput(){return B``}}class jt extends Lt{static singleLineInput=!1;static selectOnFocus=!0;#Ge;get inputContentElements(){return this.#Ge}static stringFromInputToUE(e){return e.replace(/(?=\n\s*)\n$/,"").replaceAll("\n","\\r\n")}static stringFromUEToInput(e){return e.replaceAll(/(?:\r|(?<=(?:^|[^\\])(?:\\\\)*)\\r)(?=\n)/g,"").replace(/(?<=\n\s*)$/,"\n")}#Fe=()=>this.setInputs(this.getInputs(),!0);firstUpdated(e){super.firstUpdated(e),this.#Ge=[...this.element.querySelectorAll("ueb-input")]}setup(){super.setup(),this.#Ge.forEach((e=>{e.addEventListener("focusout",this.#Fe)}))}cleanup(){super.cleanup(),this.#Ge.forEach((e=>{e.removeEventListener("focusout",this.#Fe)}))}createInputObjects(){return[...super.createInputObjects(),...this.#Ge.map((e=>new Gt(e,this.blueprint)))]}getInput(){return this.getInputs().reduce(((e,t)=>e+t),"")}getInputs(){return this.#Ge.map((e=>le.clearHTMLWhitespace(e.innerHTML)))}setInputs(e=[],t=!0){this.#Ge.forEach(this.constructor.singleLineInput?(t,i)=>t.innerText=e[i]:(t,i)=>t.innerText=e[i].replaceAll("\n","")),t&&this.setDefaultValue(e.map((e=>jt.stringFromInputToUE(e))),e),this.element.addNextUpdatedCallbacks((()=>this.element.nodeElement.acknowledgeReflow()))}setDefaultValue(e=[],t=e){this.element.setDefaultValue(e.join(""))}renderInput(){const e=this.constructor.singleLineInput,t=this.constructor.selectOnFocus;return B`
`}}class Ut extends jt{static singleLineInput=!0;setInputs(e=[],t=!1){e&&0!=e.length||(e=[this.getInput()]);let i=[];for(const t of e){let e=parseFloat(t);isNaN(e)&&(e=0,!1),i.push(e)}super.setInputs(e,!1),this.setDefaultValue(i,e)}setDefaultValue(e=[],t){this.element.setDefaultValue(e[0])}}class Xt extends Ut{setDefaultValue(e=[],t=e){const i=this.element.getDefaultValue(!0);if(!(i instanceof ze))throw new TypeError("Expected DefaultValue to be a ByteEntity");i.value=e[0],this.element.requestUpdate("DefaultValue",i)}renderInput(){return B`
`}}class Wt extends Lt{renderIcon(){return dt.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 B``;return B`${le.formatStringName(e)}`}}class Yt extends Ut{setDefaultValue(e=[],t=e){parseInt(e[0]);const i=this.element.getDefaultValue(!0);i.value=e[0],this.element.requestUpdate("DefaultValue",i)}renderInput(){return B`
`}} +var Z,J;class Q extends g{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 n,s;const r=null!==(n=null==i?void 0:i.renderBefore)&&void 0!==n?n:t;let a=r._$litPart$;if(void 0===a){const e=null!==(s=null==i?void 0:i.renderBefore)&&void 0!==s?s:null;r._$litPart$=a=new G(t.insertBefore(C(),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}}Q.finalized=!0,Q._$litElement$=!0,null===(Z=globalThis.litElementHydrateSupport)||void 0===Z||Z.call(globalThis,{LitElement:Q});const ee=globalThis.litElementPolyfillSupport;null==ee||ee({LitElement:Q}),(null!==(J=globalThis.litElementVersions)&&void 0!==J?J:globalThis.litElementVersions=[]).push("3.2.2");class te{static#e={"/Script/CoreUObject.Rotator":r``,"/Script/CoreUObject.Transform":r``,"/Script/CoreUObject.Vector":r``,"/Script/Engine.Actor":r``,"/Script/Engine.GameStateBase":r``,"/Script/Engine.Pawn":r``,"/Script/Engine.PlayerState":r``,bool:r``,byte:r``,class:r``,default:r``,exec:r``,int:r``,int64:r``,name:r``,real:r``,string:r``,wildcard: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 defaultCommentHeight=96;static defaultCommentWidth=400;static deleteNodesKeyboardKey="Delete";static distanceThreshold=5;static dragEventName="ueb-drag";static dragGeneralEventName="ueb-drag-general";static editTextEventName={begin:"ueb-edit-text-begin",end:"ueb-edit-text-end"};static enableZoomIn=["LeftControl","RightControl"];static expandGridSize=400;static focusEventName={begin:"blueprint-focus",end:"blueprint-unfocus"};static fontSize=r``;static getPinColor(e){if(!e)return te.#e.default;if(te.#e[e.pinType])return te.#e[e.pinType];if("struct"==e.entity.PinType.PinCategory||"object"==e.entity.PinType.PinCategory)switch(e.entity.PinType.PinSubCategoryObject.type){case"ScriptStruct":case"/Script/CoreUObject.ScriptStruct":return r``;default:if(e.entity.PinType.PinSubCategoryObject.getName().endsWith("Actor")||"Target"==e.getPinDisplayName())return te.#e["/Script/Engine.Actor"]}return te.#e.default}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 keysSeparator="+";static linkCurveHeight=15;static linkCurveWidth=80;static linkMinWidth=100;static linkRightSVGPath=(e,t,i)=>{let n=100-e;return`M ${e} 0 C ${t} 0, ${i} 0, 50 50 S ${n-t+e} 100, ${n} 100`};static maxZoom=7;static minZoom=-12;static mouseWheelFactor=.2;static nodeDeleteEventName="ueb-node-delete";static nodeDragGeneralEventName="ueb-node-drag-general";static nodeDragEventName="ueb-node-drag";static nodeName=(e,t)=>`${e}_${t}`;static nodeRadius=8;static nodeReflowEventName="ueb-node-reflow";static nodeType={callFunction:"/Script/BlueprintGraph.K2Node_CallFunction",comment:"/Script/UnrealEd.EdGraphNode_Comment",commutativeAssociativeBinaryOperator:"/Script/BlueprintGraph.K2Node_CommutativeAssociativeBinaryOperator",doN:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:Do N",dynamicCast:"/Script/BlueprintGraph.K2Node_DynamicCast",executionSequence:"/Script/BlueprintGraph.K2Node_ExecutionSequence",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",ifThenElse:"/Script/BlueprintGraph.K2Node_IfThenElse",knot:"/Script/BlueprintGraph.K2Node_Knot",macro:"/Script/BlueprintGraph.K2Node_MacroInstance",makeArray:"/Script/BlueprintGraph.K2Node_MakeArray",makeMap:"/Script/BlueprintGraph.K2Node_MakeMap",pawn:"/Script/Engine.Pawn",reverseForEachLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ReverseForEachLoop",select:"/Script/BlueprintGraph.K2Node_Select",variableGet:"/Script/BlueprintGraph.K2Node_VariableGet",variableSet:"/Script/BlueprintGraph.K2Node_VariableSet",whileLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:WhileLoop"};static selectAllKeyboardKey="(bCtrl=True,Key=A)";static smoothScrollTime=1e3;static trackingMouseEventName={begin:"ueb-tracking-mouse-begin",end:"ueb-tracking-mouse-end"};static windowApplyEventName="ueb-window-apply";static windowCancelEventName="ueb-window-cancel";static windowCloseEventName="ueb-window-close";static ModifierKeys=["Ctrl","Shift","Alt","Meta"];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:"Left",ArrowUp:"Up",ArrowRight:"Right",ArrowDown:"Down",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 ie{#t;get target(){return this.#t}#i;get blueprint(){return this.#i}options;listenHandler=()=>this.listenEvents();unlistenHandler=()=>this.unlistenEvents();constructor(e,t,i={}){i.consumeEvent??=!1,i.listenOnFocus??=!1,i.unlistenOnTextEdit??=!1,this.#t=e,this.#i=t,this.options=i}setup(){this.options.listenOnFocus&&(this.blueprint.addEventListener(te.focusEventName.begin,this.listenHandler),this.blueprint.addEventListener(te.focusEventName.end,this.unlistenHandler)),this.options.unlistenOnTextEdit&&(this.blueprint.addEventListener(te.editTextEventName.begin,this.unlistenHandler),this.blueprint.addEventListener(te.editTextEventName.end,this.listenHandler)),this.blueprint.focused&&this.listenEvents()}cleanup(){this.unlistenEvents(),this.blueprint.removeEventListener(te.focusEventName.begin,this.listenHandler),this.blueprint.removeEventListener(te.focusEventName.end,this.unlistenHandler),this.blueprint.removeEventListener(te.editTextEventName.begin,this.unlistenHandler),this.blueprint.removeEventListener(te.editTextEventName.end,this.listenHandler)}listenEvents(){}unlistenEvents(){}}class ne{#n=new Map;subscribe(e,t){let i=this.#n;if(i.has(e)){let n=i.get(e);if(n.includes(t))return!1;n.push(t)}else{let n=!1,s=Object.getOwnPropertyDescriptor(this,e);if(!s&&(n=!0,s=Object.getOwnPropertyDescriptor(Object.getPrototypeOf(this),e)??{},!s))return!1;i.set(e,[t]);const r="value"in s,a="set"in s;if(!r&&!a)throw new Error(`Property ${e} is not a value or a setter`);const o=Symbol.for(e+"Storage"),l=Symbol.for(e+"ValInfo");Object.defineProperties(n?Object.getPrototypeOf(this):this,{[o]:{configurable:!0,enumerable:!1,...r?{value:this[e],writable:!0}:{get:s.get,set:s.set}},[l]:{configurable:!0,enumerable:!1,value:[n,r]},[e]:{configurable:!0,...r&&{get(){return this[o]}},set(t){this[o]=t,i.get(e).forEach((t=>{t(this[e])}))}}})}return!0}unsubscribe(e,t){let i=this.#n.get(e);if(!i?.includes(t))return!1;if(i.splice(i.indexOf(t),1),0==i.length){const t=Symbol.for(e+"Storage"),i=Symbol.for(e+"ValInfo"),n=this[i][0];this[i][1],Object.defineProperty(n?Object.getPrototypeOf(this):this,e,Object.getOwnPropertyDescriptor(n?Object.getPrototypeOf(this):this,t)),delete this[i],delete this[t]}return!0}}class se{static#s=new Map;static registerSerializer(e,t){se.#s.set(e,t)}static getSerializer(e){return se.#s.get(e)}}class re{constructor(e){this.attributes=e}}class ae{static emptyObj={};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 clamp(e,t,i){return Math.min(Math.max(e,t),i)}static getScale(e){const t=e.blueprint?e.blueprint.getScale():getComputedStyle(e).getPropertyValue("--ueb-scale");return""!=t?parseFloat(t):1}static minDecimals(e,t=1){const i=e*10**t;return Math.abs(i%1)>Number.EPSILON?e.toString():e.toFixed(t)}static roundDecimals(e,t=1){const i=10**t;return Math.round(e*i)/i}static approximatelyEqual(e,t){return!(Math.abs(e-t)>Number.EPSILON)}static convertLocation(e,t,i=!1){const n=i?1:1/ae.getScale(t),s=t.getBoundingClientRect();return[Math.round((e[0]-s.x)*n),Math.round((e[1]-s.y)*n)]}static isSerialized(e,t,i=ae.objectGet(e.constructor.attributes,t)){return i.constructor===Object&&i.serialized}static objectGet(e,t,i){if(void 0!==e){if(!(t instanceof Array))throw new TypeError("UEBlueprint: Expected keys to be an array");return e instanceof re&&(e=e.attributes),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,n=!1,s=Object){if(!(t instanceof Array))throw new TypeError("Expected keys to be an array.");if(1==t.length){if(n||t[0]in e||void 0===e[t[0]])return e[t[0]]=i,!0}else if(t.length>0)return!n||e[t[0]]instanceof Object||(e[t[0]]=new s),ae.objectSet(e[t[0]],t.slice(1),i,n,s);return!1}static equals(e,t){return(e=ae.sanitize(e))===(t=ae.sanitize(t))||(e instanceof Array&&t instanceof Array?e.length==t.length&&!e.find(((e,i)=>!ae.equals(e,t[i]))):void 0)}static getType(e){return null===e?null:e.constructor===Object&&e.type instanceof Function?e.type:e?.constructor}static isValueOfType(e,t){return null===e||e instanceof t||e.constructor===t}static sanitize(e,t=e?.constructor){if(t instanceof Array){let i=t.find((t=>ae.isValueOfType(e,t)));i||(i=t[0]),t=i}return t&&!ae.isValueOfType(e,t)&&(e=new t(e)),(e instanceof Boolean||e instanceof Number||e instanceof String)&&(e=e.valueOf()),e}static snapToGrid(e,t){return 1===t?e:[t*Math.round(e[0]/t),t*Math.round(e[1]/t)]}static mergeArrays(e=[],t=[]){let i=[];e=[...e],t=[...t];e:for(let n=0;n","\n").replaceAll(/(\)/g,"")}static capitalFirstLetter(e){return 0===e.length?e:e.charAt(0).toLocaleUpperCase()+e.slice(1).toLocaleLowerCase()}static formatStringName(e){return e.trim().replace(/^b/,"").replaceAll(/^K2(?:Node|node)?_|(?<=[a-z])(?=[A-Z])|_|\s+/g," ").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 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 n=Math.atan2(t,e);return i&&n<0&&(n=2*Math.PI+n),[Math.sqrt(e*e+t*t),n]}static getCartesianCoordinates([e,t]){return[e*Math.cos(t),e*Math.sin(t)]}static range(e,t,i=1){return Array.from({length:Math.ceil((t-e)/i)},((t,n)=>e+n*i))}static paste(e,t){const i=new ClipboardEvent("paste",{bubbles:!0,cancelable:!0});i.clipboardData.setData("text",t),e.dispatchEvent(i)}static animate(e,t,i,n,s=(e=>{const t=e**3.5;return t/(t+(1-e)**3.5)})){const r=performance.now(),a=o=>{let l=(o-r)/i;ae.approximatelyEqual(l,1)||l>1?l=1:requestAnimationFrame(a);const u=e+(t-e)*s(l);n(u)};requestAnimationFrame(a)}static warn(e){console.warn("UEBlueprint: "+e)}}class oe{#r;get types(){return this.#r}constructor(...e){this.#r=e}getFirstType(){return this.#r[0]}}class le extends ne{static attributes={};static defaultAttribute={showDefault:!0,nullable:!1,ignored:!1,serialized:!1};constructor(e={},t=!1){super();const i=(e,n,s={},r="")=>{const a=Object.getOwnPropertyNames(s);for(let o of ae.mergeArrays(Object.getOwnPropertyNames(n),a)){let l=ae.objectGet(s,[o]),u=n[o];if(u instanceof re){e[o]={},i(e[o],u.attributes,s[o],o+".");continue}t||(o in n?a.length>0&&!(o in s)&&u.showDefault&&!u.ignored&&ae.warn(`${this.constructor.name} will add attribute ${r}${o} not defined in the serialized data`):ae.warn(`Attribute ${r}${o} in the serialized data is not defined in ${this.constructor.name}.attributes`));let c=u.value,h=u.type;u.serialized&&h instanceof Function&&(h=h(this)),h instanceof Array&&(h=Array),c instanceof Function&&(c=c(this)),h instanceof oe&&(h=null!=c?h.types.find((e=>c instanceof e||c.constructor==e))??h.getFirstType():h.getFirstType()),void 0===h&&(h=ae.getType(c)),void 0===l?(void 0===c&&(c=ae.sanitize(new h)),u.showDefault?(u.serialized&&c.constructor!==String&&(c=se.getSerializer(h).deserialize(c)),e[o]=ae.sanitize(c,h)):e[o]=void 0):(l?.constructor===String&&u.serialized&&h!==String&&(l=se.getSerializer(h).deserialize(l)),e[o]=ae.sanitize(l,h))}},n=this.constructor.attributes;e.constructor!==Object&&1===Object.getOwnPropertyNames(n).length&&(e={[Object.getOwnPropertyNames(n)[0]]:e}),i(this,n,e)}static cleanupAttributes(e,t=""){for(const i in e){if(e[i]instanceof re){this.cleanupAttributes(e[i].attributes,t+"."+i);continue}e[i].constructor!==Object&&(e[i]={value:e[i]});const n=e[i];if(void 0!==n.type||n.value instanceof Function||(n.type=ae.getType(n.value)),e[i]={...le.defaultAttribute,...n},void 0===n.value&&void 0===n.type)throw new Error(`UEBlueprint: Expected either "type" or "value" property in ${this.name} attribute ${t}`+i);null===n.value&&(e[i].nullable=!0)}}static isValueOfType(e,t){return null!=e&&(e instanceof t||e.constructor===t)}unexpectedKeys(){return Object.getOwnPropertyNames(this).length-Object.getOwnPropertyNames(this.constructor.attributes).length}}class ue extends le{static attributes={value:0};static{this.cleanupAttributes(this.attributes)}constructor(e=0){super(e),this.value=Math.round(this.value)}valueOf(){return this.value}toString(){return this.value.toString()}}class ce extends ue{static attributes={value:0};static{this.cleanupAttributes(this.attributes)}constructor(e=0){super(e);const t=Math.round(this.value);this.value=t>=0&&t<256?t:0}valueOf(){return this.value}toString(){return this.value.toString()}}class he extends le{static attributes={type:"",path:""};static{this.cleanupAttributes(this.attributes)}constructor(e={}){e.constructor===String&&(e={path:e}),super(e),this.type,this.path}getName(){return this.path.match(/[^\.\/]+$/)?.[0]??""}}class de extends le{static attributes={MemberParent:{type:he,showDefault:!1},MemberName:""};static{this.cleanupAttributes(this.attributes)}constructor(e){super(e),this.MemberParent,this.MemberName}}class pe extends le{static attributes={value:""};static{this.cleanupAttributes(this.attributes)}static generateGuid(e=!0){let t=new Uint32Array(4);!0===e&&crypto.getRandomValues(t);let i="";return t.forEach((e=>{i+=("0".repeat(8)+e.toString(16).toUpperCase()).slice(-8)})),new pe({value:i})}constructor(e){e||(e=pe.generateGuid().value),super(e),this.value}valueOf(){return this.value}toString(){return this.value}}class me extends le{static attributes={value:""};static{this.cleanupAttributes(this.attributes)}static attributeConverter={fromAttribute:(e,t)=>new me(e),toAttribute:(e,t)=>e.toString()};constructor(e){super(e),this.value}valueOf(){return this.value}toString(){return this.value}}class ge extends le{static lookbehind="INVTEXT";static attributes={value:""};static{this.cleanupAttributes(this.attributes)}constructor(e){super(e),this.value}}class be extends le{static attributes={ActionName:"",bShift:!1,bCtrl:!1,bAlt:!1,bCmd:!1,Key:{type:me}};static{this.cleanupAttributes(this.attributes)}constructor(e={}){e.ActionName=e.ActionName??"",e.bShift=e.bShift??!1,e.bCtrl=e.bCtrl??!1,e.bAlt=e.bAlt??!1,e.bCmd=e.bCmd??!1,super(e),this.ActionName,this.bShift,this.bCtrl,this.bAlt,this.bCmd,this.Key}}class ve extends le{static attributes={value:0};static{this.cleanupAttributes(this.attributes)}constructor(e=0){super(e),this.value=ae.clamp(this.value,0,1)}valueOf(){return this.value}toString(){return this.value.toFixed(6)}}class fe extends le{static attributes={R:{type:ve},G:{type:ve},B:{type:ve},A:{type:ve,value:()=>new ve(1),showDefault:!0},H:{type:ve,showDefault:!0,ignored:!0},S:{type:ve,showDefault:!0,ignored:!0},V:{type:ve,showDefault:!0,ignored:!0}};static{this.cleanupAttributes(this.attributes)}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 fe({R:1,G:1,B:1})}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(ae.approximatelyEqual(e,t)&&ae.approximatelyEqual(e,i)&&ae.approximatelyEqual(t,i))return this.S.value=0,void(this.V.value=e);const n=Math.max(e,t,i),s=Math.min(e,t,i),r=n-s;let a;switch(n){case s: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.#a()}setFromSRGBANumber(e){this.A.value=(255&e)/255,this.B.value=fe.sRGBtoLinear((e>>8&255)/255),this.G.value=fe.sRGBtoLinear((e>>16&255)/255),this.R.value=fe.sRGBtoLinear((e>>24&255)/255),this.#a()}toString(){return ae.printLinearColor(this)}}class ye extends le{static lookbehind="NSLOCTEXT";static attributes={namespace:"",key:"",value:""};static{this.cleanupAttributes(this.attributes)}constructor(e){super(e),this.namespace,this.key,this.value}toString(){return ae.capitalFirstLetter(this.value)}}class we extends le{static attributes={MacroGraph:{type:he},GraphBlueprint:{type:he},GraphGuid:{type:pe}};static{this.cleanupAttributes(this.attributes)}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 Ee extends le{static attributes={value:""};static{this.cleanupAttributes(this.attributes)}constructor(e){super(e),this.value}valueOf(){return this.value}toString(){return this.value}}class Se extends le{static attributes={objectName:{type:Ee},pinGuid:{type:pe}};static{this.cleanupAttributes(this.attributes)}constructor(e){super(e),this.objectName,this.pinGuid}}class Pe extends le{static attributes={R:{value:0},P:{value:0},Y:{value:0}};static{this.cleanupAttributes(this.attributes)}constructor(e){super(e),this.R,this.P,this.Y}getRoll(){return this.R}getPitch(){return this.P}getYaw(){return this.Y}}class Ce extends Pe{}class ke extends le{static attributes={X:0,Y:0};constructor(e){super(e),this.X,this.Y}}class xe extends ke{}class Ne extends le{static attributes={X:0,Y:0,Z:0};constructor(e){super(e),this.X,this.Y,this.Z}}class Le extends Ne{}class Ae extends le{static#o={"/Script/CoreUObject.LinearColor":fe,"/Script/CoreUObject.Rotator":Pe,"/Script/CoreUObject.Vector2D":ke,"/Script/CoreUObject.Vector":Ne,bool:Boolean,exec:String,int:ue,name:String,real:Number,string:String};static#l={"/Script/CoreUObject.Vector2D":xe,"/Script/CoreUObject.Vector":Le,"/Script/CoreUObject.Rotator":Ce};static lookbehind="Pin";static attributes={PinId:{type:pe},PinName:"",PinFriendlyName:{type:new oe(ye,String),showDefault:!1},PinToolTip:{type:String,showDefault:!1},Direction:{type:String,showDefault:!1},PinType:new re({PinCategory:"",PinSubCategory:"",PinSubCategoryObject:{type:he},PinSubCategoryMemberReference:{type:he,value:null},PinValueType:{type:String,value:null},ContainerType:{type:he},bIsReference:!1,bIsConst:!1,bIsWeakPointer:!1,bIsUObjectWrapper:!1,bSerializeAsSinglePrecisionFloat:!1}),LinkedTo:{type:[Se],showDefault:!1},DefaultValue:{type:e=>e.getEntityType(!0)??String,serialized:!0,showDefault:!1},AutogeneratedDefaultValue:{type:String,showDefault:!1},DefaultObject:{type:he,showDefault:!1,value:null},PersistentGuid:{type:pe},bHidden:!1,bNotConnectable:!1,bDefaultValueIsReadOnly:!1,bDefaultValueIsIgnored:!1,bAdvancedView:!1,bOrphanedPin:!1};static{this.cleanupAttributes(this.attributes)}constructor(e={},t=!1){super(e,t),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}getType(){return"struct"==this.PinType.PinCategory||"object"==this.PinType.PinCategory?this.PinType.PinSubCategoryObject.path:this.PinType.PinCategory}getEntityType(e=!1){const t=this.getType(),i=Ae.#o[t],n=Ae.#l[t];return e&&void 0!==n?n:i}getDisplayName(){let e=null;return this.PinToolTip&&(e=this.PinToolTip.match(/\s*(.+?(?=\n)|.+\S)\s*/))?ae.formatStringName(e[1]):ae.formatStringName(this.PinName)}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}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){this.LinkedTo;const i=this.LinkedTo?.find((i=>i.objectName.toString()==e&&i.pinGuid.valueOf()==t.PinId.valueOf()));return!i&&((this.LinkedTo??(this.LinkedTo=[])).push(new Se({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&&(1==this.LinkedTo.length?this.LinkedTo=void 0:this.LinkedTo.splice(i,1),!0)}getSubCategory(){return this.PinType.PinSubCategoryObject.path}}class Te extends le{static attributes={value:""};static{this.cleanupAttributes(this.attributes)}constructor(e){super(e),this.value}}class Me extends le{static attributes={MemberScope:{value:"",showDefault:!1},MemberName:"",MemberGuid:{type:pe},bSelfContext:{value:!1,showDefault:!1}};constructor(e){super(e),this.MemberName,this.GuidEntity,this.bSelfContext}}class $e extends le{static attributes={Class:{type:he},Name:"",bIsPureFunc:{value:!1,showDefault:!1},VariableReference:{type:Me,value:null,showDefault:!1},SelfContextInfo:{type:Te,value:null,showDefault:!1},FunctionReference:{type:de,value:null,showDefault:!1},EventReference:{type:de,value:null,showDefault:!1},TargetType:{type:he,value:null,showDefault:!1},MacroGraphReference:{type:we,value:null,showDefault:!1},Enum:{type:he,showDefault:!1},CommentColor:{type:fe,showDefault:!1},bCommentBubbleVisible_InDetailsPanel:{type:Boolean,showDefault:!1},bColorCommentBubble:{type:Boolean,value:!1,showDefault:!1},MoveMode:{type:Te,showDefault:!1},NodePosX:{type:ue},NodePosY:{type:ue},NodeWidth:{type:ue,showDefault:!1},NodeHeight:{type:ue,showDefault:!1},bCommentBubblePinned:{type:Boolean,showDefault:!1},bCommentBubbleVisible:{type:Boolean,showDefault:!1},NodeComment:{type:String,showDefault:!1},AdvancedPinDisplay:{type:me,value:null,showDefault:!1},EnabledState:{type:me,value:null,showDefault:!1},NodeGuid:{type:pe},ErrorType:{type:ue,showDefault:!1},ErrorMsg:{type:String,value:"",showDefault:!1},CustomProperties:{type:[Ae]}};static nameRegex=/^(\w+?)(?:_(\d+))?$/;static sequencerScriptingNameRegex=/\/Script\/SequencerScripting\.MovieSceneScripting(.+)Channel/;static{this.cleanupAttributes(this.attributes)}constructor(e,t=!1){super(e,t),this.Class,this.Name,this.bIsPureFunc,this.VariableReference,this.FunctionReference,this.EventReference,this.TargetType,this.MacroGraphReference,this.Enum,this.CommentColor,this.bCommentBubbleVisible_InDetailsPanel,this.NodePosX,this.NodePosY,this.NodeWidth,this.NodeHeight,this.bCommentBubblePinned,this.bCommentBubbleVisible,this.NodeComment,this.AdvancedPinDisplay,this.EnabledState,this.NodeGuid,this.ErrorType,this.ErrorMsg,this.CustomProperties}getClass(){return this.Class.path}getType(){let e=this.getClass();return e===te.nodeType.macro?this.MacroGraphReference.MacroGraph.path:e}getObjectName(e=!1){return e?this.getNameAndCounter()[0]:this.Name}getNameAndCounter(){const e=this.getObjectName(!1).match($e.nameRegex);let t="",i=null;return e?(e.length>1&&(t=e[1]),e.length>2&&(i=parseInt(e[2])),[t,i]):["",0]}getCounter(){return this.getNameAndCounter()[1]}getNodeWidth(){return this.NodeWidth??this.getType()==te.nodeType.comment?te.defaultCommentWidth:void 0}setNodeWidth(e){this.NodeWidth||(this.NodeWidth=new ue),this.NodeWidth.value=e}getNodeHeight(){return this.NodeHeight??this.getType()==te.nodeType.comment?te.defaultCommentHeight:void 0}setNodeHeight(e){this.NodeHeight||(this.NodeHeight=new ue),this.NodeHeight.value=e}}"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self&&self;function De(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}var Be={exports:{}};"undefined"!=typeof self&&self;var Oe=De(Be.exports=function(e){var t={};function i(n){if(t[n])return t[n].exports;var s=t[n]={i:n,l:!1,exports:{}};return e[n].call(s.exports,s,s.exports,i),s.l=!0,s.exports}return i.m=e,i.c=t,i.d=function(e,t,n){i.o(e,t)||Object.defineProperty(e,t,{configurable:!1,enumerable:!0,get:n})},i.r=function(e){Object.defineProperty(e,"__esModule",{value:!0})},i.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return i.d(t,"a",t),t},i.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},i.p="",i(i.s=0)}([function(e,t,i){function n(e){if(!(this instanceof n))return new n(e);this._=e}var s=n.prototype;function r(e,t){for(var i=0;i>7),buf:function(e){var t=a((function(e,t,i,n){return e.concat(i===n.length-1?Buffer.from([t,0]).readUInt16BE(0):n.readUInt16BE(i))}),[],e);return Buffer.from(o((function(e){return(e<<1&65535)>>8}),t))}(i.buf)}})),i}function u(){return"undefined"!=typeof Buffer}function c(){if(!u())throw new Error("Buffer global does not exist; please use webpack if you need to parse Buffers in the browser.")}function h(e){c();var t=a((function(e,t){return e+t}),0,e);if(t%8!=0)throw new Error("The bits ["+e.join(", ")+"] add up to "+t+" which is not an even number of bytes; the total should be divisible by 8");var i,s=t/8,r=(i=function(e){return e>48},a((function(e,t){return e||(i(t)?t:e)}),null,e));if(r)throw new Error(r+" bit range requested exceeds 48 bit (6 byte) Number max.");return new n((function(t,i){var n=s+i;return n>t.length?S(i,s.toString()+" bytes"):E(n,a((function(e,t){var i=l(t,e.buf);return{coll:e.coll.concat(i.v),buf:i.buf}}),{coll:[],buf:t.slice(i,n)},e).coll)}))}function d(e,t){return new n((function(i,n){return c(),n+t>i.length?S(n,t+" bytes for "+e):E(n+t,i.slice(n,n+t))}))}function p(e,t){if("number"!=typeof(i=t)||Math.floor(i)!==i||t<0||t>6)throw new Error(e+" requires integer length in range [0, 6].");var i}function m(e){return p("uintBE",e),d("uintBE("+e+")",e).map((function(t){return t.readUIntBE(0,e)}))}function g(e){return p("uintLE",e),d("uintLE("+e+")",e).map((function(t){return t.readUIntLE(0,e)}))}function b(e){return p("intBE",e),d("intBE("+e+")",e).map((function(t){return t.readIntBE(0,e)}))}function v(e){return p("intLE",e),d("intLE("+e+")",e).map((function(t){return t.readIntLE(0,e)}))}function f(e){return e instanceof n}function y(e){return"[object Array]"==={}.toString.call(e)}function w(e){return u()&&Buffer.isBuffer(e)}function E(e,t){return{status:!0,index:e,value:t,furthest:-1,expected:[]}}function S(e,t){return y(t)||(t=[t]),{status:!1,index:-1,value:null,furthest:e,expected:t}}function P(e,t){if(!t)return e;if(e.furthest>t.furthest)return e;var i=e.furthest===t.furthest?function(e,t){if(function(){if(void 0!==n._supportsSet)return n._supportsSet;var e="undefined"!=typeof Set;return n._supportsSet=e,e}()&&Array.from){for(var i=new Set(e),s=0;s=0;){if(a in i){n=i[a].line,0===r&&(r=i[a].lineStart);break}("\n"===e.charAt(a)||"\r"===e.charAt(a)&&"\n"!==e.charAt(a+1))&&(s++,0===r&&(r=a+1)),a--}var o=n+s,l=t-r;return i[t]={line:o,lineStart:r},{offset:t,line:o+1,column:l+1}}function x(e){if(!f(e))throw new Error("not a parser: "+e)}function N(e,t){return"string"==typeof e?e.charAt(t):e[t]}function L(e){if("number"!=typeof e)throw new Error("not a number: "+e)}function A(e){if("function"!=typeof e)throw new Error("not a function: "+e)}function T(e){if("string"!=typeof e)throw new Error("not a string: "+e)}var M=2,$=3,D=8,B=5*D,O=4*D,H=" ";function z(e,t){return new Array(t+1).join(e)}function R(e,t,i){var n=t-e.length;return n<=0?e:z(i,n)+e}function I(e,t,i,n){return{from:e-t>0?e-t:0,to:e+i>n?n:e+i}}function V(e,t){var i,n,s,r,l,u=t.index,c=u.offset,h=1;if(c===e.length)return"Got the end of the input";if(w(e)){var d=c-c%D,p=c-d,m=I(d,B,O+D,e.length),g=o((function(e){return o((function(e){return R(e.toString(16),2,"0")}),e)}),function(e,t){var i=e.length,n=[],s=0;if(i<=t)return[e.slice()];for(var r=0;r=4&&(i+=1),h=2,s=o((function(e){return e.length<=4?e.join(" "):e.slice(0,4).join(" ")+" "+e.slice(4).join(" ")}),g),(l=(8*(r.to>0?r.to-1:r.to)).toString(16).length)<2&&(l=2)}else{var b=e.split(/\r\n|[\n\r\u2028\u2029]/);i=u.column-1,n=u.line-1,r=I(n,M,$,b.length),s=b.slice(r.from,r.to),l=r.to.toString().length}var v=n-r.from;return w(e)&&(l=(8*(r.to>0?r.to-1:r.to)).toString(16).length)<2&&(l=2),a((function(t,n,s){var a,o=s===v,u=o?"> ":H;return a=w(e)?R((8*(r.from+s)).toString(16),l,"0"):R((r.from+s+1).toString(),l," "),[].concat(t,[u+a+" | "+n],o?[H+z(" ",l)+" | "+R("",i," ")+z("^",h)]:[])}),[],s).join("\n")}function _(e,t){return["\n","-- PARSING FAILED "+z("-",50),"\n\n",V(e,t),"\n\n",(i=t.expected,1===i.length?"Expected:\n\n"+i[0]:"Expected one of the following: \n\n"+i.join(", ")),"\n"].join("");var i}function F(e){return void 0!==e.flags?e.flags:[e.global?"g":"",e.ignoreCase?"i":"",e.multiline?"m":"",e.unicode?"u":"",e.sticky?"y":""].join("")}function G(){for(var e=[].slice.call(arguments),t=e.length,i=0;i=2?L(t):t=0;var i=function(e){return RegExp("^(?:"+e.source+")",F(e))}(e),s=""+e;return n((function(e,n){var r=i.exec(e.slice(n));if(r){if(0<=t&&t<=r.length){var a=r[0],o=r[t];return E(n+a.length,o)}return S(n,"valid match group (0 to "+r.length+") in "+s)}return S(n,s)}))}function K(e){return n((function(t,i){return E(i,e)}))}function Z(e){return n((function(t,i){return S(i,e)}))}function J(e){if(f(e))return n((function(t,i){var n=e._(t,i);return n.index=i,n.value="",n}));if("string"==typeof e)return J(Y(e));if(e instanceof RegExp)return J(q(e));throw new Error("not a string, regexp, or parser: "+e)}function Q(e){return x(e),n((function(t,i){var n=e._(t,i),s=t.slice(i,n.index);return n.status?S(i,'not "'+s+'"'):E(i,null)}))}function ee(e){return A(e),n((function(t,i){var n=N(t,i);return i=e.length?S(t,"any character/byte"):E(t+1,N(e,t))})),re=n((function(e,t){return E(e.length,e.slice(t))})),ae=n((function(e,t){return t=0})).desc(t)},n.optWhitespace=he,n.Parser=n,n.range=function(e,t){return ee((function(i){return e<=i&&i<=t})).desc(e+"-"+t)},n.regex=q,n.regexp=q,n.sepBy=X,n.sepBy1=W,n.seq=G,n.seqMap=j,n.seqObj=function(){for(var e,t={},i=0,s=(e=arguments,Array.prototype.slice.call(e)),r=s.length,a=0;a255)throw new Error("Value specified to byte constructor ("+e+"=0x"+e.toString(16)+") is larger in value than a single byte.");var t=(e>15?"0x":"0x0")+e.toString(16);return n((function(i,n){var s=N(i,n);return s===e?E(n+1,s):S(n,t)}))},buffer:function(e){return d("buffer",e).map((function(e){return Buffer.from(e)}))},encodedString:function(e,t){return d("string",t).map((function(t){return t.toString(e)}))},uintBE:m,uint8BE:m(1),uint16BE:m(2),uint32BE:m(4),uintLE:g,uint8LE:g(1),uint16LE:g(2),uint32LE:g(4),intBE:b,int8BE:b(1),int16BE:b(2),int32BE:b(4),intLE:v,int8LE:v(1),int16LE:v(2),int32LE:v(4),floatBE:d("floatBE",4).map((function(e){return e.readFloatBE(0)})),floatLE:d("floatLE",4).map((function(e){return e.readFloatLE(0)})),doubleBE:d("doubleBE",8).map((function(e){return e.readDoubleBE(0)})),doubleLE:d("doubleLE",8).map((function(e){return e.readDoubleLE(0)}))},e.exports=n}]));class He extends le{static attributes={lookbehind:{value:"",showDefault:!1,ignore:!0}};constructor(e){super(e),this.lookbehind}}let ze=Oe;class Re{static getGrammarForType(e,t,i=e.AttributeAnyValue){if(t.constructor===Object){let n,s=t.type;return n=s instanceof Array?Re.getGrammarForType(e,s[0]).trim(ze.optWhitespace).sepBy(ze.string(",")).skip(ze.regex(/,?\s*/)).wrap(ze.string("("),ze.string(")")):s instanceof oe?s.types.map((t=>Re.getGrammarForType(e,ae.getType(t)))).reduce(((t,i)=>i&&t!==e.AttributeAnyValue?t.or(i):e.AttributeAnyValue)):Re.getGrammarForType(e,s,i),!t.serialized||s instanceof String||(n=n.wrap(ze.string('"'),ze.string('"'))),t.nullable&&(n=n.or(e.Null)),n}switch(t){case Boolean:return e.Boolean;case ce:return e.Byte;case de:return e.FunctionReference;case pe:return e.Guid;case me:return e.Identifier;case ue:return e.Integer;case ge:return e.InvariantText;case fe:return e.LinearColor;case ye:return e.LocalizedText;case we:return e.MacroGraphReference;case Number:return e.Number;case he:return e.ObjectReference;case Ae:return e.Pin;case Se:return e.PinReference;case ve:return e.RealUnit;case Pe:return e.Rotator;case Ce:return e.SimpleSerializationRotator;case xe:return e.SimpleSerializationVector2D;case Le:return e.SimpleSerializationVector;case String:return e.String;case Te:return e.Symbol;case Me:return e.VariableReference;case ke:return e.Vector2D;case Ne:return e.Vector;default:return i}}static ReferencePath=(e,t)=>ze.alt(t,ze.seq(ze.string("/"),t.map((e=>e.toString())).sepBy1(ze.string(".")).tieWith(".").sepBy1(ze.string(":")).tieWith(":")).tie().atLeast(2).tie());static createAttributeGrammar=(e,t,i=ze.string("=").trim(ze.optWhitespace))=>e.AttributeName.skip(i).chain((i=>{const n=i.split("."),s=ae.objectGet(t.attributes,n);return(s.constructor===Object&&s.serialized?e.String:Re.getGrammarForType(e,s,e.AttributeAnyValue)).map((e=>t=>ae.objectSet(t,n,e,!0)))}));static createEntityGrammar=(e,t,i=!1)=>ze.seqMap(t.lookbehind?ze.seq(ze.string(t.lookbehind),ze.optWhitespace,ze.string("(")):ze.string("("),Re.createAttributeGrammar(e,t).trim(ze.optWhitespace).sepBy(ze.string(",")).skip(ze.regex(/,?/).then(ze.optWhitespace)),ze.string(")"),((e,t,i)=>{let n={};return t.forEach((e=>e(n))),n})).chain((e=>{if(i){let i=0,n=0;for(const s in e)i+=s in t.attributes?0:1,++n;if(i+.5>Math.sqrt(n))return ze.fail()}return ze.succeed().map((()=>new t(e)))}));InlineWhitespace=e=>ze.regex(/[^\S\n]+/).desc("single line whitespace");InlineOptWhitespace=e=>ze.regex(/[^\S\n]*/).desc("single line optional whitespace");MultilineWhitespace=e=>ze.regex(/[^\S\n]*\n\s*/).desc("whitespace with at least a newline");Null=e=>ze.seq(ze.string("("),e.InlineOptWhitespace,ze.string(")")).map((()=>null)).desc("null: ()");Boolean=e=>ze.alt(ze.string("True"),ze.string("true"),ze.string("False"),ze.string("false")).map((e=>"true"===e.toLocaleLowerCase())).desc("either True or False");HexDigit=e=>ze.regex(/[0-9a-fA-f]/).desc("hexadecimal digit");Number=e=>ze.regex(/[-\+]?[0-9]+(?:\.[0-9]+)?/).map(Number).desc("a number");RealNumber=e=>ze.regex(/[-\+]?[0-9]+\.[0-9]+/).map(Number).desc("a number written as real");RealUnit=e=>ze.regex(/\+?[0-9]+(?:\.[0-9]+)?/).map(Number).assert((e=>e>=0&&e<=1)).desc("a number between 0 and 1");NaturalNumber=e=>ze.regex(/0|[1-9]\d*/).map(Number).desc("a natural number");ColorNumber=e=>e.NaturalNumber.assert((e=>0<=e&&e<256),"the color must be between 0 and 256 excluded");Word=e=>ze.regex(/[a-zA-Z_]+/).desc("a word");String=e=>ze.regex(/(?:[^"\\]|\\.)*/).wrap(ze.string('"'),ze.string('"')).map(ae.unescapeString).desc('string (with possibility to escape the quote using ")');AttributeName=e=>e.Word.sepBy1(ze.string(".")).tieWith(".").desc("dot-separated words");None=e=>ze.string("None").map((()=>new he({type:"None",path:""}))).desc("none");Integer=e=>ze.regex(/[\-\+]?[0-9]+/).map((e=>new ue(e))).desc("an integer");Byte=e=>ze.regex(/\+?[0-9]+/).map((e=>parseInt(e))).assert((e=>e>=0&&e<256)).map((e=>new ce(e))).desc("a Byte");Guid=e=>e.HexDigit.times(32).tie().map((e=>new pe({value:e}))).desc("32 digit hexadecimal value");Identifier=e=>ze.regex(/\w+/).map((e=>new me(e)));PathSymbol=e=>ze.regex(/[0-9\w]+/).map((e=>new Ee({value:e})));PathSymbolOptSpaces=e=>ze.regex(/[0-9\w]+(?: [0-9\w]+)+|[0-9\w]+/).map((e=>new Ee({value:e})));Symbol=e=>ze.regex(/\w+/).map((e=>new Te({value:e})));ObjectReference=e=>ze.alt(e.None,...[Re.ReferencePath(e,e.PathSymbolOptSpaces).map((e=>new he({type:"",path:e})))].flatMap((e=>[e.wrap(ze.string('"'),ze.string('"')),e.wrap(ze.string("'\""),ze.string("\"'"))])),ze.seqMap(Re.ReferencePath(e,e.PathSymbolOptSpaces),ze.optWhitespace,ze.alt(...[Re.ReferencePath(e,e.PathSymbolOptSpaces)].flatMap((e=>[e.wrap(ze.string('"'),ze.string('"')),e.wrap(ze.string("'\""),ze.string("\"'"))]))),((e,t,i)=>new he({type:e,path:i}))),Re.ReferencePath(e,e.PathSymbol).map((e=>new he({type:"",path:e}))),e.Word.map((e=>new he({type:e,path:""}))));LocalizedText=e=>ze.seqMap(ze.string(ye.lookbehind).skip(ze.optWhitespace).skip(ze.string("(")),e.String.trim(ze.optWhitespace),ze.string(","),e.String.trim(ze.optWhitespace),ze.string(","),e.String.trim(ze.optWhitespace),ze.string(")"),((e,t,i,n,s,r,a)=>new ye({namespace:t,key:n,value:r})));InvariantText=e=>e.String.trim(ze.optWhitespace).wrap(ze.string(ge.lookbehind).skip(ze.optWhitespace).skip(ze.string("(")),ze.string(")")).map((e=>new ge({value:e})));AttributeAnyValue=e=>ze.alt(e.Boolean,e.Guid,e.None,e.Null,e.Number,e.String,e.LocalizedText,e.InvariantText,e.PinReference,Re.createEntityGrammar(e,Ne,!0),Re.createEntityGrammar(e,fe,!0),Re.createEntityGrammar(e,ke,!0),e.UnknownKeys,e.ObjectReference,e.Symbol);PinReference=e=>ze.seqMap(e.PathSymbol,ze.whitespace,e.Guid,((e,t,i)=>new Se({objectName:e,pinGuid:i})));Vector2D=e=>Re.createEntityGrammar(e,ke);Vector=e=>Re.createEntityGrammar(e,Ne);Rotator=e=>Re.createEntityGrammar(e,Pe);SimpleSerializationRotator=e=>ze.seqMap(e.Number,ze.string(",").trim(ze.optWhitespace),e.Number,ze.string(",").trim(ze.optWhitespace),e.Number,((e,t,i,n,s)=>new Ce({R:s,P:e,Y:i})));SimpleSerializationVector2D=e=>ze.seqMap(e.Number,ze.string(",").trim(ze.optWhitespace),e.Number,((e,t,i)=>new xe({X:e,Y:i})));SimpleSerializationVector=e=>ze.seqMap(e.Number,ze.string(",").trim(ze.optWhitespace),e.Number,ze.string(",").trim(ze.optWhitespace),e.Number,((e,t,i,n,s)=>new Le({X:e,Y:i,Z:s})));LinearColor=e=>Re.createEntityGrammar(e,fe);FunctionReference=e=>Re.createEntityGrammar(e,de);VariableReference=e=>Re.createEntityGrammar(e,Me);MacroGraphReference=e=>Re.createEntityGrammar(e,we);KeyBinding=e=>ze.alt(e.Identifier.map((e=>new be({Key:e}))),Re.createEntityGrammar(e,be));Pin=e=>Re.createEntityGrammar(e,Ae);CustomProperties=e=>ze.string("CustomProperties").then(ze.whitespace).then(e.Pin).map((e=>t=>{let i=ae.objectGet(t,["CustomProperties"],[]);i.push(e),ae.objectSet(t,["CustomProperties"],i,!0)}));Object=e=>ze.seqMap(ze.seq(ze.string("Begin"),ze.whitespace,ze.string("Object"),ze.whitespace),ze.alt(e.CustomProperties,Re.createAttributeGrammar(e,$e)).sepBy1(ze.whitespace),ze.seq(e.MultilineWhitespace,ze.string("End"),ze.whitespace,ze.string("Object")),((e,t,i)=>{let n={};return t.forEach((e=>e(n))),new $e(n)}));MultipleObject=e=>e.Object.sepBy1(ze.whitespace).trim(ze.optWhitespace);LinearColorFromHex=e=>ze.string("#").then(e.HexDigit.times(2).tie().times(3,4)).trim(ze.optWhitespace).map((([e,t,i,n])=>new fe({R:parseInt(e,16)/255,G:parseInt(t,16)/255,B:parseInt(i,16)/255,A:n?parseInt(n,16)/255:1})));LinearColorFromRGBList=e=>ze.seqMap(e.ColorNumber,ze.string(",").skip(ze.optWhitespace),e.ColorNumber,ze.string(",").skip(ze.optWhitespace),e.ColorNumber.map(Number),((e,t,i,n,s)=>new fe({R:e/255,G:i/255,B:s/255,A:1})));LinearColorFromRGB=e=>ze.string("rgb").then(e.LinearColorFromRGBList.wrap(ze.regex(/\(\s*/),ze.regex(/\s*\)/)));LinearColorFromRGBA=e=>ze.string("rgba").then(ze.seqMap(e.ColorNumber,ze.string(",").skip(ze.optWhitespace),e.ColorNumber,ze.string(",").skip(ze.optWhitespace),e.ColorNumber.map(Number),ze.string(",").skip(ze.optWhitespace),ze.regex(/0?\.\d+|[01]/).map(Number),((e,t,i,n,s,r,a)=>new fe({R:e/255,G:i/255,B:s/255,A:a}))).wrap(ze.regex(/\(\s*/),ze.regex(/\s*\)/)));LinearColorFromAnyColor=e=>ze.alt(e.LinearColorFromRGBList,e.LinearColorFromHex,e.LinearColorFromRGB,e.LinearColorFromRGBA);UnknownKeys=e=>ze.seqMap(ze.regex(/\w*\s*/).skip(ze.string("(")),ze.seqMap(e.AttributeName,ze.string("=").trim(ze.optWhitespace),e.AttributeAnyValue,((e,t,i)=>t=>ae.objectSet(t,e.split("."),i,!0))).trim(ze.optWhitespace).sepBy(ze.string(",")).skip(ze.regex(/,?/).then(ze.optWhitespace)),ze.string(")"),((e,t,i)=>{let n={};t.forEach((e=>e(n)));let s=new He(n);return e&&(s.lookbehind=e),s}))}class Ie{static grammar=Oe.createLanguage(new Re);constructor(e,t="",i=",",n=!1,s="=",r=(e=>e.join("."))){this.entityType=e,this.attributePrefix=t,this.attributeSeparator=i,this.trailingSeparator=n,this.attributeValueConjunctionSign=s,this.attributeKeyPrinter=r}deserialize(e){return this.read(e)}serialize(e,t=!1,i=e){return this.write(i,e,t)}read(e){throw new Error("Not implemented")}write(e,t,i){throw new Error("Not implemented")}writeValue(e,t,i,n){const s=ae.getType(t),r=se.getSerializer(s);if(!r)throw new Error(`Unknown value type "${s.name}", a serializer must be registered in the SerializerFactory class, check initializeSerializerFactory.js`);return r.write(t instanceof le?t:e,t,n)}subWrite(e,t,i,n){let s="",r=t.concat("");const a=r.length-1,o=i.constructor.attributes,l=o?ae.mergeArrays(Object.getOwnPropertyNames(o),Object.getOwnPropertyNames(i)):Object.getOwnPropertyNames(i);for(const t of l){r[a]=t;const o=i[t];if(o?.constructor===Object)s+=(s.length?this.attributeSeparator:"")+this.subWrite(e,r,o,n);else if(void 0!==o&&this.showProperty(e,i,r,o)){const t=ae.isSerialized(e,r);s+=(s.length?this.attributeSeparator:"")+this.attributePrefix+this.attributeKeyPrinter(r)+this.attributeValueConjunctionSign+(t?`"${this.writeValue(e,o,r,!0)}"`:this.writeValue(e,o,r,n))}}return this.trailingSeparator&&s.length&&1===r.length&&(s+=this.attributeSeparator),s}showProperty(e,t,i,n){const s=this.entityType.attributes,r=ae.objectGet(s,i);return r.constructor!==Object||!r.ignored&&(!ae.equals(r.value,n)||r.showDefault)}}class Ve extends Ie{constructor(){super($e," ","\n",!1)}showProperty(e,t,i,n){switch(i.toString()){case"Class":case"Name":case"CustomProperties":return!1}return super.showProperty(e,t,i,n)}read(e){const t=Ie.grammar.Object.parse(e);if(!t.status)throw new Error("Error when trying to parse the object.");return t.value}readMultiple(e){const t=Ie.grammar.MultipleObject.parse(e);if(!t.status)throw new Error("Error when trying to parse the object.");return t.value}write(e,t,i){return`Begin Object Class=${t.Class.path} Name=${this.writeValue(e,t.Name,["Name"],i)}\n${this.subWrite(e,[],t,i)+t.CustomProperties.map((e=>this.attributeSeparator+this.attributePrefix+"CustomProperties "+se.getSerializer(Ae).serialize(e))).join("")}\nEnd Object\n`}}class _e extends ie{static#u=new Ve;#c;constructor(e,t,i={}){i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,super(e,t,i);let n=this;this.#c=e=>n.copied()}listenEvents(){window.addEventListener("copy",this.#c)}unlistenEvents(){window.removeEventListener("copy",this.#c)}getSerializedText(){return this.blueprint.getNodes(!0).map((e=>_e.#u.serialize(e.entity,!1))).join("")}copied(){const e=this.getSerializedText();navigator.clipboard.writeText(e)}}class Fe{element;get blueprint(){return this.element.blueprint}#h=[];get inputObjects(){return this.#h}initialize(e){this.element=e}createInputObjects(){return[]}setup(){this.#h.forEach((e=>e.setup()))}cleanup(){this.#h.forEach((e=>e.cleanup()))}willUpdate(e){}update(e){}render(){return B``}firstUpdated(e){}updated(e){}inputSetup(){this.#h=this.createInputObjects()}}class Ge extends ie{#d;constructor(e,t,i={}){i.activateAnyKey??=!1,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 be)return e;if(e.constructor===String){const t=Ie.grammar.KeyBinding.parse(e);if(t.status)return t.value}throw new Error("Unexpected key value")})),super(e,t,i),this.#d=this.options.activationKeys??[];let n=this;this.keyDownHandler=e=>{(this.options.activateAnyKey||n.#d.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&&te.Keys[t.Key]==e.code)))&&(i.consumeEvent&&(e.preventDefault(),e.stopImmediatePropagation()),n.fire(),document.removeEventListener("keydown",n.keyDownHandler),document.addEventListener("keyup",n.keyUpHandler))},this.keyUpHandler=e=>{(this.options.activateAnyKey||n.#d.some((t=>t.bShift&&"Shift"==e.key||t.bCtrl&&"Control"==e.key||t.bAlt&&"Alt"==e.key||t.bCmd&&"Meta"==e.key||te.Keys[t.Key]==e.code)))&&(i.consumeEvent&&e.stopImmediatePropagation(),n.unfire(),document.removeEventListener("keyup",this.keyUpHandler),document.addEventListener("keydown",this.keyDownHandler))}}listenEvents(){document.addEventListener("keydown",this.keyDownHandler)}unlistenEvents(){document.removeEventListener("keydown",this.keyDownHandler)}fire(){}unfire(){}}class je extends Ge{constructor(e,t,i={}){i.activationKeys=te.deleteNodesKeyboardKey,super(e,t,i)}fire(){this.blueprint.removeGraphElement(...this.blueprint.getNodes(!0))}}class Ue extends ie{constructor(e,t,i={}){i.ignoreTranslateCompensate??=!1,i.ignoreScale??=!1,i.movementSpace??=t.getGridDOMElement()??document.documentElement,super(e,t,i),this.movementSpace=i.movementSpace}locationFromEvent(e){const t=ae.convertLocation([e.clientX,e.clientY],this.movementSpace,this.options.ignoreScale);return this.options.ignoreTranslateCompensate?t:this.blueprint.compensateTranslation(t)}}class Xe extends Ue{#p=e=>{e.preventDefault();const t=this.locationFromEvent(e);this.wheel(Math.sign(e.deltaY*te.mouseWheelFactor),t)};#m=e=>e.preventDefault();constructor(e,t,i={}){i.listenOnFocus=!0,i.strictTarget??=!1,super(e,t,i),this.strictTarget=i.strictTarget}listenEvents(){this.movementSpace.addEventListener("wheel",this.#p,!1),this.movementSpace.parentElement?.addEventListener("wheel",this.#m)}unlistenEvents(){this.movementSpace.removeEventListener("wheel",this.#p,!1),this.movementSpace.parentElement?.removeEventListener("wheel",this.#m)}wheel(e,t){}}class We extends Xe{#g=!1;get enableZoonIn(){return this.#g}set enableZoonIn(e){(e=Boolean(e))!=this.#g&&(this.#g=e)}wheel(e,t){let i=this.blueprint.getZoom();e=-e,!this.enableZoonIn&&0==i&&e>0||(i+=e,this.blueprint.setZoom(i,t))}}class Ye extends Ge{#b;constructor(e,t,i={}){i.activationKeys=te.enableZoomIn,super(e,t,i)}fire(){this.#b=this.blueprint.getInputObject(We),this.#b.enableZoonIn=!0}unfire(){this.#b.enableZoonIn=!1}}class qe extends Ge{constructor(e,t,i={}){i.activationKeys=te.selectAllKeyboardKey,super(e,t,i)}fire(){this.blueprint.selectAll()}}class Ke extends Q{#v=[];#i;get blueprint(){return this.#i}set blueprint(e){this.#i=e}#f;get entity(){return this.#f}set entity(e){this.#f=e}#y;get template(){return this.#y}isInitialized=!1;isSetup=!1;inputObjects=[];initialize(e,t){this.requestUpdate(),this.#f=e,this.#y=t,this.#y.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()))}createRenderRoot(){return this}shouldUpdate(e){return this.isInitialized&&this.isConnected}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);for(const t of this.#v)t(e);this.#v=[]}addNextUpdatedCallbacks(e,t=!1){this.#v.push(e),t&&this.requestUpdate()}isSameGraph(e){return this.blueprint&&this.blueprint==e?.blueprint}getInputObject(e){return this.template.inputObjects.find((t=>t.constructor==e))}}class Ze extends Ke{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=te.dragEventName;static dragGeneralEventName=te.dragGeneralEventName;constructor(){super(),this.locationX=0,this.locationY=0,this.sizeX=0,this.sizeY=0}computeSizes(){const e=1/this.blueprint.getScale(),t=this.getBoundingClientRect();this.sizeX=t.width*e,this.sizeY=t.height*e}firstUpdated(e){super.firstUpdated(e),this.computeSizes()}setLocation([e,t],i=!0){const n=[e-this.locationX,t-this.locationY];if(this.locationX=e,this.locationY=t,this.blueprint&&i){const e=new CustomEvent(this.constructor.dragEventName,{detail:{value: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],te.gridSize);this.locationX==e[0]&&this.locationY==e[1]||this.setLocation(e)}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 Je extends Ue{#w=e=>{if(this.blueprint.setFocused(!0),e.button===this.options.clickButton)this.options.strictTarget&&e.target!=e.currentTarget||(this.options.consumeEvent&&e.stopImmediatePropagation(),this.#E.addEventListener("mousemove",this.#S),document.addEventListener("mouseup",this.#P),this.clickedPosition=this.locationFromEvent(e),this.blueprint.mousePosition[0]=this.clickedPosition[0],this.blueprint.mousePosition[1]=this.clickedPosition[1],this.target instanceof Ze&&(this.clickedOffset=[this.clickedPosition[0]-this.target.locationX,this.clickedPosition[1]-this.target.locationY]),this.clicked(this.clickedPosition));else this.options.exitAnyButton||this.#P(e)};#S=e=>{this.options.consumeEvent&&e.stopImmediatePropagation(),this.#E.removeEventListener("mousemove",this.#S),this.#E.addEventListener("mousemove",this.#C);const t=this.getEvent(te.trackingMouseEventName.begin);this.#k=0==this.target.dispatchEvent(t);const i=this.locationFromEvent(e);this.lastLocation=ae.snapToGrid(this.clickedPosition,this.stepSize),this.startDrag(i),this.started=!0};#C=e=>{this.options.consumeEvent&&e.stopImmediatePropagation();const t=this.locationFromEvent(e),i=[e.movementX,e.movementY];this.dragTo(t,i),this.#k&&(this.blueprint.mousePosition=this.locationFromEvent(e))};#P=e=>{if(!this.options.exitAnyButton||e.button==this.options.clickButton){if(this.options.consumeEvent&&e.stopImmediatePropagation(),this.#E.removeEventListener("mousemove",this.#S),this.#E.removeEventListener("mousemove",this.#C),document.removeEventListener("mouseup",this.#P),this.started&&this.endDrag(),this.unclicked(),this.#k){const e=this.getEvent(te.trackingMouseEventName.end);this.target.dispatchEvent(e),this.#k=!1}this.started=!1}};#k=!1;#E;#x;clickedOffset=[0,0];clickedPosition=[0,0];lastLocation=[0,0];started=!1;stepSize=1;constructor(e,t,i={}){i.clickButton??=0,i.consumeEvent??=!0,i.draggableElement??=e,i.exitAnyButton??=!0,i.moveEverywhere??=!1,i.movementSpace??=t?.getGridDOMElement(),i.repositionOnClick??=!1,i.strictTarget??=!1,super(e,t,i),this.stepSize=parseInt(i?.stepSize??te.gridSize),this.#E=this.options.moveEverywhere?document.documentElement:this.movementSpace,this.#x=this.options.draggableElement,this.listenEvents()}listenEvents(){super.listenEvents(),this.#x.addEventListener("mousedown",this.#w),2==this.options.clickButton&&this.#x.addEventListener("contextmenu",(e=>e.preventDefault()))}unlistenEvents(){super.unlistenEvents(),this.#x.removeEventListener("mousedown",this.#w)}getEvent(e){return new CustomEvent(e,{detail:{tracker:this},bubbles:!0,cancelable:!0})}clicked(e){}startDrag(e){}dragTo(e,t){}endDrag(){}unclicked(e){}}class Qe extends Je{startDrag(){this.blueprint.scrolling=!0}dragTo(e,t){this.blueprint.scrollDelta([-t[0],-t[1]])}endDrag(){this.blueprint.scrolling=!1}}class et extends Ue{#N=null;#L;#A;#T;constructor(e,t,i={}){i.listenOnFocus=!0,super(e,t,i);let n=this;this.#L=e=>{e.preventDefault(),n.blueprint.mousePosition=n.locationFromEvent(e)},this.#A=e=>{n.#N||(e.preventDefault(),this.#N=e.detail.tracker,n.unlistenMouseMove())},this.#T=e=>{n.#N==e.detail.tracker&&(e.preventDefault(),n.#N=null,n.listenMouseMove())}}listenMouseMove(){this.target.addEventListener("mousemove",this.#L)}unlistenMouseMove(){this.target.removeEventListener("mousemove",this.#L)}listenEvents(){this.listenMouseMove(),this.blueprint.addEventListener(te.trackingMouseEventName.begin,this.#A),this.blueprint.addEventListener(te.trackingMouseEventName.end,this.#T)}unlistenEvents(){this.unlistenMouseMove(),this.blueprint.removeEventListener(te.trackingMouseEventName.begin,this.#A),this.blueprint.removeEventListener(te.trackingMouseEventName.end,this.#T)}}class tt{static#M=new Map;static registerElement(e,t){tt.#M.set(e,t)}static getConstructor(e){return tt.#M.get(e)}}class it extends ie{static#u=new Ve;#$;constructor(e,t,i={}){i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,super(e,t,i);let n=this;this.#$=e=>n.pasted(e.clipboardData.getData("Text"))}listenEvents(){window.addEventListener("paste",this.#$)}unlistenEvents(){window.removeEventListener("paste",this.#$)}pasted(e){let t=0,i=0,n=0,s=it.#u.readMultiple(e).map((e=>{let s=tt.getConstructor("ueb-node").newObject(e);return t+=s.locationY,i+=s.locationX,++n,s}));t/=n,i/=n,s.length>0&&this.blueprint.unselectAll();let r=this.blueprint.mousePosition;return s.forEach((e=>{const n=[r[0]-i,r[1]-t];e.addLocation(n),e.snapToGrid(),e.setSelected(!0)})),this.blueprint.addGraphElement(...s),!0}}class nt extends Je{constructor(e,t,i){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 st extends ie{#D;constructor(e,t,i={}){i.listenOnFocus=!0,super(e,t,i);let n=this;this.#D=e=>n.clickedSomewhere(e.target),this.blueprint.focus&&document.addEventListener("click",this.#D)}clickedSomewhere(e){e.closest("ueb-blueprint")||this.blueprint.setFocused(!1)}listenEvents(){document.addEventListener("click",this.#D)}unlistenEvents(){document.removeEventListener("click",this.#D)}}class rt extends Fe{static styleVariables={"--ueb-font-size":`${te.fontSize}`,"--ueb-grid-axis-line-color":`${te.gridAxisLineColor}`,"--ueb-grid-expand":`${te.expandGridSize}px`,"--ueb-grid-line-color":`${te.gridLineColor}`,"--ueb-grid-line-width":`${te.gridLineWidth}px`,"--ueb-grid-set-line-color":`${te.gridSetLineColor}`,"--ueb-grid-set":`${te.gridSet}`,"--ueb-grid-size":`${te.gridSize}px`,"--ueb-link-min-width":`${te.linkMinWidth}`,"--ueb-node-radius":`${te.nodeRadius}px`};#B=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)}));headerElement;overlayElement;viewportElement;selectorElement;gridElement;linksContainerElement;nodesContainerElement;viewportSize=[0,0];initialize(e){super.initialize(e),this.element.style.cssText=Object.entries(rt.styleVariables).map((([e,t])=>`${e}:${t};`)).join("")}setup(){super.setup(),this.#B.observe(this.viewportElement,{box:"device-pixel-content-box"});const e=this.viewportElement.getBoundingClientRect();this.viewportSize[0]=e.width,this.viewportSize[1]=e.height}cleanup(){super.cleanup(),this.#B.unobserve(this.viewportElement)}createInputObjects(){return[...super.createInputObjects(),new _e(this.element.getGridDOMElement(),this.element),new it(this.element.getGridDOMElement(),this.element),new je(this.element.getGridDOMElement(),this.element),new qe(this.element.getGridDOMElement(),this.element),new We(this.element.getGridDOMElement(),this.element),new nt(this.element.getGridDOMElement(),this.element,{clickButton:0,exitAnyButton:!0,moveEverywhere:!0}),new Qe(this.element.getGridDOMElement(),this.element,{clickButton:2,exitAnyButton:!1,moveEverywhere:!0}),new st(this.element.getGridDOMElement(),this.element),new et(this.element.getGridDOMElement(),this.element),new Ye(this.element.getGridDOMElement(),this.element)]}render(){return B`
Zoom ${0==this.element.zoom?"1:1":(this.element.zoom>0?"+":"")+this.element.zoom}
`}firstUpdated(e){super.firstUpdated(e),this.headerElement=this.element.querySelector(".ueb-viewport-header"),this.overlayElement=this.element.querySelector(".ueb-viewport-overlay"),this.viewportElement=this.element.querySelector(".ueb-viewport-body"),this.selectorElement=this.element.querySelector("ueb-selector"),this.gridElement=this.viewportElement.querySelector(".ueb-grid"),this.linksContainerElement=this.element.querySelector("[data-links]"),this.linksContainerElement.append(...this.element.getLinks()),this.nodesContainerElement=this.element.querySelector("[data-nodes]"),this.nodesContainerElement.append(...this.element.getNodes()),this.viewportElement.scroll(te.expandGridSize,te.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.element.scrollX,this.element.scrollY),e.has("zoom")){const t=e.get("zoom"),i=Math.min(t,this.element.zoom),n=Math.max(t,this.element.zoom),s=ae.range(i,n),r=e=>`ueb-zoom-${e}`;te<0)).map(r)),this.element.classList.add(...s.filter((e=>e>0)).map(r))):(this.element.classList.remove(...s.filter((e=>e>0)).map(r)),this.element.classList.add(...s.filter((e=>e<0)).map(r)))}}getCommentNodes(e=!1){return this.element.querySelectorAll(`ueb-node[data-type="${te.nodeType.comment}"]${e?'[data-selected="true"]':""}`)}getPin(e){return this.element.querySelector(`ueb-node[data-name="${e.objectName}"] ueb-pin[data-id="${e.pinGuid}"]`)}isPointVisible(e,t){return!1}gridTopVisibilityBoundary(){return this.blueprint.scrollY-this.blueprint.translateY}gridRightVisibilityBoundary(){return this.gridLeftVisibilityBoundary()+this.viewportSize[0]}gridBottomVisibilityBoundary(){return this.gridTopVisibilityBoundary()+this.viewportSize[1]}gridLeftVisibilityBoundary(){return this.blueprint.scrollX-this.blueprint.translateX}}class at extends Ke{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 ot extends Fe{update(e){super.update(e);const[t,i,n,s]=[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,n),Math.min(i,s),Math.abs(t-n),Math.abs(i-s)];(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 lt extends $e{constructor(e={},t){super(e,!0),this.Class=new he("/Script/BlueprintGraph.K2Node_Knot"),this.Name="K2Node_Knot";const i=new Ae({PinName:"InputPin"},!0),n=new Ae({PinName:"OutputPin",Direction:"EGPD_Output"},!0);t&&(i.copyTypeFrom(t),n.copyTypeFrom(t)),this.CustomProperties=[i,n]}}class ut extends Ue{static ignoreDbClick=e=>{};#O=e=>{this.options.strictTarget&&e.target!==e.currentTarget||(this.options.consumeEvent&&e.stopImmediatePropagation(),this.clickedPosition=this.locationFromEvent(e),this.blueprint.mousePosition[0]=this.clickedPosition[0],this.blueprint.mousePosition[1]=this.clickedPosition[1],this.dbclicked(this.clickedPosition))};#H;get onDbClick(){return this.#H}set onDbClick(e){this.#H=e}clickedPosition=[0,0];constructor(e,t,i={},n=ut.ignoreDbClick){i.consumeEvent??=!0,i.strictTarget??=!1,super(e,t,i),this.#H=n,this.listenEvents()}listenEvents(){this.target.addEventListener("dblclick",this.#O)}unlistenEvents(){this.target.removeEventListener("dblclick",this.#O)}dbclicked(e){this.onDbClick(e)}}class ct extends ot{static decreasingValue(e,t){const i=-e*t[0]**2,n=t[1]-i/t[0];return e=>i/e+n}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]),n=e[1]-i*e[0];return s=>st[0]?t[1]:i*s+n}static c1DecreasingValue=ct.decreasingValue(-.15,[100,15]);static c2DecreasingValue=ct.decreasingValue(-.06,[500,130]);static c2Clamped=ct.clampedLine([0,100],[200,30]);#z=e=>{const t=new lt({},this.element.sourcePin.entity),i=tt.getConstructor("ueb-node").newObject(t);i.setLocation(this.blueprint.snapToGrid(e)),this.blueprint.addGraphElement(i);const n=tt.getConstructor("ueb-link").newObject(i.template.outputPin,this.element.destinationPin);this.element.destinationPin=i.template.inputPin,this.blueprint.addGraphElement(n)};createInputObjects(){return[...super.createInputObjects(),new ut(this.element.querySelector(".ueb-link-area"),this.blueprint,void 0,(e=>this.#z(e)))]}willUpdate(e){super.willUpdate(e);const t=this.element.sourcePin,i=this.element.destinationPin;if(e.has("fromX")||e.has("toX")){const e=t?.nodeElement.getType()==te.nodeType.knot,n=i?.nodeElement.getType()==te.nodeType.knot;!e||i&&!n||(t?.isInput()&&this.element.toX>this.element.fromX+te.distanceThreshold?this.element.sourcePin=t.nodeElement.template.outputPin:t?.isOutput()&&this.element.toXthis.element.fromX-te.distanceThreshold&&(this.element.destinationPin=i.nodeElement.template.inputPin))}const n=Math.max(Math.abs(this.element.fromX-this.element.toX),1);Math.max(Math.abs(this.element.fromY-this.element.toY),1);const s=Math.max(n,te.linkMinWidth),r=n/s,a=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(){const e=`ueb-id-${Math.floor(1e12*Math.random())}`;return B` ${this.element.linkMessageIcon||this.element.linkMessageText?B``:H}`}}class ht{static branchNode=B``;static breakStruct=B``;static cast=B``;static close=B``;static correct=B``;static doN=B``;static execPin=B``;static expandIcon=B``;static forEachLoop=B``;static functionSymbol=B``;static genericPin=B``;static loop=B``;static macro=B``;static makeArray=B``;static makeMap=B``;static makeStruct=B``;static referencePin=B``;static reject=B``;static select=B``;static sequence=B``}class dt extends at{static properties={...super.properties,source:{type:String,reflect:!0},destination:{type:String,reflect:!0},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}};#R;get sourcePin(){return this.#R}set sourcePin(e){this.#I(e,!1)}#V;get destinationPin(){return this.#V}set destinationPin(e){this.#I(e,!0)}#_=()=>this.remove();#F=e=>this.addSourceLocation(e.detail.value);#G=e=>this.addDestinationLocation(e.detail.value);#j=e=>this.setSourceLocation();#U=e=>this.setDestinationLocation();linkMessageIcon=H;linkMessageText=H;pathElement;constructor(){super(),this.source=null,this.destination=null,this.dragging=!1,this.originatesFromInput=!1,this.startPercentage=0,this.svgPathD="",this.startPixels=0}static newObject(e,t){const i=new dt;return i.initialize(e,t),i}initialize(e,t){super.initialize({},new ct),e&&(this.sourcePin=e,t||(this.toX=this.fromX,this.toY=this.fromY)),t&&(this.destinationPin=t,e||(this.fromX=this.toX,this.fromY=this.toY)),this.#X()}#I(e,t){const i=()=>t?this.destinationPin:this.sourcePin;if(i()!=e){if(i()){const e=i().getNodeElement();e.removeEventListener(te.nodeDeleteEventName,this.#_),e.removeEventListener(te.nodeDragEventName,t?this.#G:this.#F),e.removeEventListener(te.nodeReflowEventName,t?this.#U:this.#j),this.#W()}if(t?this.#V=e:this.#R=e,i()){const e=i().getNodeElement();e.addEventListener(te.nodeDeleteEventName,this.#_),e.addEventListener(te.nodeDragEventName,t?this.#G:this.#F),e.addEventListener(te.nodeReflowEventName,t?this.#U:this.#j),t?this.setDestinationLocation():(this.setSourceLocation(),this.originatesFromInput=this.sourcePin.isInput()),this.#X()}}}#X(){this.sourcePin&&this.destinationPin&&(this.sourcePin.linkTo(this.destinationPin),this.destinationPin.linkTo(this.sourcePin))}#W(){this.sourcePin&&this.destinationPin&&(this.sourcePin.unlinkFrom(this.destinationPin),this.destinationPin.unlinkFrom(this.sourcePin))}cleanup(){super.cleanup(),this.#W(),this.sourcePin=null,this.destinationPin=null}setSourceLocation(e=null){if(null==e){const t=this;if(!this.hasUpdated||!this.sourcePin.hasUpdated)return void Promise.all([this.updateComplete,this.sourcePin.updateComplete]).then((()=>t.setSourceLocation()));e=this.sourcePin.template.getLinkLocation()}const[t,i]=e;this.fromX=t,this.fromY=i}setDestinationLocation(e=null){if(null==e){const t=this;if(!this.hasUpdated||!this.destinationPin.hasUpdated)return void Promise.all([this.updateComplete,this.destinationPin.updateComplete]).then((()=>t.setDestinationLocation()));e=this.destinationPin.template.getLinkLocation()}this.toX=e[0],this.toY=e[1]}startDragging(){this.dragging=!0}finishDragging(){this.dragging=!1}removeMessage(){this.linkMessageIcon="",this.linkMessageText=""}setMessageConvertType(){this.linkMessageIcon="ueb-icon-conver-type",this.linkMessageText=`Convert ${this.sourcePin.pinType} to ${this.destinationPin.pinType}.`}setMessageCorrect(){this.linkMessageIcon=ht.correct,this.linkMessageText=H}setMessageReplace(){this.linkMessageIcon=ht.correct,this.linkMessageText=H}setMessageDirectionsIncompatible(){this.linkMessageIcon=ht.reject,this.linkMessageText=B`Directions are not compatbile.`}setMessagePlaceNode(){this.linkMessageIcon="ueb-icon-place-node",this.linkMessageText=B`Place a new node.`}setMessageReplaceLink(){this.linkMessageIcon=ht.correct,this.linkMessageText=B`Replace existing input connections.`}setMessageSameNode(){this.linkMessageIcon=ht.reject,this.linkMessageText=B`Both are on the same node.`}setMEssagetypesIncompatible(){this.linkMessageIcon=ht.reject,this.linkMessageText=B`${this.sourcePin.pinType} is not compatible with ${this.destinationPin.pinType}.`}}class pt extends Je{clicked(e){this.options.repositionOnClick&&(this.target.setLocation(this.stepSize>1?ae.snapToGrid(e,this.stepSize):e),this.clickedOffset=[0,0])}dragTo(e,t){const i=[this.target.locationX??this.lastLocation[0],this.target.locationY??this.lastLocation[1]],[n,s]=this.stepSize>1?[ae.snapToGrid(e,this.stepSize),ae.snapToGrid(i,this.stepSize)]:[e,i];0==(t=[n[0]-this.lastLocation[0],n[1]-this.lastLocation[1]])[0]&&0==t[1]||(t[0]+=s[0]-i[0],t[1]+=s[1]-i[1],this.dragAction(n,t),this.lastLocation=n)}dragAction(e,t){this.target.setLocation([e[0]-this.clickedOffset[0],e[1]-this.clickedOffset[1]])}}class mt extends pt{#Y;#q;#K;#Z;constructor(e,t,i={}){super(e,t,i),i.onClicked&&(this.#Y=i.onClicked),i.onStartDrag&&(this.#q=i.onStartDrag),i.onDrag&&(this.#K=i.onDrag),i.onEndDrag&&(this.#Z=i.onEndDrag)}clicked(){super.clicked(),this.#Y?.()}startDrag(){super.startDrag(),this.#q?.()}dragAction(e,t){this.#K?.(e,t)}endDrag(){super.endDrag(),this.#Z?.()}}class gt extends Fe{getDraggableElement(){return this.element}createDraggableObject(){return new pt(this.element,this.blueprint,{draggableElement:this.getDraggableElement()})}createInputObjects(){return[...super.createInputObjects(),this.createDraggableObject()]}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 n=Math.max((t+i)/2,e);const s=this.topBoundary()-this.blueprint.template.gridTopVisibilityBoundary(),r=this.blueprint.template.gridBottomVisibilityBoundary()-this.bottomBoundary();const a=[t-n,s-Math.max((s+r)/2,e)];this.blueprint.scrollDelta(a,!0)}}class bt 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 vt extends pt{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 bt{getDraggableElement(){return this.element}createDraggableObject(){return new vt(this.element,this.blueprint,{draggableElement:this.getDraggableElement()})}firstUpdated(e){super.firstUpdated(e),this.element.selected&&!this.element.listeningDrag&&this.element.setSelected(!0)}}class yt extends ft{static#J={[te.nodeType.doN]:ht.doN,[te.nodeType.dynamicCast]:ht.cast,[te.nodeType.executionSequence]:ht.sequence,[te.nodeType.forEachElementInEnum]:ht.loop,[te.nodeType.forEachLoop]:ht.forEachLoop,[te.nodeType.forEachLoopWithBreak]:ht.forEachLoop,[te.nodeType.forLoop]:ht.loop,[te.nodeType.forLoopWithBreak]:ht.loop,[te.nodeType.ifThenElse]:ht.branchNode,[te.nodeType.makeArray]:ht.makeArray,[te.nodeType.makeMap]:ht.makeMap,[te.nodeType.select]:ht.select,[te.nodeType.whileLoop]:ht.loop,default:ht.functionSymbol};#Q=!1;toggleAdvancedDisplayHandler=()=>{this.element.toggleShowAdvancedPinDisplay(),this.element.addNextUpdatedCallbacks((()=>this.element.acknowledgeReflow()),!0)};initialize(e){super.initialize(e),this.element.style.setProperty("--ueb-node-color",this.getColor().cssText)}getColor(){const e=r``,t=r``;switch(this.element.entity.getClass()){case te.nodeType.callFunction:return this.element.entity.bIsPureFunc?t:e;case te.nodeType.makeArray:case te.nodeType.makeMap:case te.nodeType.select:return t;case te.nodeType.macro:case te.nodeType.executionSequence:case te.nodeType.dynamicCast:return r``}return e}render(){const e=this.renderNodeIcon(),t=this.renderNodeName();return B`
${e?B`
${e}
`:H} ${t?B`
${t} ${this.#Q&&this.element.entity.FunctionReference.MemberParent?B`
Target is ${ae.formatStringName(this.element.entity.FunctionReference.MemberParent.getName())}
`:H}
`:H}
${"DevelopmentOnly"==this.element.enabledState?.toString()?B`
Development Only
`:H} ${this.element.advancedPinDisplay?B`
${ht.expandIcon}
`:H}
`}renderNodeIcon(){let e=yt.#J[this.element.getType()];return e||(this.element.getNodeDisplayName().startsWith("Break")?ht.breakStruct:this.element.entity.getClass()===te.nodeType.macro?ht.macro:yt.#J.default)}renderNodeName(){return this.element.getNodeDisplayName()}firstUpdated(e){super.firstUpdated(e),this.setupPins(),this.element.updateComplete.then((()=>this.element.acknowledgeReflow()))}setupPins(){const e=this.element.querySelector(".ueb-node-inputs"),t=this.element.querySelector(".ueb-node-outputs");this.element.nodeNameElement=this.element.querySelector(".ueb-node-name-text"),this.element.getPinElements().forEach((i=>{i.isInput()?e.appendChild(i):i.isOutput()&&t.appendChild(i)}))}createPinElements(){return this.element.getPinEntities().filter((e=>!e.isHidden())).map((e=>(this.#Q||"Target"!=e.getDisplayName()||(this.#Q=!0),tt.getConstructor("ueb-pin").newObject(e,void 0,this.element))))}getPinElements(e){return e.querySelectorAll("ueb-pin")}linksChanged(){}}class wt extends yt{#ee=document.createElement("div");#te=document.createElement("div");#ie=document.createElement("div");#ne=document.createElement("div");#se=document.createElement("div");#re=document.createElement("div");#ae=document.createElement("div");#oe=document.createElement("div");initialize(e){super.initialize(e),this.element.classList.add("ueb-resizeable"),this.#ee.classList.add("ueb-resizeable-top"),this.#te.classList.add("ueb-resizeable-right"),this.#ie.classList.add("ueb-resizeable-bottom"),this.#ne.classList.add("ueb-resizeable-left"),this.#se.classList.add("ueb-resizeable-top-right"),this.#re.classList.add("ueb-resizeable-bottom-right"),this.#ae.classList.add("ueb-resizeable-bottom-left"),this.#oe.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.#ee,this.#te,this.#ie,this.#ne,this.#se,this.#re,this.#ae,this.#oe)}createInputObjects(){return[...super.createInputObjects(),new mt(this.#ee,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 mt(this.#te,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.rightBoundary(),this.setSizeX(this.element.sizeX+t[0])},onEndDrag:()=>this.endResize()}),new mt(this.#ie,this.blueprint,{onDrag:(e,t)=>{t[1]=e[1]-this.element.bottomBoundary(),this.setSizeY(this.element.sizeY+t[1])},onEndDrag:()=>this.endResize()}),new mt(this.#ne,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 mt(this.#se,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 mt(this.#re,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 mt(this.#ae,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 mt(this.#oe,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 Et extends wt{#le=fe.getWhite();#ue=0;initialize(e){e.entity.CommentColor&&(this.#le.setFromRGBANumber(e.entity.CommentColor.toNumber()),this.#le.setFromHSVA(this.#le.H.value,this.#le.S.value,.67*Math.pow(this.#le.V.value,.45))),e.classList.add("ueb-node-style-comment","ueb-node-resizeable"),e.sizeX=25*te.gridSize,e.sizeY=6*te.gridSize,super.initialize(e)}getColor(){return r`${Math.round(255*this.#le.R.value)}${Math.round(255*this.#le.G.value)}${Math.round(255*this.#le.B.value)}`}getDraggableElement(){return this.element.querySelector(".ueb-node-top")}render(){return B`
${this.element.entity.NodeComment}
`}firstUpdated(e){super.firstUpdated(e);const t=this.getDraggableElement().getBoundingClientRect();this.#ue=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))>=te.gridSet*te.gridSize&&(this.element.setNodeWidth(e),!0)}setSizeY(e){return(e=Math.round(e))>=3*te.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.#ue:super.bottomBoundary()}leftBoundary(e=!1){return this.element.locationX}}class St extends Ze{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(te.nodeDragGeneralEventName,this.dragHandler)}setSelected(e=!0){this.selected=e,this.blueprint&&(this.selected?(this.listeningDrag=!0,this.blueprint.addEventListener(te.nodeDragGeneralEventName,this.dragHandler)):(this.blueprint.removeEventListener(te.nodeDragGeneralEventName,this.dragHandler),this.listeningDrag=!1))}}class Pt extends Je{#ce;#he=null;#de=e=>{if(!this.enteredPin){this.linkValid=!1,this.enteredPin=e.target;const t=this.link.sourcePin??this.target,i=this.enteredPin;t.nodeElement.getType()==te.nodeType.knot||i.nodeElement.getType()==te.nodeType.knot?(this.link.setMessageCorrect(),this.linkValid=!0):t.getNodeElement()==i.getNodeElement()?this.link.setMessageSameNode():t.isOutput()==i.isOutput()||t.isOutput()==i.isOutput()?this.link.setMessageDirectionsIncompatible():this.blueprint.getLinks([t,i]).length?(this.link.setMessageReplaceLink(),this.linkValid=!0):(this.link.setMessageCorrect(),this.linkValid=!0)}};#pe=e=>{this.enteredPin==e.target&&(this.enteredPin=null,this.linkValid=!1,this.link?.setMessagePlaceNode())};link;enteredPin;linkValid=!1;startDrag(e){this.target.nodeElement.getType()==te.nodeType.knot&&(this.#he=this.target),this.link=tt.getConstructor("ueb-link").newObject(this.target,null),this.blueprint.template.linksContainerElement.prepend(this.link),this.link.setMessagePlaceNode(),this.#ce=this.blueprint.querySelectorAll("ueb-pin"),this.#ce.forEach((e=>{if(e!=this.target){const t=e.template.getClickableElement();t.addEventListener("mouseenter",this.#de),t.addEventListener("mouseleave",this.#pe)}})),this.link.startDragging(),this.link.setDestinationLocation(e)}dragTo(e,t){this.link.setDestinationLocation(e)}endDrag(){if(this.#ce.forEach((e=>{e.removeEventListener("mouseenter",this.#de),e.removeEventListener("mouseleave",this.#pe)})),this.enteredPin&&this.linkValid){if(this.#he){const e=this.#he!==this.link.sourcePin?this.link.sourcePin:this.enteredPin;if(this.#he.isInput()&&e.isInput()||this.#he.isOutput()&&e.isOutput()){const e=this.#he.isInput()?this.#he.nodeElement.template.outputPin:this.#he.nodeElement.template.inputPin;this.#he===this.link.sourcePin?this.link.sourcePin=e:this.enteredPin=e}}this.blueprint.addGraphElement(this.link),this.link.destinationPin=this.enteredPin,this.link.removeMessage(),this.link.finishDragging()}else this.link.finishDragging(),this.link.remove();this.enteredPin=null,this.link=null,this.#ce=null}}class Ct extends yt{#me=!1;#ge=!1;#be="";initialize(e){super.initialize(e),this.element.classList.add("ueb-node-style-glass"),this.#be=this.element.getNodeDisplayName()}render(){return B`
${this.#be?B`
${this.#be}
`:H}
${this.#me?B`
`:H} ${this.#ge?B`
`:H}
`}createPinElements(){return this.element.getPinEntities().filter((e=>!e.isHidden())).map((e=>{this.#me||=e.isInput(),this.#ge||=e.isOutput();return tt.getConstructor("ueb-pin").newObject(e,void 0,this.element)}))}}class kt extends Ct{initialize(e){super.initialize(e),this.element.classList.add("ueb-node-style-conversion")}}class xt extends Ct{initialize(e){super.initialize(e),this.element.classList.add("ueb-node-style-operation")}}class Nt extends Fe{#ve;get iconElement(){return this.#ve}isNameRendered=!0;setup(){super.setup(),this.element.nodeElement=this.element.closest("ueb-node");const e=this.element.nodeElement.template;(e instanceof kt||e instanceof xt)&&(this.isNameRendered=!1,this.element.requestUpdate())}createInputObjects(){return[new Pt(this.getClickableElement(),this.blueprint,{moveEverywhere:!0})]}render(){const e=B`
${this.renderIcon()}
`,t=B`
${this.isNameRendered?this.renderName():H} ${this.element.isInput()&&!this.element.entity.bDefaultValueIsIgnored?this.renderInput():B``}
`;return B`
${this.element.isInput()?B`${e}${t}`:B`${t}${e}`}
`}renderIcon(){return ht.genericPin}renderName(){return B`${this.element.getPinDisplayName()}`}renderInput(){return B``}updated(e){if(super.updated(e),this.element.isInput()&&e.has("isLinked")){const e=this.element.nodeElement;e.addNextUpdatedCallbacks((()=>e.acknowledgeReflow())),e.requestUpdate()}}firstUpdated(e){super.firstUpdated(e),this.element.style.setProperty("--ueb-pin-color-rgb",te.getPinColor(this.element).cssText),this.#ve=this.element.querySelector(".ueb-pin-icon svg")??this.element}getLinkLocation(){const e=this.iconElement.getBoundingClientRect(),t=ae.convertLocation([(e.left+e.right)/2,(e.top+e.bottom)/2],this.blueprint.template.gridElement);return this.blueprint.compensateTranslation(t)}getClickableElement(){return this.element}}class Lt extends Nt{render(){return this.element.isOutput()?B`
${this.renderIcon()}
`:B``}getLinkLocation(){const e=(this.element.isInput()?this.element.nodeElement.template.outputPin.template:this).iconElement.getBoundingClientRect(),t=ae.convertLocation([this.element.isInput()?e.left+1:e.right+2,(e.top+e.bottom)/2],this.blueprint.template.gridElement);return this.blueprint.compensateTranslation(t)}}class At extends yt{static#fe=new Set;#ye=null;#we;get inputPin(){return this.#we}#Ee;get outputPin(){return this.#Ee}initialize(e){super.initialize(e),this.element.classList.add("ueb-node-style-minimal")}findDirectionaPin(e){if(e.nodeElement.getType()!==te.nodeType.knot||At.#fe.has(e))return At.#fe.clear(),!0;At.#fe.add(e);for(let t of e.getLinks().map((e=>this.blueprint.getPin(e))))if(this.findDirectionaPin(t))return!0;return!1}render(){return B`
`}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],n=tt.getConstructor("ueb-pin");return[this.#we=n.newObject(t,new Lt,this.element),this.#Ee=n.newObject(i,new Lt,this.element)]}linksChanged(){}}class Tt extends Ct{initialize(e){super.initialize(e),e.getType()===te.nodeType.variableGet?this.element.classList.add("ueb-node-style-getter"):e.getType()===te.nodeType.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)}}class Mt extends St{static#Se={};static properties={...St.properties,typePath:{type:String,attribute:"data-type",reflect:!0},nodeName:{type:String,attribute:"data-name",reflect:!0},advancedPinDisplay:{type:String,attribute:"data-advanced-display",converter:me.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=te.nodeDragEventName;static dragGeneralEventName=te.nodeDragGeneralEventName;get blueprint(){return super.blueprint}set blueprint(e){super.blueprint=e,this.#Pe.forEach((t=>t.blueprint=e))}#Ce;get nodeNameElement(){return this.#Ce}set nodeNameElement(e){this.#Ce=e}#Pe=[];boundComments=[];#ke=!1;#xe=e=>{this.selected||this.#ke||(this.#ke=!0,this.addNextUpdatedCallbacks((()=>this.#ke=!1)),this.addLocation(e.detail.value))};static getTypeTemplate(e){if((e.getClass()===te.nodeType.callFunction||e.getClass()===te.nodeType.commutativeAssociativeBinaryOperator)&&"/Script/Engine.KismetMathLibrary"===e.FunctionReference.MemberParent.path){if(e.FunctionReference.MemberName?.startsWith("Conv_"))return kt;if(e.FunctionReference.MemberName?.startsWith("Percent_"))return xt;switch(e.FunctionReference.MemberName){case"Abs":case"BMax":case"BMin":case"Exp":case"FMax":case"FMin":case"Max":case"MaxInt64":case"Min":case"MinInt64":return xt}}switch(e.getClass()){case te.nodeType.comment:return Et;case te.nodeType.knot:return At;case te.nodeType.variableGet:case te.nodeType.variableSet:return Tt}return yt}static fromSerializedObject(e){e=e.trim();let t=se.getSerializer($e).deserialize(e);return Mt.newObject(t)}static newObject(e=new $e,t=new(Mt.getTypeTemplate(e))){const i=new Mt;return i.initialize(e,t),i}initialize(e=new $e,t=new(Mt.getTypeTemplate(e))){super.initialize(e,t),this.#Pe=this.template.createPinElements(),this.typePath=this.entity.getType(),this.nodeName=this.entity.getObjectName(),this.advancedPinDisplay=this.entity.AdvancedPinDisplay?.toString(),this.enabledState=this.entity.EnabledState,this.nodeDisplayName=this.getNodeDisplayName(),this.pureFunction=this.entity.bIsPureFunc,this.dragLinkObjects=[],super.setLocation([this.entity.NodePosX.value,this.entity.NodePosY.value]),this.entity.subscribe("AdvancedPinDisplay",(e=>this.advancedPinDisplay=e)),this.entity.subscribe("Name",(e=>this.nodeName=e)),this.entity.NodeWidth&&this.entity.NodeHeight?(this.sizeX=this.entity.NodeWidth.value,this.sizeY=this.entity.NodeHeight.value):this.updateComplete.then((()=>this.computeSizes()))}getUpdateComplete(){return Promise.all([super.getUpdateComplete(),...this.getPinElements().map((e=>e.updateComplete))]).then((()=>!0))}bindToComment(e){e==this||this.boundComments.includes(e)||(e.addEventListener(te.nodeDragEventName,this.#xe),this.boundComments.push(e))}unbindFromComment(e){const t=this.boundComments.indexOf(e);t>=0&&(e.removeEventListener(te.nodeDragEventName,this.#xe),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()}cleanup(){super.cleanup(),this.acknowledgeDelete()}getType(){return this.entity.getType()}getNodeName(){return this.entity.getObjectName()}getNodeDisplayName(){switch(this.getType()){case te.nodeType.callFunction:case te.nodeType.commutativeAssociativeBinaryOperator:if("AddKey"==this.entity.FunctionReference.MemberName){let e=this.entity.FunctionReference.MemberParent.path.match($e.sequencerScriptingNameRegex);if(e)return`Add Key (${ae.formatStringName(e[1])})`}let e=this.entity.FunctionReference.MemberName;if("/Script/Engine.KismetMathLibrary"==this.entity.FunctionReference.MemberParent.path){if(e.startsWith("Conv_"))return"";if(e.startsWith("Percent_"))return"%";const t=e.match(/[BF]([A-Z]\w+)/);switch(t&&(e=t[1]),e){case"Abs":return"ABS";case"Exp":return"e";case"Max":case"MaxInt64":return"MAX";case"Min":case"MinInt64":return"MIN"}}return ae.formatStringName(e);case te.nodeType.dynamicCast:return`Cast To ${this.entity.TargetType.getName()}`;case te.nodeType.executionSequence:return"Sequence";case te.nodeType.ifThenElse:return"Branch";case te.nodeType.forEachElementInEnum:return`For Each ${this.entity.Enum.getName()}`;case te.nodeType.forEachLoopWithBreak:return"For Each Loop with Break";case te.nodeType.variableGet:return"";case te.nodeType.variableSet:return"SET";default:return this.entity.getClass()===te.nodeType.macro?ae.formatStringName(this.entity.MacroGraphReference.getMacroName()):ae.formatStringName(this.entity.getNameAndCounter()[0])}}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)))}rename(e){if(this.entity.Name==e)return!1;for(let t of this.getPinElements())for(let i of t.getLinks())this.blueprint.getPin(i).redirectLink(t,new Se({objectName:e,pinGuid:t.entity.PinId}));this.entity.Name=e}getPinElements(){return this.#Pe}getPinEntities(){return this.entity.CustomProperties.filter((e=>e instanceof Ae))}setLocation(e=[0,0],t=!0){this.entity.NodePosX.value=e[0],this.entity.NodePosY.value=e[1],super.setLocation(e,t)}acknowledgeDelete(){let e=new CustomEvent(te.nodeDeleteEventName);this.dispatchEvent(e)}acknowledgeReflow(){this.addNextUpdatedCallbacks((()=>this.computeSizes()),!0);let e=new CustomEvent(te.nodeReflowEventName);this.dispatchEvent(e)}setShowAdvancedPinDisplay(e){this.entity.AdvancedPinDisplay=new me(e?"Shown":"Hidden")}toggleShowAdvancedPinDisplay(){this.setShowAdvancedPinDisplay("Shown"!=this.entity.AdvancedPinDisplay?.toString())}}class $t extends Ke{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)};#Ne=!1;#Le=new Map;nodes=[];links=[];mousePosition=[0,0];waitingExpandUpdate=!1;constructor(){super(),this.selecting=!1,this.scrolling=!1,this.focused=!1,this.zoom=0,this.scrollX=te.expandGridSize,this.scrollY=te.expandGridSize,this.translateX=te.expandGridSize,this.translateY=te.expandGridSize,super.initialize({},new rt)}initialize(){}getGridDOMElement(){return this.template.gridElement}getScroll(){return[this.scrollX,this.scrollY]}setScroll([e,t]){this.scrollX=e,this.scrollY=t}scrollDelta(e,t=!1){if(t){let t=[0,0];ae.animate(0,e[0],te.smoothScrollTime,(e=>{this.scrollDelta([e-t[0],0],!1),t[0]=e})),ae.animate(0,e[1],te.smoothScrollTime,(e=>{this.scrollDelta([0,e-t[1]],!1),t[1]=e}))}else{const t=[2*te.expandGridSize,2*te.expandGridSize];let i=this.getScroll(),n=[i[0]+e[0],i[1]+e[1]],s=[0,0];for(let e=0;e<2;++e)n[e]t[e]-te.gridExpandThreshold*te.expandGridSize&&(s[e]=1);0==s[0]&&0==s[1]||this.seamlessExpand(s),i=this.getScroll(),n=[i[0]+e[0],i[1]+e[1]],this.setScroll(n)}}scrollCenter(){const e=this.getScroll(),t=[this.translateX-e[0],this.translateY-e[1]],i=this.getViewportSize().map((e=>e/2)),n=[t[0]-i[0],t[1]-i[1]];this.scrollDelta(n,!0)}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){return ae.snapToGrid(e,te.gridSize)}seamlessExpand([e,t]){e=Math.round(e),t=Math.round(t);let i=this.getScale();[e,t]=[-e*te.expandGridSize,-t*te.expandGridSize],0!=e&&(this.scrollX+=e,e/=i),0!=t&&(this.scrollY+=t,t/=i),this.translateX+=e,this.translateY+=t}progressiveSnapToGrid(e){return te.expandGridSize*Math.round(e/te.expandGridSize+.5*Math.sign(e))}getZoom(){return this.zoom}setZoom(e,t){if((e=ae.clamp(e,te.minZoom,te.maxZoom))==this.zoom)return;let i=this.getScale();this.zoom=e,t&&requestAnimationFrame((e=>{t[0]+=this.translateX,t[1]+=this.translateY;let n=this.getScale()/i,s=[n*t[0],n*t[1]];this.scrollDelta([(s[0]-t[0])*i,(s[1]-t[1])*i])}))}getScale(){return parseFloat(getComputedStyle(this.template.gridElement).getPropertyValue("--ueb-scale"))}compensateTranslation([e,t]){return[e-=this.translateX,t-=this.translateY]}getNodes(e=!1,[t,i,n,s]=[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()<=n&&e.leftBoundary()>=s))),r}getCommentNodes(e=!1){let t=[...this.template.getCommentNodes(e)];return 0===t.length&&(t=this.nodes.filter((t=>t.getType()===te.nodeType.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,t]=[]){if(null==e!=t==null){const i=e??t;return this.links.filter((e=>e.sourcePin==i||e.destinationPin==i))}return null!=e&&null!=t?this.links.filter((i=>i.sourcePin==e&&i.destinationPin==t||i.sourcePin==t&&i.destinationPin==e)):this.links}getLink(e,t,i=!1){return this.links.find((n=>n.sourcePin==e&&n.destinationPin==t||i&&n.sourcePin==t&&n.destinationPin==e))}selectAll(){this.getNodes().forEach((e=>$t.nodeSelectToggleFunction(e,!0)))}unselectAll(){this.getNodes().forEach((e=>$t.nodeSelectToggleFunction(e,!1)))}addGraphElement(...e){for(let t of e)if(t.blueprint=this,t instanceof Mt&&!this.nodes.includes(t)){const e=t.entity.getObjectName(),i=this.nodes.find((t=>t.entity.getObjectName()==e));if(i){let e=i.entity.getObjectName(!0);this.#Le[e]=this.#Le[e]??-1;do{++this.#Le[e]}while(this.nodes.find((t=>t.entity.getObjectName()==te.nodeName(e,this.#Le[e]))));i.rename(te.nodeName(e,this.#Le[e]))}this.nodes.push(t),this.template.nodesContainerElement?.appendChild(t)}else t instanceof dt&&!this.links.includes(t)&&(this.links.push(t),this.template.linksContainerElement&&!this.template.linksContainerElement.contains(t)&&this.template.linksContainerElement.appendChild(t));e.filter((e=>e instanceof Mt)).forEach((t=>t.sanitizeLinks(e))),e.filter((e=>e instanceof Mt&&e.getType()==te.nodeType.comment)).forEach((e=>e.updateComplete.then((()=>e.template.manageNodesBind()))))}removeGraphElement(...e){for(let t of e)if(t.closest("ueb-blueprint")==this){t.remove();let e=t instanceof Mt?this.nodes:t instanceof dt?this.links:null;e?.splice(e.findIndex((e=>e===t)),1)}}setFocused(e=!0){if(this.focused==e)return;let t=new CustomEvent(e?te.focusEventName.begin:te.focusEventName.end);this.focused=e,this.focused||this.unselectAll(),this.dispatchEvent(t)}acknowledgeEditText(e){const t=new CustomEvent(e?te.editTextEventName.begin:te.editTextEventName.end);this.dispatchEvent(t)}}customElements.define("ueb-blueprint",$t);class Dt extends gt{#Ae;get locationChangeCallback(){return this.#Ae}set locationChangeCallback(e){this.#Ae=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 pt(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 Bt extends Dt{adjustLocation([e,t]){const i=Math.round(this.movementSpaceSize[0]/2);e-=i,t=-(t-i);let[n,s]=ae.getPolarCoordinates([e,t]);return n=Math.min(n,i),[e,t]=ae.getCartesianCoordinates([n,s]),this.locationChangeCallback?.(e/i,t/i),[e=Math.round(e+i),t=Math.round(-t+i)]}}class Ot extends Ze{windowElement;setup(){super.setup(),this.windowElement=this.closest("ueb-window")}setLocation([e,t]){super.setLocation(this.template.adjustLocation([e,t]))}}class Ht extends Ot{constructor(){super(),super.initialize({},new Bt)}static newObject(){return new Ht}initialize(){}}class zt extends Dt{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 Rt extends Ot{constructor(){super(),super.initialize({},new zt)}static newObject(){return new Rt}initialize(){}}class It extends Fe{#Te=()=>{this.blueprint.acknowledgeEditText(!0),this.element.selectOnFocus&&getSelection().selectAllChildren(this.element)};#Me=()=>{this.blueprint.acknowledgeEditText(!1),document.getSelection()?.removeAllRanges()};#$e=e=>e.target.querySelectorAll("br").forEach((e=>e.remove()));#De=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"}setup(){super.setup(),this.element.addEventListener("focus",this.#Te),this.element.addEventListener("focusout",this.#Me),this.element.singleLine&&this.element.addEventListener("input",this.#$e),this.element.blurOnEnter&&this.element.addEventListener("keydown",this.#De)}cleanup(){super.cleanup(),this.element.removeEventListener("focus",this.#Te),this.element.removeEventListener("focusout",this.#Me),this.element.removeEventListener("input",this.#$e),this.element.removeEventListener("keydown",this.#De)}}class Vt extends Ke{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 It)}static newObject(){return new Vt}initialize(){}}class _t extends Je{constructor(e,t,i={}){i.consumeEvent=!0,super(e,t,i)}}class Ft extends Nt{#Be;#Oe=e=>this.element.setDefaultValue(this.#Be.checked);firstUpdated(e){super.firstUpdated(e),this.#Be=this.element.querySelector(".ueb-pin-input")}setup(){super.setup(),this.#Be?.addEventListener("change",this.#Oe)}cleanup(){super.cleanup(),this.#Be?.removeEventListener("change",this.#Oe)}createInputObjects(){return[...super.createInputObjects(),new _t(this.#Be,this.blueprint)]}renderInput(){return B``}}class Gt extends Nt{static singleLineInput=!1;static selectOnFocus=!0;#He;get inputContentElements(){return this.#He}static stringFromInputToUE(e){return e.replace(/(?=\n\s*)\n$/,"").replaceAll("\n","\\r\n")}static stringFromUEToInput(e){return e.replaceAll(/(?:\r|(?<=(?:^|[^\\])(?:\\\\)*)\\r)(?=\n)/g,"").replace(/(?<=\n\s*)$/,"\n")}#ze=()=>this.setInputs(this.getInputs(),!0);firstUpdated(e){super.firstUpdated(e),this.#He=[...this.element.querySelectorAll("ueb-input")]}setup(){super.setup(),this.#He.forEach((e=>{e.addEventListener("focusout",this.#ze)}))}cleanup(){super.cleanup(),this.#He.forEach((e=>{e.removeEventListener("focusout",this.#ze)}))}createInputObjects(){return[...super.createInputObjects(),...this.#He.map((e=>new _t(e,this.blueprint)))]}getInput(){return this.getInputs().reduce(((e,t)=>e+t),"")}getInputs(){return this.#He.map((e=>ae.clearHTMLWhitespace(e.innerHTML)))}setInputs(e=[],t=!0){this.#He.forEach(this.constructor.singleLineInput?(t,i)=>t.innerText=e[i]:(t,i)=>t.innerText=e[i].replaceAll("\n","")),t&&this.setDefaultValue(e.map((e=>Gt.stringFromInputToUE(e))),e),this.element.addNextUpdatedCallbacks((()=>this.element.nodeElement.acknowledgeReflow()))}setDefaultValue(e=[],t=e){this.element.setDefaultValue(e.join(""))}renderInput(){const e=this.constructor.singleLineInput,t=this.constructor.selectOnFocus;return B`
`}}class jt extends Gt{static singleLineInput=!0;setInputs(e=[],t=!1){e&&0!=e.length||(e=[this.getInput()]);let i=[];for(const t of e){let e=parseFloat(t);isNaN(e)&&(e=0,!1),i.push(e)}super.setInputs(e,!1),this.setDefaultValue(i,e)}setDefaultValue(e=[],t){this.element.setDefaultValue(e[0])}}class Ut extends jt{setDefaultValue(e=[],t=e){const i=this.element.getDefaultValue(!0);if(!(i instanceof ce))throw new TypeError("Expected DefaultValue to be a ByteEntity");i.value=e[0],this.element.requestUpdate("DefaultValue",i)}renderInput(){return B`
`}}class Xt extends Nt{renderIcon(){return ht.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 B``;return B`${ae.formatStringName(e)}`}}class Wt extends jt{setDefaultValue(e=[],t=e){parseInt(e[0]);const i=this.element.getDefaultValue(!0);i.value=e[0],this.element.requestUpdate("DefaultValue",i)}renderInput(){return B`
`}} /** * @license * Copyright 2017 Google LLC * SPDX-License-Identifier: BSD-3-Clause - */const qt=1;class Kt{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 Yt=1;class qt{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 Zt=(e=>(...t)=>({_$litDirective$:e,values:t}))(class extends Kt{constructor(e){var t;if(super(e),e.type!==qt||"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 n=e[i];return null==n?t:t+`${i=i.replace(/(?:^(webkit|moz|ms|o)|)(?=[A-Z])/g,"-$&").toLowerCase()}:${n};`}),"")}update(e,[t]){const{style:i}=e.element;if(void 0===this.vt){this.vt=new Set;for(const e in t)this.vt.add(e);return this.render(t)}this.vt.forEach((e=>{null==t[e]&&(this.vt.delete(e),e.includes("-")?i.removeProperty(e):i[e]="")}));for(const e in t){const n=t[e];null!=n&&(this.vt.add(e),e.includes("-")?i.setProperty(e,n):i[e]=n)}return O}});class Jt extends vt{toggleAdvancedDisplayHandler;getDraggableElement(){return this.element.querySelector(".ueb-window-top")}createDraggableObject(){return new mt(this.element,this.blueprint,{draggableElement:this.getDraggableElement(),ignoreScale:!0,ignoreTranslateCompensate:!1,movementSpace:this.blueprint,stepSize:1})}render(){return B`
${this.renderWindowName()}
${dt.close}
${this.renderContent()}
`}renderWindowName(){return B`Window`}renderContent(){return B``}apply(){this.element.dispatchEvent(new CustomEvent(te.windowApplyEventName)),this.element.remove()}cancel(){this.element.dispatchEvent(new CustomEvent(te.windowCancelEventName)),this.element.remove()}}class Qt extends Jt{#je;#Ue;#Xe;#We;#Ye;#qe;#Ke;#Ze;#Je;#Qe;#et=e=>{const t=le.clearHTMLWhitespace(e.target.innerHTML),i=parseInt(t,16);isNaN(i)||(this.color.setFromRGBANumber(i),this.element.requestUpdate())};#tt=e=>{const t=le.clearHTMLWhitespace(e.target.innerHTML),i=parseInt(t,16);isNaN(i)||(this.color.setFromSRGBANumber(i),this.element.requestUpdate())};#it=e=>t=>{"Enter"==t.code&&(t.preventDefault(),e(t))};#me=new fe;get color(){return this.#me}set color(e){e.toNumber()!=this.color?.toNumber()&&(this.element.requestUpdate("color",this.#me),this.#me=e)}#nt=new fe;get fullColor(){return this.#nt}#st;get initialColor(){return this.#st}#rt=new fe;#ot(e,t,i=!1){const n=this.color.toRGBAString(),s=`${n.substring(0,2*e)}${t}${n.substring(2+2*e)}`;return i?`${s.substring(0,6)}FF`:s}initialize(e){super.initialize(e),this.#st=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.#je=this.element.querySelector(".ueb-color-picker-wheel ueb-color-handler"),this.#Ue=this.element.querySelector(".ueb-color-picker-saturation ueb-ui-slider"),this.#Xe=this.element.querySelector(".ueb-color-picker-value ueb-ui-slider"),this.#We=this.element.querySelector(".ueb-color-picker-r ueb-ui-slider"),this.#Ye=this.element.querySelector(".ueb-color-picker-g ueb-ui-slider"),this.#qe=this.element.querySelector(".ueb-color-picker-b ueb-ui-slider"),this.#Ke=this.element.querySelector(".ueb-color-picker-a ueb-ui-slider"),this.#Ze=this.element.querySelector(".ueb-color-picker-h ueb-ui-slider"),this.#Je=this.element.querySelector(".ueb-color-picker-s ueb-ui-slider"),this.#Qe=this.element.querySelector(".ueb-color-picker-v ueb-ui-slider"),this.#je.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.#Ue.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,t,this.color.V.value,this.color.A.value),this.element.requestUpdate()},this.#Xe.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,this.color.S.value,t,this.color.A.value),this.element.requestUpdate()},this.#We.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(e,this.color.G.value,this.color.B.value,this.color.A.value),this.element.requestUpdate()},this.#Ye.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(this.color.R.value,e,this.color.B.value,this.color.A.value),this.element.requestUpdate()},this.#qe.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(this.color.R.value,this.color.G.value,e,this.color.A.value),this.element.requestUpdate()},this.#Ke.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(this.color.R.value,this.color.G.value,this.color.B.value,e),this.element.requestUpdate()},this.#Ze.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(e,this.color.S.value,this.color.V.value,this.color.A.value),this.element.requestUpdate()},this.#Je.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,e,this.color.V.value,this.color.A.value),this.element.requestUpdate()},this.#Qe.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,n="";const s=e=>`linear-gradient(to right, #${this.#ot(e,"00",!0)}, #${this.#ot(e,"ff",!0)})`;switch(e){case 0:t="r",i=this.color.R.value,n=s(e);break;case 1:t="g",i=this.color.G.value,n=s(e);break;case 2:t="b",i=this.color.B.value,n=s(e);break;case 3:t="a",i=this.color.A.value,n=`${te.alphaPattern}, ${s(e)}`;break;case 4:t="h",i=360*this.color.H.value,n="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,n=`linear-gradient(to right,#${this.#rt.setFromHSVA(this.color.H.value,0,this.color.V.value,1),this.#rt.toRGBAString()},#${this.#rt.setFromHSVA(this.color.H.value,1,this.color.V.value,1),this.#rt.toRGBAString()})`;break;case 6:t="v",i=this.color.V.value,n=`linear-gradient(to right, #000, #${this.fullColor.toRGBAString()})`}return n=`background: ${n};`,B`
${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(),n=this.color.toSRGBAString(),s=this.fullColor.toRGBAString();return B`
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
OK
Cancel
`}renderWindowName(){return B`Color Picker`}}class ei extends Lt{#at;#lt=e=>{e.preventDefault(),this.blueprint.setFocused(!0),this.#at=it.getConstructor("ueb-window").newObject({type:new Qt,windowOptions:{getPinColor:()=>this.element.defaultValue,setPinColor:e=>this.element.setDefaultValue(e)}}),this.blueprint.append(this.#at);const t=()=>{this.element.setDefaultValue(this.#at.template.color)},i=()=>{this.#at.removeEventListener(te.windowApplyEventName,t),this.#at.removeEventListener(te.windowCloseEventName,i),this.#at=null};this.#at.addEventListener(te.windowApplyEventName,t),this.#at.addEventListener(te.windowCloseEventName,i)};renderInput(){return B``}}class ti extends jt{static singleLineInput=!0}class ii extends Ut{setDefaultValue(e=[],t=e){this.element.setDefaultValue(e[0])}renderInput(){return B`
`}}class ni extends Lt{renderIcon(){return dt.referencePin}}class si extends Ut{#ut(){return jt.stringFromUEToInput(le.minDecimals(this.element.getDefaultValue()?.R??0))}#ct(){return jt.stringFromUEToInput(le.minDecimals(this.element.getDefaultValue()?.P??0))}#ht(){return jt.stringFromUEToInput(le.minDecimals(this.element.getDefaultValue()?.Y??0))}setDefaultValue(e=[],t=e){const i=this.element.getDefaultValue(!0);if(!(i instanceof Pe))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 B`
X
Y
Z
`}}class ri extends jt{}class oi extends Ut{#dt(){return jt.stringFromUEToInput(le.minDecimals(this.element.getDefaultValue()?.X??0))}#ht(){return jt.stringFromUEToInput(le.minDecimals(this.element.getDefaultValue()?.Y??0))}setDefaultValue(e,t){const i=this.element.getDefaultValue(!0);if(!(i instanceof ke))throw new TypeError("Expected DefaultValue to be a Vector2DEntity");i.X=e[0],i.Y=e[1],this.element.requestUpdate("DefaultValue",i)}renderInput(){return B`
X
Y
`}}class ai extends Ut{#dt(){return jt.stringFromUEToInput(le.minDecimals(this.element.getDefaultValue()?.X??0))}#ht(){return jt.stringFromUEToInput(le.minDecimals(this.element.getDefaultValue()?.Y??0))}#pt(){return jt.stringFromUEToInput(le.minDecimals(this.element.getDefaultValue()?.Z??0))}setDefaultValue(e,t){const i=this.element.getDefaultValue(!0);if(!(i instanceof Ne))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 B`
X
Y
Z
`}}class li extends Ze{static#mt={"/Script/CoreUObject.LinearColor":ei,"/Script/CoreUObject.Rotator":si,"/Script/CoreUObject.Vector":ai,"/Script/CoreUObject.Vector2D":oi,bool:Ft,byte:Xt,int:Yt,int64:Yt,MUTABLE_REFERENCE:ni,name:ti,real:ii,string:ri};static properties={pinId:{type:de,converter:{fromAttribute:(e,t)=>e?Ve.grammar.Guid.parse(e).value: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:fe,converter:{fromAttribute:(e,t)=>e?Ve.grammar.LinearColorFromAnyColor.parse(e).value:null,toAttribute:(e,t)=>e?le.printLinearColor(e):null},attribute:"data-color",reflect:!0},defaultValue:{type:String,attribute:!1},isLinked:{type:Boolean,converter:le.booleanConverter,attribute:"data-linked",reflect:!0},pinDirection:{type:String,attribute:"data-direction",reflect:!0}};nodeElement;static getTypeTemplate(e){if(e.PinType.bIsReference&&!e.PinType.bIsConst)return li.#mt.MUTABLE_REFERENCE;if("exec"===e.getType())return Wt;let t;return e.isInput()&&(t=li.#mt[e.getType()]),t??Lt}static newObject(e=new Te,t=new(li.getTypeTemplate(e)),i){const n=new li;return n.initialize(e,t,i),n}initialize(e=new Te,t=new(li.getTypeTemplate(e)),i){super.initialize(e,t),this.pinId=this.entity.PinId,this.pinType=this.entity.getType(),this.advancedView=this.entity.bAdvancedView,this.defaultValue=this.entity.getDefaultValue(),this.color=li.properties.color.converter.fromAttribute(this.getColor().toString()),this.isLinked=!1,this.pinDirection=e.isInput()?"input":e.isOutput()?"output":"hidden",this.nodeElement=i,this.entity.subscribe("PinToolTip",(e=>{let t=e.match(/\s*(.+?(?=\n)|.+\S)\s*/);return t?le.formatStringName(t[1]):le.formatStringName(this.entity.PinName)}))}setup(){super.setup(),this.nodeElement=this.closest("ueb-node")}getPinId(){return this.entity.PinId}getPinName(){return this.entity.PinName}getPinDisplayName(){return this.entity.getDisplayName()}getColor(){return te.getPinColor(this)}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}sanitizeLinks(e=[]){this.entity.LinkedTo=this.getLinks().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,!0);t||(t=it.getConstructor("ueb-link").newObject(this,i),this.blueprint.addGraphElement(t))}return i})),this.isLinked=this.entity.isLinked()}linkTo(e){this.entity.linkTo(e.getNodeElement().getNodeName(),e.entity)&&(this.isLinked=this.entity.isLinked(),this.nodeElement?.template.linksChanged())}unlinkFrom(e){this.entity.unlinkFrom(e.getNodeElement().getNodeName(),e.entity)&&(this.isLinked=this.entity.isLinked(),this.nodeElement?.template.linksChanged())}redirectLink(e,t){const i=this.entity.LinkedTo.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 ui{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 ci{constructor(e,t,i,n){this.initialPosition=e,this.finalPosition=e,this.metadata=new Array(t.length),this.primaryOrder=new ui((e=>this.metadata[e].primaryBoundary)),this.secondaryOrder=new ui((e=>this.metadata[e].secondaryBoundary)),this.selectFunc=n,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,n(e,!1);const r=i(e);this.initialPosition[1]{if(this.metadata[i].onSecondaryAxis)this.selectFunc(this.rectangles[i],n);else if(n){this.secondaryOrder.insert(i,e[1]);const n=this.metadata[i].secondaryBoundary;Math.sign(e[1]-n)==t[1]&&Math.sign(n-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,n(this.boundaries.secondaryP.i,this.initialPosition[1]pi.#Le[e],toAttribute:(e,t)=>Object.entries(pi.#Le).find((([t,i])=>e.constructor===i))?.[0]}}};static newObject(e={},t=e.type??new Jt){const i=new pi;return i.initialize(e,t),i}initialize(e={},t=e.type??new Jt){e.windowOptions??={},this.type=e.type,this.windowOptions=e.windowOptions,super.initialize(e,t)}setup(){super.setup(),this.locationX=this.blueprint.mousePosition[0],this.locationY=this.blueprint.mousePosition[1]}cleanup(){super.cleanup(),this.acknowledgeClose()}acknowledgeClose(){let e=new CustomEvent(te.windowCloseEventName);this.dispatchEvent(e)}}class mi extends Ve{constructor(e,t,i,n,s,r,o){e=e??(e=>`(${e})`),super(t,i,n,s,r,o),this.wrap=e}read(e){const t=Re.getGrammarForType(Ve.grammar,this.entityType).parse(e);if(!t.status)throw new Error(`Error when trying to parse the entity ${this.entityType.prototype.constructor.name}.`);return t.value}write(e,t,i=!1){return this.wrap(this.subWrite(e,[],t,i),t)}}class gi extends mi{#gt;constructor(e,t){super(void 0,t),this.#gt=e}write(e,t,i=!1){return this.#gt(t,i)}}class bi extends mi{constructor(e){super(void 0,e)}write(e,t,i){return i||t.constructor!==String?le.escapeString(t.toString()):`"${le.escapeString(t.toString())}"`}}!function(){const e=e=>`(${e})`;re.registerSerializer(null,new gi(((e,t)=>"()"),null)),re.registerSerializer(Array,new gi(((e,t)=>`(${e.map((e=>re.getSerializer(le.getType(e)).serialize(e,t)+",")).join("")})`),Array)),re.registerSerializer(Boolean,new gi(((e,t)=>e?t?"true":"True":t?"false":"False"),Boolean)),re.registerSerializer(he,new mi(e,he)),re.registerSerializer(de,new bi(de)),re.registerSerializer(pe,new bi(pe)),re.registerSerializer(me,new bi(me)),re.registerSerializer(ge,new mi((e=>`${ge.lookbehind}(${e})`),ge,"",", ",!1,"",(e=>""))),re.registerSerializer(be,new mi(e,be)),re.registerSerializer(fe,new mi(e,fe)),re.registerSerializer(ye,new mi((e=>`${ye.lookbehind}(${e})`),ye,"",", ",!1,"",(e=>""))),re.registerSerializer(we,new mi(e,we)),re.registerSerializer(Number,new gi((e=>e.toString()),Number)),re.registerSerializer($e,new _e),re.registerSerializer(ce,new gi((e=>(e.type??"")+(e.path?e.type?`'"${e.path}"'`:`"${e.path}"`:"")),ce)),re.registerSerializer(Ee,new bi(Ee)),re.registerSerializer(Te,new mi((e=>`${Te.lookbehind} (${e})`),Te,"",",",!0)),re.registerSerializer(Se,new mi((e=>e),Se,""," ",!1,"",(e=>""))),re.registerSerializer(ve,new bi(ve)),re.registerSerializer(Pe,new mi(e,Pe)),re.registerSerializer(String,new gi(((e,t)=>t?le.escapeString(e):`"${le.escapeString(e)}"`),String)),re.registerSerializer(Ce,new gi(((e,t)=>`${e.P}, ${e.Y}, ${e.R}`),Ce)),re.registerSerializer(xe,new gi(((e,t)=>`${e.X}, ${e.Y}`),xe)),re.registerSerializer(Le,new gi(((e,t)=>`${e.X}, ${e.Y}, ${e.Z}`),Le)),re.registerSerializer(Ae,new bi(Ae)),re.registerSerializer(He,new mi(((e,t)=>`${t.lookbehind??""}(${e})`),He)),re.registerSerializer(Me,new mi(e,Me)),re.registerSerializer(ke,new mi(e,ke)),re.registerSerializer(Ne,new mi(e,Ne))}(),customElements.define("ueb-color-handler",zt),it.registerElement("ueb-color-handler",zt),customElements.define("ueb-input",_t),it.registerElement("ueb-input",_t),customElements.define("ueb-link",pt),it.registerElement("ueb-link",pt),customElements.define("ueb-node",$t),it.registerElement("ueb-node",$t),customElements.define("ueb-pin",li),it.registerElement("ueb-pin",li),customElements.define("ueb-selector",di),it.registerElement("ueb-selector",di),customElements.define("ueb-ui-slider",Rt),it.registerElement("ueb-ui-slider",Rt),customElements.define("ueb-window",pi),it.registerElement("ueb-window",pi);export{Dt as Blueprint,te as Configuration,pt as LinkElement,$t as NodeElement,le as Utility}; + */const Kt=(e=>(...t)=>({_$litDirective$:e,values:t}))(class extends qt{constructor(e){var t;if(super(e),e.type!==Yt||"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 n=e[i];return null==n?t:t+`${i=i.replace(/(?:^(webkit|moz|ms|o)|)(?=[A-Z])/g,"-$&").toLowerCase()}:${n};`}),"")}update(e,[t]){const{style:i}=e.element;if(void 0===this.vt){this.vt=new Set;for(const e in t)this.vt.add(e);return this.render(t)}this.vt.forEach((e=>{null==t[e]&&(this.vt.delete(e),e.includes("-")?i.removeProperty(e):i[e]="")}));for(const e in t){const n=t[e];null!=n&&(this.vt.add(e),e.includes("-")?i.setProperty(e,n):i[e]=n)}return O}});class Zt extends bt{toggleAdvancedDisplayHandler;getDraggableElement(){return this.element.querySelector(".ueb-window-top")}createDraggableObject(){return new pt(this.element,this.blueprint,{draggableElement:this.getDraggableElement(),ignoreScale:!0,ignoreTranslateCompensate:!1,movementSpace:this.blueprint,stepSize:1})}render(){return B`
${this.renderWindowName()}
${ht.close}
${this.renderContent()}
`}renderWindowName(){return B`Window`}renderContent(){return B``}apply(){this.element.dispatchEvent(new CustomEvent(te.windowApplyEventName)),this.element.remove()}cancel(){this.element.dispatchEvent(new CustomEvent(te.windowCancelEventName)),this.element.remove()}}class Jt extends Zt{#Re;#Ie;#Ve;#_e;#Fe;#Ge;#je;#Ue;#Xe;#We;#Ye=e=>{const t=ae.clearHTMLWhitespace(e.target.innerHTML),i=parseInt(t,16);isNaN(i)||(this.color.setFromRGBANumber(i),this.element.requestUpdate())};#qe=e=>{const t=ae.clearHTMLWhitespace(e.target.innerHTML),i=parseInt(t,16);isNaN(i)||(this.color.setFromSRGBANumber(i),this.element.requestUpdate())};#Ke=e=>t=>{"Enter"==t.code&&(t.preventDefault(),e(t))};#le=new fe;get color(){return this.#le}set color(e){e.toNumber()!=this.color?.toNumber()&&(this.element.requestUpdate("color",this.#le),this.#le=e)}#Ze=new fe;get fullColor(){return this.#Ze}#Je;get initialColor(){return this.#Je}#Qe=new fe;#et(e,t,i=!1){const n=this.color.toRGBAString(),s=`${n.substring(0,2*e)}${t}${n.substring(2+2*e)}`;return i?`${s.substring(0,6)}FF`:s}initialize(e){super.initialize(e),this.#Je=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.#Re=this.element.querySelector(".ueb-color-picker-wheel ueb-color-handler"),this.#Ie=this.element.querySelector(".ueb-color-picker-saturation ueb-ui-slider"),this.#Ve=this.element.querySelector(".ueb-color-picker-value ueb-ui-slider"),this.#_e=this.element.querySelector(".ueb-color-picker-r ueb-ui-slider"),this.#Fe=this.element.querySelector(".ueb-color-picker-g ueb-ui-slider"),this.#Ge=this.element.querySelector(".ueb-color-picker-b ueb-ui-slider"),this.#je=this.element.querySelector(".ueb-color-picker-a ueb-ui-slider"),this.#Ue=this.element.querySelector(".ueb-color-picker-h ueb-ui-slider"),this.#Xe=this.element.querySelector(".ueb-color-picker-s ueb-ui-slider"),this.#We=this.element.querySelector(".ueb-color-picker-v ueb-ui-slider"),this.#Re.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.#Ie.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,t,this.color.V.value,this.color.A.value),this.element.requestUpdate()},this.#Ve.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,this.color.S.value,t,this.color.A.value),this.element.requestUpdate()},this.#_e.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(e,this.color.G.value,this.color.B.value,this.color.A.value),this.element.requestUpdate()},this.#Fe.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(this.color.R.value,e,this.color.B.value,this.color.A.value),this.element.requestUpdate()},this.#Ge.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(this.color.R.value,this.color.G.value,e,this.color.A.value),this.element.requestUpdate()},this.#je.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(this.color.R.value,this.color.G.value,this.color.B.value,e),this.element.requestUpdate()},this.#Ue.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(e,this.color.S.value,this.color.V.value,this.color.A.value),this.element.requestUpdate()},this.#Xe.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,e,this.color.V.value,this.color.A.value),this.element.requestUpdate()},this.#We.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,n="";const s=e=>`linear-gradient(to right, #${this.#et(e,"00",!0)}, #${this.#et(e,"ff",!0)})`;switch(e){case 0:t="r",i=this.color.R.value,n=s(e);break;case 1:t="g",i=this.color.G.value,n=s(e);break;case 2:t="b",i=this.color.B.value,n=s(e);break;case 3:t="a",i=this.color.A.value,n=`${te.alphaPattern}, ${s(e)}`;break;case 4:t="h",i=360*this.color.H.value,n="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,n=`linear-gradient(to right,#${this.#Qe.setFromHSVA(this.color.H.value,0,this.color.V.value,1),this.#Qe.toRGBAString()},#${this.#Qe.setFromHSVA(this.color.H.value,1,this.color.V.value,1),this.#Qe.toRGBAString()})`;break;case 6:t="v",i=this.color.V.value,n=`linear-gradient(to right, #000, #${this.fullColor.toRGBAString()})`}return n=`background: ${n};`,B`
${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(),n=this.color.toSRGBAString(),s=this.fullColor.toRGBAString();return B`
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
OK
Cancel
`}renderWindowName(){return B`Color Picker`}}class Qt extends Nt{#tt;#it=e=>{e.preventDefault(),this.blueprint.setFocused(!0),this.#tt=tt.getConstructor("ueb-window").newObject({type:new Jt,windowOptions:{getPinColor:()=>this.element.defaultValue,setPinColor:e=>this.element.setDefaultValue(e)}}),this.blueprint.append(this.#tt);const t=()=>{this.element.setDefaultValue(this.#tt.template.color)},i=()=>{this.#tt.removeEventListener(te.windowApplyEventName,t),this.#tt.removeEventListener(te.windowCloseEventName,i),this.#tt=null};this.#tt.addEventListener(te.windowApplyEventName,t),this.#tt.addEventListener(te.windowCloseEventName,i)};renderInput(){return B``}}class ei extends Gt{static singleLineInput=!0}class ti extends jt{setDefaultValue(e=[],t=e){this.element.setDefaultValue(e[0])}renderInput(){return B`
`}}class ii extends Nt{renderIcon(){return ht.referencePin}}class ni extends jt{#nt(){return Gt.stringFromUEToInput(ae.minDecimals(this.element.getDefaultValue()?.R??0))}#st(){return Gt.stringFromUEToInput(ae.minDecimals(this.element.getDefaultValue()?.P??0))}#rt(){return Gt.stringFromUEToInput(ae.minDecimals(this.element.getDefaultValue()?.Y??0))}setDefaultValue(e=[],t=e){const i=this.element.getDefaultValue(!0);if(!(i instanceof Pe))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 B`
X
Y
Z
`}}class si extends Gt{}class ri extends jt{#at(){return Gt.stringFromUEToInput(ae.minDecimals(this.element.getDefaultValue()?.X??0))}#rt(){return Gt.stringFromUEToInput(ae.minDecimals(this.element.getDefaultValue()?.Y??0))}setDefaultValue(e,t){const i=this.element.getDefaultValue(!0);if(!(i instanceof ke))throw new TypeError("Expected DefaultValue to be a Vector2DEntity");i.X=e[0],i.Y=e[1],this.element.requestUpdate("DefaultValue",i)}renderInput(){return B`
X
Y
`}}class ai extends jt{#at(){return Gt.stringFromUEToInput(ae.minDecimals(this.element.getDefaultValue()?.X??0))}#rt(){return Gt.stringFromUEToInput(ae.minDecimals(this.element.getDefaultValue()?.Y??0))}#ot(){return Gt.stringFromUEToInput(ae.minDecimals(this.element.getDefaultValue()?.Z??0))}setDefaultValue(e,t){const i=this.element.getDefaultValue(!0);if(!(i instanceof Ne))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 B`
X
Y
Z
`}}class oi extends Ke{static#lt={"/Script/CoreUObject.LinearColor":Qt,"/Script/CoreUObject.Rotator":ni,"/Script/CoreUObject.Vector":ai,"/Script/CoreUObject.Vector2D":ri,bool:Ft,byte:Ut,int:Wt,int64:Wt,MUTABLE_REFERENCE:ii,name:ei,real:ti,string:si};static properties={pinId:{type:pe,converter:{fromAttribute:(e,t)=>e?Ie.grammar.Guid.parse(e).value: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:fe,converter:{fromAttribute:(e,t)=>e?Ie.grammar.LinearColorFromAnyColor.parse(e).value: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}};nodeElement;static getTypeTemplate(e){if(e.PinType.bIsReference&&!e.PinType.bIsConst)return oi.#lt.MUTABLE_REFERENCE;if("exec"===e.getType())return Xt;let t;return e.isInput()&&(t=oi.#lt[e.getType()]),t??Nt}static newObject(e=new Ae,t=new(oi.getTypeTemplate(e)),i){const n=new oi;return n.initialize(e,t,i),n}initialize(e=new Ae,t=new(oi.getTypeTemplate(e)),i){super.initialize(e,t),this.pinId=this.entity.PinId,this.pinType=this.entity.getType(),this.advancedView=this.entity.bAdvancedView,this.defaultValue=this.entity.getDefaultValue(),this.color=oi.properties.color.converter.fromAttribute(this.getColor().toString()),this.isLinked=!1,this.pinDirection=e.isInput()?"input":e.isOutput()?"output":"hidden",this.nodeElement=i,this.entity.subscribe("PinToolTip",(e=>{let t=e.match(/\s*(.+?(?=\n)|.+\S)\s*/);return t?ae.formatStringName(t[1]):ae.formatStringName(this.entity.PinName)}))}setup(){super.setup(),this.nodeElement=this.closest("ueb-node")}getPinId(){return this.entity.PinId}getPinName(){return this.entity.PinName}getPinDisplayName(){return this.entity.getDisplayName()}getColor(){return te.getPinColor(this)}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}sanitizeLinks(e=[]){this.entity.LinkedTo=this.getLinks().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,!0);t||(t=tt.getConstructor("ueb-link").newObject(this,i),this.blueprint.addGraphElement(t))}return i})),this.isLinked=this.entity.isLinked()}linkTo(e){this.entity.linkTo(e.getNodeElement().getNodeName(),e.entity)&&(this.isLinked=this.entity.isLinked(),this.nodeElement?.template.linksChanged())}unlinkFrom(e){this.entity.unlinkFrom(e.getNodeElement().getNodeName(),e.entity)&&(this.isLinked=this.entity.isLinked(),this.nodeElement?.template.linksChanged())}redirectLink(e,t){const i=this.entity.LinkedTo.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 li{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 ui{constructor(e,t,i,n){this.initialPosition=e,this.finalPosition=e,this.metadata=new Array(t.length),this.primaryOrder=new li((e=>this.metadata[e].primaryBoundary)),this.secondaryOrder=new li((e=>this.metadata[e].secondaryBoundary)),this.selectFunc=n,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,n(e,!1);const r=i(e);this.initialPosition[1]{if(this.metadata[i].onSecondaryAxis)this.selectFunc(this.rectangles[i],n);else if(n){this.secondaryOrder.insert(i,e[1]);const n=this.metadata[i].secondaryBoundary;Math.sign(e[1]-n)==t[1]&&Math.sign(n-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,n(this.boundaries.secondaryP.i,this.initialPosition[1]di.#Se[e],toAttribute:(e,t)=>Object.entries(di.#Se).find((([t,i])=>e.constructor===i))?.[0]}}};static newObject(e={},t=e.type??new Zt){const i=new di;return i.initialize(e,t),i}initialize(e={},t=e.type??new Zt){e.windowOptions??={},this.type=e.type,this.windowOptions=e.windowOptions,super.initialize(e,t)}setup(){super.setup(),this.locationX=this.blueprint.mousePosition[0],this.locationY=this.blueprint.mousePosition[1]}cleanup(){super.cleanup(),this.acknowledgeClose()}acknowledgeClose(){let e=new CustomEvent(te.windowCloseEventName);this.dispatchEvent(e)}}class pi extends Ie{constructor(e,t,i,n,s,r,a){e=e??(e=>`(${e})`),super(t,i,n,s,r,a),this.wrap=e}read(e){const t=Re.getGrammarForType(Ie.grammar,this.entityType).parse(e);if(!t.status)throw new Error(`Error when trying to parse the entity ${this.entityType.prototype.constructor.name}.`);return t.value}write(e,t,i=!1){return this.wrap(this.subWrite(e,[],t,i),t)}}class mi extends pi{#ut;constructor(e,t){super(void 0,t),this.#ut=e}write(e,t,i=!1){return this.#ut(t,i)}}class gi extends pi{constructor(e){super(void 0,e)}write(e,t,i){return i||t.constructor!==String?ae.escapeString(t.toString()):`"${ae.escapeString(t.toString())}"`}}!function(){const e=e=>`(${e})`;se.registerSerializer(null,new mi(((e,t)=>"()"),null)),se.registerSerializer(Array,new mi(((e,t)=>`(${e.map((e=>se.getSerializer(ae.getType(e)).serialize(e,t)+",")).join("")})`),Array)),se.registerSerializer(Boolean,new mi(((e,t)=>e?t?"true":"True":t?"false":"False"),Boolean)),se.registerSerializer(de,new pi(e,de)),se.registerSerializer(pe,new gi(pe)),se.registerSerializer(me,new gi(me)),se.registerSerializer(ue,new gi(ue)),se.registerSerializer(ge,new pi((e=>`${ge.lookbehind}(${e})`),ge,"",", ",!1,"",(e=>""))),se.registerSerializer(be,new pi(e,be)),se.registerSerializer(fe,new pi(e,fe)),se.registerSerializer(ye,new pi((e=>`${ye.lookbehind}(${e})`),ye,"",", ",!1,"",(e=>""))),se.registerSerializer(we,new pi(e,we)),se.registerSerializer(Number,new mi((e=>e.toString()),Number)),se.registerSerializer($e,new Ve),se.registerSerializer(he,new mi((e=>(e.type??"")+(e.path?e.type?`'"${e.path}"'`:`"${e.path}"`:"")),he)),se.registerSerializer(Ee,new gi(Ee)),se.registerSerializer(Ae,new pi((e=>`${Ae.lookbehind} (${e})`),Ae,"",",",!0)),se.registerSerializer(Se,new pi((e=>e),Se,""," ",!1,"",(e=>""))),se.registerSerializer(ve,new gi(ve)),se.registerSerializer(Pe,new pi(e,Pe)),se.registerSerializer(String,new mi(((e,t)=>t?ae.escapeString(e):`"${ae.escapeString(e)}"`),String)),se.registerSerializer(Ce,new mi(((e,t)=>`${e.P}, ${e.Y}, ${e.R}`),Ce)),se.registerSerializer(xe,new mi(((e,t)=>`${e.X}, ${e.Y}`),xe)),se.registerSerializer(Le,new mi(((e,t)=>`${e.X}, ${e.Y}, ${e.Z}`),Le)),se.registerSerializer(Te,new gi(Te)),se.registerSerializer(He,new pi(((e,t)=>`${t.lookbehind??""}(${e})`),He)),se.registerSerializer(Me,new pi(e,Me)),se.registerSerializer(ke,new pi(e,ke)),se.registerSerializer(Ne,new pi(e,Ne))}(),customElements.define("ueb-color-handler",Ht),tt.registerElement("ueb-color-handler",Ht),customElements.define("ueb-input",Vt),tt.registerElement("ueb-input",Vt),customElements.define("ueb-link",dt),tt.registerElement("ueb-link",dt),customElements.define("ueb-node",Mt),tt.registerElement("ueb-node",Mt),customElements.define("ueb-pin",oi),tt.registerElement("ueb-pin",oi),customElements.define("ueb-selector",hi),tt.registerElement("ueb-selector",hi),customElements.define("ueb-ui-slider",Rt),tt.registerElement("ueb-ui-slider",Rt),customElements.define("ueb-window",di),tt.registerElement("ueb-window",di);export{$t as Blueprint,te as Configuration,dt as LinkElement,Mt as NodeElement,ae as Utility}; diff --git a/js/Utility.js b/js/Utility.js index 2c60b9b..9417f86 100755 --- a/js/Utility.js +++ b/js/Utility.js @@ -1,17 +1,13 @@ -import CalculatedType from "./entity/CalculatedType" -import TypeInitialization from "./entity/TypeInitialization" -import UnionType from "./entity/UnionType" +import SubAttributesDeclaration from "./entity/SubObject" /** * @typedef {import("./element/IElement").default} IElement + * @typedef {import("./entity/IEntity").AnyValue} AnyValue + * @typedef {import("./entity/IEntity").AnyValueConstructor<*>} AnyValueConstructor + * @typedef {import("./entity/IEntity").AttributeInformation} TypeInformation * @typedef {import("./entity/IEntity").default} IEntity * @typedef {import("./entity/IEntity").EntityConstructor} EntityConstructor * @typedef {import("./entity/LinearColorEntity").default} LinearColorEntity - * @typedef {import("./entity/TypeInitialization").AnyValue} AnyValue - */ -/** - * @template T - * @typedef {import("./entity/TypeInitialization").AnyValueConstructor} AnyValueConstructor */ export default class Utility { @@ -98,22 +94,15 @@ export default class Utility { /** * @param {IEntity} entity * @param {String[]} keys - * @param {any} propertyDefinition * @returns {Boolean} */ static isSerialized( entity, keys, - propertyDefinition = Utility.objectGet(/** @type {EntityConstructor} */(entity.constructor).attributes, keys) + attribute = Utility.objectGet(/** @type {EntityConstructor} */(entity.constructor).attributes, keys) ) { - if (propertyDefinition instanceof CalculatedType) { - return Utility.isSerialized(entity, keys, propertyDefinition.calculate(entity)) - } - if (propertyDefinition instanceof TypeInitialization) { - if (propertyDefinition.serialized) { - return true - } - return Utility.isSerialized(entity, keys, propertyDefinition.type) + if (attribute.constructor === Object) { + return /** @type {TypeInformation} */(attribute).serialized } return false } @@ -124,7 +113,10 @@ export default class Utility { return undefined } if (!(keys instanceof Array)) { - throw new TypeError("Expected keys to be an array.") + throw new TypeError("UEBlueprint: Expected keys to be an array") + } + if (target instanceof SubAttributesDeclaration) { + target = target.attributes } if (keys.length == 0 || !(keys[0] in target) || target[keys[0]] === undefined) { return defaultValue @@ -158,9 +150,13 @@ export default class Utility { return false } + /** + * @param {AnyValue} a + * @param {AnyValue} b + */ static equals(a, b) { - a = TypeInitialization.sanitize(a) - b = TypeInitialization.sanitize(b) + a = Utility.sanitize(a) + b = Utility.sanitize(b) if (a === b) { return true } @@ -169,25 +165,45 @@ export default class Utility { } } - /** - * @param {AnyValue | AnyValueConstructor} value - * @returns {AnyValueConstructor | AnyValueConstructor[]} + /** + * @param {null | AnyValue | TypeInformation} value + * @returns {AnyValueConstructor} */ static getType(value) { if (value === null) { return null } - if (value instanceof TypeInitialization) { - return Utility.getType(value.type) + if (value.constructor === Object && value.type instanceof Function) { + // @ts-expect-error + return value.type } - if (value instanceof UnionType) { - return value.types + return /** @type {AnyValueConstructor} */(value?.constructor) + } + + /** + * @param {AnyValue} value + * @param {AnyValueConstructor} type + */ + static isValueOfType(value, type) { + return value === null || (value instanceof type || value.constructor === type) + } + + /** @param {AnyValue} value */ + static sanitize(value, targetType = /** @type {AnyValueConstructor} */(value?.constructor)) { + if (targetType instanceof Array) { + let type = targetType.find(t => Utility.isValueOfType(value, t)) + if (!type) { + type = targetType[0] + } + targetType = type } - if (value instanceof Function) { - // value is already a constructor - return value + if (targetType && !Utility.isValueOfType(value, targetType)) { + value = new targetType(value) } - return /** @type {AnyValueConstructor} */(value?.constructor) + if (value instanceof Boolean || value instanceof Number || value instanceof String) { + value = value.valueOf() // Get the relative primitive value + } + return value } /** @@ -347,4 +363,9 @@ export default class Utility { } requestAnimationFrame(doAnimation) } + + /** @param {String} value */ + static warn(value) { + console.warn("UEBlueprint: " + value) + } } diff --git a/js/element/IElement.js b/js/element/IElement.js index 23478d8..14ed5fa 100644 --- a/js/element/IElement.js +++ b/js/element/IElement.js @@ -15,10 +15,6 @@ import { LitElement } from "lit" */ export default class IElement extends LitElement { - /** @type {PropertyDeclarations} */ - static properties = { - } - #nextUpdatedCallbacks = [] /** @type {Blueprint} */ diff --git a/js/element/PinElement.js b/js/element/PinElement.js index 0657364..9f95ff4 100644 --- a/js/element/PinElement.js +++ b/js/element/PinElement.js @@ -21,8 +21,8 @@ import Vector2DPinTemplate from "../template/pin/Vector2DPinTemplate" import VectorPinTemplate from "../template/pin/VectorPinTemplate" /** + * @typedef {import("../entity/IEntity").AnyValue} AnyValue * @typedef {import("../entity/PinReferenceEntity").default} PinReferenceEntity - * @typedef {import("../entity/TypeInitialization").AnyValue} AnyValue * @typedef {import("./LinkElement").LinkElementConstructor} LinkElementConstructor * @typedef {import("./NodeElement").default} NodeElement * @typedef {import("lit").CSSResult} CSSResult diff --git a/js/entity/ByteEntity.js b/js/entity/ByteEntity.js index d24ea7a..6f1e665 100755 --- a/js/entity/ByteEntity.js +++ b/js/entity/ByteEntity.js @@ -6,10 +6,13 @@ export default class ByteEntity extends IntegerEntity { value: 0, } + static { + this.cleanupAttributes(this.attributes) + } + /** @param {Object | Number | String} values */ constructor(values = 0) { super(values) - /** @type {Number} */ const value = Math.round(this.value) this.value = value >= 0 && value < 1 << 8 ? value : 0 } diff --git a/js/entity/FunctionReferenceEntity.js b/js/entity/FunctionReferenceEntity.js index c2d7057..8cd2ce2 100755 --- a/js/entity/FunctionReferenceEntity.js +++ b/js/entity/FunctionReferenceEntity.js @@ -1,14 +1,20 @@ import IEntity from "./IEntity" import ObjectReferenceEntity from "./ObjectReferenceEntity" -import TypeInitialization from "./TypeInitialization" export default class FunctionReferenceEntity extends IEntity { static attributes = { - MemberParent: new TypeInitialization(ObjectReferenceEntity, false), + MemberParent: { + type: ObjectReferenceEntity, + showDefault: false + }, MemberName: "", } + static { + this.cleanupAttributes(this.attributes) + } + constructor(values) { super(values) /** @type {ObjectReferenceEntity} */ this.MemberParent diff --git a/js/entity/GuidEntity.js b/js/entity/GuidEntity.js index 5870ead..00c8c6e 100755 --- a/js/entity/GuidEntity.js +++ b/js/entity/GuidEntity.js @@ -3,7 +3,11 @@ import IEntity from "./IEntity" export default class GuidEntity extends IEntity { static attributes = { - value: String, + value: "", + } + + static { + this.cleanupAttributes(this.attributes) } static generateGuid(random = true) { diff --git a/js/entity/IEntity.js b/js/entity/IEntity.js index 436bae5..88aa443 100644 --- a/js/entity/IEntity.js +++ b/js/entity/IEntity.js @@ -1,19 +1,43 @@ -import CalculatedType from "./CalculatedType" import Observable from "../Observable" import SerializerFactory from "../serialization/SerializerFactory" -import TypeInitialization from "./TypeInitialization" -import Utility from "../Utility" +import SubAttributesDeclaration from "./SubObject" import UnionType from "./UnionType" +import Utility from "../Utility" -/** @typedef {typeof IEntity} EntityConstructor */ /** - * @template {IEntity} T - * @typedef {new (Object) => T} IEntityConstructor + * @typedef {(entity: IEntity) => AnyValue} ValueSupplier + * @typedef {(entity: IEntity) => AnyValueConstructor} TypeSupplier + * @typedef {IEntity | String | Number | Boolean} AnySimpleValue + * @typedef {AnySimpleValue | AnySimpleValue[]} AnyValue + * @typedef {{ + * [key: String]: AttributeInformation | AnyValue | SubAttributesDeclaration + * }} AttributeDeclarations + * @typedef {typeof IEntity} EntityConstructor + * @typedef {{ + * type?: AnyValueConstructor | AnyValueConstructor[] | UnionType | TypeSupplier, + * value?: AnyValue | ValueSupplier, + * showDefault?: Boolean, + * nullable?: Boolean, + * ignored?: Boolean, + * serialized?: Boolean, + * }} AttributeInformation + */ + +/** + * @template {AnyValue} T + * @typedef {(new () => T) | EntityConstructor | StringConstructor | NumberConstructor | BooleanConstructor | ArrayConstructor} AnyValueConstructor */ export default class IEntity extends Observable { + /** @type {AttributeDeclarations} */ static attributes = {} + static defaultAttribute = { + showDefault: true, + nullable: false, + ignored: false, + serialized: false, + } constructor(values = {}, suppressWarns = false) { super() @@ -24,82 +48,94 @@ export default class IEntity extends Observable { * @param {String} prefix */ const defineAllAttributes = (target, attributes, values = {}, prefix = "") => { - const valuesPropertyNames = Object.getOwnPropertyNames(values) - for (let attribute of Utility.mergeArrays(Object.getOwnPropertyNames(attributes), valuesPropertyNames)) { - let value = Utility.objectGet(values, [attribute]) - let defaultValue = attributes[attribute] - let defaultType = Utility.getType(defaultValue) - if (defaultValue instanceof CalculatedType) { - defaultValue = defaultValue.calculate(this) - defaultType = Utility.getType(defaultValue) - } - if (defaultValue != null && defaultValue === defaultType) { - defaultValue = new defaultType() + const valuesNames = Object.getOwnPropertyNames(values) + for (let attributeName of Utility.mergeArrays(Object.getOwnPropertyNames(attributes), valuesNames)) { + let value = Utility.objectGet(values, [attributeName]) + /** @type {AttributeInformation} */ + let attribute = attributes[attributeName] + + if (attribute instanceof SubAttributesDeclaration) { + target[attributeName] = {} + defineAllAttributes( + target[attributeName], + attribute.attributes, + values[attributeName], + attributeName + "." + ) + continue } if (!suppressWarns) { - if (!(attribute in attributes)) { - console.warn( - `Attribute ${prefix}${attribute} in the serialized data is not defined in ${this.constructor.name}.attributes` + if (!(attributeName in attributes)) { + Utility.warn( + `Attribute ${prefix}${attributeName} in the serialized data is not defined in ` + + `${this.constructor.name}.attributes` ) } else if ( - valuesPropertyNames.length > 0 - && !(attribute in values) - && defaultValue !== undefined - && !(defaultValue instanceof TypeInitialization && (!defaultValue.showDefault || defaultValue.ignored)) + valuesNames.length > 0 + && !(attributeName in values) + && !(!attribute.showDefault || attribute.ignored) ) { - console.warn( - `${this.constructor.name} will add attribute ${prefix}${attribute} not defined in the serialized data` + Utility.warn( + `${this.constructor.name} will add attribute ${prefix}${attributeName} not defined in the ` + + "serialized data" ) } } - // Not instanceof because all objects are instenceof Object, exact match needed - // @ts-expect-error - if (defaultType === Object) { - target[attribute] = {} - defineAllAttributes(target[attribute], attributes[attribute], values[attribute], attribute + ".") - continue + let defaultValue = attribute.value + let defaultType = attribute.type + if (attribute.serialized && defaultType instanceof Function) { + // If the attribute is serialized, the type must contain a function providing the type + defaultType = /** @type {TypeSupplier} */(defaultType)(this) + } + if (defaultType instanceof Array) { + defaultType = Array + } + if (defaultValue instanceof Function) { + defaultValue = defaultValue(this) + } + if (defaultType instanceof UnionType) { + if (defaultValue != undefined) { + defaultType = defaultType.types.find( + type => defaultValue instanceof type || defaultValue.constructor == type + ) ?? defaultType.getFirstType() + } else { + defaultType = defaultType.getFirstType() + } + } + if (defaultType === undefined) { + defaultType = Utility.getType(defaultValue) } if (value !== undefined) { // Remember value can still be null - if ( - value?.constructor === String - && defaultValue instanceof TypeInitialization - && defaultValue.serialized - && defaultValue.type !== String - ) { - // @ts-expect-error - value = SerializerFactory.getSerializer(defaultValue.type).deserialize(value) + if (value?.constructor === String && attribute.serialized && defaultType !== String) { + value = SerializerFactory + .getSerializer(/** @type {AnyValueConstructor<*>} */(defaultType)) + .deserialize(/** @type {String} */(value)) } - target[attribute] = TypeInitialization.sanitize(value, Utility.getType(defaultValue)) + target[attributeName] = Utility.sanitize(value, /** @type {AnyValueConstructor<*>} */(defaultType)) continue // We have a value, need nothing more } - - if (defaultValue instanceof TypeInitialization) { - if (!defaultValue.showDefault) { - target[attribute] = undefined // Declare undefined to preserve the order of attributes - continue - } - if (defaultValue.serialized) { - defaultValue = "" - } else { - defaultType = defaultValue.type - defaultValue = defaultValue.value - if (defaultValue instanceof Function) { - defaultValue = defaultValue() - } + if (defaultValue === undefined) { + defaultValue = Utility.sanitize(new /** @type {AnyValueConstructor<*>} */(defaultType)()) + } + if (!attribute.showDefault) { + target[attributeName] = undefined // Declare undefined to preserve the order of attributes + continue + } + if (attribute.serialized) { + if (defaultType !== String && defaultValue.constructor === String) { + defaultValue = SerializerFactory + .getSerializer(/** @type {AnyValueConstructor<*>} */(defaultType)) + .deserialize(defaultValue) } } - if (defaultValue instanceof UnionType) { - defaultType = defaultValue.getFirstType() - defaultValue = TypeInitialization.sanitize(null, defaultType) - } - if (defaultValue instanceof Array) { - defaultValue = [] - } - target[attribute] = TypeInitialization.sanitize(defaultValue, defaultType) + target[attributeName] = Utility.sanitize( + /** @type {AnyValue} */(defaultValue), + /** @type {AnyValueConstructor} */(defaultType) + ) } } const attributes = /** @type {typeof IEntity} */(this.constructor).attributes @@ -112,6 +148,45 @@ export default class IEntity extends Observable { defineAllAttributes(this, attributes, values) } + /** @param {AttributeDeclarations} attributes */ + static cleanupAttributes(attributes, prefix = "") { + for (const attributeName in attributes) { + if (attributes[attributeName] instanceof SubAttributesDeclaration) { + this.cleanupAttributes( + /** @type {SubAttributesDeclaration} */(attributes[attributeName]).attributes, + prefix + "." + attributeName + ) + continue + } + if (attributes[attributeName].constructor !== Object) { + attributes[attributeName] = { + value: attributes[attributeName], + } + } + const attribute = /** @type {AttributeInformation} */(attributes[attributeName]) + if (attribute.type === undefined && !(attribute.value instanceof Function)) { + attribute.type = Utility.getType(attribute.value) + } + attributes[attributeName] = { + ...IEntity.defaultAttribute, + ...attribute, + } + if (attribute.value === undefined && attribute.type === undefined) { + throw new Error( + `UEBlueprint: Expected either "type" or "value" property in ${this.name} attribute ${prefix}` + + attributeName + ) + } + if (attribute.value === null) { + attributes[attributeName].nullable = true + } + } + } + + static isValueOfType(value, type) { + return value != null && (value instanceof type || value.constructor === type) + } + unexpectedKeys() { // @ts-expect-error return Object.getOwnPropertyNames(this).length - Object.getOwnPropertyNames(this.constructor.attributes).length diff --git a/js/entity/IdentifierEntity.js b/js/entity/IdentifierEntity.js index 12b476e..63dba20 100644 --- a/js/entity/IdentifierEntity.js +++ b/js/entity/IdentifierEntity.js @@ -3,7 +3,11 @@ import IEntity from "./IEntity" export default class IdentifierEntity extends IEntity { static attributes = { - value: String, + value: "", + } + + static { + this.cleanupAttributes(this.attributes) } static attributeConverter = { diff --git a/js/entity/IntegerEntity.js b/js/entity/IntegerEntity.js index 06ec7e7..a2ea3ad 100755 --- a/js/entity/IntegerEntity.js +++ b/js/entity/IntegerEntity.js @@ -6,10 +6,13 @@ export default class IntegerEntity extends IEntity { value: 0, } - /** @param {Object | Number | String} values */ - constructor(values = 0) { - super(values) - /** @type {Number} */ + static { + this.cleanupAttributes(this.attributes) + } + + /** @param {Object | Number | String} value */ + constructor(value = 0) { + super(value) this.value = Math.round(this.value) } diff --git a/js/entity/InvariantTextEntity.js b/js/entity/InvariantTextEntity.js index 36017a1..26500e3 100644 --- a/js/entity/InvariantTextEntity.js +++ b/js/entity/InvariantTextEntity.js @@ -4,7 +4,11 @@ export default class InvariantTextEntity extends IEntity { static lookbehind = "INVTEXT" static attributes = { - value: String, + value: "", + } + + static { + this.cleanupAttributes(this.attributes) } constructor(values) { diff --git a/js/entity/KeyBindingEntity.js b/js/entity/KeyBindingEntity.js index 052ed0b..3e33d51 100644 --- a/js/entity/KeyBindingEntity.js +++ b/js/entity/KeyBindingEntity.js @@ -9,7 +9,13 @@ export default class KeyBindingEntity extends IEntity { bCtrl: false, bAlt: false, bCmd: false, - Key: IdentifierEntity, + Key: { + type: IdentifierEntity + }, + } + + static { + this.cleanupAttributes(this.attributes) } constructor(values = {}) { diff --git a/js/entity/LinearColorEntity.js b/js/entity/LinearColorEntity.js index c3fda73..3340541 100644 --- a/js/entity/LinearColorEntity.js +++ b/js/entity/LinearColorEntity.js @@ -1,18 +1,43 @@ import IEntity from "./IEntity" import RealUnitEntity from "./UnitRealEntity" -import TypeInitialization from "./TypeInitialization" import Utility from "../Utility" export default class LinearColorEntity extends IEntity { static attributes = { - R: RealUnitEntity, - G: RealUnitEntity, - B: RealUnitEntity, - A: new TypeInitialization(RealUnitEntity, true, () => new RealUnitEntity(1), false, false), - H: new TypeInitialization(RealUnitEntity, true, undefined, false, true), - S: new TypeInitialization(RealUnitEntity, true, undefined, false, true), - V: new TypeInitialization(RealUnitEntity, true, undefined, false, true), + R: { + type: RealUnitEntity, + }, + G: { + type: RealUnitEntity, + }, + B: { + type: RealUnitEntity, + }, + A: { + type: RealUnitEntity, + value: () => new RealUnitEntity(1), + showDefault: true, + }, + H: { + type: RealUnitEntity, + showDefault: true, + ignored: true, + }, + S: { + type: RealUnitEntity, + showDefault: true, + ignored: true, + }, + V: { + type: RealUnitEntity, + showDefault: true, + ignored: true, + }, + } + + static { + this.cleanupAttributes(this.attributes) } /** @param {Number} x */ diff --git a/js/entity/LocalizedTextEntity.js b/js/entity/LocalizedTextEntity.js index 5874eea..3168785 100755 --- a/js/entity/LocalizedTextEntity.js +++ b/js/entity/LocalizedTextEntity.js @@ -5,9 +5,13 @@ export default class LocalizedTextEntity extends IEntity { static lookbehind = "NSLOCTEXT" static attributes = { - namespace: String, - key: String, - value: String, + namespace: "", + key: "", + value: "", + } + + static { + this.cleanupAttributes(this.attributes) } constructor(values) { diff --git a/js/entity/MacroGraphReferenceEntity.js b/js/entity/MacroGraphReferenceEntity.js index c173aba..a7deeb8 100755 --- a/js/entity/MacroGraphReferenceEntity.js +++ b/js/entity/MacroGraphReferenceEntity.js @@ -5,9 +5,19 @@ import ObjectReferenceEntity from "./ObjectReferenceEntity" export default class MacroGraphReferenceEntity extends IEntity { static attributes = { - MacroGraph: ObjectReferenceEntity, - GraphBlueprint: ObjectReferenceEntity, - GraphGuid: GuidEntity, + MacroGraph: { + type: ObjectReferenceEntity, + }, + GraphBlueprint: { + type: ObjectReferenceEntity, + }, + GraphGuid: { + type: GuidEntity, + }, + } + + static { + this.cleanupAttributes(this.attributes) } constructor(values) { diff --git a/js/entity/ObjectEntity.js b/js/entity/ObjectEntity.js index 60e1f09..f98903d 100755 --- a/js/entity/ObjectEntity.js +++ b/js/entity/ObjectEntity.js @@ -9,45 +9,130 @@ import MacroGraphReferenceEntity from "./MacroGraphReferenceEntity" import ObjectReferenceEntity from "./ObjectReferenceEntity" import PinEntity from "./PinEntity" import SymbolEntity from "./SymbolEntity" -import TypeInitialization from "./TypeInitialization" -import Utility from "../Utility" import VariableReferenceEntity from "./VariableReferenceEntity" export default class ObjectEntity extends IEntity { static attributes = { - Class: ObjectReferenceEntity, + Class: { + type: ObjectReferenceEntity, + }, Name: "", - bIsPureFunc: new TypeInitialization(Boolean, false, false), - VariableReference: new TypeInitialization(VariableReferenceEntity, false, null), - SelfContextInfo: new TypeInitialization(SymbolEntity, false, null), - FunctionReference: new TypeInitialization(FunctionReferenceEntity, false, null,), - EventReference: new TypeInitialization(FunctionReferenceEntity, false, null,), - TargetType: new TypeInitialization(ObjectReferenceEntity, false, null), - MacroGraphReference: new TypeInitialization(MacroGraphReferenceEntity, false, null), - Enum: new TypeInitialization(ObjectReferenceEntity, false), - CommentColor: new TypeInitialization(LinearColorEntity, false), - bCommentBubbleVisible_InDetailsPanel: new TypeInitialization(Boolean, false), - bColorCommentBubble: new TypeInitialization(Boolean, false, false), - MoveMode: new TypeInitialization(SymbolEntity, false), - NodePosX: IntegerEntity, - NodePosY: IntegerEntity, - NodeWidth: new TypeInitialization(IntegerEntity, false), - NodeHeight: new TypeInitialization(IntegerEntity, false), - bCommentBubblePinned: new TypeInitialization(Boolean, false), - bCommentBubbleVisible: new TypeInitialization(Boolean, false), - NodeComment: new TypeInitialization(String, false), - AdvancedPinDisplay: new TypeInitialization(IdentifierEntity, false, null), - EnabledState: new TypeInitialization(IdentifierEntity, false, null), - NodeGuid: GuidEntity, - ErrorType: new TypeInitialization(IntegerEntity, false), - ErrorMsg: new TypeInitialization(String, false, ""), - CustomProperties: [PinEntity], + bIsPureFunc: { + value: false, + showDefault: false, + }, + VariableReference: { + type: VariableReferenceEntity, + value: null, + showDefault: false, + }, + SelfContextInfo: { + type: SymbolEntity, + value: null, + showDefault: false, + }, + FunctionReference: { + type: FunctionReferenceEntity, + value: null, + showDefault: false, + }, + EventReference: { + type: FunctionReferenceEntity, + value: null, + showDefault: false, + }, + TargetType: { + type: ObjectReferenceEntity, + value: null, + showDefault: false, + }, + MacroGraphReference: { + type: MacroGraphReferenceEntity, + value: null, + showDefault: false, + }, + Enum: { + type: ObjectReferenceEntity, + showDefault: false, + }, + CommentColor: { + type: LinearColorEntity, + showDefault: false, + }, + bCommentBubbleVisible_InDetailsPanel: { + type: Boolean, + showDefault: false, + }, + bColorCommentBubble: { + type: Boolean, + value: false, + showDefault: false, + }, + MoveMode: { + type: SymbolEntity, + showDefault: false, + }, + NodePosX: { + type: IntegerEntity, + }, + NodePosY: { + type: IntegerEntity, + }, + NodeWidth: { + type: IntegerEntity, + showDefault: false, + }, + NodeHeight: { + type: IntegerEntity, + showDefault: false, + }, + bCommentBubblePinned: { + type: Boolean, + showDefault: false, + }, + bCommentBubbleVisible: { + type: Boolean, + showDefault: false, + }, + NodeComment: { + type: String, + showDefault: false, + }, + AdvancedPinDisplay: { + type: IdentifierEntity, + value: null, + showDefault: false, + }, + EnabledState: { + type: IdentifierEntity, + value: null, + showDefault: false, + }, + NodeGuid: { + type: GuidEntity, + }, + ErrorType: { + type: IntegerEntity, + showDefault: false, + }, + ErrorMsg: { + type: String, + value: "", + showDefault: false, + }, + CustomProperties: { + type: [PinEntity] + }, } static nameRegex = /^(\w+?)(?:_(\d+))?$/ static sequencerScriptingNameRegex = /\/Script\/SequencerScripting\.MovieSceneScripting(.+)Channel/ + static { + this.cleanupAttributes(this.attributes) + } + constructor(values, suppressWarns = false) { super(values, suppressWarns) /** @type {ObjectReferenceEntity} */ this.Class diff --git a/js/entity/ObjectReferenceEntity.js b/js/entity/ObjectReferenceEntity.js index a6e853d..be87faa 100755 --- a/js/entity/ObjectReferenceEntity.js +++ b/js/entity/ObjectReferenceEntity.js @@ -3,12 +3,16 @@ import IEntity from "./IEntity" export default class ObjectReferenceEntity extends IEntity { static attributes = { - type: String, - path: String, + type: "", + path: "", + } + + static { + this.cleanupAttributes(this.attributes) } constructor(values = {}) { - if (values.constructor !== Object) { + if (values.constructor === String) { values = { path: values } diff --git a/js/entity/PathSymbolEntity.js b/js/entity/PathSymbolEntity.js index 5a5a67f..7b1996b 100755 --- a/js/entity/PathSymbolEntity.js +++ b/js/entity/PathSymbolEntity.js @@ -3,7 +3,11 @@ import IEntity from "./IEntity" export default class PathSymbolEntity extends IEntity { static attributes = { - value: String, + value: "", + } + + static { + this.cleanupAttributes(this.attributes) } constructor(values) { diff --git a/js/entity/PinEntity.js b/js/entity/PinEntity.js index f1bad17..5cb1afc 100755 --- a/js/entity/PinEntity.js +++ b/js/entity/PinEntity.js @@ -1,4 +1,3 @@ -import CalculatedType from "./CalculatedType" import GuidEntity from "./GuidEntity" import IEntity from "./IEntity" import IntegerEntity from "./IntegerEntity" @@ -10,13 +9,13 @@ import RotatorEntity from "./RotatorEntity" import SimpleSerializationRotatorEntity from "./SimpleSerializationRotatorEntity" import SimpleSerializationVector2DEntity from "./SimpleSerializationVector2DEntity" import SimpleSerializationVectorEntity from "./SimpleSerializationVectorEntity" -import TypeInitialization from "./TypeInitialization" +import SubAttributesDeclaration from "./SubObject" import UnionType from "./UnionType" import Utility from "../Utility" import Vector2DEntity from "./Vector2DEntity" import VectorEntity from "./VectorEntity" -/** @typedef {import("./TypeInitialization").AnyValue} AnyValue */ +/** @typedef {import("./IEntity").AnyValue} AnyValue */ /** @template {AnyValue} T */ export default class PinEntity extends IEntity { @@ -40,38 +39,67 @@ export default class PinEntity extends IEntity { } static lookbehind = "Pin" static attributes = { - PinId: GuidEntity, + PinId: { + type: GuidEntity, + }, PinName: "", - PinFriendlyName: new TypeInitialization(new UnionType(LocalizedTextEntity, String), false, null), - PinToolTip: new TypeInitialization(String, false, ""), - Direction: new TypeInitialization(String, false, ""), - PinType: { + PinFriendlyName: { + type: new UnionType(LocalizedTextEntity, String), + showDefault: false, + }, + PinToolTip: { + type: String, + showDefault: false, + }, + Direction: { + type: String, + showDefault: false, + }, + PinType: new SubAttributesDeclaration({ PinCategory: "", PinSubCategory: "", - PinSubCategoryObject: ObjectReferenceEntity, - PinSubCategoryMemberReference: null, - PinValueType: null, - ContainerType: ObjectReferenceEntity, + PinSubCategoryObject: { + type: ObjectReferenceEntity, + }, + PinSubCategoryMemberReference: { + type: ObjectReferenceEntity, + value: null, + }, + PinValueType: { + type: String, + value: null, + }, + ContainerType: { + type: ObjectReferenceEntity, + }, bIsReference: false, bIsConst: false, bIsWeakPointer: false, bIsUObjectWrapper: false, bSerializeAsSinglePrecisionFloat: false, + }), + LinkedTo: { + type: [PinReferenceEntity], + showDefault: false, + }, + DefaultValue: { + /** @param {PinEntity} pinEntity */ + type: pinEntity => pinEntity.getEntityType(true) ?? String, + serialized: true, + showDefault: false, + }, + AutogeneratedDefaultValue: { + type: String, + showDefault: false, + }, + DefaultObject: { + type: ObjectReferenceEntity, + showDefault: false, + value: null, + }, + PersistentGuid: { + type: GuidEntity, }, - LinkedTo: new TypeInitialization([PinReferenceEntity], false), - DefaultValue: - new CalculatedType( - /** @param {PinEntity} pinEntity */ - pinEntity => new TypeInitialization( - pinEntity.getEntityType(true) ?? String, - false, - undefined, - true - ) - ), - AutogeneratedDefaultValue: new TypeInitialization(String, false), - DefaultObject: new TypeInitialization(ObjectReferenceEntity, false, null), - PersistentGuid: GuidEntity, bHidden: false, bNotConnectable: false, bDefaultValueIsReadOnly: false, @@ -80,6 +108,10 @@ export default class PinEntity extends IEntity { bOrphanedPin: false, } + static { + this.cleanupAttributes(this.attributes) + } + constructor(values = {}, suppressWarns = false) { super(values, suppressWarns) /** @type {GuidEntity} */ this.PinId diff --git a/js/entity/PinReferenceEntity.js b/js/entity/PinReferenceEntity.js index 8e19819..be60ac2 100755 --- a/js/entity/PinReferenceEntity.js +++ b/js/entity/PinReferenceEntity.js @@ -5,8 +5,16 @@ import PathSymbolEntity from "./PathSymbolEntity" export default class PinReferenceEntity extends IEntity { static attributes = { - objectName: PathSymbolEntity, - pinGuid: GuidEntity, + objectName: { + type: PathSymbolEntity, + }, + pinGuid: { + type: GuidEntity, + }, + } + + static { + this.cleanupAttributes(this.attributes) } constructor(values) { diff --git a/js/entity/RotatorEntity.js b/js/entity/RotatorEntity.js index effb698..08cb76c 100644 --- a/js/entity/RotatorEntity.js +++ b/js/entity/RotatorEntity.js @@ -3,9 +3,19 @@ import IEntity from "./IEntity" export default class RotatorEntity extends IEntity { static attributes = { - R: Number, - P: Number, - Y: Number, + R: { + value: 0, + }, + P: { + value: 0, + }, + Y: { + value: 0, + }, + } + + static { + this.cleanupAttributes(this.attributes) } constructor(values) { @@ -14,4 +24,16 @@ export default class RotatorEntity extends IEntity { /** @type {Number} */ this.P /** @type {Number} */ this.Y } + + getRoll() { + return this.R + } + + getPitch() { + return this.P + } + + getYaw() { + return this.Y + } } diff --git a/js/entity/SubObject.js b/js/entity/SubObject.js new file mode 100644 index 0000000..c2446ef --- /dev/null +++ b/js/entity/SubObject.js @@ -0,0 +1,9 @@ +/** @typedef {import("./IEntity").AttributeDeclarations} AttributeDeclarations */ + +export default class SubAttributesDeclaration { + + /** @param {AttributeDeclarations} attributes */ + constructor(attributes) { + this.attributes = attributes + } +} diff --git a/js/entity/SymbolEntity.js b/js/entity/SymbolEntity.js index 2f64439..1a0124e 100644 --- a/js/entity/SymbolEntity.js +++ b/js/entity/SymbolEntity.js @@ -3,7 +3,11 @@ import IEntity from "./IEntity" export default class SymbolEntity extends IEntity { static attributes = { - value: String + value: "", + } + + static { + this.cleanupAttributes(this.attributes) } constructor(values) { diff --git a/js/entity/TypeInitialization.js b/js/entity/TypeInitialization.js deleted file mode 100755 index 91afdb3..0000000 --- a/js/entity/TypeInitialization.js +++ /dev/null @@ -1,106 +0,0 @@ -import UnionType from "./UnionType" - -/** - * @typedef {IEntity | String | Number | Boolean | Array} AnyValue - * @typedef {import("./IEntity").default} IEntity - */ -/** - * @template {AnyValue} T - * @typedef {import("./IEntity").IEntityConstructor} IEntityConstructor - */ -/** - * @template {AnyValue} T - * @typedef {IEntityConstructor | StringConstructor | NumberConstructor | BooleanConstructor | ArrayConstructor | UnionType} AnyValueConstructor - */ - -/** @template {AnyValue} T */ -export default class TypeInitialization { - - /** @type {AnyValueConstructor|AnyValueConstructor[]} */ - #type - get type() { - return this.#type - } - set type(v) { - this.#type = v - } - - #showDefault = true - get showDefault() { - return this.#showDefault - } - set showDefault(v) { - this.#showDefault = v - } - - /** @type {T | T[] | String | (() => T) | (() => T[])} */ - #value - get value() { - return this.#value - } - set value(v) { - this.#value = v - } - - /** @type {Boolean} */ - #serialized - get serialized() { - return this.#serialized - } - set serialized(v) { - this.#serialized = v - } - - #ignored - get ignored() { - return this.#ignored - } - set ignored(v) { - this.#ignored = v - } - - static isValueOfType(value, type) { - return value != null && (value instanceof type || value.constructor === type) - } - - static sanitize(value, targetType) { - if (targetType === undefined) { - targetType = value?.constructor - } - if (targetType instanceof Array) { - let type = targetType.find(t => TypeInitialization.isValueOfType(value, t)) - if (!type) { - type = targetType[0] - } - targetType = type - } - if (targetType && !TypeInitialization.isValueOfType(value, targetType)) { - value = new targetType(value) - } - if (value instanceof Boolean || value instanceof Number || value instanceof String) { - value = value.valueOf() // Get the relative primitive value - } - return value - } - - /** - * @param {AnyValueConstructor|AnyValueConstructor[]} type - * @param {Boolean} showDefault - * @param {T | T[] | String | (() => T) | (() => T[])} value - * @param {Boolean} serialized - */ - constructor(type, showDefault = true, value = undefined, serialized = false, ignored = false) { - if (value === undefined) { - if (type instanceof Array) { - value = [] - } else { - value = () => TypeInitialization.sanitize(new type()) - } - } - this.#type = type - this.#showDefault = showDefault - this.#value = value - this.#serialized = serialized - this.#ignored = ignored - } -} diff --git a/js/entity/UnionType.js b/js/entity/UnionType.js index 2996a09..b5dd036 100644 --- a/js/entity/UnionType.js +++ b/js/entity/UnionType.js @@ -1,7 +1,4 @@ -/** - * @template T - * @typedef {import("./TypeInitialization").AnyValueConstructor} AnyValueConstructor - */ +/** @typedef {import("./IEntity").AnyValueConstructor<*>} AnyValueConstructor */ export default class UnionType { @@ -10,7 +7,7 @@ export default class UnionType { return this.#types } - /** @param {...AnyValueConstructor} types */ + /** @param {...AnyValueConstructor} types */ constructor(...types) { this.#types = types } diff --git a/js/entity/UnitRealEntity.js b/js/entity/UnitRealEntity.js index fb56685..fbb8b45 100644 --- a/js/entity/UnitRealEntity.js +++ b/js/entity/UnitRealEntity.js @@ -7,6 +7,10 @@ export default class RealUnitEntity extends IEntity { value: 0, } + static { + this.cleanupAttributes(this.attributes) + } + /** @param {Object | Number | String} values */ constructor(values = 0) { super(values) diff --git a/js/entity/UnknownKeysEntity.js b/js/entity/UnknownKeysEntity.js index 71eea17..2f21fc4 100644 --- a/js/entity/UnknownKeysEntity.js +++ b/js/entity/UnknownKeysEntity.js @@ -1,10 +1,14 @@ import IEntity from "./IEntity" -import TypeInitialization from "./TypeInitialization" export default class UnknownKeysEntity extends IEntity { static attributes = { - lookbehind: new TypeInitialization(String, false, "", false, true) + lookbehind: + { + value: "", + showDefault: false, + ignore: true, + }, } constructor(values) { diff --git a/js/entity/VariableReferenceEntity.js b/js/entity/VariableReferenceEntity.js index 6989fd3..f57987a 100755 --- a/js/entity/VariableReferenceEntity.js +++ b/js/entity/VariableReferenceEntity.js @@ -1,14 +1,21 @@ import IEntity from "./IEntity" import GuidEntity from "./GuidEntity" -import TypeInitialization from "./TypeInitialization" export default class VariableReferenceEntity extends IEntity { static attributes = { - MemberScope: new TypeInitialization(String, false), - MemberName: String, - MemberGuid: GuidEntity, - bSelfContext: new TypeInitialization(Boolean, false, false) + MemberScope: { + value: "", + showDefault: false, + }, + MemberName: "", + MemberGuid: { + type: GuidEntity, + }, + bSelfContext: { + value: false, + showDefault: false, + }, } constructor(values) { diff --git a/js/entity/Vector2DEntity.js b/js/entity/Vector2DEntity.js index b40a9d6..7b1df3e 100644 --- a/js/entity/Vector2DEntity.js +++ b/js/entity/Vector2DEntity.js @@ -3,8 +3,8 @@ import IEntity from "./IEntity" export default class Vector2DEntity extends IEntity { static attributes = { - X: Number, - Y: Number, + X: 0, + Y: 0, } constructor(values) { diff --git a/js/entity/VectorEntity.js b/js/entity/VectorEntity.js index 26ceab9..451327c 100644 --- a/js/entity/VectorEntity.js +++ b/js/entity/VectorEntity.js @@ -3,9 +3,9 @@ import IEntity from "./IEntity" export default class VectorEntity extends IEntity { static attributes = { - X: Number, - Y: Number, - Z: Number, + X: 0, + Y: 0, + Z: 0, } constructor(values) { diff --git a/js/serialization/CustomSerializer.js b/js/serialization/CustomSerializer.js index 125e5b9..a945cde 100755 --- a/js/serialization/CustomSerializer.js +++ b/js/serialization/CustomSerializer.js @@ -2,11 +2,8 @@ import GeneralSerializer from "./GeneralSerializer" /** * @typedef {import("../entity/IEntity").default} IEntity - * @typedef {import("../entity/TypeInitialization").AnyValue} AnyValue - */ -/** - * @template {AnyValue} T - * @typedef {import("../entity/TypeInitialization").AnyValueConstructor} AnyValueConstructor + * @typedef {import("../entity/IEntity").AnyValue} AnyValue + * @typedef {import("../entity/IEntity").AnyValueConstructor<*>} AnyValueConstructor */ /** @@ -19,7 +16,7 @@ export default class CustomSerializer extends GeneralSerializer { /** * @param {(v: T, insideString: Boolean) => String} objectWriter - * @param {AnyValueConstructor} entityType + * @param {AnyValueConstructor} entityType */ constructor(objectWriter, entityType) { super(undefined, entityType) diff --git a/js/serialization/GeneralSerializer.js b/js/serialization/GeneralSerializer.js index 30e82a5..3e5f68d 100755 --- a/js/serialization/GeneralSerializer.js +++ b/js/serialization/GeneralSerializer.js @@ -3,11 +3,8 @@ import ISerializer from "./ISerializer" /** * @typedef {import("../entity/IEntity").default} IEntity - * @typedef {import("../entity/TypeInitialization").AnyValue} AnyValue - */ -/** - * @template {AnyValue} T - * @typedef {import("../entity/TypeInitialization").AnyValueConstructor} AnyValueConstructor + * @typedef {import("../entity/IEntity").AnyValue} AnyValue + * @typedef {import("../entity/IEntity").AnyValueConstructor<*>} AnyValueConstructor */ /** @@ -18,7 +15,7 @@ export default class GeneralSerializer extends ISerializer { /** * @param {(value: String, entity: T) => String} wrap - * @param {AnyValueConstructor} entityType + * @param {AnyValueConstructor} entityType */ constructor(wrap, entityType, attributePrefix, attributeSeparator, trailingSeparator, attributeValueConjunctionSign, attributeKeyPrinter) { wrap = wrap ?? (v => `(${v})`) @@ -35,7 +32,6 @@ export default class GeneralSerializer extends ISerializer { let grammar = Grammar.getGrammarForType(ISerializer.grammar, this.entityType) const parseResult = grammar.parse(value) if (!parseResult.status) { - // @ts-expect-error throw new Error(`Error when trying to parse the entity ${this.entityType.prototype.constructor.name}.`) } return parseResult.value diff --git a/js/serialization/Grammar.js b/js/serialization/Grammar.js index c62a72b..04c2cf6 100755 --- a/js/serialization/Grammar.js +++ b/js/serialization/Grammar.js @@ -1,4 +1,5 @@ // @ts-nocheck +import ByteEntity from "../entity/ByteEntity" import FunctionReferenceEntity from "../entity/FunctionReferenceEntity" import GuidEntity from "../entity/GuidEntity" import IdentifierEntity from "../entity/IdentifierEntity" @@ -17,17 +18,17 @@ import PinReferenceEntity from "../entity/PinReferenceEntity" import RealUnitEntity from "../entity/UnitRealEntity" import RotatorEntity from "../entity/RotatorEntity" import SimpleSerializationRotatorEntity from "../entity/SimpleSerializationRotatorEntity" +import SimpleSerializationVector2DEntity from "../entity/SimpleSerializationVector2DEntity" import SimpleSerializationVectorEntity from "../entity/SimpleSerializationVectorEntity" import SymbolEntity from "../entity/SymbolEntity" -import TypeInitialization from "../entity/TypeInitialization" import UnionType from "../entity/UnionType" import UnknownKeysEntity from "../entity/UnknownKeysEntity" import Utility from "../Utility" import VariableReferenceEntity from "../entity/VariableReferenceEntity" import Vector2DEntity from "../entity/Vector2DEntity" import VectorEntity from "../entity/VectorEntity" -import SimpleSerializationVector2DEntity from "../entity/SimpleSerializationVector2DEntity" -import ByteEntity from "../entity/ByteEntity" + +/** @typedef {import ("../entity/IEntity").AttributeInformation} AttributeInformation */ let P = Parsimmon @@ -36,30 +37,35 @@ export default class Grammar { /* --- Factory --- */ /** @param {Grammar} r */ - static getGrammarForType(r, attributeType, defaultGrammar = r.AttributeAnyValue) { - if (attributeType instanceof TypeInitialization) { - let result = Grammar.getGrammarForType(r, attributeType.type, defaultGrammar) - if (attributeType.serialized && !(attributeType.type instanceof String)) { + static getGrammarForType(r, attribute, defaultGrammar = r.AttributeAnyValue) { + if (attribute.constructor === Object) { + attribute = /** @type {AttributeInformation} */(attribute) + let type = attribute.type + let result + if (type instanceof Array) { + result = Grammar.getGrammarForType(r, type[0]) + .trim(P.optWhitespace) + .sepBy(P.string(",")) + .skip(P.regex(/,?\s*/)) + .wrap(P.string("("), P.string(")")) + } else if (type instanceof UnionType) { + result = type.types + .map(v => Grammar.getGrammarForType(r, Utility.getType(v))) + .reduce((accum, cur) => !cur || accum === r.AttributeAnyValue + ? r.AttributeAnyValue + : accum.or(cur)) + } else { + result = Grammar.getGrammarForType(r, type, defaultGrammar) + } + if (attribute.serialized && !(type instanceof String)) { result = result.wrap(P.string('"'), P.string('"')) } + if (attribute.nullable) { + result = result.or(r.Null) + } return result } - switch (Utility.getType(attributeType)) { - case Array: - return P.seqMap( - P.string("("), - attributeType - .map(v => Grammar.getGrammarForType(r, Utility.getType(v))) - .reduce((accum, cur) => !cur || accum === r.AttributeAnyValue - ? r.AttributeAnyValue - : accum.or(cur) - ) - .trim(P.optWhitespace) - .sepBy(P.string(",")) - .skip(P.regex(/,?\s*/)), - P.string(")"), - (_0, grammar, _2) => grammar - ) + switch (attribute) { case Boolean: return r.Boolean case ByteEntity: @@ -102,12 +108,6 @@ export default class Grammar { return r.String case SymbolEntity: return r.Symbol - case UnionType: - return attributeType.types - .map(v => Grammar.getGrammarForType(r, Utility.getType(v))) - .reduce((accum, cur) => !cur || accum === r.AttributeAnyValue - ? r.AttributeAnyValue - : accum.or(cur)) case VariableReferenceEntity: return r.VariableReference case Vector2DEntity: @@ -145,7 +145,10 @@ export default class Grammar { // Once the attribute name is known, look into entityType.attributes to get its type const attributeKey = attributeName.split(".") const attribute = Utility.objectGet(entityType.attributes, attributeKey) - let attributeValueGrammar = Grammar.getGrammarForType(r, attribute, r.AttributeAnyValue) + let attributeValueGrammar = + attribute.constructor === Object && /** @type {AttributeInformation} */(attribute).serialized + ? r.String + : Grammar.getGrammarForType(r, attribute, r.AttributeAnyValue) // Returns a setter function for the attribute return attributeValueGrammar.map(attributeValue => entity => Utility.objectSet(entity, attributeKey, attributeValue, true) diff --git a/js/serialization/ISerializer.js b/js/serialization/ISerializer.js index 84c07ee..313978f 100644 --- a/js/serialization/ISerializer.js +++ b/js/serialization/ISerializer.js @@ -1,16 +1,13 @@ import Grammar from "./Grammar" import Parsimmon from "parsimmon" import SerializerFactory from "./SerializerFactory" -import TypeInitialization from "../entity/TypeInitialization" import Utility from "../Utility" +import IEntity from "../entity/IEntity" /** * @typedef {import("../entity/IEntity").EntityConstructor} EntityConstructor - * @typedef {import("../entity/TypeInitialization").AnyValue} AnyValue - */ -/** - * @template {AnyValue} T - * @typedef {import("../entity/TypeInitialization").AnyValueConstructor} AnyValueConstructor + * @typedef {import("../entity/IEntity").AnyValue} AnyValue + * @typedef {import("../entity/IEntity").AnyValueConstructor<*>} AnyValueConstructor */ /** @template {AnyValue} T */ @@ -18,7 +15,7 @@ export default class ISerializer { static grammar = Parsimmon.createLanguage(new Grammar()) - /** @param {AnyValueConstructor} entityType */ + /** @param {AnyValueConstructor} entityType */ constructor( entityType, attributePrefix = "", @@ -76,7 +73,11 @@ export default class ISerializer { if (!serializer) { throw new Error(`Unknown value type "${type.name}", a serializer must be registered in the SerializerFactory class, check initializeSerializerFactory.js`) } - return serializer.write(entity, value, insideString) + return serializer.write( + value instanceof IEntity ? value : entity, + value, + insideString + ) } /** @@ -90,13 +91,12 @@ export default class ISerializer { let fullKey = key.concat("") const last = fullKey.length - 1 const attributes = /** @type {EntityConstructor} */(object.constructor).attributes - const keys = - attributes ? - Utility.mergeArrays( - Object.getOwnPropertyNames(attributes), - Object.getOwnPropertyNames(object) - ) - : Object.getOwnPropertyNames(object) + const keys = attributes + ? Utility.mergeArrays( + Object.getOwnPropertyNames(attributes), + Object.getOwnPropertyNames(object) + ) + : Object.getOwnPropertyNames(object) for (const property of keys) { fullKey[last] = property const value = object[property] @@ -125,10 +125,9 @@ export default class ISerializer { } showProperty(entity, object, attributeKey, attributeValue) { - // @ts-expect-error const attributes = /** @type {EntityConstructor} */(this.entityType).attributes const attribute = Utility.objectGet(attributes, attributeKey) - if (attribute instanceof TypeInitialization) { + if (attribute.constructor === Object) { if (attribute.ignored) { return false } diff --git a/js/serialization/SerializerFactory.js b/js/serialization/SerializerFactory.js index 5ba6f1f..3a8cea1 100755 --- a/js/serialization/SerializerFactory.js +++ b/js/serialization/SerializerFactory.js @@ -1,10 +1,11 @@ /** * @typedef {import("../entity/IEntity").default} IEntity - * @typedef {import("../entity/TypeInitialization").AnyValue} AnyValue + * @typedef {import("../entity/IEntity").AnyValue} AnyValue */ + /** - * @template T - * @typedef {import("../entity/TypeInitialization").AnyValueConstructor} AnyValueConstructor + * @template {AnyValue} T + * @typedef {import("../entity/IEntity").AnyValueConstructor} AnyValueConstructor */ /** * @template {AnyValue} T @@ -16,6 +17,11 @@ export default class SerializerFactory { /** @type {Map, ISerializer>} */ static #serializers = new Map() + /** + * @template {AnyValue} T + * @param {AnyValueConstructor} entity + * @param {ISerializer} object + */ static registerSerializer(entity, object) { SerializerFactory.#serializers.set(entity, object) } diff --git a/js/serialization/ToStringSerializer.js b/js/serialization/ToStringSerializer.js index 36bed70..551e1e5 100755 --- a/js/serialization/ToStringSerializer.js +++ b/js/serialization/ToStringSerializer.js @@ -1,18 +1,18 @@ import Utility from "../Utility" import GeneralSerializer from "./GeneralSerializer" -/** @typedef {import("../entity/TypeInitialization").AnyValue} AnyValue */ -/** - * @template {AnyValue} T - * @typedef {import("../entity/TypeInitialization").AnyValueConstructor} AnyValueConstructor +/** + * @typedef {import("../entity/IEntity").AnyValue} AnyValue + * @typedef {import("../entity/IEntity").AnyValueConstructor<*>} AnyValueConstructor */ + /** * @template {AnyValue} T * @extends {GeneralSerializer} */ export default class ToStringSerializer extends GeneralSerializer { - /** @param {AnyValueConstructor} entityType */ + /** @param {AnyValueConstructor} entityType */ constructor(entityType) { super(undefined, entityType) } diff --git a/js/serialization/initializeSerializerFactory.js b/js/serialization/initializeSerializerFactory.js index 4f0e9cd..a4566b2 100755 --- a/js/serialization/initializeSerializerFactory.js +++ b/js/serialization/initializeSerializerFactory.js @@ -19,6 +19,7 @@ import RealUnitEntity from "../entity/UnitRealEntity" import RotatorEntity from "../entity/RotatorEntity" import SerializerFactory from "./SerializerFactory" import SimpleSerializationRotatorEntity from "../entity/SimpleSerializationRotatorEntity" +import SimpleSerializationVector2DEntity from "../entity/SimpleSerializationVector2DEntity" import SimpleSerializationVectorEntity from "../entity/SimpleSerializationVectorEntity" import SymbolEntity from "../entity/SymbolEntity" import ToStringSerializer from "./ToStringSerializer" @@ -27,7 +28,11 @@ import Utility from "../Utility" import VariableReferenceEntity from "../entity/VariableReferenceEntity" import Vector2DEntity from "../entity/Vector2DEntity" import VectorEntity from "../entity/VectorEntity" -import SimpleSerializationVector2DEntity from "../entity/SimpleSerializationVector2DEntity" + +/** + * @typedef {import("../entity/IEntity").AnySimpleValue} AnySimpleValue + * @typedef {import("../entity/IEntity").AnyValue} AnyValue + */ export default function initializeSerializerFactory() { @@ -44,11 +49,10 @@ export default function initializeSerializerFactory() { SerializerFactory.registerSerializer( Array, new CustomSerializer( - /** @param {Array} array */ + /** @param {AnySimpleValue[]} array */ (array, insideString) => `(${array .map(v => - // @ts-expect-error SerializerFactory.getSerializer(Utility.getType(v)).serialize(v, insideString) + "," ) .join("")