diff --git a/dist/ueblueprint.js b/dist/ueblueprint.js index d53052e..5118431 100755 --- a/dist/ueblueprint.js +++ b/dist/ueblueprint.js @@ -1138,7 +1138,7 @@ class Reply { } } - /** @param {Parsernostrum} parsernostrum */ + /** @param {Parsernostrum} parsernostrum */ static makeContext(parsernostrum = null, input = "") { return /** @type {Context} */({ parsernostrum, @@ -1156,6 +1156,7 @@ class Reply { } } +/** @template T */ class Parser { static indentation = " " @@ -1241,7 +1242,7 @@ class Parser { * @param {Number} position * @param {PathNode} path * @param {Number} index - * @returns {Result>} + * @returns {Result} */ parse(context, position, path, index) { return null @@ -1294,6 +1295,7 @@ class StringParser extends Parser { * @param {Number} position * @param {PathNode} path * @param {Number} index + * @returns {Result} */ parse(context, position, path, index) { path = this.makePath(path, index); @@ -1317,6 +1319,7 @@ class StringParser extends Parser { } } +/** @extends Parser<""> */ class SuccessParser extends Parser { static instance = new SuccessParser() @@ -1326,6 +1329,7 @@ class SuccessParser extends Parser { * @param {Number} position * @param {PathNode} path * @param {Number} index + * @returns {Result<"">} */ parse(context, position, path, index) { path = this.makePath(path, index); @@ -1344,7 +1348,18 @@ class SuccessParser extends Parser { } } -/** @template {Parser[]} T */ +/** + * @template {any[]} T + * @typedef {T extends [infer A] ? A + * : T extends [infer A, ...infer B] ? A | Union + * : never + * } Union + */ + +/** + * @template {any[]} T + * @extends Parser> + */ class AlternativeParser extends Parser { #parsers @@ -1352,7 +1367,7 @@ class AlternativeParser extends Parser { return this.#parsers } - /** @param {T} parsers */ + /** @param {Parser[]} parsers */ constructor(...parsers) { super(); this.#parsers = parsers; @@ -1366,7 +1381,7 @@ class AlternativeParser extends Parser { */ parse(context, position, path, index) { path = this.makePath(path, index); - const result = Reply.makeSuccess(0, /** @type {ParserValue} */("")); + const result = /** @type {Result>} */(Reply.makeSuccess(0, "")); for (let i = 0; i < this.#parsers.length; ++i) { const outcome = this.#parsers[i].parse(context, position, path, i); if (outcome.bestPosition > result.bestPosition) { @@ -1418,8 +1433,9 @@ class AlternativeParser extends Parser { } /** - * @template {Parser} T - * @template {(v: ParserValue, input: String, position: Number) => Parsernostrum} C + * @template S + * @template T + * @extends Parser */ class ChainedParser extends Parser { @@ -1431,8 +1447,8 @@ class ChainedParser extends Parser { #fn /** - * @param {T} parser - * @param {C} chained + * @param {Parser} parser + * @param {(v: S, input: String, position: Number) => Parsernostrum} chained */ constructor(parser, chained) { super(); @@ -1445,7 +1461,7 @@ class ChainedParser extends Parser { * @param {Number} position * @param {PathNode} path * @param {Number} index - * @returns {Result>>>} + * @returns {Result} */ parse(context, position, path, index) { path = this.makePath(path, index); @@ -1454,10 +1470,9 @@ class ChainedParser extends Parser { // @ts-expect-error return outcome } - // @ts-expect-error const result = this.#fn(outcome.value, context.input, outcome.position) .getParser() - .parse(context, outcome.position); + .parse(context, outcome.position, path, 0); if (outcome.bestPosition > result.bestPosition) { result.bestParser = outcome.bestParser; result.bestPosition = outcome.bestPosition; @@ -1478,6 +1493,7 @@ class ChainedParser extends Parser { } } +/** @extends Parser */ class FailureParser extends Parser { static instance = new FailureParser() @@ -1504,7 +1520,10 @@ class FailureParser extends Parser { } } -/** @template {Parser} T */ +/** + * @template T + * @extends Parser + */ class Label extends Parser { #parser @@ -1515,7 +1534,7 @@ class Label extends Parser { #label = "" /** - * @param {T} parser + * @param {Parser} parser * @param {String} label */ constructor(parser, label) { @@ -1557,12 +1576,15 @@ class Label extends Parser { } } -/** @template {Parser} T */ +/** + * @template T + * @extends Parser + */ class LazyParser extends Parser { #parser - /** @type {T} */ + /** @type {Parser} */ #resolvedPraser /** @param {() => Parsernostrum} parser */ @@ -1604,6 +1626,7 @@ class LazyParser extends Parser { * @param {Number} position * @param {PathNode} path * @param {Number} index + * @returns {Result} */ parse(context, position, path, index) { this.resolve(); @@ -1625,7 +1648,7 @@ class LazyParser extends Parser { } } -/** @template {Parser} T */ +/** @extends Parser<""> */ class Lookahead extends Parser { #parser @@ -1650,7 +1673,7 @@ class Lookahead extends Parser { } /** - * @param {T} parser + * @param {Parser} parser * @param {Type} type */ constructor(parser, type) { @@ -1664,6 +1687,7 @@ class Lookahead extends Parser { * @param {Number} position * @param {PathNode} path * @param {Number} index + * @returns {Result<"">} */ parse(context, position, path, index) { path = this.makePath(path, index); @@ -1686,7 +1710,10 @@ class Lookahead extends Parser { } } -/** @template T */ +/** + * @template T + * @extends Parser + */ class RegExpParser extends Parser { /** @type {RegExp} */ @@ -1717,7 +1744,6 @@ class RegExpParser extends Parser { backtickQuotedString: new RegExp("`(" + this.#createEscapeable("`") + ")`"), } - /** * @param {RegExp} regexp * @param {(match: RegExpExecArray) => T} matchMapper @@ -1734,6 +1760,7 @@ class RegExpParser extends Parser { * @param {Number} position * @param {PathNode} path * @param {Number} index + * @returns {Result} */ parse(context, position, path, index) { path = this.makePath(path, index); @@ -1765,8 +1792,9 @@ class RegExpParser extends Parser { } /** - * @template {Parser} T - * @template P + * @template S + * @template T + * @extends Parser */ class MapParser extends Parser { @@ -1781,8 +1809,8 @@ class MapParser extends Parser { } /** - * @param {T} parser - * @param {(v: ParserValue

) => P} mapper + * @param {Parser} parser + * @param {(v: S) => T} mapper */ constructor(parser, mapper) { super(); @@ -1808,12 +1836,14 @@ class MapParser extends Parser { * @param {Number} position * @param {PathNode} path * @param {Number} index - * @returns {Result

} + * @returns {Result} */ parse(context, position, path, index) { path = this.makePath(path, index); - const result = this.#parser.parse(context, position, path, 0); + // @ts-expect-error + const result = /** @type {Result} */(this.#parser.parse(context, position, path, 0)); if (result.status) { + // @ts-expect-error result.value = this.#mapper(result.value); } return result @@ -1865,15 +1895,14 @@ class RegExpValueParser extends RegExpParser { /** @param {RegExp} regexp */ constructor(regexp, group = 0) { - super( - regexp, - /** @param {RegExpExecArray} match */ - match => match[group] - ); + super(regexp, match => match[group]); } } -/** @template {Parser[]} T */ +/** + * @template {any[]} T + * @extends Parser + */ class SequenceParser extends Parser { #parsers @@ -1881,7 +1910,7 @@ class SequenceParser extends Parser { return this.#parsers } - /** @param {T} parsers */ + /** @param {Parser[]} parsers */ constructor(...parsers) { super(); this.#parsers = parsers; @@ -1892,6 +1921,7 @@ class SequenceParser extends Parser { * @param {Number} position * @param {PathNode} path * @param {Number} index + * @returns {Result} */ parse(context, position, path, index) { path = this.makePath(path, index); @@ -1933,7 +1963,10 @@ class SequenceParser extends Parser { } } -/** @template {Parser} T */ +/** + * @template T + * @extends Parser + */ class TimesParser extends Parser { #parser @@ -1951,7 +1984,7 @@ class TimesParser extends Parser { return this.#max } - /** @param {T} parser */ + /** @param {Parser} parser */ constructor(parser, min = 0, max = Number.POSITIVE_INFINITY) { super(); if (min > max) { @@ -1967,6 +2000,7 @@ class TimesParser extends Parser { * @param {Number} position * @param {PathNode} path * @param {Number} index + * @returns {Result} */ parse(context, position, path, index) { path = this.makePath(path, index); @@ -1985,9 +2019,11 @@ class TimesParser extends Parser { } break } + // @ts-expect-error result.value.push(outcome.value); result.position = outcome.position; } + // @ts-expect-error return result } @@ -2013,12 +2049,12 @@ class TimesParser extends Parser { } } -/** @template {Parser} T */ +/** @template T */ class Parsernostrum { #parser - /** @type {(new (parser: Parser) => Parsernostrum) & typeof Parsernostrum} */ + /** @type {(new (parser: Parser) => Parsernostrum) & typeof Parsernostrum} */ Self static lineColumnFromOffset(string, offset) { @@ -2027,9 +2063,9 @@ class Parsernostrum { const column = lines[lines.length - 1].length + 1; return { line, column } } - /** @param {[any, ...any]|RegExpExecArray} param0 */ + /** @param {[any, ...any] | RegExpExecArray} param0 */ static #firstElementGetter = ([v, _]) => v - /** @param {[any, any, ...any]|RegExpExecArray} param0 */ + /** @param {[any, any, ...any] | RegExpExecArray} param0 */ static #secondElementGetter = ([_, v]) => v static #arrayFlatter = ([first, rest]) => [first, ...rest] /** @@ -2039,7 +2075,6 @@ class Parsernostrum { */ // @ts-expect-error static #joiner = v => v instanceof Array ? v.join("") : v - static #createEscapeable = character => String.raw`[^${character}\\]*(?:\\.[^${character}\\]*)*` // Prefedined parsers @@ -2050,6 +2085,7 @@ class Parsernostrum { static numberInteger = this.reg(RegExpParser.common.numberInteger).map(Number) /** Parser accepting any digits only number and returns a BigInt */ + // @ts-expect-error static numberBigInteger = this.reg(this.numberInteger.getParser().parser.regexp).map(BigInt) /** Parser accepting any digits only number */ @@ -2088,7 +2124,7 @@ class Parsernostrum { /** Parser accepting a backtick quoted string and returns the content */ static backtickQuotedString = this.reg(RegExpParser.common.backtickQuotedString, 1) - /** @param {T} parser */ + /** @param {Parser} parser */ constructor(parser, optimized = false) { this.#parser = parser; } @@ -2125,16 +2161,13 @@ class Parsernostrum { return this.#parser } - /** - * @param {String} input - * @returns {Result>} - */ + /** @param {String} input */ run(input) { const result = this.#parser.parse(Reply.makeContext(this, input), 0, Reply.makePathNode(), 0); if (result.position !== input.length) { result.status = false; } - return result + return /** @type {Result} */(result) } /** @@ -2231,28 +2264,25 @@ class Parsernostrum { // Combinators /** - * @template {[Parsernostrum, Parsernostrum, ...Parsernostrum[]]} P + * @template {Parsernostrum[]} P * @param {P} parsers - * @returns {Parsernostrum>>} + * @returns {Parsernostrum>} */ static seq(...parsers) { - const results = new this(new SequenceParser(...parsers.map(p => p.getParser()))); - // @ts-expect-error - return results + return new this(new SequenceParser(...parsers.map(p => p.getParser()))) } /** - * @template {Parsernostrum[]} P + * @template {Parsernostrum[]} P * @param {P} parsers - * @returns {Parsernostrum>>} + * @returns {Parsernostrum>>} */ static alt(...parsers) { - // @ts-expect-error return new this(new AlternativeParser(...parsers.map(p => p.getParser()))) } /** - * @template {Parsernostrum} P + * @template {Parsernostrum} P * @param {P} parser */ static lookahead(parser) { @@ -2260,9 +2290,9 @@ class Parsernostrum { } /** - * @template {Parsernostrum} P + * @template {Parsernostrum} P * @param {() => P} parser - * @returns {Parsernostrum>>} + * @returns {Parsernostrum>} */ static lazy(parser) { return new this(new LazyParser(parser)) @@ -2294,7 +2324,7 @@ class Parsernostrum { } /** - * @template {Parsernostrum} P + * @template {Parsernostrum} P * @param {P} separator */ sepBy(separator, allowTrailing = false) { @@ -2311,29 +2341,29 @@ class Parsernostrum { } /** - * @template P - * @param {(v: ParserValue) => P} fn - * @returns {Parsernostrum>} + * @template R + * @param {(v: T) => R} fn + * @returns {Parsernostrum} */ map(fn) { - // @ts-expect-error return new Parsernostrum(new MapParser(this.#parser, fn)) } /** - * @template {Parsernostrum} P - * @param {(v: ParserValue, input: String, position: Number) => P} fn + * @template {Parsernostrum} P + * @param {(v: T, input: String, position: Number) => P} fn + * @returns {P} */ chain(fn) { + // @ts-expect-error return new Parsernostrum(new ChainedParser(this.#parser, fn)) } /** - * @param {(v: ParserValue, input: String, position: Number) => boolean} fn + * @param {(v: T, input: String, position: Number) => boolean} fn * @return {Parsernostrum} */ assert(fn) { - // @ts-expect-error return this.chain((v, input, position) => fn(v, input, position) ? Parsernostrum.success().map(() => v) : Parsernostrum.failure() @@ -2344,11 +2374,12 @@ class Parsernostrum { return this.map(Parsernostrum.#joiner) } + /** @return {Parsernostrum} */ label(value = "") { return new Parsernostrum(new Label(this.#parser, value)) } - /** @param {Parsernostrum | Parser | PathNode} highlight */ + /** @param {Parsernostrum | Parser | PathNode} highlight */ toString(indentation = "", newline = false, highlight = null) { if (highlight instanceof Parsernostrum) { highlight = highlight.getParser(); @@ -2487,45 +2518,22 @@ class IEntity { /** @type {(entity: Attribute, serialized: String) => String} */ static notWrapped = (entity, serialized) => serialized - /** @type {(entity: Attribute, serialized: String) => String} */ - static bracketsWrapped = (entity, serialized) => `(${serialized})` + /** @type {(entity: IEntity, serialized: String) => String} */ + static defaultWrapped = (entity, serialized) => `${entity.lookbehind}(${serialized})` - static wrap = this.notWrapped + static wrap = this.defaultWrapped static attributeSeparator = "," - static trailingSeparator = false - /** @type {(k: String) => String} */ static printKey = k => k - /** @type {P} */ - static grammar = Parsernostrum.failure() + /** @type {P>} */ + static grammar = /** @type {any} */(Parsernostrum.failure()) /** @type {{ [key: String]: typeof IEntity }} */ static attributes = {} - /** @type {String | String[]} */ - static lookbehind = "" - - /** @type {typeof IEntity.lookbehind} */ - #lookbehind = this.Self().lookbehind - get lookbehind() { - return this.#lookbehind - } - set lookbehind(value) { - throw this.#lookbehind = value - } - - /** @type {String[]} */ - #keys - get keys() { - return this.#keys ?? Object.keys(this.Self().attributes) - } - set keys(value) { - this.#keys = [... new Set(value)]; - } - /** @type {(type: typeof IEntity) => InstanceType} */ static default static nullable = false @@ -2535,10 +2543,30 @@ class IEntity { static inlined = false // The key is a subobject or array and printed as inlined (A.B=123, A(0)=123) static quoted = false // Key is serialized with quotes static silent = false // Do not serialize if default - static uninitialized = false // Do not initialize with default + static trailing = false // Add attribute separator after the last attribute when serializing + + /** @type {String | String[]} */ + static lookbehind = "" + + #lookbehind = /** @type {String} */(this.Self().lookbehind) + get lookbehind() { + return this.#lookbehind + } + set lookbehind(value) { + this.#lookbehind = value; + } + + /** @type {String[]} */ + #keys + get keys() { + return this.#keys ?? Object.keys(this) + } + set keys(value) { + this.#keys = [... new Set(value)]; + } constructor(values = {}) { - const keys = Utility.mergeArrays(Object.keys(values.attributes), Object.keys(this.Self().attributes)); + const keys = Utility.mergeArrays(Object.keys(values), Object.keys(this.Self().attributes)); for (const key of keys) { if (values[key] !== undefined) { this[key] = values[key]; @@ -2552,6 +2580,14 @@ class IEntity { } } + static className() { + let self = this; + while (!self.name) { + self = Object.getPrototypeOf(self); + } + return self.name + } + /** @param {String} key */ showProperty(key) { /** @type {IEntity} */ @@ -2581,6 +2617,17 @@ class IEntity { return this } + /** + * @template {typeof IEntity} T + * @this {T} + * @param {String} value + */ + static withLookbehind(value) { + const result = this.asUniqueClass(); + result.lookbehind = value; + return result + } + /** * @template {typeof IEntity} T * @this {T} @@ -2621,6 +2668,16 @@ class IEntity { return result } + /** + * @template {typeof IEntity} T + * @this {T} + */ + static flagQuoted(value = true) { + const result = this.asUniqueClass(); + result.quoted = value; + return result + } + /** * @template {typeof IEntity} T * @this {T} @@ -2631,6 +2688,16 @@ class IEntity { return result } + /** + * @template {typeof IEntity} T + * @this {T} + */ + static flagTrailing(value = true) { + const result = this.asUniqueClass(); + result.trailing = value; + return result + } + /** * @template {typeof IEntity} T * @this {InstanceType} @@ -2683,6 +2750,9 @@ class IEntity { if (thisKeys.length != otherKeys.length) { return false } + if (this.valueOf && other.valueOf) { + return this.valueOf() === other.valueOf() + } for (let i = 0; i < thisKeys.length; ++i) { if (!(this[thisKeys[i]] instanceof IEntity && this[thisKeys[i]].equals(other[otherKeys[i]]))) { return false @@ -2727,7 +2797,7 @@ class IEntity { } result += serialization; } - if (Self.trailingSeparator && result.length) { + if (Self.trailing && result.length) { result += Self.attributeSeparator; } return Self.wrap(this, result) @@ -2740,7 +2810,7 @@ class MirroredEntity$1 extends IEntity { /** @type {typeof IEntity} */ static type - /** @param {() => T} getter */ + /** @param {() => InstanceType} getter */ constructor(getter = null) { super(); this.getter = getter; @@ -2766,8 +2836,12 @@ class MirroredEntity$1 extends IEntity { return result } - toString() { - return this.getter().toString() + toString( + insideString = false, + indentation = "", + printKey = this.Self().printKey, + ) { + return this.getter().toString(insideString, indentation, printKey) } } @@ -2779,6 +2853,10 @@ class Serializable { class Grammar { + /** @type {String} */ + // @ts-expect-error + static numberRegexSource = Parsernostrum.number.getParser().parser.regexp.source + static separatedBy = (source, separator, min = 1) => new RegExp( source + "(?:" + separator + source + ")" @@ -2959,45 +3037,32 @@ class Grammar { /** * @template {IEntity} T - * @param {(new (...args: any) => T) & EntityConstructor} entityType - * @param {Boolean | Number} acceptUnknownKeys Number to specify the limit or true, to let it be a reasonable value + * @param {new (...args: any) => T} entityType + * @return {Parsernostrum} */ - static createEntityGrammar(entityType, acceptUnknownKeys = true, entriesSeparator = this.commaSeparation) { - const lookbehind = entityType.attributes.lookbehind.default; + static createEntityGrammar(entityType, entriesSeparator = this.commaSeparation) { + const lookbehind = entityType.lookbehind instanceof Array ? entityType.lookbehind.join("|") : entityType.lookbehind; return Parsernostrum.seq( - Parsernostrum.reg( - lookbehind instanceof Union - ? new RegExp(`(${lookbehind.values.reduce((acc, cur) => acc + "|" + cur)})\\s*\\(\\s*`) - : lookbehind.constructor == String && lookbehind.length > 0 - ? new RegExp(`(${lookbehind})\\s*\\(\\s*`) - : /()\(\s*/, - 1 - ), + Parsernostrum.reg(new RegExp(String.raw`(${lookbehind})\s*\(\s*`), 1), this.createAttributeGrammar(entityType).sepBy(entriesSeparator), - Parsernostrum.reg(/\s*(?:,\s*)?\)/), // trailing comma + Parsernostrum.reg(/\s*(,\s*)?\)/, 1), // optional trailing comma ) - .map(([lookbehind, attributes, _2]) => { + .map(([lookbehind, attributes, trailing]) => { let values = {}; - attributes.forEach(attributeSetter => attributeSetter(values)); if (lookbehind.length) { - values.lookbehind = lookbehind; + values["#lookbehind"] = lookbehind; } + attributes.forEach(attributeSetter => attributeSetter(values)); + values["#trailing"] = trailing !== undefined; return values }) // Decide if we accept the entity or not. It is accepted if it doesn't have too many unexpected keys .chain(values => { - let totalKeys = Object.keys(values); - // Check missing values - if ( - Object.keys(/** @type {AttributeDeclarations} */(entityType.attributes)) - .filter(key => entityType.attributes[key].expected) - .find(key => !totalKeys.includes(key) && (key)) - ) { - return Parsernostrum.failure() + if (entityType.lookbehind instanceof Array || entityType.lookbehind !== lookbehind) { + entityType = entityType.withLookbehind(lookbehind); } - const unknownKeys = Object.keys(values).filter(key => !(key in entityType.attributes)).length; - if (!acceptUnknownKeys && unknownKeys > 0) { - return Parsernostrum.failure() + if (entityType.trailing !== values["#trailing"]) { + entityType = entityType.flagTrailing(values["#trailing"]); } return Parsernostrum.success().map(() => new entityType(values)) }) @@ -3034,7 +3099,7 @@ class LinearColorEntity extends IEntity { B: ColorChannelEntity.withDefault(), A: ColorChannelEntity.withDefault(type => new type(1)), } - static grammar = Grammar.createEntityGrammar(this, false) + static grammar = Grammar.createEntityGrammar(this).label("LinearColorEntity") #H = new ColorChannelEntity() get H() { @@ -3046,18 +3111,35 @@ class LinearColorEntity extends IEntity { #S = new ColorChannelEntity() get S() { - return this.#H + return this.#S } set S(value) { - this.#H = value; + this.#S = value; } #V = new ColorChannelEntity() get V() { - return this.#H + return this.#V } set V(value) { - this.#H = value; + this.#V = value; + } + + constructor(values) { + super(values); + if (values instanceof Array) { + values = { + R: values[0] ?? 0, + G: values[1] ?? 0, + B: values[2] ?? 0, + A: values[3] ?? 1, + }; + } + /** @type {InstanceType} */ this.R; + /** @type {InstanceType} */ this.G; + /** @type {InstanceType} */ this.B; + /** @type {InstanceType} */ this.A; + this.#updateHSV(); } /** @param {Number} x */ @@ -3149,23 +3231,6 @@ class LinearColorEntity extends IEntity { ) } - constructor(values) { - super(values); - if (values instanceof Array) { - values = { - R: values[0] ?? 0, - G: values[1] ?? 0, - B: values[2] ?? 0, - A: values[3] ?? 1, - }; - } - /** @type {ColorChannelEntity} */ this.R; - /** @type {ColorChannelEntity} */ this.G; - /** @type {ColorChannelEntity} */ this.B; - /** @type {ColorChannelEntity} */ this.A; - this.#updateHSV(); - } - #updateHSV() { const r = this.R.value; const g = this.G.value; @@ -3331,10 +3396,6 @@ class LinearColorEntity extends IEntity { toArray() { return [this.R.value, this.G.value, this.B.value, this.A.value] } - - toString() { - return Utility.printLinearColor(this) - } } /** @param {ObjectEntity} entity */ @@ -4316,7 +4377,7 @@ if (typeof window === "undefined") { class GuidEntity extends IEntity { - static grammar = Parsernostrum.reg(/[0-9a-fA-F]{32}/).map(v => new this(v)) + static grammar = Parsernostrum.reg(/[0-9A-F]{32}/i).map(v => new this(v)).label("GuidEntity") static generateGuid() { let values = new Uint32Array(4); @@ -4431,13 +4492,20 @@ class AlternativesEntity extends IEntity { /** @type {(typeof IEntity)[]} */ static alternatives = [] + static className() { + let result = super.className(); + if (this.alternatives.length) { + result += " (accepting: " + this.alternatives.map(v => v.className()).join(", ") + ")"; + } + return result + } + static createGrammar() { - return this.alternatives - .map(entity => entity.grammar) - .reduce((acc, cur) => !cur || cur === Grammar.unknownValue || acc === Grammar.unknownValue - ? Grammar.unknownValue - : Parsernostrum.alt(acc, cur) - ) + const grammars = this.alternatives.map(entity => entity.grammar); + if (grammars.includes(Grammar.unknownValue)) { + return Grammar.unknownValue + } + return Parsernostrum.alt(...grammars) } /** @@ -4457,21 +4525,30 @@ class ArrayEntity extends IEntity { /** @type {typeof IEntity} */ static type + static grammar = this.createGrammar() - /** @param {InstanceType[]} values */ + /** @param {ExtractType[]} values */ constructor(values = []) { super(); this.values = values; } - static createGrammar(elementGrammar = this.type.grammar) { + static createGrammar(elementGrammar = this.type?.grammar ?? Parsernostrum.lazy(() => Grammar.unknownValue)) { return this.inlined ? elementGrammar : Parsernostrum.seq( Parsernostrum.reg(/\(\s*/), elementGrammar.sepBy(Grammar.commaSeparation).opt(), - Parsernostrum.reg(/\s*(?:,\s*)?\)/), - ).map(([_0, values, _3]) => new this(values instanceof Array ? values : [])) + Parsernostrum.reg(/\s*(,\s*)?\)/, 1), + ).map(([_0, values, trailing]) => { + let self = this; + const hasTrailing = trailing !== undefined; + if (hasTrailing !== self.trailing) { + self = self.flagTrailing(hasTrailing); + } + values = values instanceof Array ? values : []; + return new self(values) + }).label(`ArrayEntity of ${this.type?.className() ?? "unknown values"}`) } /** @@ -4479,8 +4556,10 @@ class ArrayEntity extends IEntity { * @param {NonNullable} type */ static of(type) { - const result = /** @type {(typeof ArrayEntity) & { type: T }} */(this.asUniqueClass()); - result.type = type; + const result = /** @type {typeof ArrayEntity & { type: ExtractType, grammar: P> }} */( + this.asUniqueClass() + ); + result.type = /** @type {ExtractType} */(type); this.grammar = result.createGrammar(); return result } @@ -4492,7 +4571,9 @@ class ArrayEntity extends IEntity { class BooleanEntity extends IEntity { - static grammar = Parsernostrum.regArray(/(true)|false/i).map(v => v[1] ? new this(true) : new this(false)) + static grammar = Parsernostrum.regArray(/(true)|false/i) + .map(v => v[1] ? new this(true) : new this(false)) + .label("BooleanEntity") constructor(value = false) { super(); @@ -4503,18 +4584,24 @@ class BooleanEntity extends IEntity { return this.value } - toString() { - return this.value.toString() + toString(insideString = false) { + return this.value + ? insideString + ? "true" + : "True" + : insideString + ? "false" + : "False" } } class NumberEntity extends IEntity { static grammar = Parsernostrum.regArray( - new RegExp(`(${Parsernostrum.number.getParser().parser.regexp.source})|(\\+?inf)|(-inf)`) + new RegExp(`(${Grammar.numberRegexSource})|(\\+?inf)|(-inf)`) ).map(([_0, n, plusInf, minusInf]) => new this( n ? Number(n) : plusInf ? Number.POSITIVE_INFINITY : Number.NEGATIVE_INFINITY - )) + )).label("NumberEntity") /** @type {Number} */ #value @@ -4538,11 +4625,16 @@ class NumberEntity extends IEntity { } toString() { + if (this.value === Number.POSITIVE_INFINITY) { + return "+inf" + } + if (this.value === Number.NEGATIVE_INFINITY) { + return "-inf" + } return this.value.toString() } } -// @ts-expect-error class IntegerEntity extends NumberEntity { static grammar = Parsernostrum.numberInteger.map(v => new this(v)) @@ -4589,7 +4681,7 @@ class ComputedTypeEntity extends IEntity { class SymbolEntity extends IEntity { - static grammar = Grammar.symbol.map(v => new this(v)) + static grammar = Grammar.symbol.map(v => new this(v)).label("SymbolEntity") /** @param {String} value */ constructor(value = "") { @@ -4616,7 +4708,14 @@ class EnumDisplayValueEntity extends EnumEntity { static grammar = Parsernostrum.reg(Grammar.Regex.InsideString).map(v => new this(v)) } -class InvariantTextEntity extends IEntity { +class IPrintableEntity extends IEntity { + + print() { + return this.toString() + } +} + +class InvariantTextEntity extends IPrintableEntity { static lookbehind = "INVTEXT" @@ -4625,36 +4724,53 @@ class InvariantTextEntity extends IEntity { Parsernostrum.reg(new RegExp(`${this.lookbehind}\\s*\\(`)), Parsernostrum.doubleQuotedString, Parsernostrum.reg(/\s*\)/) - ).map(([_0, value, _2]) => new this(value)), - Parsernostrum.reg(new RegExp(this.lookbehind)).map(() => new this()) // InvariantTextEntity can not have arguments - ).map(value => new this(value)) + ).map(([_0, value, _2]) => Number(value)), + Parsernostrum.reg(new RegExp(this.lookbehind)).map(() => 0) // InvariantTextEntity can not have arguments + ) + .map(value => new this(value)) + .label("InvariantTextEntity") constructor(value = "") { super(); this.value = value; } - toString() { + print() { + Parsernostrum.alt( + Parsernostrum.seq( + Parsernostrum.reg(new RegExp(`${this.lookbehind}\\s*\\(`)), + Parsernostrum.doubleQuotedString, + Parsernostrum.reg(/\s*\)/) + ).map(([_0, value, _2]) => Number(value)), + Parsernostrum.reg(new RegExp(this.lookbehind)).map(() => 0) // InvariantTextEntity can not have arguments + ); return this.value } + + toString() { + return this.lookbehind + "(" + this.value + ")" + } } -class LocalizedTextEntity extends IEntity { +class LocalizedTextEntity extends IPrintableEntity { static lookbehind = "NSLOCTEXT" static grammar = Parsernostrum.regArray(new RegExp( - String.raw`${this.attributes.lookbehind.default}\s*\(` + String.raw`${this.lookbehind}\s*\(` + String.raw`\s*"(${Grammar.Regex.InsideString.source})"\s*,` + String.raw`\s*"(${Grammar.Regex.InsideString.source})"\s*,` + String.raw`\s*"(${Grammar.Regex.InsideString.source})"\s*` - + String.raw`(?:,\s+)?` + + String.raw`(,\s+)?` + String.raw`\)`, "m" - )).map(matchResult => new this( - Utility.unescapeString(matchResult[1]), - Utility.unescapeString(matchResult[2]), - Utility.unescapeString(matchResult[3]), - )) + )).map(matchResult => { + const self = matchResult[4] ? this.flagTrailing() : this; + return new self( + Utility.unescapeString(matchResult[1]), + Utility.unescapeString(matchResult[2]), + Utility.unescapeString(matchResult[3]), + ) + }).label("LocalizedTextEntity") #namespace get namespace() { @@ -4680,7 +4796,6 @@ class LocalizedTextEntity extends IEntity { this.#value = value; } - constructor(namespace = "", key = "", value = "") { super(); this.namespace = namespace; @@ -4688,14 +4803,21 @@ class LocalizedTextEntity extends IEntity { this.value = value; } - toString() { + print() { return Utility.capitalFirstLetter(this.value) } + + toString() { + const trailer = this.Self().trailing ? ", " : ""; + return `${this.lookbehind}(${this.namespace}, ${this.key}, ${this.value}${trailer})` + } } -class StringEntity extends IEntity { +class StringEntity extends IPrintableEntity { - static grammar = Parsernostrum.doubleQuotedString.map(insideString => Utility.unescapeString(insideString)) + static grammar = Parsernostrum.doubleQuotedString + .map(insideString => new this(Utility.unescapeString(insideString))) + .label("StringEntity") /** @param {String} value */ constructor(value = "") { @@ -4703,21 +4825,29 @@ class StringEntity extends IEntity { this.value = value; } + print() { + return this.value + } + valueOf() { return this.value } - toString() { - return this.value.toString() + toString(insideString = false) { + let result = Utility.escapeString(this.value); + if (!insideString) { + result = `"${result}"`; + } + return result } } -class FormatTextEntity extends IEntity { +class FormatTextEntity extends IPrintableEntity { static lookbehind = ["LOCGEN_FORMAT_NAMED", "LOCGEN_FORMAT_ORDERED"] static grammar = Parsernostrum.seq( // Resulting regex: /(LOCGEN_FORMAT_NAMED|LOCGEN_FORMAT_ORDERED)\s*/ - Parsernostrum.reg(new RegExp(String.raw`(${this.lookbehind.reduce((acc, cur) => acc + "|" + cur)})\s*\(\s*)`), 1), + Parsernostrum.reg(new RegExp(String.raw`(${this.lookbehind.reduce((acc, cur) => acc + "|" + cur)})\s*`), 1), Parsernostrum.alt( ...[StringEntity, LocalizedTextEntity, InvariantTextEntity, FormatTextEntity].map(type => type.grammar) ).sepBy(Parsernostrum.reg(/\s*\,\s*/)), @@ -4728,6 +4858,7 @@ class FormatTextEntity extends IEntity { result.lookbehind = lookbehind; return result }) + .label("FormatTextEntity") /** @param {(StringEntity | LocalizedTextEntity | InvariantTextEntity | FormatTextEntity)[]} values */ constructor(values) { @@ -4735,27 +4866,29 @@ class FormatTextEntity extends IEntity { this.values = values; } - toString() { + print() { const pattern = this.values?.[0]?.toString(); // The pattern is always the first element of the array if (!pattern) { return "" } + const values = this.values.slice(1).map(v => v.toString()); - return this.lookbehind == "LOCGEN_FORMAT_NAMED" + let result = this.Self().lookbehind == "LOCGEN_FORMAT_NAMED" ? pattern.replaceAll(/\{([a-zA-Z]\w*)\}/g, (substring, arg) => { const argLocation = values.indexOf(arg) + 1; return argLocation > 0 && argLocation < values.length ? values[argLocation] : substring }) - : this.lookbehind == "LOCGEN_FORMAT_ORDERED" + : this.Self().lookbehind == "LOCGEN_FORMAT_ORDERED" ? pattern.replaceAll(/\{(\d+)\}/g, (substring, arg) => { const argValue = Number(arg); return argValue < values.length ? values[argValue] : substring }) - : "" + : ""; + result = this.Self().lookbehind + "(" + result + ")"; } } @@ -4797,11 +4930,14 @@ class ObjectReferenceEntity extends IEntity { + `'(${Grammar.Regex.InsideSingleQuotedString.source})'` )).map(([_0, a, b]) => a ?? b) static typeReference = Parsernostrum.reg( + // @ts-expect-error new RegExp(Grammar.Regex.Path.source + "|" + Grammar.symbol.getParser().regexp.source) ) static fullReferenceGrammar = Parsernostrum.regArray( new RegExp( + // @ts-expect-error "(" + this.typeReference.getParser().regexp.source + ")" + // @ts-expect-error + "(?:" + this.#quotedParser.getParser().parser.regexp.source + ")" ) ).map(([full, type, ...path]) => new this(type, path.find(v => v), full)) @@ -4816,7 +4952,7 @@ class ObjectReferenceEntity extends IEntity { this.fullReferenceSerializedGrammar, this.fullReferenceGrammar, this.typeReferenceGrammar, - ) + ).label("ObjectReferenceEntity") #type get type() { @@ -4858,39 +4994,27 @@ class ObjectReferenceEntity extends IEntity { return Utility.getNameFromPath(this.path.replace(/_C$/, ""), dropCounter) } - toString() { + toString( + insideString = false, + indentation = "", + printKey = this.Self().printKey, + ) { return this.full } } -class PathSymbolEntity extends IEntity { - - static grammar = Grammar.symbol.map(v => new this(v)) - - constructor(value = "") { - super(); - this.value = value; - } - - valueOf() { - return this.value - } - - toString() { - return this.value.toString() - } -} - class PinReferenceEntity extends IEntity { static grammar = Parsernostrum.seq( - PathSymbolEntity.grammar, + SymbolEntity.grammar, Parsernostrum.whitespace, GuidEntity.grammar - ).map(([objectName, _1, pinGuid]) => new this(objectName, pinGuid)) + ) + .map(([objectName, _1, pinGuid]) => new this(objectName, pinGuid)) + .label("PinReferenceEntity") /** - * @param {PathSymbolEntity} objectName + * @param {SymbolEntity} objectName * @param {GuidEntity} pinGuid */ constructor(objectName = null, pinGuid = null) { @@ -4898,6 +5022,14 @@ class PinReferenceEntity extends IEntity { this.objectName = objectName; this.pinGuid = pinGuid; } + + toString( + insideString = false, + indentation = "", + printKey = this.Self().printKey, + ) { + return this.objectName.toString() + " " + this.pinGuid.toString() + } } class FunctionReferenceEntity extends IEntity { @@ -4912,9 +5044,9 @@ class FunctionReferenceEntity extends IEntity { constructor(values) { super(values); - /** @type {ObjectReferenceEntity} */ this.MemberParent; - /** @type {String} */ this.MemberName; - /** @type {GuidEntity} */ this.MemberGuid; + /** @type {InstanceType} */ this.MemberParent; + /** @type {InstanceType} */ this.MemberName; + /** @type {InstanceType} */ this.MemberGuid; } } @@ -4927,29 +5059,29 @@ class PinTypeEntity extends IEntity { PinSubCategoryObject: ObjectReferenceEntity.withDefault(), PinSubCategoryMemberReference: FunctionReferenceEntity.withDefault(type => null), PinValueType: PinTypeEntity.withDefault(), - ContainerType: PathSymbolEntity, + ContainerType: SymbolEntity, bIsReference: BooleanEntity.withDefault(), bIsConst: BooleanEntity.withDefault(), bIsWeakPointer: BooleanEntity.withDefault(), bIsUObjectWrapper: BooleanEntity.withDefault(), bSerializeAsSinglePrecisionFloat: BooleanEntity.withDefault(), } - static grammar = Grammar.createEntityGrammar(this) + static grammar = Grammar.createEntityGrammar(this).label("PinTypeEntity") constructor(values = {}) { super(values); - /** @type {String} */ this.PinCategory; - /** @type {String} */ this.PinSubCategory; - /** @type {ObjectReferenceEntity} */ this.PinSubCategoryObject; - /** @type {FunctionReferenceEntity} */ this.PinSubCategoryMemberReference; - /** @type {PinTypeEntity} */ this.PinValueType; - /** @type {PathSymbolEntity} */ this.ContainerType; - /** @type {Boolean} */ this.bIsReference; - /** @type {Boolean} */ this.bIsConst; - /** @type {Boolean} */ this.bIsWeakPointer; - /** @type {Boolean} */ this.bIsUObjectWrapper; - /** @type {Boolean} */ this.bIsUObjectWrapper; - /** @type {Boolean} */ this.bSerializeAsSinglePrecisionFloat; + /** @type {InstanceType} */ this.PinCategory; + /** @type {InstanceType} */ this.PinSubCategory; + /** @type {InstanceType} */ this.PinSubCategoryObject; + /** @type {InstanceType} */ this.PinSubCategoryMemberReference; + /** @type {InstanceType} */ this.PinValueType; + /** @type {InstanceType} */ this.ContainerType; + /** @type {InstanceType} */ this.bIsReference; + /** @type {InstanceType} */ this.bIsConst; + /** @type {InstanceType} */ this.bIsWeakPointer; + /** @type {InstanceType} */ this.bIsUObjectWrapper; + /** @type {InstanceType} */ this.bIsUObjectWrapper; + /** @type {InstanceType} */ this.bSerializeAsSinglePrecisionFloat; } /** @param {PinTypeEntity} other */ @@ -4969,12 +5101,12 @@ class Vector2DEntity extends IEntity { X: NumberEntity.withDefault(), Y: NumberEntity.withDefault(), } - static grammar = Grammar.createEntityGrammar(this, false) + static grammar = Grammar.createEntityGrammar(this).label("Vector2DEntity") constructor(values) { super(values); - /** @type {NumberEntity} */ this.X; - /** @type {NumberEntity} */ this.Y; + /** @type {InstanceType} */ this.X; + /** @type {InstanceType} */ this.Y; } /** @returns {[Number, Number]} */ @@ -4987,15 +5119,15 @@ class RBSerializationVector2DEntity extends Vector2DEntity { static grammar = Parsernostrum.alt( Parsernostrum.regArray(new RegExp( - /X\s*=\s*/.source + "(?" + Parsernostrum.number.getParser().parser.regexp.source + ")" + /X\s*=\s*/.source + "(?" + Grammar.numberRegexSource + ")" + "\\s+" - + /Y\s*=\s*/.source + "(?" + Parsernostrum.number.getParser().parser.regexp.source + ")" + + /Y\s*=\s*/.source + "(?" + Grammar.numberRegexSource + ")" )).map(({ groups: { x, y } }) => new this({ X: Number(x), Y: Number(y), })), Vector2DEntity.grammar - ) + ).label("RBSerializationVector2DEntity") } class RotatorEntity extends IEntity { @@ -5006,13 +5138,13 @@ class RotatorEntity extends IEntity { P: NumberEntity.withDefault(), Y: NumberEntity.withDefault(), } - static grammar = Grammar.createEntityGrammar(this, false) + static grammar = Grammar.createEntityGrammar(this).label("RotatorEntity") constructor(values) { super(values); - /** @type {NumberEntity} */ this.R; - /** @type {NumberEntity} */ this.P; - /** @type {NumberEntity} */ this.Y; + /** @type {InstanceType} */ this.R; + /** @type {InstanceType} */ this.P; + /** @type {InstanceType} */ this.Y; } getRoll() { @@ -5032,11 +5164,11 @@ class SimpleSerializationRotatorEntity extends RotatorEntity { static grammar = Parsernostrum.alt( Parsernostrum.regArray(new RegExp( - `(${Parsernostrum.number.getParser().parser.regexp.source})` + `(${Grammar.numberRegexSource})` + String.raw`\s*,\s*` - + `(${Parsernostrum.number.getParser().parser.regexp.source})` + + `(${Grammar.numberRegexSource})` + String.raw`\s*,\s*` - + `(${Parsernostrum.number.getParser().parser.regexp.source})` + + `(${Grammar.numberRegexSource})` )).map(([_, p, y, r]) => new this({ R: Number(r), P: Number(p), @@ -5050,9 +5182,9 @@ class SimpleSerializationVector2DEntity extends Vector2DEntity { static grammar = Parsernostrum.alt( Parsernostrum.regArray(new RegExp( - `(${Parsernostrum.number.getParser().parser.regexp.source})` + `(${Grammar.numberRegexSource})` + String.raw`\s*,\s*` - + `(${Parsernostrum.number.getParser().parser.regexp.source})` + + `(${Grammar.numberRegexSource})` )).map(([_, x, y]) => new this({ X: Number(x), Y: Number(y), @@ -5070,14 +5202,14 @@ class Vector4DEntity extends IEntity { Z: NumberEntity.withDefault(), W: NumberEntity.withDefault(), } - static grammar = Grammar.createEntityGrammar(Vector4DEntity, false) + static grammar = Grammar.createEntityGrammar(this).label("Vector4DEntity") constructor(values) { super(values); - /** @type {NumberEntity} */ this.X; - /** @type {NumberEntity} */ this.Y; - /** @type {NumberEntity} */ this.Z; - /** @type {NumberEntity} */ this.W; + /** @type {InstanceType} */ this.X; + /** @type {InstanceType} */ this.Y; + /** @type {InstanceType} */ this.Z; + /** @type {InstanceType} */ this.W; } /** @returns {[Number, Number, Number, Number]} */ @@ -5091,16 +5223,15 @@ class SimpleSerializationVector4DEntity extends Vector4DEntity { static grammar = this.createGrammar() static createGrammar() { - Parsernostrum.number.getParser().parser.regexp.source; return Parsernostrum.alt( Parsernostrum.regArray(new RegExp( - `(${Parsernostrum.number.getParser().parser.regexp.source})` + `(${Grammar.numberRegexSource})` + String.raw`\s*,\s*` - + `(${Parsernostrum.number.getParser().parser.regexp.source})` + + `(${Grammar.numberRegexSource})` + String.raw`\s*,\s*` - + `(${Parsernostrum.number.getParser().parser.regexp.source})` + + `(${Grammar.numberRegexSource})` + String.raw`\s*,\s*` - + `(${Parsernostrum.number.getParser().parser.regexp.source})` + + `(${Grammar.numberRegexSource})` )) .map(([_0, x, y, z, w]) => new this({ X: Number(x), @@ -5121,13 +5252,13 @@ class VectorEntity extends IEntity { Y: NumberEntity.withDefault(), Z: NumberEntity.withDefault(), } - static grammar = Grammar.createEntityGrammar(VectorEntity, false) + static grammar = Grammar.createEntityGrammar(this).label("VectorEntity") constructor(values) { super(values); - /** @type {NumberEntity} */ this.X; - /** @type {NumberEntity} */ this.Y; - /** @type {NumberEntity} */ this.Z; + /** @type {InstanceType} */ this.X; + /** @type {InstanceType} */ this.Y; + /** @type {InstanceType} */ this.Z; } /** @returns {[Number, Number, Number]} */ @@ -5140,11 +5271,11 @@ class SimpleSerializationVectorEntity extends VectorEntity { static grammar = Parsernostrum.alt( Parsernostrum.regArray(new RegExp( - `(${Parsernostrum.number.getParser().parser.regexp.source})` + `(${Grammar.numberRegexSource})` + String.raw`\s*,\s*` - + `(${Parsernostrum.number.getParser().parser.regexp.source})` + + `(${Grammar.numberRegexSource})` + String.raw`\s*,\s*` - + `(${Parsernostrum.number.getParser().parser.regexp.source})` + + `(${Grammar.numberRegexSource})` )) .map(([_0, x, y, z]) => new this({ X: Number(x), @@ -5155,7 +5286,7 @@ class SimpleSerializationVectorEntity extends VectorEntity { ) } -/** @template {TerminalAttribute} T */ +/** @template {IEntity} T */ class PinEntity extends IEntity { static lookbehind = "INVTEXT" @@ -5243,25 +5374,23 @@ class PinEntity extends IEntity { constructor(values = {}) { super(values); - /** @type {ObjectEntity} */ this.objectEntity; - /** @type {Number} */ this.pinIndex; - /** @type {GuidEntity} */ this.PinId; - /** @type {String} */ this.PinName; - /** @type {LocalizedTextEntity | String} */ this.PinFriendlyName; - /** @type {String} */ this.PinToolTip; - /** @type {String} */ this.Direction; - /** @type {PinTypeEntity} */ this.PinType; - /** @type {PinReferenceEntity[]} */ this.LinkedTo; - /** @type {T} */ this.DefaultValue; - /** @type {String} */ this.AutogeneratedDefaultValue; - /** @type {ObjectReferenceEntity} */ this.DefaultObject; - /** @type {GuidEntity} */ this.PersistentGuid; - /** @type {Boolean} */ this.bHidden; - /** @type {Boolean} */ this.bNotConnectable; - /** @type {Boolean} */ this.bDefaultValueIsReadOnly; - /** @type {Boolean} */ this.bDefaultValueIsIgnored; - /** @type {Boolean} */ this.bAdvancedView; - /** @type {Boolean} */ this.bOrphanedPin; + /** @type {InstanceType} */ this.PinId; + /** @type {InstanceType} */ this.PinName; + /** @type {InstanceType} */ this.PinFriendlyName; + /** @type {InstanceType} */ this.PinToolTip; + /** @type {InstanceType} */ this.Direction; + /** @type {InstanceType} */ this.PinType; + /** @type {InstanceType} */ this.LinkedTo; + /** @type {InstanceType} */ this.DefaultValue; + /** @type {InstanceType} */ this.AutogeneratedDefaultValue; + /** @type {InstanceType} */ this.DefaultObject; + /** @type {InstanceType} */ this.PersistentGuid; + /** @type {InstanceType} */ this.bHidden; + /** @type {InstanceType} */ this.bNotConnectable; + /** @type {InstanceType} */ this.bDefaultValueIsReadOnly; + /** @type {InstanceType} */ this.bDefaultValueIsIgnored; + /** @type {InstanceType} */ this.bAdvancedView; + /** @type {InstanceType} */ this.bOrphanedPin; } /** @param {ObjectEntity} objectEntity */ @@ -5350,7 +5479,6 @@ class PinEntity extends IEntity { getDefaultValue(maybeCreate = false) { if (this.DefaultValue === undefined && maybeCreate) { - // @ts-expect-error this.DefaultValue = new (this.getEntityType(true))(); } return this.DefaultValue @@ -5394,10 +5522,7 @@ class PinEntity extends IEntity { && pinReferenceEntity.pinGuid.valueOf() == targetPinEntity.PinId.valueOf() ); if (!linkFound) { - (this.LinkedTo ??= []).push(new PinReferenceEntity({ - objectName: targetObjectName, - pinGuid: targetPinEntity.PinId, - })); + (this.LinkedTo ??= []).push(new PinReferenceEntity(targetObjectName, targetPinEntity.PinId,)); return true } return false // Already linked @@ -5612,9 +5737,9 @@ class MacroGraphReferenceEntity extends IEntity { constructor(values) { super(values); - /** @type {ObjectReferenceEntity} */ this.MacroGraph; - /** @type {ObjectReferenceEntity} */ this.GraphBlueprint; - /** @type {GuidEntity} */ this.GuidEntity; + /** @type {InstanceType} */ this.MacroGraph; + /** @type {InstanceType} */ this.GraphBlueprint; + /** @type {InstanceType} */ this.GraphGuid; } getMacroName() { @@ -5644,12 +5769,12 @@ class ScriptVariableEntity extends IEntity { ScriptVariable: ObjectReferenceEntity, OriginalChangeId: GuidEntity, } - static grammar = Grammar.createEntityGrammar(this) + static grammar = Grammar.createEntityGrammar(this).label("ScriptVariableEntity") constructor(values = {}) { super(values); - /** @type {ObjectReferenceEntity} */ this.ScriptVariable; - /** @type {GuidEntity} */ this.OriginalChangeId; + /** @type {InstanceType} */ this.ScriptVariable; + /** @type {InstanceType} */ this.OriginalChangeId; } } @@ -5667,7 +5792,7 @@ class UnknownPinEntity extends PinEntity { } attributes.forEach(attributeSetter => attributeSetter(values)); return new this(values) - }) + }).label("UnknownPinEntity") } class VariableReferenceEntity extends IEntity { @@ -5679,24 +5804,27 @@ class VariableReferenceEntity extends IEntity { MemberGuid: GuidEntity, bSelfContext: BooleanEntity, } - static grammar = Grammar.createEntityGrammar(this) + static grammar = Grammar.createEntityGrammar(this).label("VariableReferenceEntity") constructor(values) { super(values); - /** @type {String} */ this.MemberName; - /** @type {GuidEntity} */ this.GuidEntity; - /** @type {Boolean} */ this.bSelfContext; + /** @type {InstanceType} */ this.MemberScope; + /** @type {InstanceType} */ this.MemberName; + /** @type {InstanceType} */ this.MemberGuid; + /** @type {InstanceType} */ this.bSelfContext; } } class ObjectEntity extends IEntity { - #_exported = false - get _exported() { - return this.#_exported + static trailing = true + + #exported = false + get exported() { + return this.#exported } - set _exported(value) { - this.#_exported = value; + set exported(value) { + this.#exported = value; } static attributes = { @@ -5793,7 +5921,7 @@ class ObjectEntity extends IEntity { ScriptVariables: ArrayEntity.of(ScriptVariableEntity), Node: MirroredEntity$1.of(ObjectReferenceEntity), ExportedNodes: StringEntity, - CustomProperties: ArrayEntity.of(AlternativesEntity.accepting(PinEntity, UnknownPinEntity)), + CustomProperties: ArrayEntity.of(AlternativesEntity.accepting(PinEntity, UnknownPinEntity)).withDefault().flagSilent(), } static #nameRegex = /^(\w+?)(?:_(\d+))?$/ static customPropertyGrammar = Parsernostrum.seq( @@ -5807,28 +5935,28 @@ class ObjectEntity extends IEntity { Grammar.symbolQuoted.map(v => [v, true]), Grammar.symbol.map(v => [v, false]), ), - Parsernostrum.reg( - new RegExp(`\\s*\\(\\s*(\\d+)\\s*\\)\\s*\\=\\s*`), - 1 - ).map(Number) + Parsernostrum.reg(new RegExp(String.raw`\s*\(\s*(\d+)\s*\)\s*\=\s*`), 1).map(Number) ) .chain( - /** @param {[[String, Boolean], Number]} param */ + /** @param {[[keyof ObjectEntity.attributes, Boolean], Number]} param */ ([[symbol, quoted], index]) => - Grammar.grammarFor(this.attributes[symbol]) - .map(currentValue => - values => { - (values[symbol] ??= [])[index] = currentValue; - Utility.objectSet(values, ["attributes", symbol, "quoted"], quoted); - if (!this.attributes[symbol]?.inlined) { - if (!values.attributes) { - IEntity.defineAttributes(values, {}); - } - Utility.objectSet(values, ["attributes", symbol, "type"], [currentValue.constructor]); - Utility.objectSet(values, ["attributes", symbol, "inlined"], true); + this.attributes[symbol].grammar.map(currentValue => + values => { + if (values[symbol] === undefined) { + let arrayEntity = ArrayEntity; + if (quoted != arrayEntity.quoted) { + arrayEntity = arrayEntity.flagQuoted(quoted); } + if (!arrayEntity.inlined) { + arrayEntity = arrayEntity.flagInlined(); + } + values[symbol] = new arrayEntity(); } - ) + /** @type {ArrayEntity} */ + const target = values[symbol]; + target.values[index] = currentValue; + } + ) ) static grammar = this.createGrammar() @@ -5896,73 +6024,71 @@ class ObjectEntity extends IEntity { super(values); // Attributes - /** @type {(PinEntity | UnknownPinEntity)[]} */ this.CustomProperties; - /** @type {Boolean} */ this.bIsPureFunc; - /** @type {Boolean} */ this.isExported; - /** @type {FunctionReferenceEntity} */ this.ComponentPropertyName; - /** @type {FunctionReferenceEntity} */ this.EventReference; - /** @type {FunctionReferenceEntity} */ this.FunctionReference; - /** @type {IdentifierEntity} */ this.AdvancedPinDisplay; - /** @type {IdentifierEntity} */ this.EnabledState; - /** @type {IntegerEntity} */ this.NodeHeight; - /** @type {IntegerEntity} */ this.NodePosX; - /** @type {IntegerEntity} */ this.NodePosY; - /** @type {IntegerEntity} */ this.NodeWidth; - /** @type {LinearColorEntity} */ this.CommentColor; - /** @type {LinearColorEntity} */ this.NodeTitleColor; - /** @type {MacroGraphReferenceEntity} */ this.MacroGraphReference; - /** @type {MirroredEntity} */ this.MaterialExpressionEditorX; - /** @type {MirroredEntity} */ this.MaterialExpressionEditorY; - /** @type {MirroredEntity} */ this.SizeX; - /** @type {MirroredEntity} */ this.SizeY; - /** @type {MirroredEntity} */ this.Text; - /** @type {MirroredEntity} */ this.PositionX; - /** @type {MirroredEntity} */ this.PositionY; - /** @type {MirroredEntity} */ this.Node; - /** @type {null[]} */ this.PinTags; - /** @type {Number} */ this.NumAdditionalInputs; - /** @type {ObjectReferenceEntity[]} */ this.InputPins; - /** @type {ObjectReferenceEntity[]} */ this.OutputPins; - /** @type {ObjectReferenceEntity} */ this.Archetype; - /** @type {ObjectReferenceEntity} */ this.BlueprintElementInstance; - /** @type {ObjectReferenceEntity} */ this.BlueprintElementType; - /** @type {ObjectReferenceEntity} */ this.Class; - /** @type {ObjectReferenceEntity} */ this.Enum; - /** @type {ObjectReferenceEntity} */ this.ExportPath; - /** @type {ObjectReferenceEntity} */ this.FunctionScript; - /** @type {ObjectReferenceEntity} */ this.Graph; - /** @type {ObjectReferenceEntity} */ this.MaterialExpression; - /** @type {ObjectReferenceEntity} */ this.MaterialExpressionComment; - /** @type {ObjectReferenceEntity} */ this.MaterialFunction; - /** @type {ObjectReferenceEntity} */ this.ObjectRef; - /** @type {ObjectReferenceEntity} */ this.PCGNode; - /** @type {ObjectReferenceEntity} */ this.SettingsInterface; - /** @type {ObjectReferenceEntity} */ this.StructType; - /** @type {ObjectReferenceEntity} */ this.TargetType; - /** @type {ScriptVariableEntity[]} */ this.ScriptVariables; - /** @type {String[]} */ this.EnumEntries; - /** @type {String[]} */ this.PinNames; - /** @type {String} */ this.CustomFunctionName; - /** @type {String} */ this.DelegatePropertyName; - /** @type {String} */ this.ExportedNodes; - /** @type {String} */ this.FunctionDisplayName; - /** @type {String} */ this.InputName; - /** @type {String} */ this.Name; - /** @type {String} */ this.NodeComment; - /** @type {String} */ this.NodeTitle; - /** @type {String} */ this.Operation; - /** @type {String} */ this.OpName; - /** @type {String} */ this.ProxyFactoryFunctionName; - /** @type {String} */ this.SubgraphInstance; - /** @type {String} */ this.Text; - /** @type {SymbolEntity} */ this.AxisKey; - /** @type {SymbolEntity} */ this.HiGenGridSize; - /** @type {SymbolEntity} */ this.InputAxisKey; - /** @type {SymbolEntity} */ this.InputKey; - /** @type {SymbolEntity} */ this.InputType; - /** @type {UnknownPinEntity[]} */ this.AddedPins; - /** @type {VariableReferenceEntity} */ this.DelegateReference; - /** @type {VariableReferenceEntity} */ this.VariableReference; + /** @type {InstanceType} */ this.AddedPins; + /** @type {InstanceType} */ this.AdvancedPinDisplay; + /** @type {InstanceType} */ this.Archetype; + /** @type {InstanceType} */ this.AxisKey; + /** @type {InstanceType} */ this.bIsPureFunc; + /** @type {InstanceType} */ this.BlueprintElementInstance; + /** @type {InstanceType} */ this.BlueprintElementType; + /** @type {InstanceType} */ this.Class; + /** @type {InstanceType} */ this.CommentColor; + /** @type {InstanceType} */ this.ComponentPropertyName; + /** @type {InstanceType} */ this.CustomFunctionName; + /** @type {InstanceType} */ this.CustomProperties; + /** @type {InstanceType} */ this.DelegatePropertyName; + /** @type {InstanceType} */ this.DelegateReference; + /** @type {InstanceType} */ this.EnabledState; + /** @type {InstanceType} */ this.Enum; + /** @type {InstanceType} */ this.EnumEntries; + /** @type {InstanceType} */ this.EventReference; + /** @type {InstanceType} */ this.ExportedNodes; + /** @type {InstanceType} */ this.ExportPath; + /** @type {InstanceType} */ this.FunctionDisplayName; + /** @type {InstanceType} */ this.FunctionReference; + /** @type {InstanceType} */ this.FunctionScript; + /** @type {InstanceType} */ this.Graph; + /** @type {InstanceType} */ this.HiGenGridSize; + /** @type {InstanceType} */ this.InputAxisKey; + /** @type {InstanceType} */ this.InputKey; + /** @type {InstanceType} */ this.InputName; + /** @type {InstanceType} */ this.InputPins; + /** @type {InstanceType} */ this.InputType; + /** @type {InstanceType} */ this.MacroGraphReference; + /** @type {InstanceType} */ this.MaterialExpression; + /** @type {InstanceType} */ this.MaterialExpressionComment; + /** @type {InstanceType} */ this.MaterialExpressionEditorX; + /** @type {InstanceType} */ this.MaterialExpressionEditorY; + /** @type {InstanceType} */ this.MaterialFunction; + /** @type {InstanceType} */ this.Name; + /** @type {InstanceType} */ this.Node; + /** @type {InstanceType} */ this.NodeComment; + /** @type {InstanceType} */ this.NodeHeight; + /** @type {InstanceType} */ this.NodePosX; + /** @type {InstanceType} */ this.NodePosY; + /** @type {InstanceType} */ this.NodeTitle; + /** @type {InstanceType} */ this.NodeTitleColor; + /** @type {InstanceType} */ this.NodeWidth; + /** @type {InstanceType} */ this.NumAdditionalInputs; + /** @type {InstanceType} */ this.ObjectRef; + /** @type {InstanceType} */ this.Operation; + /** @type {InstanceType} */ this.OpName; + /** @type {InstanceType} */ this.OutputPins; + /** @type {InstanceType} */ this.PCGNode; + /** @type {InstanceType} */ this.PinNames; + /** @type {InstanceType} */ this.PositionX; + /** @type {InstanceType} */ this.PositionY; + /** @type {InstanceType} */ this.ProxyFactoryFunctionName; + /** @type {InstanceType} */ this.ScriptVariables; + /** @type {InstanceType} */ this.SettingsInterface; + /** @type {InstanceType} */ this.SizeX; + /** @type {InstanceType} */ this.SizeY; + /** @type {InstanceType} */ this.StructType; + /** @type {InstanceType} */ this.SubgraphInstance; + /** @type {InstanceType} */ this.TargetType; + /** @type {InstanceType} */ this.Text; + /** @type {InstanceType} */ this.Text; + /** @type {InstanceType} */ this.VariableReference; // Legacy nodes pins if (this["Pins"] instanceof Array) { @@ -6141,10 +6267,7 @@ class ObjectEntity extends IEntity { } getCustomproperties(canCreate = false) { - if (canCreate && !this.CustomProperties) { - this.CustomProperties = []; - } - return this.CustomProperties ?? [] + return this.CustomProperties.values } /** @returns {PinEntity[]} */ @@ -6275,6 +6398,46 @@ class ObjectEntity extends IEntity { additionalPinInserter() { return nodeVariadic(this) } + + /** @param {String} key */ + showProperty(key) { + switch (key) { + case "Class": + case "Name": + case "Archetype": + case "ExportPath": + case "CustomProperties": + // Serielized separately, check doWrite() + return false + } + return super.showProperty(key) + } + + toString( + insideString = false, + indentation = "", + printKey = this.Self().printKey, + ) { + const moreIndentation = indentation + Configuration.indentation; + let result = indentation + "Begin Object" + + (this.Class?.type || this.Class?.path ? ` Class=${this.Class.toString(insideString)}` : "") + + (this.Name ? ` Name=${this.Name.toString(insideString)}` : "") + + (this.Archetype ? ` Archetype=${this.Archetype.toString(insideString)}` : "") + + (this.ExportPath?.type || this.ExportPath?.path ? ` ExportPath=${this.ExportPath.toString(insideString)}` : "") + + "\n" + + super.toString(insideString, moreIndentation, k => this[k] instanceof ObjectEntity ? "" : k) + + (!this.CustomProperties.Self().ignored + ? this.getCustomproperties().map(pin => + moreIndentation + + printKey("CustomProperties ") + + pin.toString(insideString) + + this.Self().attributeSeparator + ).join("") + : "" + ) + + indentation + "End Object"; + return result + } } class KnotEntity extends ObjectEntity { @@ -6403,12 +6566,12 @@ class KeyBindingEntity extends IEntity { constructor() { super(); - /** @type {String} */ this.ActionName; - /** @type {Boolean} */ this.bShift; - /** @type {Boolean} */ this.bCtrl; - /** @type {Boolean} */ this.bAlt; - /** @type {Boolean} */ this.bCmd; - /** @type {IdentifierEntity} */ this.Key; + /** @type {InstanceType} */ this.ActionName; + /** @type {InstanceType} */ this.bShift; + /** @type {InstanceType} */ this.bCtrl; + /** @type {InstanceType} */ this.bAlt; + /** @type {InstanceType} */ this.bCmd; + /** @type {InstanceType} */ this.Key; } } @@ -9440,18 +9603,18 @@ class BlueprintEntity extends ObjectEntity { /** @param {ObjectEntity} entity */ mergeWith(entity) { - if (!entity.ScriptVariables || entity.ScriptVariables.length === 0) { + if (!entity.ScriptVariables || entity.ScriptVariables.values.length === 0) { return this } - if (!this.ScriptVariables || this.ScriptVariables.length === 0) { + if (!this.ScriptVariables || this.ScriptVariables.values.length === 0) { this.ScriptVariables = entity.ScriptVariables; } let scriptVariables = Utility.mergeArrays( - this.ScriptVariables, - entity.ScriptVariables, + this.ScriptVariables.values, + entity.ScriptVariables.values, (l, r) => l.OriginalChangeId.value == r.OriginalChangeId.value ); - if (scriptVariables.length === this.ScriptVariables.length) { + if (scriptVariables.length === this.ScriptVariables.values.length) { return this } const entries = scriptVariables.concat(scriptVariables).map((v, i) => { @@ -13047,7 +13210,6 @@ class TerminalTypeEntity extends IEntity { class UnknownKeysEntity extends IEntity { - static grammar = Parsernostrum.seq( // Lookbehind Parsernostrum.reg(new RegExp(`(${Grammar.Regex.Path.source}|${Grammar.Regex.Symbol.source}\\s*)?\\(\\s*`), 1), @@ -13067,7 +13229,7 @@ class UnknownKeysEntity extends IEntity { } attributes.forEach(attributeSetter => attributeSetter(values)); return new this(values) - }) + }).label("UnknownKeysEntity") constructor(values = {}) { super(values); @@ -13128,34 +13290,34 @@ class ToStringSerializer extends Serializer { } } -Grammar.unknownValue = - Parsernostrum.alt( - // Remember to keep the order, otherwise parsing might fail - BooleanEntity.grammar, - GuidEntity.grammar, - Parsernostrum.str("None").map(() => ObjectReferenceEntity.createNoneInstance()), - Grammar.null, - NumberEntity.grammar, - ObjectReferenceEntity.fullReferenceGrammar, - StringEntity.grammar, - LocalizedTextEntity.grammar, - InvariantTextEntity.grammar, - FormatTextEntity.grammar, - PinReferenceEntity.grammar, - Vector4DEntity.grammar, - VectorEntity.grammar, - RotatorEntity.grammar, - LinearColorEntity.grammar, - Vector2DEntity.grammar, - UnknownKeysEntity.grammar, - SymbolEntity.grammar, - ArrayEntity.of(PinReferenceEntity).grammar, - ArrayEntity.of(AlternativesEntity.accepting(NumberEntity, StringEntity, SymbolEntity)).grammar, - Parsernostrum.lazy(() => ArrayEntity.createGrammar(Grammar.unknownValue)), - ); - function initializeSerializerFactory() { + Grammar.unknownValue = + Parsernostrum.alt( + // Remember to keep the order, otherwise parsing might fail + BooleanEntity.grammar, + GuidEntity.grammar, + Parsernostrum.str("None").map(() => ObjectReferenceEntity.createNoneInstance()), + Grammar.null, + NumberEntity.grammar, + ObjectReferenceEntity.fullReferenceGrammar, + StringEntity.grammar, + LocalizedTextEntity.grammar, + InvariantTextEntity.grammar, + FormatTextEntity.grammar, + PinReferenceEntity.grammar, + Vector4DEntity.grammar, + VectorEntity.grammar, + RotatorEntity.grammar, + LinearColorEntity.grammar, + Vector2DEntity.grammar, + UnknownKeysEntity.grammar, + SymbolEntity.grammar, + ArrayEntity.of(PinReferenceEntity).grammar, + ArrayEntity.of(AlternativesEntity.accepting(NumberEntity, StringEntity, SymbolEntity)).grammar, + Parsernostrum.lazy(() => ArrayEntity.createGrammar(Grammar.unknownValue)), + ); + SerializerFactory.registerSerializer( null, new CustomSerializer( @@ -13201,26 +13363,6 @@ function initializeSerializerFactory() { ) ); - SerializerFactory.registerSerializer( - ByteEntity, - new ToStringSerializer(ByteEntity) - ); - - SerializerFactory.registerSerializer( - ColorChannelEntity, - new ToStringSerializer(ColorChannelEntity) - ); - - SerializerFactory.registerSerializer( - EnumDisplayValueEntity, - new ToStringSerializer(EnumDisplayValueEntity) - ); - - SerializerFactory.registerSerializer( - EnumEntity, - new ToStringSerializer(EnumEntity) - ); - SerializerFactory.registerSerializer( FormatTextEntity, new CustomSerializer( @@ -13235,94 +13377,11 @@ function initializeSerializerFactory() { FormatTextEntity) ); - SerializerFactory.registerSerializer( - FunctionReferenceEntity, - new Serializer(FunctionReferenceEntity, Serializer.bracketsWrapped) - ); - - SerializerFactory.registerSerializer( - GuidEntity, - new ToStringSerializer(GuidEntity) - ); - - SerializerFactory.registerSerializer( - IdentifierEntity, - new ToStringSerializer(IdentifierEntity) - ); - - SerializerFactory.registerSerializer( - Integer64Entity, - new ToStringSerializer(Integer64Entity) - ); - - SerializerFactory.registerSerializer( - IntegerEntity, - new ToStringSerializer(IntegerEntity) - ); - - SerializerFactory.registerSerializer( - InvariantTextEntity, - new Serializer(InvariantTextEntity, (entity, v) => `${entity.getLookbehind()}(${v})`, ", ", false, "", () => "") - ); - - SerializerFactory.registerSerializer( - KeyBindingEntity, - new Serializer(KeyBindingEntity, Serializer.bracketsWrapped) - ); - - SerializerFactory.registerSerializer( - LinearColorEntity, - new Serializer(LinearColorEntity, Serializer.bracketsWrapped) - ); - - SerializerFactory.registerSerializer( - LocalizedTextEntity, - new Serializer(LocalizedTextEntity, (entity, v) => `${entity.getLookbehind()}(${v})`, ", ", false, "", () => "") - ); - - SerializerFactory.registerSerializer( - MacroGraphReferenceEntity, - new Serializer(MacroGraphReferenceEntity, Serializer.bracketsWrapped) - ); - - SerializerFactory.registeOrSerializer( - MirroredEntity$1, - new CustomSerializer( - (v, insideString) => SerializerFactory.getSerializer(v.getTargetType()).write(v.get(), insideString), - MirroredEntity$1 - ) - ); - - SerializerFactory.registerSerializer( - Number, - new ToStringSerializer(Number) - ); - - SerializerFactory.registerSerializer( - ObjectEntity, - new ObjectSerializer() - ); - - SerializerFactory.registerSerializer( - ObjectReferenceEntity, - new ToStringSerializer(ObjectReferenceEntity, false) - ); - - SerializerFactory.registerSerializer( - PathSymbolEntity, - new ToStringSerializer(PathSymbolEntity) - ); - SerializerFactory.registerSerializer( PinEntity, new Serializer(PinEntity, (entity, v) => `${entity.getLookbehind()} (${v})`, ",", true) ); - SerializerFactory.registerSerializer( - PinReferenceEntity, - new Serializer(PinReferenceEntity, undefined, " ", false, "", () => "") - ); - SerializerFactory.registerSerializer( PinTypeEntity, new Serializer(PinTypeEntity) diff --git a/dist/ueblueprint.min.js b/dist/ueblueprint.min.js index 1cdd969..f513871 100644 --- a/dist/ueblueprint.min.js +++ b/dist/ueblueprint.min.js @@ -14,20 +14,20 @@ const e=window,t=e.ShadowRoot&&(void 0===e.ShadyCSS||e.ShadyCSS.nativeShadow)&&" * Copyright 2017 Google LLC * SPDX-License-Identifier: BSD-3-Clause */ -var v;b[g]=!0,b.elementProperties=new Map,b.elementStyles=[],b.shadowRootOptions={mode:"open"},null==h||h({ReactiveElement:b}),(null!==(o=l.reactiveElementVersions)&&void 0!==o?o:l.reactiveElementVersions=[]).push("1.6.3");const f=window,y=f.trustedTypes,w=y?y.createPolicy("lit-html",{createHTML:e=>e}):void 0,S="$lit$",E=`lit$${(Math.random()+"").slice(9)}$`,C="?"+E,N=`<${C}>`,x=document,P=()=>x.createComment(""),k=e=>null===e||"object"!=typeof e&&"function"!=typeof e,A=Array.isArray,L="[ \t\n\f\r]",M=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,T=/-->/g,I=/>/g,$=RegExp(`>|${L}(?:([^\\s"'>=/]+)(${L}*=${L}*(?:[^ \t\n\f\r"'\`<>=]|("|')|))|$)`,"g"),D=/'/g,B=/"/g,V=/^(?:script|style|textarea|title)$/i,H=(e=>(t,...i)=>({_$litType$:e,strings:t,values:i}))(1),O=Symbol.for("lit-noChange"),R=Symbol.for("lit-nothing"),G=new WeakMap,z=x.createTreeWalker(x,129,null,!1);function _(e,t){if(!Array.isArray(e)||!e.hasOwnProperty("raw"))throw Error("invalid template strings array");return void 0!==w?w.createHTML(t):t}const F=(e,t)=>{const i=e.length-1,s=[];let n,r=2===t?"":"",a=M;for(let t=0;t"===l[0]?(a=null!=n?n:M,u=-1):void 0===l[1]?u=-2:(u=a.lastIndex-l[2].length,o=l[1],a=void 0===l[3]?$:'"'===l[3]?B:D):a===B||a===D?a=$:a===T||a===I?a=M:(a=$,n=void 0);const h=a===$&&e[t+1].startsWith("/>")?" ":"";r+=a===M?i+N:u>=0?(s.push(o),i.slice(0,u)+S+i.slice(u)+E+h):i+E+(-2===u?(s.push(void 0),t):h)}return[_(e,r+(e[i]||"")+(2===t?"":"")),s]};class j{constructor({strings:e,_$litType$:t},i){let s;this.parts=[];let n=0,r=0;const a=e.length-1,o=this.parts,[l,u]=F(e,t);if(this.el=j.createElement(l,i),z.currentNode=this.el.content,2===t){const e=this.el.content,t=e.firstChild;t.remove(),e.append(...t.childNodes)}for(;null!==(s=z.nextNode())&&o.length0){s.textContent=y?y.emptyScript:"";for(let i=0;iA(e)||"function"==typeof(null==e?void 0:e[Symbol.iterator]))(e)?this.T(e):this._(e)}k(e){return this._$AA.parentNode.insertBefore(e,this._$AB)}$(e){this._$AH!==e&&(this._$AR(),this._$AH=this.k(e))}_(e){this._$AH!==R&&k(this._$AH)?this._$AA.nextSibling.data=e:this.$(x.createTextNode(e)),this._$AH=e}g(e){var t;const{values:i,_$litType$:s}=e,n="number"==typeof s?this._$AC(e):(void 0===s.el&&(s.el=j.createElement(_(s.h,s.h[0]),this.options)),s);if((null===(t=this._$AH)||void 0===t?void 0:t._$AD)===n)this._$AH.v(i);else{const e=new W(n,this),t=e.u(this.options);e.v(i),this.$(t),this._$AH=e}}_$AC(e){let t=G.get(e.strings);return void 0===t&&G.set(e.strings,t=new j(e)),t}T(e){A(this._$AH)||(this._$AH=[],this._$AR());const t=this._$AH;let i,s=0;for(const n of e)s===t.length?t.push(i=new K(this.k(P()),this.k(P()),this,this.options)):i=t[s],i._$AI(n),s++;s2||""!==i[0]||""!==i[1]?(this._$AH=Array(i.length-1).fill(new String),this.strings=i):this._$AH=R}get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}_$AI(e,t=this,i,s){const n=this.strings;let r=!1;if(void 0===n)e=U(this,e,t,0),r=!k(e)||e!==this._$AH&&e!==O,r&&(this._$AH=e);else{const s=e;let a,o;for(e=n[0],a=0;ae}):void 0,S="$lit$",E=`lit$${(Math.random()+"").slice(9)}$`,C="?"+E,N=`<${C}>`,x=document,P=()=>x.createComment(""),k=e=>null===e||"object"!=typeof e&&"function"!=typeof e,A=Array.isArray,L="[ \t\n\f\r]",M=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,T=/-->/g,I=/>/g,$=RegExp(`>|${L}(?:([^\\s"'>=/]+)(${L}*=${L}*(?:[^ \t\n\f\r"'\`<>=]|("|')|))|$)`,"g"),D=/'/g,V=/"/g,B=/^(?:script|style|textarea|title)$/i,O=(e=>(t,...i)=>({_$litType$:e,strings:t,values:i}))(1),H=Symbol.for("lit-noChange"),R=Symbol.for("lit-nothing"),G=new WeakMap,_=x.createTreeWalker(x,129,null,!1);function F(e,t){if(!Array.isArray(e)||!e.hasOwnProperty("raw"))throw Error("invalid template strings array");return void 0!==w?w.createHTML(t):t}const z=(e,t)=>{const i=e.length-1,s=[];let n,r=2===t?"":"",a=M;for(let t=0;t"===l[0]?(a=null!=n?n:M,u=-1):void 0===l[1]?u=-2:(u=a.lastIndex-l[2].length,o=l[1],a=void 0===l[3]?$:'"'===l[3]?V:D):a===V||a===D?a=$:a===T||a===I?a=M:(a=$,n=void 0);const h=a===$&&e[t+1].startsWith("/>")?" ":"";r+=a===M?i+N:u>=0?(s.push(o),i.slice(0,u)+S+i.slice(u)+E+h):i+E+(-2===u?(s.push(void 0),t):h)}return[F(e,r+(e[i]||"")+(2===t?"":"")),s]};class j{constructor({strings:e,_$litType$:t},i){let s;this.parts=[];let n=0,r=0;const a=e.length-1,o=this.parts,[l,u]=z(e,t);if(this.el=j.createElement(l,i),_.currentNode=this.el.content,2===t){const e=this.el.content,t=e.firstChild;t.remove(),e.append(...t.childNodes)}for(;null!==(s=_.nextNode())&&o.length0){s.textContent=y?y.emptyScript:"";for(let i=0;iA(e)||"function"==typeof(null==e?void 0:e[Symbol.iterator]))(e)?this.T(e):this._(e)}k(e){return this._$AA.parentNode.insertBefore(e,this._$AB)}$(e){this._$AH!==e&&(this._$AR(),this._$AH=this.k(e))}_(e){this._$AH!==R&&k(this._$AH)?this._$AA.nextSibling.data=e:this.$(x.createTextNode(e)),this._$AH=e}g(e){var t;const{values:i,_$litType$:s}=e,n="number"==typeof s?this._$AC(e):(void 0===s.el&&(s.el=j.createElement(F(s.h,s.h[0]),this.options)),s);if((null===(t=this._$AH)||void 0===t?void 0:t._$AD)===n)this._$AH.v(i);else{const e=new W(n,this),t=e.u(this.options);e.v(i),this.$(t),this._$AH=e}}_$AC(e){let t=G.get(e.strings);return void 0===t&&G.set(e.strings,t=new j(e)),t}T(e){A(this._$AH)||(this._$AH=[],this._$AR());const t=this._$AH;let i,s=0;for(const n of e)s===t.length?t.push(i=new K(this.k(P()),this.k(P()),this,this.options)):i=t[s],i._$AI(n),s++;s2||""!==i[0]||""!==i[1]?(this._$AH=Array(i.length-1).fill(new String),this.strings=i):this._$AH=R}get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}_$AI(e,t=this,i,s){const n=this.strings;let r=!1;if(void 0===n)e=U(this,e,t,0),r=!k(e)||e!==this._$AH&&e!==H,r&&(this._$AH=e);else{const s=e;let a,o;for(e=n[0],a=0;a{var s,n;const r=null!==(s=null==i?void 0:i.renderBefore)&&void 0!==s?s:t;let a=r._$litPart$;if(void 0===a){const e=null!==(n=null==i?void 0:i.renderBefore)&&void 0!==n?n:null;r._$litPart$=a=new K(t.insertBefore(P(),e),e,void 0,null!=i?i:{})}return a._$AI(e),a})(t,this.renderRoot,this.renderOptions)}connectedCallback(){var e;super.connectedCallback(),null===(e=this._$Do)||void 0===e||e.setConnected(!0)}disconnectedCallback(){var e;super.disconnectedCallback(),null===(e=this._$Do)||void 0===e||e.setConnected(!1)}render(){return O}}se.finalized=!0,se._$litElement$=!0,null===(te=globalThis.litElementHydrateSupport)||void 0===te||te.call(globalThis,{LitElement:se});const ne=globalThis.litElementPolyfillSupport;null==ne||ne({LitElement:se}),(null!==(ie=globalThis.litElementVersions)&&void 0!==ie?ie:globalThis.litElementVersions=[]).push("3.3.3");class re{static nodeColors={black:r``,blue:r``,darkBlue:r``,darkerBlue:r``,darkTurquoise:r``,gray:r``,green:r``,intenseGreen:r``,lime:r``,red:r``,turquoise:r``,violet:r``,yellow:r``};static alphaPattern="repeating-conic-gradient(#7c8184 0% 25%, #c2c3c4 0% 50%) 50% / 10px 10px";static colorDragEventName="ueb-color-drag";static colorPickEventName="ueb-color-pick";static colorWindowEventName="ueb-color-window";static colorWindowName="Color Picker";static defaultCommentHeight=96;static defaultCommentWidth=400;static distanceThreshold=5;static dragEventName="ueb-drag";static dragGeneralEventName="ueb-drag-general";static edgeScrollThreshold=50;static editTextEventName={begin:"ueb-edit-text-begin",end:"ueb-edit-text-end"};static expandGridSize=400;static focusEventName={begin:"blueprint-focus",end:"blueprint-unfocus"};static fontSize=r``;static gridAxisLineColor=r``;static gridExpandThreshold=.25;static gridLineColor=r``;static gridLineWidth=1;static gridSet=8;static gridSetLineColor=r``;static gridShrinkThreshold=4;static gridSize=16;static hexColorRegex=/^\s*#(?[0-9a-fA-F]{2})(?[0-9a-fA-F]{2})(?[0-9a-fA-F]{2})([0-9a-fA-F]{2})?|#(?[0-9a-fA-F])(?[0-9a-fA-F])(?[0-9a-fA-F])\s*$/;static indentation=" ";static keysSeparator=/[\.\(\)]/;static knotOffset=[-re.gridSize,-.5*re.gridSize];static lineTracePattern=/LineTrace(Single|Multi)(\w*)/;static linkCurveHeight=15;static linkCurveWidth=80;static linkMinWidth=100;static nameRegexSpaceReplacement=new RegExp("^K2(?:[Nn]ode)?_|(?<=[a-z])(?=[A-Z0-9])|(?<=[A-Z])(?{let s=100-e;return`M ${e} 0 C ${t.toFixed(3)} 0, ${i.toFixed(3)} 0, 50 50 S ${(s-t+e).toFixed(3)} 100, ${s.toFixed(3)} 100`};static maxZoom=7;static minZoom=-12;static mouseClickButton=0;static mouseRightClickButton=2;static mouseWheelZoomThreshold=80;static nodeDragEventName="ueb-node-drag";static nodeDragGeneralEventName="ueb-node-drag-general";static nodeTitle=(e,t)=>`${e}_${t}`;static nodeRadius=8;static nodeReflowEventName="ueb-node-reflow";static paths={actorBoundEvent:"/Script/BlueprintGraph.K2Node_ActorBoundEvent",addDelegate:"/Script/BlueprintGraph.K2Node_AddDelegate",ambientSound:"/Script/Engine.AmbientSound",asyncAction:"/Script/BlueprintGraph.K2Node_AsyncAction",blueprint:"/Script/Engine.Blueprint",blueprintGameplayTagLibrary:"/Script/GameplayTags.BlueprintGameplayTagLibrary",blueprintMapLibrary:"/Script/Engine.BlueprintMapLibrary",blueprintSetLibrary:"/Script/Engine.BlueprintSetLibrary",callArrayFunction:"/Script/BlueprintGraph.K2Node_CallArrayFunction",callDelegate:"/Script/BlueprintGraph.K2Node_CallDelegate",callFunction:"/Script/BlueprintGraph.K2Node_CallFunction",comment:"/Script/UnrealEd.EdGraphNode_Comment",commutativeAssociativeBinaryOperator:"/Script/BlueprintGraph.K2Node_CommutativeAssociativeBinaryOperator",componentBoundEvent:"/Script/BlueprintGraph.K2Node_ComponentBoundEvent",createDelegate:"/Script/BlueprintGraph.K2Node_CreateDelegate",customEvent:"/Script/BlueprintGraph.K2Node_CustomEvent",doN:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:Do N",doOnce:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:DoOnce",dynamicCast:"/Script/BlueprintGraph.K2Node_DynamicCast",eAttachmentRule:"/Script/Engine.EAttachmentRule",edGraph:"/Script/Engine.EdGraph",eDrawDebugTrace:"/Script/Engine.EDrawDebugTrace",eMaterialSamplerType:"/Script/Engine.EMaterialSamplerType",eNiagara_Float4Channel:"/Niagara/Enums/ENiagara_Float4Channel.ENiagara_Float4Channel",enum:"/Script/CoreUObject.Enum",enumLiteral:"/Script/BlueprintGraph.K2Node_EnumLiteral",eSamplerSourceMode:"/Script/Engine.ESamplerSourceMode",eSearchCase:"/Script/CoreUObject.ESearchCase",eSearchDir:"/Script/CoreUObject.ESearchDir",eSpawnActorCollisionHandlingMethod:"/Script/Engine.ESpawnActorCollisionHandlingMethod",eTextureMipValueMode:"/Script/Engine.ETextureMipValueMode",eTraceTypeQuery:"/Script/Engine.ETraceTypeQuery",event:"/Script/BlueprintGraph.K2Node_Event",executionSequence:"/Script/BlueprintGraph.K2Node_ExecutionSequence",flipflop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:FlipFlop",forEachElementInEnum:"/Script/BlueprintGraph.K2Node_ForEachElementInEnum",forEachLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ForEachLoop",forEachLoopWithBreak:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ForEachLoopWithBreak",forLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ForLoop",forLoopWithBreak:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ForLoopWithBreak",functionEntry:"/Script/BlueprintGraph.K2Node_FunctionEntry",functionResult:"/Script/BlueprintGraph.K2Node_FunctionResult",gameplayTag:"/Script/GameplayTags.GameplayTag",getInputAxisKeyValue:"/Script/BlueprintGraph.K2Node_GetInputAxisKeyValue",ifThenElse:"/Script/BlueprintGraph.K2Node_IfThenElse",inputAxisKeyEvent:"/Script/BlueprintGraph.K2Node_InputAxisKeyEvent",inputDebugKey:"/Script/InputBlueprintNodes.K2Node_InputDebugKey",inputKey:"/Script/BlueprintGraph.K2Node_InputKey",inputVectorAxisEvent:"/Script/BlueprintGraph.K2Node_InputVectorAxisEvent",isValid:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:IsValid",kismetArrayLibrary:"/Script/Engine.KismetArrayLibrary",kismetMathLibrary:"/Script/Engine.KismetMathLibrary",knot:"/Script/BlueprintGraph.K2Node_Knot",linearColor:"/Script/CoreUObject.LinearColor",literal:"/Script/BlueprintGraph.K2Node_Literal",macro:"/Script/BlueprintGraph.K2Node_MacroInstance",makeArray:"/Script/BlueprintGraph.K2Node_MakeArray",makeMap:"/Script/BlueprintGraph.K2Node_MakeMap",makeSet:"/Script/BlueprintGraph.K2Node_MakeSet",makeStruct:"/Script/BlueprintGraph.K2Node_MakeStruct",materialExpressionComponentMask:"/Script/Engine.MaterialExpressionComponentMask",materialExpressionConstant:"/Script/Engine.MaterialExpressionConstant",materialExpressionConstant2Vector:"/Script/Engine.MaterialExpressionConstant2Vector",materialExpressionConstant3Vector:"/Script/Engine.MaterialExpressionConstant3Vector",materialExpressionConstant4Vector:"/Script/Engine.MaterialExpressionConstant4Vector",materialExpressionFunctionInput:"/Script/Engine.MaterialExpressionFunctionInput",materialExpressionLogarithm:"/Script/InterchangeImport.MaterialExpressionLogarithm",materialExpressionLogarithm10:"/Script/Engine.MaterialExpressionLogarithm10",materialExpressionLogarithm2:"/Script/Engine.MaterialExpressionLogarithm2",materialExpressionMaterialFunctionCall:"/Script/Engine.MaterialExpressionMaterialFunctionCall",materialExpressionSquareRoot:"/Script/Engine.MaterialExpressionSquareRoot",materialExpressionTextureCoordinate:"/Script/Engine.MaterialExpressionTextureCoordinate",materialExpressionTextureSample:"/Script/Engine.MaterialExpressionTextureSample",materialGraphNode:"/Script/UnrealEd.MaterialGraphNode",materialGraphNodeComment:"/Script/UnrealEd.MaterialGraphNode_Comment",metasoundEditorGraphExternalNode:"/Script/MetasoundEditor.MetasoundEditorGraphExternalNode",multiGate:"/Script/BlueprintGraph.K2Node_MultiGate",niagaraBool:"/Script/Niagara.NiagaraBool",niagaraClipboardContent:"/Script/NiagaraEditor.NiagaraClipboardContent",niagaraDataInterfaceVolumeTexture:"/Script/Niagara.NiagaraDataInterfaceVolumeTexture",niagaraFloat:"/Script/Niagara.NiagaraFloat",niagaraMatrix:"/Script/Niagara.NiagaraMatrix",niagaraNodeFunctionCall:"/Script/NiagaraEditor.NiagaraNodeFunctionCall",niagaraNodeOp:"/Script/NiagaraEditor.NiagaraNodeOp",niagaraNumeric:"/Script/Niagara.NiagaraNumeric",niagaraPosition:"/Script/Niagara.NiagaraPosition",pawn:"/Script/Engine.Pawn",pcgEditorGraphNode:"/Script/PCGEditor.PCGEditorGraphNode",pcgEditorGraphNodeInput:"/Script/PCGEditor.PCGEditorGraphNodeInput",pcgEditorGraphNodeOutput:"/Script/PCGEditor.PCGEditorGraphNodeOutput",pcgHiGenGridSizeSettings:"/Script/PCG.PCGHiGenGridSizeSettings",pcgSubgraphSettings:"/Script/PCG.PCGSubgraphSettings",promotableOperator:"/Script/BlueprintGraph.K2Node_PromotableOperator",quat4f:"/Script/CoreUObject.Quat4f",reverseForEachLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ReverseForEachLoop",rotator:"/Script/CoreUObject.Rotator",select:"/Script/BlueprintGraph.K2Node_Select",self:"/Script/BlueprintGraph.K2Node_Self",slateBlueprintLibrary:"/Script/UMG.SlateBlueprintLibrary",spawnActorFromClass:"/Script/BlueprintGraph.K2Node_SpawnActorFromClass",switchEnum:"/Script/BlueprintGraph.K2Node_SwitchEnum",switchGameplayTag:"/Script/GameplayTagsEditor.GameplayTagsK2Node_SwitchGameplayTag",switchInteger:"/Script/BlueprintGraph.K2Node_SwitchInteger",switchName:"/Script/BlueprintGraph.K2Node_SwitchName",switchString:"/Script/BlueprintGraph.K2Node_SwitchString",timeline:"/Script/BlueprintGraph.K2Node_Timeline",timeManagementBlueprintLibrary:"/Script/TimeManagement.TimeManagementBlueprintLibrary",transform:"/Script/CoreUObject.Transform",userDefinedEnum:"/Script/Engine.UserDefinedEnum",variableGet:"/Script/BlueprintGraph.K2Node_VariableGet",variableSet:"/Script/BlueprintGraph.K2Node_VariableSet",vector:"/Script/CoreUObject.Vector",vector2D:"/Script/CoreUObject.Vector2D",vector3f:"/Script/CoreUObject.Vector3f",vector4f:"/Script/CoreUObject.Vector4f",whileLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:WhileLoop"};static pinInputWrapWidth=143;static removeEventName="ueb-element-delete";static scale={[-12]:.133333,[-11]:.166666,[-10]:.2,[-9]:.233333,[-8]:.266666,[-7]:.3,[-6]:.333333,[-5]:.375,[-4]:.5,[-3]:.675,[-2]:.75,[-1]:.875,0:1,1:1.25,2:1.375,3:1.5,4:1.675,5:1.75,6:1.875,7:2};static smoothScrollTime=1e3;static stringEscapedCharacters=/["\\]/g;static subObjectAttributeNamePrefix="#SubObject";static subObjectAttributeNameFromEntity=(e,t=!1)=>this.subObjectAttributeNamePrefix+(!t&&e.Class?`_${e.Class.type}`:"")+"_"+e.Name;static subObjectAttributeNameFromReference=(e,t=!1)=>this.subObjectAttributeNamePrefix+(t?"":"_"+e.type)+"_"+e.path;static subObjectAttributeNameFromName=e=>this.subObjectAttributeNamePrefix+"_"+e;static switchTargetPattern=/\/Script\/[\w\.\/\:]+K2Node_Switch([A-Z]\w+)+/;static trackingMouseEventName={begin:"ueb-tracking-mouse-begin",end:"ueb-tracking-mouse-end"};static unescapedBackslash=/(?<=(?:[^\\]|^)(?:\\\\)*)\\(?!\\)/;static windowApplyEventName="ueb-window-apply";static windowApplyButtonText="OK";static windowCancelEventName="ueb-window-cancel";static windowCancelButtonText="Cancel";static windowCloseEventName="ueb-window-close";static CommonEnums={[this.paths.eAttachmentRule]:["KeepRelative","KeepWorld","SnapToTarget"],[this.paths.eMaterialSamplerType]:["Color","Grayscale","Alpha","Normal","Masks","Distance Field Font","Linear Color","Linear Grayscale","Data","External","Virtual Color","Virtual Grayscale","Virtual Alpha","Virtual Normal","Virtual Mask","Virtual Linear Color","Virtual Linear Grayscal"],[this.paths.eNiagara_Float4Channel]:[["NewEnumerator0","R"],["NewEnumerator1","G"],["NewEnumerator2","B"],["NewEnumerator3","A"]],[this.paths.eSamplerSourceMode]:["From texture asset","Shared: Wrap","Shared: Clamp","Hidden"],[this.paths.eSpawnActorCollisionHandlingMethod]:[["Undefined","Default"],["AlwaysSpawn","Always Spawn, Ignore Collisions"],["AdjustIfPossibleButAlwaysSpawn","Try To Adjust Location, But Always Spawn"],["AdjustIfPossibleButDontSpawnIfColliding","Try To Adjust Location, Don't Spawn If Still Colliding"],["DontSpawnIfColliding","Do Not Spawn"]],[this.paths.eSearchCase]:["CaseSensitive","IgnoreCase"],[this.paths.eSearchDir]:["FromStart","FromEnd"],[this.paths.eDrawDebugTrace]:["None","ForOneFrame","ForDuration","Persistent"],[this.paths.eTextureMipValueMode]:["None (use computed mip level)","MipLevel (absolute, 0 is full resolution)","MipBias (relative to the computed mip level)","Derivative (explicit derivative to compute mip level)"],[this.paths.eTraceTypeQuery]:[["TraceTypeQuery1","Visibility"],["TraceTypeQuery2","Camera"]]};static ModifierKeys=["Ctrl","Shift","Alt","Meta"];static rgba=["R","G","B","A"];static Keys={Backspace:"Backspace",Tab:"Tab",LeftControl:"ControlLeft",RightControl:"ControlRight",LeftShift:"ShiftLeft",RightShift:"ShiftRight",LeftAlt:"AltLeft",RightAlt:"AltRight",Enter:"Enter",Pause:"Pause",CapsLock:"CapsLock",Escape:"Escape",Space:"Space",PageUp:"PageUp",PageDown:"PageDown",End:"End",Home:"Home",ArrowLeft:"ArrowLeft",ArrowUp:"ArrowUp",ArrowRight:"ArrowRight",ArrowDown:"ArrowDown",PrintScreen:"PrintScreen",Insert:"Insert",Delete:"Delete",Zero:"Digit0",One:"Digit1",Two:"Digit2",Three:"Digit3",Four:"Digit4",Five:"Digit5",Six:"Digit6",Seven:"Digit7",Eight:"Digit8",Nine:"Digit9",A:"KeyA",B:"KeyB",C:"KeyC",D:"KeyD",E:"KeyE",F:"KeyF",G:"KeyG",H:"KeyH",I:"KeyI",K:"KeyK",L:"KeyL",M:"KeyM",N:"KeyN",O:"KeyO",P:"KeyP",Q:"KeyQ",R:"KeyR",S:"KeyS",T:"KeyT",U:"KeyU",V:"KeyV",W:"KeyW",X:"KeyX",Y:"KeyY",Z:"KeyZ",NumPadZero:"Numpad0",NumPadOne:"Numpad1",NumPadTwo:"Numpad2",NumPadThree:"Numpad3",NumPadFour:"Numpad4",NumPadFive:"Numpad5",NumPadSix:"Numpad6",NumPadSeven:"Numpad7",NumPadEight:"Numpad8",NumPadNine:"Numpad9",Multiply:"NumpadMultiply",Add:"NumpadAdd",Subtract:"NumpadSubtract",Decimal:"NumpadDecimal",Divide:"NumpadDivide",F1:"F1",F2:"F2",F3:"F3",F4:"F4",F5:"F5",F6:"F6",F7:"F7",F8:"F8",F9:"F9",F10:"F10",F11:"F11",F12:"F12",NumLock:"NumLock",ScrollLock:"ScrollLock"}}class ae{static booleanConverter={fromAttribute:(e,t)=>{},toAttribute:(e,t)=>!0===e?"true":!1===e?"false":""};static sigmoid(e,t=1.7){return 1/(1+e/(1-e)**-t)}static sigmoidPositive(e,t=3.7,i=1.1){return 1-Math.exp(-((e/i)**t))}static clamp(e,t=-1/0,i=1/0){return Math.min(Math.max(e,t),i)}static getScale(e){const t=e.blueprint?.getScale()??getComputedStyle(e).getPropertyValue("--ueb-scale");return""!=t?parseFloat(t):1}static minDecimals(e,t=1,i=1e-8){const s=e*10**t;return Math.abs(s%1)>i?e.toString():e.toFixed(t)}static numberFromText(e=""){switch(e=e.toLowerCase()){case"zero":return 0;case"one":return 1;case"two":return 2;case"three":return 3;case"four":return 4;case"five":return 5;case"six":return 6;case"seven":return 7;case"eight":return 8;case"nine":return 9}}static roundDecimals(e,t=1){const i=10**t;return Math.round(e*i)/i}static printNumber(e){return e==Number.POSITIVE_INFINITY?"inf":e==Number.NEGATIVE_INFINITY?"-inf":ae.minDecimals(e)}static printExponential(e){if(e==Number.POSITIVE_INFINITY)return"inf";if(e==Number.NEGATIVE_INFINITY)return"-inf";const t=Math.round(e);if(t>=1e3){const i=Math.floor(Math.log10(t));return`${Math.round(e/10**(i-2))/100}e+${i<10?"0":""}${i}`}return 0==Math.floor(e)?e.toString():this.roundDecimals(e,Math.max(0,3-Math.floor(e).toString().length)).toString()}static approximatelyEqual(e,t,i=1e-8){return!(Math.abs(e-t)>i)}static convertLocation(e,t,i=!1){const s=i?1:1/ae.getScale(t),n=t.getBoundingClientRect();return[Math.round((e[0]-n.x)*s),Math.round((e[1]-n.y)*s)]}static isSerialized(e,t){return e.attributes?.[t]?.serialized??e.constructor.attributes?.[t]?.serialized??!1}static objectGet(e,t,i=void 0){if(void 0!==e){if(!(t instanceof Array))throw new TypeError("UEBlueprint: Expected keys to be an array");return 0!=t.length&&t[0]in e&&void 0!==e[t[0]]?1==t.length?e[t[0]]:ae.objectGet(e[t[0]],t.slice(1),i):i}}static objectSet(e,t,i,s=Object){if(!(t instanceof Array))throw new TypeError("Expected keys to be an array.");if(1==t.length){if(t[0]in e||void 0===e[t[0]])return e[t[0]]=i,!0}else if(t.length>0)return e[t[0]]instanceof Object||(e[t[0]]=new s),ae.objectSet(e[t[0]],t.slice(1),i,s);return!1}static equals(e,t){for(;e instanceof MirroredEntity;)e=e.get();for(;t instanceof MirroredEntity;)t=t.get();return e?.equals&&t?.equals?e.equals(t):(e=ae.sanitize(e),t=ae.sanitize(t),e?.constructor===BigInt&&t?.constructor===Number?t=BigInt(t):e?.constructor===Number&&t?.constructor===BigInt&&(e=BigInt(e)),e===t||e instanceof Array&&t instanceof Array&&(e.length===t.length&&e.every(((e,i)=>ae.equals(e,t[i])))))}static getType(e){return null===e?null:e?.constructor===Object&&e?.type instanceof Function?e.type:e?.constructor}static isValueOfType(e,t,i=!1){return t instanceof MirroredEntity&&(t=t.getTargetType()),i&&null===e||e instanceof t||e?.constructor===t}static snapToGrid(e,t,i){return 1===i?[e,t]:[i*Math.floor(e/i),i*Math.floor(t/i)]}static mergeArrays(e=[],t=[],i=((e,t)=>e==t)){let s=[];e=[...e],t=[...t];e:for(;;){for(let n=0;n|
/g,"\n").replaceAll(/(\)/g,"")}static encodeHTMLWhitespace(e){return e.replaceAll(" "," ")}static capitalFirstLetter(e){return 0===e.length?e:e.charAt(0).toUpperCase()+e.slice(1)}static formatStringName(e=""){return e.replace(/^\s*b(?=[A-Z])/,"").replaceAll(re.nameRegexSpaceReplacement," ").trim().split(" ").map((e=>ae.capitalFirstLetter(e))).join(" ")}static getIdFromReference(e){return e.replace(/(?:.+\.)?([^\.]+)$/,"$1").replaceAll(/(?<=[a-z\d])(?=[A-Z])|(?<=[a-zA-Z])(?=\d)|(?<=[A-Z]{2})(?=[A-Z][a-z])/g,"-").toLowerCase()}static getNameFromPath(e,t=!1){const i=t?/([^\.\/]+?)(?:_\d+)$/:/([^\.\/]+)$/;return e.match(i)?.[1]??""}static printLinearColor(e){return`${Math.round(255*e.R.valueOf())}, ${Math.round(255*e.G.valueOf())}, ${Math.round(255*e.B.valueOf())}`}static getPolarCoordinates(e,t,i=!1){let s=Math.atan2(t,e);return i&&s<0&&(s=2*Math.PI+s),[Math.sqrt(e*e+t*t),s]}static getCartesianCoordinates(e,t){return[e*Math.cos(t),e*Math.sin(t)]}static range(e=0,t=0,i=(t>=e?1:-1)){return Array.from({length:Math.ceil((t-e)/i)},((t,s)=>e+s*i))}static getFirstWordOrder(e){return new RegExp(/\s*/.source+e.join(/[^\n]+\n\s*/.source)+/\s*/.source)}static paste(e,t){const i=new ClipboardEvent("paste",{bubbles:!0,cancelable:!0,clipboardData:new DataTransfer});i.clipboardData.setData("text",t),e.dispatchEvent(i)}static async copy(e){const t=new ClipboardEvent("copy",{bubbles:!0,cancelable:!0,clipboardData:new DataTransfer});e.dispatchEvent(t)}static animate(e,t,i,s,n=(e=>{}),r=(e=>{const t=e**3.5;return t/(t+(1-e)**3.5)})){let a;const o=l=>{void 0===a&&(a=l);let u=(l-a)/i;ae.approximatelyEqual(u,1)||u>1?u=1:n(requestAnimationFrame(o));const c=e+(t-e)*r(u);s(c)};n(requestAnimationFrame(o))}}class oe extends se{#e;get blueprint(){return this.#e}set blueprint(e){this.#e=e}#t;get entity(){return this.#t}set entity(e){this.#t=e}#i;get template(){return this.#i}isInitialized=!1;isSetup=!1;inputObjects=[];initialize(e,t){this.requestUpdate(),this.#t=e,this.#i=t,this.#i.initialize(this),this.isConnected&&this.updateComplete.then((()=>this.setup())),this.isInitialized=!0}connectedCallback(){super.connectedCallback(),this.blueprint=this.closest("ueb-blueprint"),this.isInitialized&&(this.requestUpdate(),this.updateComplete.then((()=>this.setup())))}disconnectedCallback(){super.disconnectedCallback(),this.isSetup&&this.updateComplete.then((()=>this.cleanup())),this.acknowledgeDelete()}createRenderRoot(){return this}setup(){this.template.setup(),this.isSetup=!0}cleanup(){this.template.cleanup(),this.isSetup=!1}willUpdate(e){super.willUpdate(e),this.template.willUpdate(e)}update(e){super.update(e),this.template.update(e)}render(){return this.template.render()}firstUpdated(e){super.firstUpdated(e),this.template.firstUpdated(e),this.template.inputSetup()}updated(e){super.updated(e),this.template.updated(e)}acknowledgeDelete(){let e=new CustomEvent(re.removeEventName);this.dispatchEvent(e)}isSameGraph(e){return this.blueprint&&this.blueprint==e?.blueprint}}class le extends oe{static properties={...super.properties,fromX:{type:Number,attribute:!1},fromY:{type:Number,attribute:!1},toX:{type:Number,attribute:!1},toY:{type:Number,attribute:!1}};constructor(){super(),this.fromX=0,this.fromY=0,this.toX=0,this.toY=0}setBothLocations([e,t]){this.fromX=e,this.fromY=t,this.toX=e,this.toY=t}addSourceLocation(e,t){this.fromX+=e,this.fromY+=t}addDestinationLocation(e,t){this.toX+=e,this.toY+=t}}class ue{static deleteNodes="Delete";static duplicateNodes="(bCtrl=True,Key=D)";static enableLinkDelete="LeftAlt";static enableZoomIn=["LeftControl","RightControl"];static selectAllNodes="(bCtrl=True,Key=A)"}class ce{static#s=new Map;static registerElement(e,t){ce.#s.set(e,t)}static getConstructor(e){return ce.#s.get(e)}}class he{static makeSuccess(e,t,i=null,s=0){return{status:!0,value:t,position:e,bestParser:i,bestPosition:s}}static makeFailure(e=0,t=null,i=0){return{status:!1,value:null,position:e,bestParser:t,bestPosition:i}}static makeContext(e=null,t=""){return{parsernostrum:e,input:t,highlighted:null}}static makePathNode(e,t=0,i=null){return{parent:i,current:e,index:t}}}class pe{static indentation=" ";static highlight="Last valid parser";Self;static frame(e,t="",i=""){t=e?"[ "+t+" ]":"";let s=e.split("\n");const n=Math.max(...s.map((e=>e.length))),r=n";const n=this.isVisited(i),r=this.isHighlighted(e,i);let a=n?"<...>":this.doToString(e,r?"":t,i,s);return r&&(a=pe.frame(a,pe.highlight,t)),a}doToString(e,t,i,s){return`${this.constructor.name} does not implement toString()`}}class de extends pe{#n;get value(){return this.#n}constructor(e){super(),this.#n=e}parse(e,t,i,s){i=this.makePath(i,s);const n=t+this.#n.length,r=e.input.substring(t,n);return this.#n===r?he.makeSuccess(n,this.#n,i,n):he.makeFailure()}doToString(e,t,i,s){return`"${this.value.replaceAll("\n","\\n").replaceAll('"','\\"')}"`}}class me extends pe{static instance=new me;parse(e,t,i,s){return i=this.makePath(i,s),he.makeSuccess(t,"",i,0)}doToString(e,t,i,s){return""}}class ge extends pe{#r;get parsers(){return this.#r}constructor(...e){super(),this.#r=e}parse(e,t,i,s){i=this.makePath(i,s);const n=he.makeSuccess(0,"");for(let s=0;sn.bestPosition&&(n.bestParser=r.bestParser,n.bestPosition=r.bestPosition),r.status)return n.value=r.value,n.position=r.position,n}return n.status=!1,n.value=null,n}doToString(e,t,i,s){if(2===this.#r.length&&this.#r[1]instanceof me){let s=this.#r[0].toString(e,t,i,0);return this.#r[0]instanceof de||(s="<"+s+">"),s+="?",s}const n=t+pe.indentation;let r="ALT<\n"+n+this.#r.map(((t,s)=>t.toString(e,n+" ".repeat(0===s?0:pe.indentation.length-2),i,s))).join("\n"+n+"| ")+"\n"+t+">";return r}}class be extends pe{#a;get parser(){return this.#a}#o;constructor(e,t){super(),this.#a=e,this.#o=t}parse(e,t,i,s){i=this.makePath(i,s);const n=this.#a.parse(e,t,i,0);if(!n.status)return n;const r=this.#o(n.value,e.input,n.position).getParser().parse(e,n.position);return n.bestPosition>r.bestPosition&&(r.bestParser=n.bestParser,r.bestPosition=n.bestPosition),r}doToString(e,t,i,s){return this.#a.toString(e,t,i,0)+" => chained"}}class ve extends pe{static instance=new ve;parse(e,t,i,s){return he.makeFailure()}doToString(e,t,i,s){return""}}class fe extends pe{#a;get parser(){return this.#a}#l="";constructor(e,t){super(),this.#a=e,this.#l=t}makePath(e,t){return e}parse(e,t,i,s){return this.parse=this.#a.parse.bind(this.#a),this.parse(e,t,i,s)}doToString(e,t,i,s){let n=this.#a.toString(e,"",i,s);return n=pe.frame(n,this.#l,t),n}}class ye extends pe{#a;#u;constructor(e){super(),this.#a=e}makePath(e,t){return e}isHighlighted(e,t){if(super.isHighlighted(e,t)){const i={parent:t,parser:this.#u,index:0};e.highlighted=e.highlighted instanceof pe?this.#u:i}return!1}resolve(){return this.#u||(this.#u=this.#a().getParser()),this.#u}parse(e,t,i,s){return this.resolve(),this.parse=this.#u.parse.bind(this.#u),this.parse(e,t,i,s)}doToString(e,t,i,s){return this.resolve(),this.doToString=this.#u.toString.bind(this.#u),this.doToString(e,t,i,s)}}class we extends pe{#a;get parser(){return this.#a}#c;get type(){return this.#c}static Type={NEGATIVE_AHEAD:"?!",NEGATIVE_BEHIND:"?String.raw`[^${e}\\]*(?:\\.[^${e}\\]*)*`;static#g=/[-\+]?(?:\d*\.)?\d+/;static common={number:new RegExp(this.#g.source+String.raw`(?!\.)`),numberInteger:/[\-\+]?\d+(?!\.\d)/,numberNatural:/\d+/,numberExponential:new RegExp(this.#g.source+String.raw`(?:[eE][\+\-]?\d+)?(?!\.)`),numberUnit:/\+?(?:0(?:\.\d+)?|1(?:\.0+)?)(?![\.\d])/,numberByte:/0*(?:25[0-5]|2[0-4]\d|1?\d?\d)(?!\d|\.)/,whitespace:/\s+/,whitespaceOpt:/\s*/,whitespaceInline:/[^\S\n]+/,whitespaceInlineOpt:/[^\S\n]*/,whitespaceMultiline:/\s*?\n\s*/,doubleQuotedString:new RegExp(`"(${this.#m('"')})"`),singleQuotedString:new RegExp(`'(${this.#m("'")})'`),backtickQuotedString:new RegExp("`("+this.#m("`")+")`")};constructor(e,t){super(),this.#h=e,this.#p=new RegExp(`^(?:${e.source})`,e.flags),this.#d=t}parse(e,t,i,s){i=this.makePath(i,s);const n=this.#p.exec(e.input.substring(t));n&&(t+=n[0].length);return n?he.makeSuccess(t,this.#d(n),i,t):he.makeFailure()}doToString(e,t,i,s){let n="/"+this.#h.source+"/";const r=Object.entries(Se.common).find((([e,t])=>t.source===this.#h.source))?.[0];return r&&(n="P."+r),n}}class Ee extends pe{#a;get parser(){return this.#a}#b;get mapper(){return this.#b}constructor(e,t){super(),this.#a=e,this.#b=t}isHighlighted(e,t){if(super.isHighlighted(e,t)){const i={parent:t,parser:this.#a,index:0};e.highlighted=e.highlighted instanceof pe?this.#a:i}return!1}parse(e,t,i,s){i=this.makePath(i,s);const n=this.#a.parse(e,t,i,0);return n.status&&(n.value=this.#b(n.value)),n}doToString(e,t,i,s){let n=this.#a.toString(e,t,i,0);if(this.#a instanceof Se&&Object.values(Se.common).includes(this.#a.regexp))return this.#a.regexp===Se.common.numberInteger&&this.#b===BigInt?"P.numberBigInteger":n;let r=this.#b.toString();return(r.length>60||r.includes("\n"))&&(r="(...) => { ... }"),n+=` -> map<${r}>`,n}}class Ce extends Se{static#b=e=>e;constructor(e){super(e,Ce.#b)}}class Ne extends Se{constructor(e,t=0){super(e,(e=>e[t]))}}class xe extends pe{#r;get parsers(){return this.#r}constructor(...e){super(),this.#r=e}parse(e,t,i,s){i=this.makePath(i,s);const n=new Array(this.#r.length),r=he.makeSuccess(t,n);for(let t=0;tr.bestPosition&&(r.bestParser=s.bestParser,r.bestPosition=s.bestPosition),!s.status){r.status=!1,r.value=null;break}r.value[t]=s.value,r.position=s.position}return r}doToString(e,t,i,s){const n=t+pe.indentation,r="SEQ<\n"+n+this.#r.map(((t,s)=>t.toString(e,n,i,s))).join("\n"+n)+"\n"+t+">";return r}}class Pe extends pe{#a;get parser(){return this.#a}#v;get min(){return this.#v}#f;get max(){return this.#f}constructor(e,t=0,i=Number.POSITIVE_INFINITY){if(super(),t>i)throw new Error("Min is greater than max");this.#a=e,this.#v=t,this.#f=i}parse(e,t,i,s){i=this.makePath(i,s);const n=he.makeSuccess(t,[],i);for(let t=0;tn.bestPosition&&(n.bestParser=s.bestParser,n.bestPosition=s.bestPosition),!s.status){te;static#w=([e,t])=>t;static#S=([e,t])=>[e,...t];static#E=e=>e instanceof Array?e.join(""):e;static#m=e=>String.raw`[^${e}\\]*(?:\\.[^${e}\\]*)*`;static number=this.reg(Se.common.number).map(Number);static numberInteger=this.reg(Se.common.numberInteger).map(Number);static numberBigInteger=this.reg(this.numberInteger.getParser().parser.regexp).map(BigInt);static numberNatural=this.reg(Se.common.numberNatural).map(Number);static numberExponential=this.reg(Se.common.numberExponential).map(Number);static numberUnit=this.reg(Se.common.numberUnit).map(Number);static numberByte=this.reg(Se.common.numberByte).map(Number);static whitespace=this.reg(Se.common.whitespace);static whitespaceOpt=this.reg(Se.common.whitespaceOpt);static whitespaceInline=this.reg(Se.common.whitespaceInline);static whitespaceInlineOpt=this.reg(Se.common.whitespaceInlineOpt);static whitespaceMultiline=this.reg(Se.common.whitespaceMultiline);static doubleQuotedString=this.reg(Se.common.doubleQuotedString,1);static singleQuotedString=this.reg(Se.common.singleQuotedString,1);static backtickQuotedString=this.reg(Se.common.backtickQuotedString,1);constructor(e,t=!1){this.#a=e}static#C(e){const t=[];for(;e;)t.push(e),e=e.parent;t.reverse();let i=new Map;for(let e=1;ei<=s||i>e))),i.set(t[e].current,s),t.splice(s+1,e-s),e=s):i.set(t[e].current,e)}return t[t.length-1]}getParser(){return this.#a}run(e){const t=this.#a.parse(he.makeContext(this,e),0,he.makePathNode(),0);return t.position!==e.length&&(t.status=!1),t}parse(e,t=!0){const i=this.run(e);if(i.status)return i.value;const s=[Math.ceil(30),Math.floor(30)],n=ke.lineColumnFromOffset(e,i.bestPosition);let r=i.bestPosition;const a=e.replaceAll(/^(\s)+|\s{6,}|\s*?\n\s*/g,((e,t,s)=>{let n=t?"...":" ... ";return s<=i.bestPosition&&(i.bestPosition0&&(c="..."+c,u+=3),s[1]e.getParser()))));return t}static alt(...e){return new this(new ge(...e.map((e=>e.getParser()))))}static lookahead(e){return new this(new we(e.getParser(),we.Type.POSITIVE_AHEAD))}static lazy(e){return new this(new ye(e))}times(e,t=e){return new ke(new Pe(this.#a,e,t))}many(){return this.times(0,Number.POSITIVE_INFINITY)}atLeast(e){return this.times(e,Number.POSITIVE_INFINITY)}atMost(e){return this.times(0,e)}opt(){return ke.alt(this,ke.success())}sepBy(e,t=!1){return ke.seq(this,ke.seq(e,this).map(ke.#w).many()).map(ke.#S)}skipSpace(){return ke.seq(this,ke.whitespaceOpt).map(ke.#y)}map(e){return new ke(new Ee(this.#a,e))}chain(e){return new ke(new be(this.#a,e))}assert(e){return this.chain(((t,i,s)=>e(t,i,s)?ke.success().map((()=>t)):ke.failure()))}join(e=""){return this.map(ke.#E)}label(e=""){return new ke(new fe(this.#a,e))}toString(e="",t=!1,i=null){i instanceof ke&&(i=i.getParser());const s=he.makeContext(this,"");s.highlighted=i;const n=he.makePathNode();return(t?"\n"+e:"")+this.#a.toString(s,e,n)}}class Ae{static#N={nullable:!1,ignored:!1,serialized:!1,expected:!1,inlined:!1,quoted:!1,silent:!1,uninitialized:!1};constructor(e){this.type=e.type??e.default?.constructor,this.default=e.default,this.nullable=e.nullable??null===e.default,this.ignored=e.ignored,this.serialized=e.serialized,this.expected=e.expected,this.inlined=e.inlined,this.quoted=e.quoted,this.silent=e.silent,this.uninitialized=e.uninitialized,this.predicate=e.predicate,this.type===Array&&this.default instanceof Array&&this.default.length>0&&(this.type=this.default.map((e=>e.constructor)).reduce(((e,t)=>(e.includes(t)||e.push(t),e)),[]))}static createType(e){return new Ae({type:e})}static createValue(e){return new Ae({default:e})}static hasAttribute(e,t,i,s=e.constructor){const n=e,r=n.attributes[t]?.[i];return r??s?.attributes?.[t]?.[i]??Ae.#N[i]}static getAttribute(e,t,i,s=e.constructor){let n=e.attributes?.[t]?.[i];return void 0!==n?n:(n=(s?.attributes)?.[t]?.[i],void 0!==n?n:(n=Ae.#N[i],void 0!==n?n:void 0))}get(e){return this[e]??Ae.#N[e]}}class Le{static same=e=>e;static notWrapped=(e,t)=>t;static bracketsWrapped=(e,t)=>`(${t})`;static wrap=this.notWrapped;static attributeSeparator=",";static trailingSeparator=!1;static printKey=e=>e;static grammar=ke.failure();static attributes={};static lookbehind="";#x=this.Self().lookbehind;get lookbehind(){return this.#x}set lookbehind(e){throw this.#x=e}#P;get keys(){return this.#P??Object.keys(this.Self().attributes)}set keys(e){this.#P=[...new Set(e)]}static default;static nullable=!1;static ignored=!1;static serialized=!1;static expected=!1;static inlined=!1;static quoted=!1;static silent=!1;static uninitialized=!1;constructor(e={}){const t=ae.mergeArrays(Object.keys(e.attributes),Object.keys(this.Self().attributes));for(const i of t){if(void 0!==e[i]){this[i]=e[i];continue}const t=this.Self().attributes[i];void 0===t.default||(this[i]=t.default(t))}}showProperty(e){let t=this[e];const i=t.Self();if(i.silent&&void 0!==i.default){void 0===i["#default"]&&(i["#default"]=i.default(i));const e=i["#default"];return!t.equals(e)}return!0}static asUniqueClass(){return this.name.length?class extends(this){}:this}static withDefault(e=(e=>new e)){const t=this.asUniqueClass();return t.default=e,t}static flagNullable(e=!0){const t=this.asUniqueClass();return t.nullable=e,t}static flagSerialized(e=!0){const t=this.asUniqueClass();return t.serialized=e,t}static flagInlined(e=!0){const t=this.asUniqueClass();return t.inlined=e,t}static flagSilent(e=!0){const t=this.asUniqueClass();return t.silent=e,t}Self(){return this.constructor}listenAttribute(e,t){const i=Object.getOwnPropertyDescriptor(this,e),s=i.set;s?(i.set=e=>{s(e),t(e)},Object.defineProperties(this,{[e]:i})):i.value&&Object.defineProperties(this,{["#"+e]:{value:i.value,writable:!0,enumerable:!1},[e]:{enumerable:!0,get(){return this["#"+e]},set(i){i!=this["#"+e]&&(t(i),this["#"+e]=i)}}})}equals(e){const t=Object.keys(this),i=Object.keys(e);if(t.length!=i.length)return!1;for(let s=0;si(`${a}.${e}`)));continue}let l=i(a);l.length&&(s.quoted&&(l=`"${l}"`),n+=s.attributeSeparator.includes("\n")?t:"");let u=o.toString(e,t,i);s.serialized&&(u=`"${u.replaceAll(/(?<=(?:[^\\]|^)(?:\\\\)*?)"/,'\\"')}"`),n+=u}return s.trailingSeparator&&n.length&&(n+=s.attributeSeparator),s.wrap(this,n)}}class Me extends Le{static type;constructor(e=null){super(),this.getter=e}static of(e){const t=this.asUniqueClass();return t.type=e,t.grammar=t.getTargetType().grammar.map((e=>new this)),t}static getTargetType(){const e=this.type;return e.prototype instanceof Me?e.getTargetType():e}toString(){return this.getter().toString()}}class Te{static grammar=ke.failure()}class Ie{static separatedBy=(e,t,i=1)=>new RegExp(e+"(?:"+t+e+")"+(1===i?"*":2===i?"+":`{${i},}`));static Regex=class{static HexDigit=/[0-9a-fA-F]/;static InsideString=/(?:[^"\\]|\\.)*/;static InsideSingleQuotedString=/(?:[^'\\]|\\.)*/;static Integer=/[\-\+]?\d+(?!\d|\.)/;static Number=/[-\+]?(?:\d*\.)?\d+(?!\d|\.)/;static RealUnit=/\+?(?:0(?:\.\d+)?|1(?:\.0+)?)(?![\.\d])/;static Word=Ie.separatedBy("[a-zA-Z]","_");static Symbol=/[a-zA-Z_]\w*/;static DotSeparatedSymbols=Ie.separatedBy(this.Symbol.source,"\\.");static MultipleWordsSymbols=Ie.separatedBy(this.Symbol.source,"(?:\\.|\\ +)");static PathFragment=Ie.separatedBy(this.Symbol.source,"[\\.:]");static PathSpaceFragment=Ie.separatedBy(this.Symbol.source,"[\\.:\\ ]");static Path=new RegExp(`(?:\\/${this.PathFragment.source}){2,}`)};static null=ke.reg(/\(\s*\)/).map((()=>null));static true=ke.reg(/true/i).map((()=>!0));static false=ke.reg(/false/i).map((()=>!1));static number=ke.regArray(new RegExp(`(${ke.number.getParser().parser.regexp.source})|(\\+?inf)|(-inf)`)).map((([e,t,i,s])=>t?Number(t):i?Number.POSITIVE_INFINITY:Number.NEGATIVE_INFINITY));static bigInt=ke.reg(new RegExp(ke.number.getParser().parser.regexp.source)).map(BigInt).map((e=>void 0!==e[2]?Number.POSITIVE_INFINITY:void 0!==e[3]?Number.NEGATIVE_INFINITY:Number(e[1])));static naturalNumber=ke.lazy((()=>ke.reg(/\d+/).map(Number)));static string=ke.doubleQuotedString.map((e=>ae.unescapeString(e)));static colorValue=ke.numberByte;static word=ke.reg(Ie.Regex.Word);static symbol=ke.reg(Ie.Regex.Symbol);static symbolQuoted=ke.reg(new RegExp('"('+Ie.Regex.Symbol.source+')"'),1);static attributeName=ke.reg(Ie.Regex.DotSeparatedSymbols);static attributeNameQuoted=ke.reg(new RegExp('"('+Ie.Regex.InsideString.source+')"'),1);static guid=ke.reg(new RegExp(`${Ie.Regex.HexDigit.source}{32}`));static commaSeparation=ke.reg(/\s*,\s*(?!\))/);static commaOrSpaceSeparation=ke.reg(/\s*,\s*(?!\))|\s+/);static equalSeparation=ke.reg(/\s*=\s*/);static hexColorChannel=ke.reg(new RegExp(Ie.Regex.HexDigit.source+"{2}"));static grammarFor(e,t=e?.type,i=this.unknownValue){let s=i;if(t===Array||t instanceof Array){if(e?.inlined)return this.grammarFor(void 0,t[0]);s=ke.seq(ke.reg(/\(\s*/),this.grammarFor(void 0,t[0]).sepBy(this.commaSeparation).opt(),ke.reg(/\s*(?:,\s*)?\)/)).map((([e,t,i])=>t instanceof Array?t:[]))}else if(t instanceof Union)s=t.values.map((e=>this.grammarFor(void 0,e))).reduce(((e,t)=>t&&t!==this.unknownValue&&e!==this.unknownValue?ke.alt(e,t):this.unknownValue));else{if(t instanceof Me)return this.grammarFor(void 0,t.getTargetType()).map((e=>new Me(t.type,(()=>e))));if(e?.constructor===Object)s=this.grammarFor(void 0,t);else switch(t){case Boolean:s=this.boolean;break;case null:s=this.null;break;case Number:s=this.number;break;case BigInt:s=this.bigInt;break;case String:s=this.string;break;default:t?.prototype instanceof Te&&(s=t.grammar)}}return e&&(e.serialized&&t.constructor!==String&&(s=s==this.unknownValue?this.string:ke.seq(ke.str('"'),s,ke.str('"')).map((([e,t,i])=>t))),e.nullable&&(s=ke.alt(s,this.null))),s}static getAttribute(e,t){let i,s;if(e instanceof Union)for(let s of e.values)if(i=this.getAttribute(s,t))return i;return e instanceof Le.constructor?(i=e.attributes[t[0]],s=i?.type):e instanceof Array&&(i=e[t[0]],s=i),t.length>1?this.getAttribute(s,t.slice(1)):i}static createAttributeGrammar(e,t=this.attributeName,i=this.equalSeparation,s=((e,t,i)=>{})){return ke.seq(t,i).chain((([t,i])=>{const n=t.split(re.keysSeparator),r=this.getAttribute(e,n);return this.grammarFor(r).map((e=>t=>{s(t,n,e),ae.objectSet(t,n,e)}))}))}static createEntityGrammar(e,t=!0,i=this.commaSeparation){const s=e.attributes.lookbehind.default;return ke.seq(ke.reg(s instanceof Union?new RegExp(`(${s.values.reduce(((e,t)=>e+"|"+t))})\\s*\\(\\s*`):s.constructor==String&&s.length>0?new RegExp(`(${s})\\s*\\(\\s*`):/()\(\s*/,1),this.createAttributeGrammar(e).sepBy(i),ke.reg(/\s*(?:,\s*)?\)/)).map((([e,t,i])=>{let s={};return t.forEach((e=>e(s))),e.length&&(s.lookbehind=e),s})).chain((i=>{let s=Object.keys(i);if(Object.keys(e.attributes).filter((t=>e.attributes[t].expected)).find((e=>!s.includes(e)&&e)))return ke.failure();const n=Object.keys(i).filter((t=>!(t in e.attributes))).length;return!t&&n>0?ke.failure():ke.success().map((()=>new e(i)))}))}static unknownValue}class $e extends Le{static grammar=ke.number.map((e=>new this(e)));constructor(e=0){super(),this.value=e}valueOf(){return this.value}toString(){return this.value.toFixed(6)}}class De extends Le{static attributes={...super.attributes,R:$e.withDefault(),G:$e.withDefault(),B:$e.withDefault(),A:$e.withDefault((e=>new e(1)))};static grammar=Ie.createEntityGrammar(this,!1);#k=new $e;get H(){return this.#k}set H(e){this.#k=e}#A=new $e;get S(){return this.#k}set S(e){this.#k=e}#L=new $e;get V(){return this.#k}set V(e){this.#k=e}static linearToSRGB(e){return e<=0?0:e>=1?1:e<.0031308?12.92*e:1.055*Math.pow(e,1/2.4)-.055}static sRGBtoLinear(e){return e<=0?0:e>=1?1:e<.04045?e/12.92:Math.pow((e+.055)/1.055,2.4)}static getWhite(){return new De({R:1,G:1,B:1})}static getLinearColorFromHexGrammar(){const e=/[0-9a-fA-F]/;return ke.regArray(new RegExp("#("+e.source+"{2})("+e.source+"{2})("+e.source+"{2})("+e.source+"{2})?")).map((([e,t,i,s,n])=>new this({R:parseInt(t,16)/255,G:parseInt(i,16)/255,B:parseInt(s,16)/255,A:parseInt(n??"FF",16)/255})))}static getLinearColorRGBListGrammar(){return ke.seq(ke.numberByte,Ie.commaSeparation,ke.numberByte,Ie.commaSeparation,ke.numberByte).map((([e,t,i,s,n])=>new this({R:e/255,G:i/255,B:n/255,A:1})))}static getLinearColorRGBGrammar(){return ke.seq(ke.reg(/rgb\s*\(\s*/),this.getLinearColorRGBListGrammar(),ke.reg(/\s*\)/)).map((([e,t,i])=>t))}static getLinearColorRGBAGrammar(){return ke.seq(ke.reg(/rgba\s*\(\s*/),this.getLinearColorRGBListGrammar(),ke.reg(/\s*\)/)).map((([e,t,i])=>t))}static getLinearColorFromAnyFormat(){return ke.alt(this.getLinearColorFromHexGrammar(),this.getLinearColorRGBAGrammar(),this.getLinearColorRGBGrammar(),this.getLinearColorRGBListGrammar())}constructor(e){super(e),e instanceof Array&&(e={R:e[0]??0,G:e[1]??0,B:e[2]??0,A:e[3]??1}),this.R,this.G,this.B,this.A,this.#M()}#M(){const e=this.R.value,t=this.G.value,i=this.B.value;if(ae.approximatelyEqual(e,t)&&ae.approximatelyEqual(e,i)&&ae.approximatelyEqual(t,i))return this.S.value=0,void(this.V.value=e);const s=Math.max(e,t,i),n=Math.min(e,t,i),r=s-n;let a;switch(s){case n:a=0;break;case e:a=(t-i)/r+(te.toString(16).toUpperCase().padStart(2,"0"))).join("")}toSRGBAString(){return this.toSRGBA().map((e=>e.toString(16).toUpperCase().padStart(2,"0"))).join("")}toHSVA(){return[this.H.value,this.S.value,this.V.value,this.A.value]}toNumber(){return(Math.round(255*this.R.value)<<24)+(Math.round(255*this.G.value)<<16)+(Math.round(255*this.B.value)<<8)+Math.round(255*this.A.value)}setFromRGBANumber(e){this.A.value=(255&e)/255,this.B.value=(e>>8&255)/255,this.G.value=(e>>16&255)/255,this.R.value=(e>>24&255)/255,this.#M()}setFromSRGBANumber(e){this.A.value=(255&e)/255,this.B.value=De.sRGBtoLinear((e>>8&255)/255),this.G.value=De.sRGBtoLinear((e>>16&255)/255),this.R.value=De.sRGBtoLinear((e>>24&255)/255),this.#M()}toArray(){return[this.R.value,this.G.value,this.B.value,this.A.value]}toString(){return ae.printLinearColor(this)}}class Be{static arrayPin=H``;static branchNode=H``;static breakStruct=H``;static cast=H``;static close=H``;static convert=H``;static correct=H``;static delegate=H``;static doN=H``;static doOnce=H``;static enum=H``;static event=H``;static execPin=H``;static expandIcon=H``;static flipflop=H``;static forEachLoop=H``;static functionSymbol=H``;static gamepad=H``;static genericPin=H``;static keyboard=H``;static loop=H``;static macro=H``;static mapPin=H``;static makeArray=H``;static makeMap=H``;static makeSet=H``;static makeStruct=H``;static metasoundFunction=H``;static mouse=H``;static node=H``;static operationPin=H``;static pcgStackPin=H``;static pcgPin=H``;static pcgParamPin=H``;static pcgSpatialPin=H``;static plusCircle=H``;static questionMark=H``;static referencePin=H``;static reject=H``;static setPin=H``;static select=H``;static sequence=H``;static sound=H``;static spawnActor=H``;static switch=H``;static timer=H``;static touchpad=H``}const Ve=/\/Script\/SequencerScripting\.MovieSceneScripting(.+)Channel/,He={A_AccentGrave:"à",Add:"Num +",C_Cedille:"ç",Decimal:"Num .",Divide:"Num /",E_AccentAigu:"é",E_AccentGrave:"è",F1:"F1",F10:"F10",F11:"F11",F12:"F12",F2:"F2",F3:"F3",F4:"F4",F5:"F5",F6:"F6",F7:"F7",F8:"F8",F9:"F9",Gamepad_Special_Left_X:"Touchpad Button X Axis",Gamepad_Special_Left_Y:"Touchpad Button Y Axis",Mouse2D:"Mouse XY 2D-Axis",Multiply:"Num *",Section:"§",Subtract:"Num -",Tilde:"`"};function Oe(e){let t;switch(e.getType()){case re.paths.asyncAction:if(e.ProxyFactoryFunctionName)return ae.formatStringName(e.ProxyFactoryFunctionName);case re.paths.actorBoundEvent:case re.paths.componentBoundEvent:return`${ae.formatStringName(e.DelegatePropertyName)} (${e.ComponentPropertyName??"Unknown"})`;case re.paths.callDelegate:return`Call ${e.DelegateReference?.MemberName??"None"}`;case re.paths.createDelegate:return"Create Event";case re.paths.customEvent:if(e.CustomFunctionName)return e.CustomFunctionName;case re.paths.dynamicCast:return e.TargetType?`Cast To ${e.TargetType?.getName()}`:"Bad cast node";case re.paths.enumLiteral:return`Literal enum ${e.Enum?.getName()}`;case re.paths.event:return`Event ${(e.EventReference?.MemberName??"").replace(/^Receive/,"")}`;case re.paths.executionSequence:return"Sequence";case re.paths.forEachElementInEnum:return`For Each ${e.Enum?.getName()}`;case re.paths.forEachLoopWithBreak:return"For Each Loop with Break";case re.paths.functionEntry:return"UserConstructionScript"===e.FunctionReference?.MemberName?"Construction Script":e.FunctionReference?.MemberName;case re.paths.functionResult:return"Return Node";case re.paths.ifThenElse:return"Branch";case re.paths.makeStruct:if(e.StructType)return`Make ${e.StructType.getName()}`;case re.paths.materialExpressionComponentMask:{const t=e.getMaterialSubobject();return`Mask ( ${re.rgba.filter((e=>!0===t[e].get())).map((e=>e+" ")).join("")})`}case re.paths.materialExpressionConstant:t??=[e.getCustomproperties().find((e=>"Value"==e.PinName))?.DefaultValue];case re.paths.materialExpressionConstant2Vector:t??=[e.getCustomproperties().find((e=>"X"==e.PinName))?.DefaultValue,e.getCustomproperties().find((e=>"Y"==e.PinName))?.DefaultValue];case re.paths.materialExpressionConstant3Vector:if(!t){const i=e.getCustomproperties().find((e=>"Constant"==e.PinName))?.DefaultValue;t=[i.X,i.Y,i.Z]}case re.paths.materialExpressionConstant4Vector:if(!t){const i=e.getCustomproperties().find((e=>"Constant"==e.PinName))?.DefaultValue;t=[i.R,i.G,i.B,i.A].map((e=>e.valueOf()))}if(t.length>0)return t.map((e=>ae.printExponential(e))).reduce(((e,t)=>e+","+t));break;case re.paths.materialExpressionFunctionInput:{const t=e.getMaterialSubobject();return`Input ${t?.InputName??"In"} (${t?.InputType?.value.match(/^.+?_(\w+)$/)?.[1]??"Vector3"})`}case re.paths.materialExpressionLogarithm:return"Ln";case re.paths.materialExpressionLogarithm10:return"Log10";case re.paths.materialExpressionLogarithm2:return"Log2";case re.paths.materialExpressionMaterialFunctionCall:const i=e.getMaterialSubobject()?.MaterialFunction;if(i)return i.getName();break;case re.paths.materialExpressionSquareRoot:return"Sqrt";case re.paths.metasoundEditorGraphExternalNode:{const t=e.ClassName?.Name;if(t)return"Add"===t?"+":t}case re.paths.pcgEditorGraphNodeInput:return"Input";case re.paths.pcgEditorGraphNodeOutput:return"Output";case re.paths.spawnActorFromClass:let s=e.getCustomproperties().find((e=>"ReturnValue"==e.PinName))?.PinType?.PinSubCategoryObject?.getName();return"Actor"===s&&(s=null),`SpawnActor ${ae.formatStringName(s??"NONE")}`;case re.paths.switchEnum:return`Switch on ${e.Enum?.getName()??"Enum"}`;case re.paths.switchInteger:return"Switch on Int";case re.paths.variableGet:return"";case re.paths.variableSet:return"SET"}let i=e.switchTarget();if(i)return"E"!==i[0]&&(i=ae.formatStringName(i)),`Switch on ${i}`;if(e.isComment())return e.NodeComment;const s=e.getHIDAttribute();if(s){const t=s.toString();let i=function(e){let t=He[e];if(t)return t;if(t=ae.numberFromText(e)?.toString(),t)return t;const i=e.match(/NumPad([a-zA-Z]+)/);return i&&(t=ae.numberFromText(i[1]).toString(),t)?"Num "+t:void 0}(t)??ae.formatStringName(t);return e.getClass()===re.paths.inputDebugKey?i="Debug Key "+i:e.getClass()===re.paths.getInputAxisKeyValue&&(i="Get "+i),i}if(e.getClass()===re.paths.macro)return ae.formatStringName(e.MacroGraphReference?.getMacroName());if(e.isMaterial()&&e.getMaterialSubobject()){let t=Oe(e.getMaterialSubobject());return t=t.match(/Material Expression (.+)/)?.[1]??t,t}if(e.isPcg()&&e.getPcgSubobject()){let t=e.getPcgSubobject();return t.NodeTitle?t.NodeTitle:Oe(t)}const n=e.getSubgraphObject();if(n)return n.Graph.getName();const r=e.getSettingsObject();if(r){if(r.ExportPath.type===re.paths.pcgHiGenGridSizeSettings)return`Grid Size: ${r.HiGenGridSize?.toString().match(/\d+/)?.[0]?.concat("00")??r.HiGenGridSize?.toString().match(/^\w+$/)?.[0]??"256"}`;if(r.BlueprintElementInstance)return ae.formatStringName(r.BlueprintElementType.getName());if(r.Operation){const e=r.Name.match(/PCGMetadata(\w+)Settings_\d+/);if(e)return ae.formatStringName(e[1]+": "+r.Operation)}const e=r.getSubgraphObject();if(e&&e.Graph)return e.Graph.getName()}let a=e.FunctionReference?.MemberName;if(a){const t=e.FunctionReference.MemberParent?.path??"";switch(a){case"AddKey":let e=t.match(Ve);if(e)return`Add Key (${ae.formatStringName(e[1])})`;case"Concat_StrStr":return"Append"}const i=a.match(re.lineTracePattern);if(i)return"Line Trace"+("Multi"===i[1]?" Multi ":" ")+(""===i[2]?"By Channel":ae.formatStringName(i[2]));switch(t){case re.paths.blueprintGameplayTagLibrary:case re.paths.kismetMathLibrary:case re.paths.slateBlueprintLibrary:case re.paths.timeManagementBlueprintLibrary:const e=a.match(/[BF]([A-Z]\w+)/);switch(e&&(a=e[1]),a){case"Abs":return"ABS";case"BooleanAND":return"AND";case"BooleanNAND":return"NAND";case"BooleanOR":return"OR";case"Exp":return"e";case"LineTraceSingle":return"Line Trace By Channel";case"Max":case"MaxInt64":return"MAX";case"Min":case"MinInt64":return"MIN";case"Not_PreBool":return"NOT";case"Sin":return"SIN";case"Sqrt":return"SQRT";case"Square":return"^2";case"CrossProduct2D":return"cross";case"Vector4_CrossProduct3":return"cross3";case"DotProduct2D":case"Vector4_DotProduct":return"dot";case"Vector4_DotProduct3":return"dot3"}if(a.startsWith("Add_"))return"+";if(a.startsWith("And_"))return"&";if(a.startsWith("Conv_"))return"";if(a.startsWith("Cross_"))return"cross";if(a.startsWith("Divide_"))return String.fromCharCode(247);if(a.startsWith("Dot_"))return"dot";if(a.startsWith("EqualEqual_"))return"==";if(a.startsWith("Greater_"))return">";if(a.startsWith("GreaterEqual_"))return">=";if(a.startsWith("Less_"))return"<";if(a.startsWith("LessEqual_"))return"<=";if(a.startsWith("Multiply_"))return String.fromCharCode(10799);if(a.startsWith("Not_"))return"~";if(a.startsWith("NotEqual_"))return"!=";if(a.startsWith("Or_"))return"|";if(a.startsWith("Percent_"))return"%";if(a.startsWith("Subtract_"))return"-";if(a.startsWith("Xor_"))return"^";break;case re.paths.blueprintSetLibrary:{const e=a.match(/Set_(\w+)/);if(e)return ae.formatStringName(e[1]).toUpperCase()}break;case re.paths.blueprintMapLibrary:{const e=a.match(/Map_(\w+)/);if(e)return ae.formatStringName(e[1]).toUpperCase()}break;case re.paths.kismetArrayLibrary:{const e=a.match(/Array_(\w+)/);if(e)return e[1].toUpperCase()}}return ae.formatStringName(a)}if(e.OpName){switch(e.OpName){case"Boolean::LogicAnd":return"Logic AND";case"Boolean::LogicEq":return"==";case"Boolean::LogicNEq":return"!=";case"Boolean::LogicNot":return"Logic NOT";case"Boolean::LogicOr":return"Logic OR";case"Matrix::MatrixMultiply":return"Multiply (Matrix * Matrix)";case"Matrix::MatrixVectorMultiply":return"Multiply (Matrix * Vector4)";case"Numeric::Abs":return"Abs";case"Numeric::Add":return"+";case"Numeric::DistancePos":return"Distance";case"Numeric::Mul":return String.fromCharCode(10799)}return ae.formatStringName(e.OpName).replaceAll("::"," ")}return e.FunctionDisplayName?ae.formatStringName(e.FunctionDisplayName):e.ObjectRef?e.ObjectRef.getName():ae.formatStringName(e.getNameAndCounter()[0])}var Re;"undefined"==typeof window?import("crypto").then((e=>Re=e.default)).catch():Re=window.crypto;class Ge extends Le{static grammar=ke.reg(/[0-9a-fA-F]{32}/).map((e=>new this(e)));static generateGuid(){let e=new Uint32Array(4);Re.getRandomValues(e);let t="";return e.forEach((e=>{t+=("0".repeat(8)+e.toString(16).toUpperCase()).slice(-8)})),t}constructor(e=Ge.generateGuid()){super(),this.value=e}valueOf(){return this.value}toString(){return this.value}}const ze={[re.paths.niagaraBool]:r``,[re.paths.niagaraDataInterfaceVolumeTexture]:r``,[re.paths.niagaraFloat]:r``,[re.paths.niagaraMatrix]:r``,[re.paths.niagaraNumeric]:r``,[re.paths.niagaraPosition]:r``,[re.paths.quat4f]:r``,[re.paths.rotator]:r``,[re.paths.transform]:r``,[re.paths.vector]:r``,[re.paths.vector3f]:r``,[re.paths.vector4f]:r``,Any:r``,"Any[]":r``,audio:r``,blue:r``,bool:r``,byte:r``,class:r``,default:r``,delegate:r``,enum:r``,exec:r``,float:r``,green:r``,int:r``,int32:r``,int64:r``,interface:r``,name:r``,object:r``,Param:r``,"Param[]":r``,Point:r``,"Point[]":r``,real:r``,red:r``,string:r``,struct:r``,Surface:r``,"Surface[]":r``,text:r``,time:r``,Volume:r``,"Volume[]":r``,wildcard:r``},_e=r``;class Fe extends Le{static alternatives=[];static createGrammar(){return this.alternatives.map((e=>e.grammar)).reduce(((e,t)=>t&&t!==Ie.unknownValue&&e!==Ie.unknownValue?ke.alt(e,t):Ie.unknownValue))}static accepting(...e){const t=this.asUniqueClass();return t.alternatives=e,t.grammar=t.createGrammar(),t}}class je extends Le{static type;constructor(e=[]){super(),this.values=e}static createGrammar(e=this.type.grammar){return this.inlined?e:ke.seq(ke.reg(/\(\s*/),e.sepBy(Ie.commaSeparation).opt(),ke.reg(/\s*(?:,\s*)?\)/)).map((([e,t,i])=>new this(t instanceof Array?t:[])))}static of(e){const t=this.asUniqueClass();return t.type=e,this.grammar=t.createGrammar(),t}valueOf(){return this.values}}class Ue extends Le{static grammar=ke.regArray(/(true)|false/i).map((e=>e[1]?new this(!0):new this(!1)));constructor(e=!1){super(),this.value=e}valueOf(){return this.value}toString(){return this.value.toString()}}class We extends Le{static grammar=ke.regArray(new RegExp(`(${ke.number.getParser().parser.regexp.source})|(\\+?inf)|(-inf)`)).map((([e,t,i,s])=>new this(t?Number(t):i?Number.POSITIVE_INFINITY:Number.NEGATIVE_INFINITY)));#n;get value(){return this.#n}set value(e){-0===e&&(e=0),this.#n=e}constructor(e=0){super(),this.value=e}valueOf(){return this.value}toString(){return this.value.toString()}}class Ke extends We{static grammar=ke.numberInteger.map((e=>new this(e)));set value(e){e>=-(1<<31)&&e<1<<31&&(e=Math.floor(e),super.value=e)}}class Ye extends Ke{static grammar=ke.numberByte.map((e=>new this(e)));set value(e){e%1==0&&e>=0&&e<256&&(super.value=e)}}class Xe extends Le{static f;static from(e){const t=this.asUniqueClass();return t.f=e,t}compute(e){return this.Self().f(e)}}class qe extends Le{static grammar=Ie.symbol.map((e=>new this(e)));constructor(e=""){super(),this.value=e}valueOf(){return this.value}toString(){return this.value}}class Ze extends qe{static grammar=Ie.symbol.map((e=>new this(e)))}class Qe extends Ze{static grammar=ke.reg(Ie.Regex.InsideString).map((e=>new this(e)))}class Je extends Le{static lookbehind="INVTEXT";static grammar=ke.alt(ke.seq(ke.reg(new RegExp(`${this.lookbehind}\\s*\\(`)),ke.doubleQuotedString,ke.reg(/\s*\)/)).map((([e,t,i])=>new this(t))),ke.reg(new RegExp(this.lookbehind)).map((()=>new this))).map((e=>new this(e)));constructor(e=""){super(),this.value=e}toString(){return this.value}}class et extends Le{static lookbehind="NSLOCTEXT";static grammar=ke.regArray(new RegExp(String.raw`${this.attributes.lookbehind.default}\s*\(`+String.raw`\s*"(${Ie.Regex.InsideString.source})"\s*,`+String.raw`\s*"(${Ie.Regex.InsideString.source})"\s*,`+String.raw`\s*"(${Ie.Regex.InsideString.source})"\s*`+String.raw`(?:,\s+)?`+String.raw`\)`,"m")).map((e=>new this(ae.unescapeString(e[1]),ae.unescapeString(e[2]),ae.unescapeString(e[3]))));#T;get namespace(){return this.#T}set namespace(e){this.#T=e}#I;get key(){return this.#I}set key(e){this.#I=e}#n;get value(){return this.#n}set value(e){this.#n=e}constructor(e="",t="",i=""){super(),this.namespace=e,this.key=t,this.value=i}toString(){return ae.capitalFirstLetter(this.value)}}class tt extends Le{static grammar=ke.doubleQuotedString.map((e=>ae.unescapeString(e)));constructor(e=""){super(),this.value=e}valueOf(){return this.value}toString(){return this.value.toString()}}class it extends Le{static lookbehind=["LOCGEN_FORMAT_NAMED","LOCGEN_FORMAT_ORDERED"];static grammar=ke.seq(ke.reg(new RegExp(String.raw`(${this.lookbehind.reduce(((e,t)=>e+"|"+t))})\s*\(\s*)`),1),ke.alt(...[tt,et,Je,it].map((e=>e.grammar))).sepBy(ke.reg(/\s*\,\s*/)),ke.reg(/\s*\)/)).map((([e,t])=>{const i=new this(t);return i.lookbehind=e,i}));constructor(e){super(),this.values=e}toString(){const e=this.values?.[0]?.toString();if(!e)return"";const t=this.values.slice(1).map((e=>e.toString()));return"LOCGEN_FORMAT_NAMED"==this.lookbehind?e.replaceAll(/\{([a-zA-Z]\w*)\}/g,((e,i)=>{const s=t.indexOf(i)+1;return s>0&&s{const s=Number(i);return snew this(e)));#n;get value(){return this.#n}set value(e){e>=-(1n<<63n)&&e<1n<<63n&&(this.#n=e)}constructor(e=0n){super(),this.value=BigInt(e)}valueOf(){return this.value}toString(){return this.value.toString()}}class nt extends Le{static#$=ke.regArray(new RegExp(`'"(${Ie.Regex.InsideString.source})"'|'(${Ie.Regex.InsideSingleQuotedString.source})'`)).map((([e,t,i])=>t??i));static typeReference=ke.reg(new RegExp(Ie.Regex.Path.source+"|"+Ie.symbol.getParser().regexp.source));static fullReferenceGrammar=ke.regArray(new RegExp("("+this.typeReference.getParser().regexp.source+")(?:"+this.#$.getParser().parser.regexp.source+")")).map((([e,t,...i])=>new this(t,i.find((e=>e)),e)));static fullReferenceSerializedGrammar=ke.regArray(new RegExp('"('+Ie.Regex.InsideString.source+"?)(?:'("+Ie.Regex.InsideSingleQuotedString.source+"?)')?\"")).map((([e,t,i])=>new this(t,i,e)));static typeReferenceGrammar=this.typeReference.map((e=>new this(e,"",e)));static grammar=ke.alt(this.fullReferenceSerializedGrammar,this.fullReferenceGrammar,this.typeReferenceGrammar);#c;get type(){return this.#c}set type(e){this.#c=e}#D;get path(){return this.#D}set path(e){this.#D=e}#B;get full(){return this.#B}set full(e){this.#B=e}constructor(e="None",t="",i=null){super(),this.#c=e,this.#D=t,this.#B=i??`"${this.type+(this.path?`'${this.path}'`:"")}"`}static createNoneInstance(){return new nt("None")}getName(e=!1){return ae.getNameFromPath(this.path.replace(/_C$/,""),e)}toString(){return this.full}}class rt extends Le{static grammar=Ie.symbol.map((e=>new this(e)));constructor(e=""){super(),this.value=e}valueOf(){return this.value}toString(){return this.value.toString()}}class at extends Le{static grammar=ke.seq(rt.grammar,ke.whitespace,Ge.grammar).map((([e,t,i])=>new this(e,i)));constructor(e=null,t=null){super(),this.objectName=e,this.pinGuid=t}}class ot extends Le{static attributes={...super.attributes,MemberParent:nt,MemberName:tt,MemberGuid:Ge};static grammar=Ie.createEntityGrammar(this);constructor(e){super(e),this.MemberParent,this.MemberName,this.MemberGuid}}class lt extends Le{static attributes={...super.attributes,PinCategory:tt.withDefault(),PinSubCategory:tt.withDefault(),PinSubCategoryObject:nt.withDefault(),PinSubCategoryMemberReference:ot.withDefault((e=>null)),PinValueType:lt.withDefault(),ContainerType:rt,bIsReference:Ue.withDefault(),bIsConst:Ue.withDefault(),bIsWeakPointer:Ue.withDefault(),bIsUObjectWrapper:Ue.withDefault(),bSerializeAsSinglePrecisionFloat:Ue.withDefault()};static grammar=Ie.createEntityGrammar(this);constructor(e={}){super(e),this.PinCategory,this.PinSubCategory,this.PinSubCategoryObject,this.PinSubCategoryMemberReference,this.PinValueType,this.ContainerType,this.bIsReference,this.bIsConst,this.bIsWeakPointer,this.bIsUObjectWrapper,this.bIsUObjectWrapper,this.bSerializeAsSinglePrecisionFloat}copyTypeFrom(e){for(const t of this.keys)void 0!==e[t]&&(this[t]=e[t])}}class ut extends Le{static attributes={...super.attributes,X:We.withDefault(),Y:We.withDefault()};static grammar=Ie.createEntityGrammar(this,!1);constructor(e){super(e),this.X,this.Y}toArray(){return[this.X.valueOf(),this.Y.valueOf()]}}class ct extends ut{static grammar=ke.alt(ke.regArray(new RegExp(/X\s*=\s*/.source+"(?"+ke.number.getParser().parser.regexp.source+")\\s+"+/Y\s*=\s*/.source+"(?"+ke.number.getParser().parser.regexp.source+")")).map((({groups:{x:e,y:t}})=>new this({X:Number(e),Y:Number(t)}))),ut.grammar)}class ht extends Le{static attributes={...super.attributes,R:We.withDefault(),P:We.withDefault(),Y:We.withDefault()};static grammar=Ie.createEntityGrammar(this,!1);constructor(e){super(e),this.R,this.P,this.Y}getRoll(){return this.R}getPitch(){return this.P}getYaw(){return this.Y}}class pt extends ht{static grammar=ke.alt(ke.regArray(new RegExp(`(${ke.number.getParser().parser.regexp.source})`+String.raw`\s*,\s*`+`(${ke.number.getParser().parser.regexp.source})`+String.raw`\s*,\s*`+`(${ke.number.getParser().parser.regexp.source})`)).map((([e,t,i,s])=>new this({R:Number(s),P:Number(t),Y:Number(i)}))),ht.grammar)}class dt extends ut{static grammar=ke.alt(ke.regArray(new RegExp(`(${ke.number.getParser().parser.regexp.source})`+String.raw`\s*,\s*`+`(${ke.number.getParser().parser.regexp.source})`)).map((([e,t,i])=>new this({X:Number(t),Y:Number(i)}))),ut.grammar)}class mt extends Le{static attributes={...super.attributes,X:We.withDefault(),Y:We.withDefault(),Z:We.withDefault(),W:We.withDefault()};static grammar=Ie.createEntityGrammar(mt,!1);constructor(e){super(e),this.X,this.Y,this.Z,this.W}toArray(){return[this.X.valueOf(),this.Y.valueOf(),this.Z.valueOf(),this.W.valueOf()]}}class gt extends mt{static grammar=this.createGrammar();static createGrammar(){return ke.number.getParser().parser.regexp.source,ke.alt(ke.regArray(new RegExp(`(${ke.number.getParser().parser.regexp.source})`+String.raw`\s*,\s*`+`(${ke.number.getParser().parser.regexp.source})`+String.raw`\s*,\s*`+`(${ke.number.getParser().parser.regexp.source})`+String.raw`\s*,\s*`+`(${ke.number.getParser().parser.regexp.source})`)).map((([e,t,i,s,n])=>new this({X:Number(t),Y:Number(i),Z:Number(s),W:Number(n)}))),mt.grammar)}}class bt extends Le{static attributes={...super.attributes,X:We.withDefault(),Y:We.withDefault(),Z:We.withDefault()};static grammar=Ie.createEntityGrammar(bt,!1);constructor(e){super(e),this.X,this.Y,this.Z}toArray(){return[this.X.valueOf(),this.Y.valueOf(),this.Z.valueOf()]}}class vt extends bt{static grammar=ke.alt(ke.regArray(new RegExp(`(${ke.number.getParser().parser.regexp.source})`+String.raw`\s*,\s*`+`(${ke.number.getParser().parser.regexp.source})`+String.raw`\s*,\s*`+`(${ke.number.getParser().parser.regexp.source})`)).map((([e,t,i,s])=>new this({X:Number(t),Y:Number(i),Z:Number(s)}))),bt.grammar)}class ft extends Le{static lookbehind="INVTEXT";static#V={[re.paths.linearColor]:De,[re.paths.rotator]:ht,[re.paths.vector]:bt,[re.paths.vector2D]:ut,[re.paths.vector4f]:mt,bool:Ue,byte:Ye,enum:Ze,exec:tt,int:Ke,int64:st,name:tt,real:We,string:tt};static#H={enum:Qe,rg:ct,[re.paths.rotator]:pt,[re.paths.vector]:vt,[re.paths.vector2D]:dt,[re.paths.vector3f]:vt,[re.paths.vector4f]:gt};static attributes={...super.attributes,PinId:Ge.withDefault(),PinName:tt.withDefault(),PinFriendlyName:Fe.accepting(et,it,Je,tt),PinToolTip:tt,Direction:tt,PinType:lt.withDefault().flagInlined(),LinkedTo:je.of(at),SubPins:je.of(at),ParentPin:at,DefaultValue:Xe.from((e=>e.getEntityType(!0)??tt)).flagSerialized(),AutogeneratedDefaultValue:tt,DefaultObject:nt,PersistentGuid:Ge,bHidden:Ue.withDefault(),bNotConnectable:Ue.withDefault(),bDefaultValueIsReadOnly:Ue.withDefault(),bDefaultValueIsIgnored:Ue.withDefault(),bAdvancedView:Ue.withDefault(),bOrphanedPin:Ue.withDefault()};static grammar=Ie.createEntityGrammar(this);#O=!1;set recomputesNodeTitleOnChange(e){this.#O=e}get recomputesNodeTitleOnChange(){return this.#O}#R;get objectEntity(){return this.#R}set objectEntity(e){this.#R=e}#G;get pinIndex(){return this.#G}set pinIndex(e){this.#G=e}constructor(e={}){super(e),this.objectEntity,this.pinIndex,this.PinId,this.PinName,this.PinFriendlyName,this.PinToolTip,this.Direction,this.PinType,this.LinkedTo,this.DefaultValue,this.AutogeneratedDefaultValue,this.DefaultObject,this.PersistentGuid,this.bHidden,this.bNotConnectable,this.bDefaultValueIsReadOnly,this.bDefaultValueIsIgnored,this.bAdvancedView,this.bOrphanedPin}static fromLegacyObject(e){return new ft(e)}getType(){const e=this.PinType.PinCategory.toLocaleLowerCase();if("struct"===e||"class"===e||"object"===e||"type"===e)return this.PinType.PinSubCategoryObject.path;if(this.isEnum())return"enum";if(this.objectEntity?.isPcg()){const e=this.objectEntity.getPcgSubobject(),t=this.isInput()?e.InputPins?.[this.pinIndex]:e.OutputPins?.[this.pinIndex];if(t){const i=e[re.subObjectAttributeNameFromReference(t,!0)];let s=i.Properties?.AllowedTypes?.toString()??"";if(""==s&&(s=this.PinType.PinCategory??"",""==s&&(s="Any")),s)return!1!==i.Properties.bAllowMultipleData&&!1!==i.Properties.bAllowMultipleConnections&&(s+="[]"),s}}if("optional"===e)switch(this.PinType.PinSubCategory){case"red":return"real";case"rg":return"rg";case"rgb":return re.paths.vector;case"rgba":return re.paths.linearColor;default:return this.PinType.PinSubCategory}return e}getEntityType(e=!1){const t=this.getType(),i=ft.#V[t],s=ft.#H[t];return e&&void 0!==s?s:i}pinTitle(){return function(e){let t,i=e.PinFriendlyName?e.PinFriendlyName.toString():ae.formatStringName(e.PinName??"");return e.PinToolTip&&(t=e.PinToolTip.match(/\s*(.+?(?=\n)|.+\S)\s*/))&&t[1].toLowerCase()===i.toLowerCase()?t[1]:i}(this)}copyTypeFrom(e){this.PinType.PinCategory=e.PinType.PinCategory,this.PinType.PinSubCategory=e.PinType.PinSubCategory,this.PinType.PinSubCategoryObject=e.PinType.PinSubCategoryObject,this.PinType.PinSubCategoryMemberReference=e.PinType.PinSubCategoryMemberReference,this.PinType.PinValueType=e.PinType.PinValueType,this.PinType.ContainerType=e.PinType.ContainerType,this.PinType.bIsReference=e.PinType.bIsReference,this.PinType.bIsConst=e.PinType.bIsConst,this.PinType.bIsWeakPointer=e.PinType.bIsWeakPointer,this.PinType.bIsUObjectWrapper=e.PinType.bIsUObjectWrapper,this.PinType.bSerializeAsSinglePrecisionFloat=e.PinType.bSerializeAsSinglePrecisionFloat}getDefaultValue(e=!1){return void 0===this.DefaultValue&&e&&(this.DefaultValue=new(this.getEntityType(!0))),this.DefaultValue}isEnum(){const e=this.PinType.PinSubCategoryObject.type;return e===re.paths.enum||e===re.paths.userDefinedEnum||"enum"===e.toLowerCase()}isExecution(){return"exec"===this.PinType.PinCategory}isHidden(){return this.bHidden}isInput(){return!this.bHidden&&"EGPD_Output"!=this.Direction}isOutput(){return!this.bHidden&&"EGPD_Output"==this.Direction}isLinked(){return this.LinkedTo?.length>0??!1}linkTo(e,t){const i=this.LinkedTo?.some((i=>i.objectName.toString()==e&&i.pinGuid.valueOf()==t.PinId.valueOf()));return!i&&((this.LinkedTo??=[]).push(new at({objectName:e,pinGuid:t.PinId})),!0)}unlinkFrom(e,t){const i=this.LinkedTo?.findIndex((i=>i.objectName.toString()==e&&i.pinGuid.valueOf()==t.PinId.valueOf()));return i>=0&&(this.LinkedTo.splice(i,1),0===this.LinkedTo.length&&void 0===ft.attributes.LinkedTo.default&&(this.LinkedTo=void 0),!0)}getSubCategory(){return this.PinType.PinSubCategoryObject.path}pinColor(){return function(e){if("mask"==e.PinType.PinCategory){const t=ze[e.PinType.PinSubCategory];if(t)return t}else if("optional"==e.PinType.PinCategory)return _e;return ze[e.getType()]??ze[e.PinType.PinCategory.toLowerCase()]??ze.default}(this)}}const yt=e=>e.PinName.match(/^\s*([A-Z])\s*$/)?.[1]?.charCodeAt(0)-"A".charCodeAt(0);class wt extends Le{static attributeConverter={fromAttribute:(e,t)=>new wt(e),toAttribute:(e,t)=>e.toString()};static grammar=Ie.symbol.map((e=>new this(e)));constructor(e){super(),this.value=e}valueOf(){return this.value}toString(){return this.value.toString()}}class St extends Le{static attributes={...super.attributes,MacroGraph:nt,GraphBlueprint:nt,GraphGuid:Ge};static grammar=Ie.createEntityGrammar(this);constructor(e){super(e),this.MacroGraph,this.GraphBlueprint,this.GuidEntity}getMacroName(){const e=this.MacroGraph.path.search(":");return this.MacroGraph.path.substring(e+1)}}class Et extends Ke{static grammar=ke.numberNatural.map((e=>new this(e)));set value(e){e=Math.round(ae.clamp(this.value,0)),super.value=e}constructor(e=0){super(e)}}class Ct extends Le{static attributes={...super.attributes,ScriptVariable:nt,OriginalChangeId:Ge};static grammar=Ie.createEntityGrammar(this);constructor(e={}){super(e),this.ScriptVariable,this.OriginalChangeId}}class Nt extends ft{static grammar=ke.seq(ke.reg(new RegExp(`(${Ie.Regex.Symbol.source})\\s*\\(\\s*`),1),Ie.createAttributeGrammar(this).sepBy(Ie.commaSeparation),ke.reg(/\s*(?:,\s*)?\)/)).map((([e,t,i])=>{e??="";let s={};return e.length&&(s.lookbehind=e),t.forEach((e=>e(s))),new this(s)}))}class xt extends Le{static attributes={...super.attributes,MemberScope:tt,MemberName:tt.withDefault(),MemberGuid:Ge,bSelfContext:Ue};static grammar=Ie.createEntityGrammar(this);constructor(e){super(e),this.MemberName,this.GuidEntity,this.bSelfContext}}class Pt extends Le{#z=!1;get _exported(){return this.#z}set _exported(e){this.#z=e}static attributes={...super.attributes,Class:nt,Name:tt,Archetype:nt,ExportPath:nt,ObjectRef:nt,BlueprintElementType:nt,BlueprintElementInstance:nt,PinNames:je.of(tt).flagInlined(),AxisKey:qe,InputAxisKey:qe,InputName:tt,InputType:qe,NumAdditionalInputs:Et,bIsPureFunc:Ue,bIsConstFunc:Ue,bIsCaseSensitive:Ue,VariableReference:xt,SelfContextInfo:qe,DelegatePropertyName:tt,DelegateOwnerClass:nt,ComponentPropertyName:tt,EventReference:ot,FunctionReference:ot,FunctionScript:nt,CustomFunctionName:tt,TargetType:nt,MacroGraphReference:St,Enum:nt,EnumEntries:je.of(tt).flagInlined(),InputKey:qe,OpName:tt,CachedChangeId:Ge,FunctionDisplayName:tt,AddedPins:je.of(Nt).withDefault().flagInlined().flagSilent(),ChangeId:Ge,MaterialFunction:nt,bOverrideFunction:Ue,bInternalEvent:Ue,bConsumeInput:Ue,bExecuteWhenPaused:Ue,bOverrideParentBinding:Ue,bControl:Ue,bAlt:Ue,bShift:Ue,bCommand:Ue,CommentColor:De,bCommentBubbleVisible_InDetailsPanel:Ue,bColorCommentBubble:Ue,ProxyFactoryFunctionName:tt,ProxyFactoryClass:nt,ProxyClass:nt,StructType:nt,MaterialExpression:nt,MaterialExpressionComment:nt,MoveMode:qe,TimelineName:tt,TimelineGuid:Ge,SizeX:Me.of(Ke),SizeY:Me.of(Ke),Text:Me.of(tt),MaterialExpressionEditorX:Me.of(Ke),MaterialExpressionEditorY:Me.of(Ke),NodeTitle:tt,NodeTitleColor:De,PositionX:Me.of(Ke),PositionY:Me.of(Ke),SettingsInterface:nt,PCGNode:nt,HiGenGridSize:qe,Operation:qe,NodePosX:Ke,NodePosY:Ke,NodeHeight:Ke,NodeWidth:Ke,Graph:nt,SubgraphInstance:tt,InputPins:je.of(nt).flagInlined(),OutputPins:je.of(nt).flagInlined(),bExposeToLibrary:Ue,bCanRenameNode:Ue,bCommentBubblePinned:Ue,bCommentBubbleVisible:Ue,NodeComment:tt,AdvancedPinDisplay:wt,DelegateReference:xt,EnabledState:wt,NodeGuid:Ge,ErrorType:Ke,ErrorMsg:tt,ScriptVariables:je.of(Ct),Node:Me.of(nt),ExportedNodes:tt,CustomProperties:je.of(Fe.accepting(ft,Nt))};static#_=/^(\w+?)(?:_(\d+))?$/;static customPropertyGrammar=ke.seq(ke.reg(/CustomProperties\s+/),this.attributes.CustomProperties.type.grammar).map((([e,t])=>e=>{(e.CustomProperties??=[]).push(t)}));static inlinedArrayEntryGrammar=ke.seq(ke.alt(Ie.symbolQuoted.map((e=>[e,!0])),Ie.symbol.map((e=>[e,!1]))),ke.reg(new RegExp("\\s*\\(\\s*(\\d+)\\s*\\)\\s*\\=\\s*"),1).map(Number)).chain((([[e,t],i])=>Ie.grammarFor(this.attributes[e]).map((s=>n=>{(n[e]??=[])[i]=s,ae.objectSet(n,["attributes",e,"quoted"],t),this.attributes[e]?.inlined||(n.attributes||Le.defineAttributes(n,{}),ae.objectSet(n,["attributes",e,"type"],[s.constructor]),ae.objectSet(n,["attributes",e,"inlined"],!0))}))));static grammar=this.createGrammar();static createSubObjectGrammar(){return ke.lazy((()=>this.grammar)).map((e=>t=>t[re.subObjectAttributeNameFromEntity(e)]=e))}static createGrammar(){return ke.seq(ke.reg(/Begin +Object/),ke.seq(ke.whitespace,ke.alt(this.createSubObjectGrammar(),this.customPropertyGrammar,Ie.createAttributeGrammar(this,ke.reg(Ie.Regex.MultipleWordsSymbols)),Ie.createAttributeGrammar(this,Ie.attributeNameQuoted,void 0,((e,t,i)=>ae.objectSet(e,["attributes",...t,"quoted"],!0))),this.inlinedArrayEntryGrammar)).map((([e,t])=>t)).many(),ke.reg(/\s+End +Object/)).map((([e,t,i])=>{const s={};return t.forEach((e=>e(s))),new this(s)}))}static getMultipleObjectsGrammar(){return ke.seq(ke.whitespaceOpt,this.grammar,ke.seq(ke.whitespace,this.grammar).map((([e,t])=>t)).many(),ke.whitespaceOpt).map((([e,t,i,s])=>[t,...i]))}#F;constructor(e={}){if("NodePosX"in e!="NodePosY"in e){const t=Object.entries(e),[i,s]="NodePosX"in e?["NodePosY",Object.keys(e).indexOf("NodePosX")+1]:["NodePosX",Object.keys(e).indexOf("NodePosY")],n=[i,new(Ae.getAttribute(e,i,"type",Pt))];t.splice(s,0,n),e=Object.fromEntries(t)}super(e),this.CustomProperties,this.bIsPureFunc,this.isExported,this.ComponentPropertyName,this.EventReference,this.FunctionReference,this.AdvancedPinDisplay,this.EnabledState,this.NodeHeight,this.NodePosX,this.NodePosY,this.NodeWidth,this.CommentColor,this.NodeTitleColor,this.MacroGraphReference,this.MaterialExpressionEditorX,this.MaterialExpressionEditorY,this.SizeX,this.SizeY,this.Text,this.PositionX,this.PositionY,this.Node,this.PinTags,this.NumAdditionalInputs,this.InputPins,this.OutputPins,this.Archetype,this.BlueprintElementInstance,this.BlueprintElementType,this.Class,this.Enum,this.ExportPath,this.FunctionScript,this.Graph,this.MaterialExpression,this.MaterialExpressionComment,this.MaterialFunction,this.ObjectRef,this.PCGNode,this.SettingsInterface,this.StructType,this.TargetType,this.ScriptVariables,this.EnumEntries,this.PinNames,this.CustomFunctionName,this.DelegatePropertyName,this.ExportedNodes,this.FunctionDisplayName,this.InputName,this.Name,this.NodeComment,this.NodeTitle,this.Operation,this.OpName,this.ProxyFactoryFunctionName,this.SubgraphInstance,this.Text,this.AxisKey,this.HiGenGridSize,this.InputAxisKey,this.InputKey,this.InputType,this.AddedPins,this.DelegateReference,this.VariableReference,this.Pins instanceof Array&&this.Pins.forEach((e=>{const t=this[re.subObjectAttributeNameFromReference(e,!0)];if(t){const e=ft.fromLegacyObject(t);e.LinkedTo=[],this.getCustomproperties(!0).push(e),ae.objectSet(this,["attributes","CustomProperties","ignored"],!0)}}));const t=this.getMaterialSubobject();if(t){const e=t;if(void 0!==e.SizeX&&(e.SizeX.getter=()=>this.NodeWidth),e.SizeY&&(e.SizeY.getter=()=>this.NodeHeight),e.Text&&(e.Text.getter=()=>this.NodeComment),e.MaterialExpressionEditorX&&(e.MaterialExpressionEditorX.getter=()=>this.NodePosX),e.MaterialExpressionEditorY&&(e.MaterialExpressionEditorY.getter=()=>this.NodePosY),this.getType()===re.paths.materialExpressionComponentMask){const t=re.rgba.map((e=>this.getPinEntities().find((t=>t.PinName===e&&(t.recomputesNodeTitleOnChange=!0)))));e.R=new(Me.of(Ue).withDefault().flagSilent())((()=>t[0].DefaultValue)),e.G=new(Me.of(Ue).withDefault().flagSilent())((()=>t[1].DefaultValue)),e.B=new(Me.of(Ue).withDefault().flagSilent())((()=>t[2].DefaultValue)),e.A=new(Me.of(Ue).withDefault().flagSilent())((()=>t[3].DefaultValue)),e.keys=[...re.rgba,...super.keys.filter((e=>!re.rgba.includes(e)))]}}const i=this.getPcgSubobject();i&&(i.PositionX&&(i.PositionX.getter=()=>this.NodePosX),i.PositionY&&(i.PositionY.getter=()=>this.NodePosY),i.getSubobjects().forEach((e=>{if(void 0!==e.Node){const t=e.Node.get();t.type===this.PCGNode.type&&t.path===`${this.Name}.${this.PCGNode.path}`&&(e.Node.getter=()=>new nt(this.PCGNode.type,`${this.Name}.${this.PCGNode.path}`))}})));let s=0,n=0;this.CustomProperties?.forEach(((e,t)=>{e.objectEntity=this,e.pinIndex=e.isInput()?s++:e.isOutput()?n++:t}))}getClass(){if(!this.#F&&(this.#F=(this.Class?.path?this.Class.path:this.Class?.type)??(this.ExportPath?.path?this.ExportPath.path:this.ExportPath?.type)??"",this.#F&&!this.#F.startsWith("/"))){let e=Object.values(re.paths).find((e=>e.endsWith("."+this.#F)));e&&(this.#F=e)}return this.#F}getType(){let e=this.getClass();return this.MacroGraphReference?.MacroGraph?.path?this.MacroGraphReference.MacroGraph.path:this.MaterialExpression?this.MaterialExpression.type:e}getObjectName(e=!1){return e?this.getNameAndCounter()[0]:this.Name}getNameAndCounter(){const e=this.getObjectName().match(Pt.#_);return e?[e[1]??"",parseInt(e[2]??"0")]:["",0]}getCounter(){return this.getNameAndCounter()[1]}getNodeWidth(){return this.NodeWidth??this.isComment()?re.defaultCommentWidth:void 0}setNodeWidth(e){this.NodeWidth||(this.NodeWidth=new Ke),this.NodeWidth.value=e}getNodeHeight(){return this.NodeHeight??this.isComment()?re.defaultCommentHeight:void 0}setNodeHeight(e){this.NodeHeight||(this.NodeHeight=new Ke),this.NodeHeight.value=e}getNodePosX(){return this.NodePosX?.value??0}setNodePosX(e){this.NodePosX||(this.NodePosX=new Ke),this.NodePosX.value=Math.round(e)}getNodePosY(){return this.NodePosY?.value??0}setNodePosY(e){this.NodePosY||(this.NodePosY=new Ke),this.NodePosY.value=Math.round(e)}getCustomproperties(e=!1){return e&&!this.CustomProperties&&(this.CustomProperties=[]),this.CustomProperties??[]}getPinEntities(){return this.getCustomproperties().filter((e=>e.constructor===ft))}getSubobjects(){return Object.keys(this).filter((e=>e.startsWith(re.subObjectAttributeNamePrefix))).flatMap((e=>[this[e],...this[e].getSubobjects()]))}switchTarget(){const e=this.getClass().match(re.switchTargetPattern);if(e)return e[1]}isEvent(){switch(this.getClass()){case re.paths.actorBoundEvent:case re.paths.componentBoundEvent:case re.paths.customEvent:case re.paths.event:case re.paths.inputAxisKeyEvent:case re.paths.inputVectorAxisEvent:return!0}return!1}isComment(){switch(this.getClass()){case re.paths.comment:case re.paths.materialGraphNodeComment:return!0}return!1}isMaterial(){return this.getClass()===re.paths.materialGraphNode}getMaterialSubobject(){const e=this.MaterialExpression??this.MaterialExpressionComment;return e?this[re.subObjectAttributeNameFromReference(e,!0)]:null}isPcg(){return this.getClass()===re.paths.pcgEditorGraphNode||this.getPcgSubobject()}isNiagara(){return this.Class&&(this.Class.type?this.Class.type:this.Class.path)?.startsWith("/Script/NiagaraEditor.")}getPcgSubobject(){const e=this.PCGNode;return e?this[re.subObjectAttributeNameFromReference(e,!0)]:null}getSettingsObject(){const e=this.SettingsInterface;return e?this[re.subObjectAttributeNameFromReference(e,!0)]:null}getSubgraphObject(){const e=this.SubgraphInstance;return e?this[re.subObjectAttributeNameFromName(e)]:null}isDevelopmentOnly(){const e=this.getClass();return"DevelopmentOnly"===this.EnabledState?.toString()||e.includes("Debug",Math.max(0,e.lastIndexOf(".")))}getHIDAttribute(){return this.InputKey??this.AxisKey??this.InputAxisKey}getDelegatePin(){return this.getCustomproperties().find((e=>"delegate"===e.PinType.PinCategory))}nodeColor(){return function(e){switch(e.getType()){case re.paths.materialExpressionConstant2Vector:case re.paths.materialExpressionConstant3Vector:case re.paths.materialExpressionConstant4Vector:return re.nodeColors.yellow;case re.paths.makeStruct:return re.nodeColors.darkBlue;case re.paths.materialExpressionMaterialFunctionCall:return re.nodeColors.blue;case re.paths.materialExpressionFunctionInput:return re.nodeColors.red;case re.paths.materialExpressionTextureSample:return re.nodeColors.darkTurquoise;case re.paths.materialExpressionTextureCoordinate:case re.paths.pcgEditorGraphNodeInput:case re.paths.pcgEditorGraphNodeOutput:return re.nodeColors.red}switch(e.getClass()){case re.paths.callFunction:return e.bIsPureFunc?re.nodeColors.green:re.nodeColors.blue;case re.paths.niagaraNodeFunctionCall:return re.nodeColors.darkerBlue;case re.paths.dynamicCast:return re.nodeColors.turquoise;case re.paths.inputDebugKey:case re.paths.inputKey:return re.nodeColors.red;case re.paths.createDelegate:case re.paths.enumLiteral:case re.paths.makeArray:case re.paths.makeMap:case re.paths.materialGraphNode:case re.paths.select:return re.nodeColors.green;case re.paths.executionSequence:case re.paths.ifThenElse:case re.paths.macro:case re.paths.multiGate:return re.nodeColors.gray;case re.paths.functionEntry:case re.paths.functionResult:return re.nodeColors.violet;case re.paths.timeline:return re.nodeColors.yellow}if(e.switchTarget())return re.nodeColors.lime;if(e.isEvent())return re.nodeColors.red;if(e.isComment())return(e.CommentColor?e.CommentColor:De.getWhite()).toDimmedColor().toCSSRGBValues();const t=e.getPcgSubobject();if(t){if(t.NodeTitleColor)return t.NodeTitleColor.toDimmedColor(.1).toCSSRGBValues();switch(e.PCGNode?.getName(!0)){case"Branch":case"Select":return re.nodeColors.intenseGreen}}return e.bIsPureFunc?re.nodeColors.green:re.nodeColors.blue}(this)}nodeIcon(){return function(e){if(e.isMaterial()||e.isPcg()||e.isNiagara())return null;switch(e.getType()){case re.paths.addDelegate:case re.paths.asyncAction:case re.paths.callDelegate:case re.paths.createDelegate:case re.paths.functionEntry:case re.paths.functionResult:return Be.node;case re.paths.customEvent:return Be.event;case re.paths.doN:return Be.doN;case re.paths.doOnce:return Be.doOnce;case re.paths.dynamicCast:return Be.cast;case re.paths.enumLiteral:return Be.enum;case re.paths.event:return Be.event;case re.paths.executionSequence:case re.paths.multiGate:return Be.sequence;case re.paths.flipflop:return Be.flipflop;case re.paths.forEachElementInEnum:case re.paths.forLoop:case re.paths.forLoopWithBreak:case re.paths.whileLoop:return Be.loop;case re.paths.forEachLoop:case re.paths.forEachLoopWithBreak:return Be.forEachLoop;case re.paths.ifThenElse:return Be.branchNode;case re.paths.isValid:return Be.questionMark;case re.paths.makeArray:return Be.makeArray;case re.paths.makeMap:return Be.makeMap;case re.paths.makeSet:return Be.makeSet;case re.paths.makeStruct:return Be.makeStruct;case re.paths.metasoundEditorGraphExternalNode:return Be.metasoundFunction;case re.paths.select:return Be.select;case re.paths.spawnActorFromClass:return Be.spawnActor;case re.paths.timeline:return Be.timer}if(e.switchTarget())return Be.switch;if(Oe(e).startsWith("Break"))return Be.breakStruct;if(e.getClass()===re.paths.macro)return Be.macro;const t=e.getHIDAttribute()?.toString();return t?t.includes("Mouse")?Be.mouse:t.includes("Gamepad_Special")?Be.keyboard:t.includes("Gamepad")||t.includes("Steam")?Be.gamepad:t.includes("Touch")?Be.touchpad:Be.keyboard:e.getDelegatePin()?Be.event:e.ObjectRef?.type===re.paths.ambientSound?Be.sound:Be.functionSymbol}(this)}additionalPinInserter(){return function(e){let t,i,s,n;switch(e.getType()){case re.paths.commutativeAssociativeBinaryOperator:case re.paths.promotableOperator:switch(n=e.FunctionReference?.MemberName,n){default:if(!(n?.startsWith("Add_")||n?.startsWith("Subtract_")||n?.startsWith("Multiply_")||n?.startsWith("Divide_")))break;case"And_Int64Int64":case"And_IntInt":case"BMax":case"BMin":case"BooleanAND":case"BooleanNAND":case"BooleanOR":case"Concat_StrStr":case"FMax":case"FMin":case"Max":case"MaxInt64":case"Min":case"MinInt64":case"Or_Int64Int64":case"Or_IntInt":t??=()=>e.getPinEntities().filter((e=>e.isInput())),i??=yt,s??=(i,s=-1,n=-1)=>{const r=String.fromCharCode(i>=0?i:n+"A".charCodeAt(0)+1);return e.NumAdditionalInputs=t().length-1,r}}break;case re.paths.multiGate:t??=()=>e.getPinEntities().filter((e=>e.isOutput())),i??=e=>Number(e.PinName.match(/^\s*Out[_\s]+(\d+)\s*$/i)?.[1]),s??=(e,t=-1,i=-1,s)=>`Out ${e>=0?e:t>0?"Out 0":i+1}`;break;case re.paths.switchInteger:t??=()=>e.getPinEntities().filter((e=>e.isOutput())),i??=e=>Number(e.PinName.match(/^\s*(\d+)\s*$/)?.[1]),s??=(e,t=-1,i=-1,s)=>(e<0?i+1:e).toString();break;case re.paths.switchGameplayTag:s??=(t,i=-1,s=-1,n)=>{const r=`Case_${t>=0?t:i>0?"0":s+1}`;return e.PinNames??=[],e.PinNames.push(r),delete e.PinTags[e.PinTags.length-1],e.PinTags[e.PinTags.length]=null,r};case re.paths.switchName:case re.paths.switchString:t??=()=>e.getPinEntities().filter((e=>e.isOutput())),i??=e=>Number(e.PinName.match(/^\s*Case[_\s]+(\d+)\s*$/i)?.[1]),s??=(t,i=-1,s=-1,n)=>{const r=`Case_${t>=0?t:i>0?"0":s+1}`;return e.PinNames??=[],e.PinNames.push(r),r}}if(t)return()=>{let n=Number.MAX_SAFE_INTEGER,r=Number.MIN_SAFE_INTEGER,a=[];const o=t().reduce(((e,t)=>{const s=i(t);if(isNaN(s)){if(void 0===e)return t}else if(a.push(s),n=Math.min(s,n),s>r)return r=s,t;return e}),void 0);if(n!==Number.MAX_SAFE_INTEGER&&r!==Number.MIN_SAFE_INTEGER||(n=void 0,r=void 0),!o)return null;a.sort(((e,t)=>e{const t=e-l>1;return l=e,t}));const c=new ft(o);return c.PinId=Ge.generateGuid(),c.PinName=s(u,n,r,c),c.PinToolTip=void 0,e.getCustomproperties(!0).push(c),c}}(this)}}class kt extends Pt{constructor(e={},t=void 0){e.Class=new nt(re.paths.knot),e.Name="K2Node_Knot";const i=new ft({PinName:"InputPin"}),s=new ft({PinName:"OutputPin",Direction:"EGPD_Output"});t&&(i.copyTypeFrom(t),s.copyTypeFrom(t)),e.CustomProperties=[i,s],super(e)}}class At{#j;get target(){return this.#j}#e;get blueprint(){return this.#e}consumeEvent;options;listenHandler=()=>this.listenEvents();unlistenHandler=()=>this.unlistenEvents();constructor(e,t,i={}){i.consumeEvent??=!1,i.listenOnFocus??=!1,i.unlistenOnTextEdit??=!1,this.#j=e,this.#e=t,this.consumeEvent=i.consumeEvent,this.options=i}setup(){this.options.listenOnFocus&&(this.blueprint.addEventListener(re.focusEventName.begin,this.listenHandler),this.blueprint.addEventListener(re.focusEventName.end,this.unlistenHandler)),this.options.unlistenOnTextEdit&&(this.blueprint.addEventListener(re.editTextEventName.begin,this.unlistenHandler),this.blueprint.addEventListener(re.editTextEventName.end,this.listenHandler)),this.blueprint.focused&&this.listenEvents()}cleanup(){this.unlistenEvents(),this.blueprint.removeEventListener(re.focusEventName.begin,this.listenHandler),this.blueprint.removeEventListener(re.focusEventName.end,this.unlistenHandler),this.blueprint.removeEventListener(re.editTextEventName.begin,this.unlistenHandler),this.blueprint.removeEventListener(re.editTextEventName.end,this.listenHandler)}listenEvents(){}unlistenEvents(){}}class Lt extends Le{static attributes={...super.attributes,ActionName:tt,bShift:Ue,bCtrl:Ue,bAlt:Ue,bCmd:Ue,Key:wt};static grammar=ke.alt(wt.grammar.map((e=>{const t=new this;return t.Key=e,t})),Ie.createEntityGrammar(this));constructor(){super(),this.ActionName,this.bShift,this.bCtrl,this.bAlt,this.bCmd,this.Key}}class Mt extends At{static#U=e=>{};#W;pressedKey="";constructor(e,t,i={},s=Mt.#U,n=Mt.#U){i.activationKeys??=[],i.consumeEvent??=!0,i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,i.activationKeys instanceof Array||(i.activationKeys=[i.activationKeys]),i.activationKeys=i.activationKeys.map((e=>{if(e instanceof Lt)return e;if(e.constructor===String){const t=Lt.grammar.run(e);if(t.status)return t.value}throw new Error("Unexpected key value")})),super(e,t,i),this.onKeyDown=s,this.onKeyUp=n,this.#W=this.options.activationKeys??[];let r=this;this.keyDownHandler=e=>{r.#W.some((t=>(e=>e.bShift||"LeftShift"==e.Key||"RightShift"==e.Key)(t)==e.shiftKey&&(e=>e.bCtrl||"LeftControl"==e.Key||"RightControl"==e.Key)(t)==e.ctrlKey&&(e=>e.bAlt||"LeftAlt"==e.Key||"RightAlt"==e.Key)(t)==e.altKey&&re.Keys[t.Key.value]==e.code))&&(this.consumeEvent&&(e.preventDefault(),e.stopImmediatePropagation()),this.pressedKey=e.code,r.fire(),document.removeEventListener("keydown",r.keyDownHandler),document.addEventListener("keyup",r.keyUpHandler))},this.keyUpHandler=e=>{r.#W.some((t=>t.bShift&&"Shift"==e.key||t.bCtrl&&"Control"==e.key||t.bAlt&&"Alt"==e.key||t.bCmd&&"Meta"==e.key||re.Keys[t.Key.value]==e.code))&&(this.consumeEvent&&e.stopImmediatePropagation(),r.unfire(),this.pressedKey="",document.removeEventListener("keyup",this.keyUpHandler),document.addEventListener("keydown",this.keyDownHandler))}}listenEvents(){document.addEventListener("keydown",this.keyDownHandler)}unlistenEvents(){document.removeEventListener("keydown",this.keyDownHandler)}fire(){this.onKeyDown(this)}unfire(){this.onKeyUp(this)}}class Tt extends At{#K=[0,0];get location(){return this.#K}#Y;get enablerKey(){return this.#Y}#X=!0;get enablerActivated(){return this.#X}constructor(e,t,i={}){i.ignoreTranslateCompensate??=!1,i.ignoreScale??=!1,i.movementSpace??=t.getGridDOMElement()??document.documentElement,super(e,t,i),this.movementSpace=i.movementSpace,i.enablerKey&&(this.#Y=i.enablerKey,this.#Y.onKeyDown=()=>this.#X=!0,this.#Y.onKeyUp=()=>this.#X=!1,this.#Y.consumeEvent=!1,this.#Y.listenEvents(),this.#X=!1)}setLocationFromEvent(e){let t=ae.convertLocation([e.clientX,e.clientY],this.movementSpace,this.options.ignoreScale);return t=this.options.ignoreTranslateCompensate?t:this.blueprint.compensateTranslation(t[0],t[1]),this.#K=[...t],this.#K}}class It extends Tt{static#U=e=>{};#q=e=>{if(this.blueprint.setFocused(!0),!this.enablerKey||this.enablerActivated)if(e.button===this.options.clickButton)this.options.strictTarget&&e.target!==e.currentTarget||(this.consumeEvent&&e.stopImmediatePropagation(),document.addEventListener("mouseup",this.#Z),this.setLocationFromEvent(e),this.clickedPosition[0]=this.location[0],this.clickedPosition[1]=this.location[1],this.blueprint.mousePosition[0]=this.location[0],this.blueprint.mousePosition[1]=this.location[1],this.clicked(this.clickedPosition));else this.options.exitAnyButton||this.#Z(e)};#Z=e=>{this.options.exitAnyButton&&e.button!=this.options.clickButton||(this.consumeEvent&&e.stopImmediatePropagation(),document.removeEventListener("mouseup",this.#Z),this.unclicked())};clickedPosition=[0,0];constructor(e,t,i={},s=It.#U,n=It.#U){i.clickButton??=re.mouseClickButton,i.consumeEvent??=!0,i.exitAnyButton??=!0,i.strictTarget??=!1,super(e,t,i),this.onClick=s,this.onUnclick=n,this.listenEvents()}listenEvents(){this.target.addEventListener("mousedown",this.#q),this.options.clickButton===re.mouseRightClickButton&&this.target.addEventListener("contextmenu",(e=>e.preventDefault()))}unlistenEvents(){this.target.removeEventListener("mousedown",this.#q)}clicked(e){this.onClick(this)}unclicked(e){this.onUnclick(this)}}class $t extends Tt{static ignoreDbClick=e=>{};#Q=e=>{this.options.strictTarget&&e.target!==e.currentTarget||(this.consumeEvent&&e.stopImmediatePropagation(),this.clickedPosition=this.setLocationFromEvent(e),this.blueprint.mousePosition=[...this.clickedPosition],this.dbclicked(this.clickedPosition))};#J;get onDbClick(){return this.#J}set onDbClick(e){this.#J=e}clickedPosition=[0,0];constructor(e,t,i={},s=$t.ignoreDbClick){i.consumeEvent??=!0,i.strictTarget??=!1,super(e,t,i),this.#J=s,this.listenEvents()}listenEvents(){this.target.addEventListener("dblclick",this.#Q)}unlistenEvents(){this.target.removeEventListener("dblclick",this.#Q)}dbclicked(e){this.onDbClick(e)}}class Dt{element;get blueprint(){return this.element.blueprint}#ee=[];get inputObjects(){return this.#ee}initialize(e){this.element=e}createInputObjects(){return[]}setup(){this.#ee.forEach((e=>e.setup()))}cleanup(){this.#ee.forEach((e=>e.cleanup()))}willUpdate(e){}update(e){}render(){return H``}firstUpdated(e){}updated(e){}inputSetup(){this.#ee=this.createInputObjects()}}class Bt extends Dt{update(e){super.update(e);const[t,i,s,n]=[Math.round(this.element.fromX),Math.round(this.element.fromY),Math.round(this.element.toX),Math.round(this.element.toY)],[r,a,o,l]=[Math.min(t,s),Math.min(i,n),Math.abs(t-s),Math.abs(i-n)];(e.has("fromX")||e.has("toX"))&&(this.element.style.left=`${r}px`,this.element.style.width=`${o}px`),(e.has("fromY")||e.has("toY"))&&(this.element.style.top=`${a}px`,this.element.style.height=`${l}px`)}}class Vt extends Bt{static decreasingValue(e,t){const i=-e*t[0]**2,s=t[1]-i/t[0];return e=>i/e+s}static clampedLine(e,t){if(e[0]>t[0]){const i=e;e=t,t=i}const i=(t[1]-e[1])/(t[0]-e[0]),s=e[1]-i*e[0];return n=>nt[0]?t[1]:i*n+s}static c1DecreasingValue=Vt.decreasingValue(-.15,[100,15]);static c2DecreasingValue=Vt.decreasingValue(-.05,[500,130]);static c2Clamped=Vt.clampedLine([0,80],[200,40]);#te=`ueb-id-${Math.floor(1e12*Math.random())}`;#ie=e=>{const t=new kt({},this.element.source.entity),i=ce.getConstructor("ueb-node").newObject(t);i.setLocation(...this.blueprint.snapToGrid(...e));const s=i.template;this.blueprint.addGraphElement(i);const n=this.element.getInputPin(),r=this.element.getOutputPin();this.element.source=null,this.element.destination=null;const a=ce.getConstructor("ueb-link").newObject(r,s.inputPin);this.blueprint.addGraphElement(a),this.element.source=s.outputPin,this.element.destination=n};createInputObjects(){const e=this.element.querySelector(".ueb-link-area");return[...super.createInputObjects(),new $t(e,this.blueprint,void 0,(e=>{e[0]+=re.knotOffset[0],e[1]+=re.knotOffset[1],e=ae.snapToGrid(e[0],e[1],re.gridSize),this.#ie(e)})),new It(e,this.blueprint,{enablerKey:new Mt(this.blueprint,this.blueprint,{activationKeys:ue.enableLinkDelete})},(()=>this.blueprint.removeGraphElement(this.element)))]}willUpdate(e){super.willUpdate(e);const t=this.element.source,i=this.element.destination;if(e.has("fromX")||e.has("toX")){const e=this.element.fromX,s=this.element.toX,n=t?.nodeElement.getType()==re.paths.knot,r=i?.nodeElement.getType()==re.paths.knot;!n||i&&!r||(t?.isInput()&&s>e+re.distanceThreshold?this.element.source=t.nodeElement.template.outputPin:t?.isOutput()&&se+re.distanceThreshold&&(this.element.destination=i.nodeElement.template.inputPin))}const s=Math.max(Math.abs(this.element.fromX-this.element.toX),1),n=Math.max(Math.abs(this.element.fromY-this.element.toY),1),r=Math.max(s,re.linkMinWidth),a=s/r,o=this.element.originatesFromInput?this.element.fromXthis.element.toY?1:0)),this.element.style.setProperty("--ueb-start-percentage",`${Math.round(this.element.startPercentage)}%`),this.element.style.setProperty("--ueb-link-start",`${Math.round(this.element.startPixels)}`)}render(){return H` ${this.element.linkMessageIcon||this.element.linkMessageText?H`

`:R}`}}class Ht extends le{static properties={...super.properties,dragging:{type:Boolean,attribute:"data-dragging",converter:ae.booleanConverter,reflect:!0},originatesFromInput:{type:Boolean,attribute:!1},svgPathD:{type:String,attribute:!1},linkMessageIcon:{type:String,attribute:!1},linkMessageText:{type:String,attribute:!1}};#se;get source(){return this.#se}set source(e){this.#ne(e,!1)}#re;get destination(){return this.#re}set destination(e){this.#ne(e,!0)}#ae=()=>this.remove();#oe=e=>this.addSourceLocation(...e.detail.value);#le=e=>this.addDestinationLocation(...e.detail.value);#ue=e=>this.setSourceLocation();#ce=e=>this.setDestinationLocation();linkMessageIcon=R;linkMessageText=R;pathElement;constructor(){super(),this.dragging=!1,this.originatesFromInput=!1,this.startPercentage=0,this.svgPathD="",this.startPixels=0}static newObject(e,t){const i=new Ht;return i.initialize(e,t),i}initialize(e,t){super.initialize({},new Vt),e&&(this.source=e,t||(this.toX=this.fromX,this.toY=this.fromY)),t&&(this.destination=t,e||(this.fromX=this.toX,this.fromY=this.toY))}#ne(e,t){const i=()=>t?this.destination:this.source;if(i()!=e){if(i()){const e=i().getNodeElement();e.removeEventListener(re.removeEventName,this.#ae),e.removeEventListener(re.nodeDragEventName,t?this.#le:this.#oe),e.removeEventListener(re.nodeReflowEventName,t?this.#ce:this.#ue),this.#he()}if(t?this.#re=e:this.#se=e,i()){const e=i().getNodeElement();e.addEventListener(re.removeEventName,this.#ae),e.addEventListener(re.nodeDragEventName,t?this.#le:this.#oe),e.addEventListener(re.nodeReflowEventName,t?this.#ce:this.#ue),t?this.setDestinationLocation():(this.setSourceLocation(),this.originatesFromInput=this.source.isInput()),this.#pe()}}}#pe(){this.source&&this.destination&&(this.source.linkTo(this.destination),this.destination.linkTo(this.source))}#he(){this.source&&this.destination&&(this.source.unlinkFrom(this.destination,!1),this.destination.unlinkFrom(this.source,!1))}cleanup(){super.cleanup(),this.#he(),this.source=null,this.destination=null}setSourceLocation(e=null,t=!0){if(null==e){const i=this;if(t&&(!this.hasUpdated||!this.source.hasUpdated))return void Promise.all([this.updateComplete,this.source.updateComplete]).then((()=>i.setSourceLocation(null,!1)));e=this.source.template.getLinkLocation()}const[i,s]=e;this.fromX=i,this.fromY=s}setDestinationLocation(e=null,t=!0){if(null==e){const i=this;if(t&&(!this.hasUpdated||!this.destination.hasUpdated))return void Promise.all([this.updateComplete,this.destination.updateComplete]).then((()=>i.setDestinationLocation(null,!1)));e=this.destination.template.getLinkLocation()}this.toX=e[0],this.toY=e[1]}getInputPin(){return this.source?.isInput()?this.source:this.destination}setInputPin(e){this.source?.isInput()&&(this.source=e),this.destination=e}getOutputPin(){return this.destination?.isOutput()?this.destination:this.source}setOutputPin(e){this.destination?.isOutput()&&(this.destination=e),this.source=e}startDragging(){this.dragging=!0}finishDragging(){this.dragging=!1}removeMessage(){this.linkMessageIcon=R,this.linkMessageText=R}setMessageConvertType(){this.linkMessageIcon=Be.convert,this.linkMessageText=H`Convert ${this.source.pinType} to ${this.destination.pinType}.`}setMessageCorrect(){this.linkMessageIcon=Be.correct,this.linkMessageText=R}setMessageReplace(){this.linkMessageIcon=Be.correct,this.linkMessageText=R}setMessageDirectionsIncompatible(){this.linkMessageIcon=Be.reject,this.linkMessageText=H`Directions are not compatbile.`}setMessagePlaceNode(){this.linkMessageIcon=R,this.linkMessageText=H`Place a new node.`}setMessageReplaceLink(){this.linkMessageIcon=Be.correct,this.linkMessageText=H`Replace existing input connections.`}setMessageReplaceOutputLink(){this.linkMessageIcon=Be.correct,this.linkMessageText=H`Replace existing output connections.`}setMessageSameNode(){this.linkMessageIcon=Be.reject,this.linkMessageText=H`Both are on the same node.`}setMessageTypesIncompatible(e,t){this.linkMessageIcon=Be.reject,this.linkMessageText=H`${ae.capitalFirstLetter(e.pinType)} is not compatible with ${ae.capitalFirstLetter(t.pinType)}.`}}class Ot extends oe{static properties={...super.properties,locationX:{type:Number,attribute:!1},locationY:{type:Number,attribute:!1},sizeX:{type:Number,attribute:!1},sizeY:{type:Number,attribute:!1}};static dragEventName=re.dragEventName;static dragGeneralEventName=re.dragGeneralEventName;constructor(){super(),this.locationX=0,this.locationY=0,this.sizeX=0,this.sizeY=0}computeSizes(){const e=this.getBoundingClientRect();this.sizeX=this.blueprint.scaleCorrect(e.width),this.sizeY=this.blueprint.scaleCorrect(e.height)}firstUpdated(e){super.firstUpdated(e),this.computeSizes()}setLocation(e,t,i=!0){const s=e-this.locationX,n=t-this.locationY;if(this.locationX=e,this.locationY=t,this.blueprint&&i){const e=new CustomEvent(this.constructor.dragEventName,{detail:{value:[s,n]},bubbles:!1,cancelable:!0});this.dispatchEvent(e)}}addLocation(e,t,i=!0){this.setLocation(this.locationX+e,this.locationY+t,i)}acknowledgeDrag(e){const t=new CustomEvent(this.constructor.dragGeneralEventName,{detail:{value:e},bubbles:!0,cancelable:!0});this.dispatchEvent(t)}snapToGrid(){const e=ae.snapToGrid(this.locationX,this.locationY,re.gridSize);this.locationX==e[0]&&this.locationY==e[1]||this.setLocation(e[0],e[1])}topBoundary(e=!1){return this.template.topBoundary(e)}rightBoundary(e=!1){return this.template.rightBoundary(e)}bottomBoundary(e=!1){return this.template.bottomBoundary(e)}leftBoundary(e=!1){return this.template.leftBoundary(e)}}class Rt extends Tt{#q=e=>{if(this.blueprint.setFocused(!0),e.button===this.options.clickButton)this.options.strictTarget&&e.target!=e.currentTarget||(this.consumeEvent&&e.stopImmediatePropagation(),this.#de.addEventListener("mousemove",this.#me),document.addEventListener("mouseup",this.#Z),this.setLocationFromEvent(e),this.clickedPosition[0]=this.location[0],this.clickedPosition[1]=this.location[1],this.blueprint.mousePosition[0]=this.location[0],this.blueprint.mousePosition[1]=this.location[1],this.target instanceof Ot&&(this.clickedOffset=[this.clickedPosition[0]-this.target.locationX,this.clickedPosition[1]-this.target.locationY]),this.clicked(this.clickedPosition));else this.options.exitAnyButton||this.#Z(e)};#me=e=>{this.consumeEvent&&e.stopImmediatePropagation(),this.#de.removeEventListener("mousemove",this.#me),this.#de.addEventListener("mousemove",this.#ge);const t=this.getEvent(re.trackingMouseEventName.begin);this.#be=0==this.target.dispatchEvent(t),this.setLocationFromEvent(e),this.lastLocation=ae.snapToGrid(this.clickedPosition[0],this.clickedPosition[1],this.stepSize),this.startDrag(this.location),this.started=!0,this.#ge(e)};#ge=e=>{this.consumeEvent&&e.stopImmediatePropagation();const t=this.setLocationFromEvent(e),i=[e.movementX,e.movementY];if(this.dragTo(t,i),this.#be&&(this.blueprint.mousePosition=t),this.options.scrollGraphEdge){const e=Math.sqrt(i[0]*i[0]+i[1]*i[1]),s=this.blueprint.scaleCorrect(re.edgeScrollThreshold),n=this.blueprint.template.gridLeftVisibilityBoundary()+s,r=this.blueprint.template.gridRightVisibilityBoundary()-s;let a=0;t[0]r&&(a=t[0]-r);const o=this.blueprint.template.gridTopVisibilityBoundary()+s,l=this.blueprint.template.gridBottomVisibilityBoundary()-s;let u=0;t[1]l&&(u=t[1]-l),a=ae.clamp(this.blueprint.scaleCorrectReverse(a)**3*e*.6,-20,20),u=ae.clamp(this.blueprint.scaleCorrectReverse(u)**3*e*.6,-20,20),this.blueprint.scrollDelta(a,u)}};#Z=e=>{if(!this.options.exitAnyButton||e.button==this.options.clickButton){if(this.consumeEvent&&e.stopImmediatePropagation(),this.#de.removeEventListener("mousemove",this.#me),this.#de.removeEventListener("mousemove",this.#ge),document.removeEventListener("mouseup",this.#Z),this.started&&this.endDrag(),this.unclicked(),this.#be){const e=this.getEvent(re.trackingMouseEventName.end);this.target.dispatchEvent(e),this.#be=!1}this.started=!1}};#be=!1;#de;#ve;get draggableElement(){return this.#ve}clickedOffset=[0,0];clickedPosition=[0,0];lastLocation=[0,0];started=!1;stepSize=1;constructor(e,t,i={}){i.clickButton??=re.mouseClickButton,i.consumeEvent??=!0,i.draggableElement??=e,i.exitAnyButton??=!0,i.moveEverywhere??=!1,i.movementSpace??=t?.getGridDOMElement(),i.repositionOnClick??=!1,i.scrollGraphEdge??=!1,i.strictTarget??=!1,super(e,t,i),this.stepSize=Number(i.stepSize??re.gridSize),this.#de=this.options.moveEverywhere?document.documentElement:this.movementSpace,this.#ve=this.options.draggableElement,this.listenEvents()}listenEvents(){super.listenEvents(),this.#ve.addEventListener("mousedown",this.#q),this.options.clickButton===re.mouseRightClickButton&&this.#ve.addEventListener("contextmenu",(e=>e.preventDefault()))}unlistenEvents(){super.unlistenEvents(),this.#ve.removeEventListener("mousedown",this.#q)}getEvent(e){return new CustomEvent(e,{detail:{tracker:this},bubbles:!0,cancelable:!0})}clicked(e){}startDrag(e){}dragTo(e,t){}endDrag(){}unclicked(e){}}class Gt extends Rt{clicked(e){this.options.repositionOnClick&&(this.target.setLocation(...this.stepSize>1?ae.snapToGrid(e[0],e[1],this.stepSize):e),this.clickedOffset=[0,0])}dragTo(e,t){const i=[this.target.locationX??this.lastLocation[0],this.target.locationY??this.lastLocation[1]],[s,n]=this.stepSize>1?[ae.snapToGrid(e[0],e[1],this.stepSize),ae.snapToGrid(i[0],i[1],this.stepSize)]:[e,i];0==(t=[s[0]-this.lastLocation[0],s[1]-this.lastLocation[1]])[0]&&0==t[1]||(t[0]+=n[0]-i[0],t[1]+=n[1]-i[1],this.dragAction(s,t),this.lastLocation=s)}dragAction(e,t){this.target.setLocation(e[0]-this.clickedOffset[0],e[1]-this.clickedOffset[1])}}class zt extends Gt{#fe;#ye;#we;#Se;constructor(e,t,i={}){super(e,t,i),i.onClicked&&(this.#fe=i.onClicked),i.onStartDrag&&(this.#ye=i.onStartDrag),i.onDrag&&(this.#we=i.onDrag),i.onEndDrag&&(this.#Se=i.onEndDrag)}clicked(e){super.clicked(e),this.#fe?.()}startDrag(){super.startDrag(),this.#ye?.()}dragAction(e,t){this.#we?.(e,t)}endDrag(){super.endDrag(),this.#Se?.()}}class _t extends Gt{constructor(e,t,i={}){super(e,t,i),this.draggableElement.classList.add("ueb-draggable")}startDrag(){this.target.selected||(this.blueprint.unselectAll(),this.target.setSelected(!0))}dragAction(e,t){this.target.acknowledgeDrag(t)}unclicked(){this.started?(this.blueprint.getNodes(!0).forEach((e=>e.boundComments.filter((t=>!e.isInsideComment(t))).forEach((t=>e.unbindFromComment(t))))),this.blueprint.getCommentNodes().forEach((e=>e.template.manageNodesBind()))):(this.blueprint.unselectAll(),this.target.setSelected(!0))}}class Ft extends Dt{getDraggableElement(){return this.element}createDraggableObject(){const e=this.getDraggableElement();return new Gt(this.element,this.blueprint,{draggableElement:e})}createInputObjects(){return[...super.createInputObjects(),this.createDraggableObject(),new Mt(this.element,this.blueprint,{activationKeys:[re.Keys.ArrowUp,re.Keys.ArrowRight,re.Keys.ArrowDown,re.Keys.ArrowLeft]},(e=>e.target.acknowledgeDrag([e.pressedKey===re.Keys.ArrowLeft?-re.gridSize:e.pressedKey===re.Keys.ArrowRight?re.gridSize:0,e.pressedKey===re.Keys.ArrowUp?-re.gridSize:e.pressedKey===re.Keys.ArrowDown?re.gridSize:0])))]}topBoundary(e=!1){return this.element.locationY}rightBoundary(e=!1){return this.element.locationX+this.element.sizeX}bottomBoundary(e=!1){return this.element.locationY+this.element.sizeY}leftBoundary(e=!1){return this.element.locationX}centerInViewport(){const e=Math.min(this.blueprint.template.viewportSize[0]/10,this.blueprint.template.viewportSize[1]/10),t=this.leftBoundary()-this.blueprint.template.gridLeftVisibilityBoundary(),i=this.blueprint.template.gridRightVisibilityBoundary()-this.rightBoundary();let s=Math.max((t+i)/2,e);const n=this.topBoundary()-this.blueprint.template.gridTopVisibilityBoundary(),r=this.blueprint.template.gridBottomVisibilityBoundary()-this.bottomBoundary();let a=Math.max((n+r)/2,e);this.blueprint.scrollDelta(t-s,n-a,!0)}}class jt extends Ft{update(e){super.update(e),e.has("locationX")&&(this.element.style.left=`${this.element.locationX}px`),e.has("locationY")&&(this.element.style.top=`${this.element.locationY}px`)}}class Ut extends jt{getDraggableElement(){return this.element}createDraggableObject(){return new _t(this.element,this.blueprint,{draggableElement:this.getDraggableElement(),scrollGraphEdge:!0})}firstUpdated(e){super.firstUpdated(e),this.element.selected&&!this.element.listeningDrag&&this.element.setSelected(!0)}}class Wt extends Ut{static nodeStyleClasses=["ueb-node-style-default"];#Ee=!1;pinInserter;inputContainer;outputContainer;pinElement;addPinHandler=()=>{const e=this.pinInserter?.();e&&(this.defaultPin&&this.defaultPin.isInput()===e.isInput()?this.defaultPin.before(this.createPinElement(e)):(e.isInput()?this.inputContainer:this.outputContainer).appendChild(this.createPinElement(e)),this.element.acknowledgeReflow())};toggleAdvancedDisplayHandler=()=>{this.element.toggleShowAdvancedPinDisplay(),this.element.requestUpdate(),this.element.updateComplete.then((()=>this.element.acknowledgeReflow()))};createPinElement(e){const t=ce.getConstructor("ueb-pin").newObject(e,void 0,this.element);return this.pinInserter&&!this.defaultPin&&"Default"===t.getPinName()&&(this.defaultPin=t,this.defaultPin.classList.add("ueb-node-variadic-default")),t}initialize(e){super.initialize(e),this.element.classList.add(...this.constructor.nodeStyleClasses),this.element.style.setProperty("--ueb-node-color",this.getColor().cssText),this.pinInserter=this.element.entity.additionalPinInserter(),this.pinInserter&&this.element.classList.add("ueb-node-is-variadic")}getColor(){return this.element.entity.nodeColor()}render(){return H`
${this.renderTop()}
${this.pinInserter?H`
Add pin ${Be.plusCircle}
`:R} ${this.element.entity.isDevelopmentOnly()?H`
Development Only
`:R} ${this.element.advancedPinDisplay?H`
${Be.expandIcon}
`:R}
`}renderNodeIcon(){return this.element.entity.nodeIcon()}renderNodeName(){return this.element.nodeDisplayName}renderTop(){const e=this.renderNodeIcon(),t=this.renderNodeName();return H`
${e?H`
${e}
`:R} ${t?H`
${t} ${this.#Ee&&this.getTargetType().length>0?H`
Target is ${ae.formatStringName(this.getTargetType())}
`:R}
`:R}
`}firstUpdated(e){super.firstUpdated(e),this.inputContainer=this.element.querySelector(".ueb-node-inputs"),this.outputContainer=this.element.querySelector(".ueb-node-outputs"),this.setupPins(),this.element.updateComplete.then((()=>this.element.acknowledgeReflow()))}setupPins(){this.element.nodeNameElement=this.element.querySelector(".ueb-node-name-text");let e=!1,t=!1;for(const i of this.element.getPinElements())i!==this.defaultPin&&(i.isInput()?(this.inputContainer.appendChild(i),e=!0):i.isOutput()&&(this.outputContainer.appendChild(i),t=!0));this.defaultPin&&(this.defaultPin.isInput()?this.inputContainer:this.outputContainer).appendChild(this.defaultPin),e&&this.element.classList.add("ueb-node-has-inputs"),t&&this.element.classList.add("ueb-node-has-outputs")}createPinElements(){return this.element.getPinEntities().filter((e=>!e.isHidden())).map((e=>(this.#Ee=this.#Ee||"self"===e.PinName&&"Target"===e.pinTitle(),this.createPinElement(e))))}getTargetType(){return this.element.entity.FunctionReference?.MemberParent?.getName()??"Untitled"}getPinElements(e){return e.querySelectorAll("ueb-pin")}linksChanged(){}}class Kt extends Wt{#Ce=document.createElement("div");#Ne=document.createElement("div");#xe=document.createElement("div");#Pe=document.createElement("div");#ke=document.createElement("div");#Ae=document.createElement("div");#Le=document.createElement("div");#Me=document.createElement("div");initialize(e){super.initialize(e),this.element.classList.add("ueb-resizeable"),this.#Ce.classList.add("ueb-resizeable-top"),this.#Ne.classList.add("ueb-resizeable-right"),this.#xe.classList.add("ueb-resizeable-bottom"),this.#Pe.classList.add("ueb-resizeable-left"),this.#ke.classList.add("ueb-resizeable-top-right"),this.#Ae.classList.add("ueb-resizeable-bottom-right"),this.#Le.classList.add("ueb-resizeable-bottom-left"),this.#Me.classList.add("ueb-resizeable-top-left")}update(e){super.update(e),this.element.sizeX>=0&&e.has("sizeX")&&(this.element.style.width=`${this.element.sizeX}px`),this.element.sizeY>=0&&e.has("sizeY")&&(this.element.style.height=`${this.element.sizeY}px`)}firstUpdated(e){super.firstUpdated(e),this.element.append(this.#Ce,this.#Ne,this.#xe,this.#Pe,this.#ke,this.#Ae,this.#Le,this.#Me)}createInputObjects(){return[...super.createInputObjects(),new zt(this.#Ce,this.blueprint,{onDrag:(e,t)=>{t[1]=e[1]-this.element.topBoundary(),this.setSizeY(this.element.sizeY-t[1])&&this.element.addLocation(0,t[1],!1)},onEndDrag:()=>this.endResize()}),new zt(this.#Ne,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.rightBoundary(),this.setSizeX(this.element.sizeX+t[0])},onEndDrag:()=>this.endResize()}),new zt(this.#xe,this.blueprint,{onDrag:(e,t)=>{t[1]=e[1]-this.element.bottomBoundary(),this.setSizeY(this.element.sizeY+t[1])},onEndDrag:()=>this.endResize()}),new zt(this.#Pe,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.leftBoundary(),this.setSizeX(this.element.sizeX-t[0])&&this.element.addLocation(t[0],0,!1)},onEndDrag:()=>this.endResize()}),new zt(this.#ke,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.rightBoundary(),t[1]=e[1]-this.element.topBoundary(),this.setSizeX(this.element.sizeX+t[0]),this.setSizeY(this.element.sizeY-t[1])&&this.element.addLocation(0,t[1],!1)},onEndDrag:()=>this.endResize()}),new zt(this.#Ae,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.rightBoundary(),t[1]=e[1]-this.element.bottomBoundary(),this.setSizeX(this.element.sizeX+t[0]),this.setSizeY(this.element.sizeY+t[1])},onEndDrag:()=>this.endResize()}),new zt(this.#Le,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.leftBoundary(),t[1]=e[1]-this.element.bottomBoundary(),this.setSizeX(this.element.sizeX-t[0])&&this.element.addLocation(t[0],0,!1),this.setSizeY(this.element.sizeY+t[1])},onEndDrag:()=>this.endResize()}),new zt(this.#Me,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.leftBoundary(),t[1]=e[1]-this.element.topBoundary(),this.setSizeX(this.element.sizeX-t[0])&&this.element.addLocation(t[0],0,!1),this.setSizeY(this.element.sizeY-t[1])&&this.element.addLocation(0,t[1],!1)},onEndDrag:()=>this.endResize()})]}setSizeX(e){return this.element.setNodeWidth(e),!0}setSizeY(e){return this.element.setNodeHeight(e),!0}endResize(){}}class Yt extends Kt{#Te=0;initialize(e){super.initialize(e),e.classList.add("ueb-node-style-comment","ueb-node-resizeable"),e.sizeX=25*re.gridSize,e.sizeY=6*re.gridSize,super.initialize(e)}getDraggableElement(){return this.element.querySelector(".ueb-node-top")}render(){return H`
`}firstUpdated(e){super.firstUpdated(e);const t=this.getDraggableElement().getBoundingClientRect();this.#Te=t.height}manageNodesBind(){let e=this.blueprint.getNodes();for(let t of e)t.topBoundary()>=this.element.topBoundary()&&t.rightBoundary()<=this.element.rightBoundary()&&t.bottomBoundary()<=this.element.bottomBoundary()&&t.leftBoundary()>=this.element.leftBoundary()?t.bindToComment(this.element):t.unbindFromComment(this.element)}setSizeX(e){return(e=Math.round(e))>=2*re.gridSize&&(this.element.setNodeWidth(e),!0)}setSizeY(e){return(e=Math.round(e))>=2*re.gridSize&&(this.element.setNodeHeight(e),!0)}endResize(){this.manageNodesBind()}topBoundary(e=!1){return this.element.locationY}rightBoundary(e=!1){return this.element.locationX+this.element.sizeX}bottomBoundary(e=!1){return e?this.element.locationY+this.#Te:super.bottomBoundary()}leftBoundary(e=!1){return this.element.locationX}}class Xt extends Rt{#Ie;#$e=null;#De=e=>{if(!this.enteredPin){this.linkValid=!1,this.enteredPin=e.target;const t=this.link.source??this.target,i=this.enteredPin,s=t.isOutput()?t:i;t.nodeElement.getType()===re.paths.knot||i.nodeElement.getType()===re.paths.knot?(this.link.setMessageCorrect(),this.linkValid=!0):t.getNodeElement()===i.getNodeElement()?this.link.setMessageSameNode():t.isOutput()===i.isOutput()?this.link.setMessageDirectionsIncompatible():this.blueprint.getLinks(t,i).length?(this.link.setMessageReplaceLink(),this.linkValid=!0):"exec"===s.entity.getType()&&s.isLinked?(this.link.setMessageReplaceOutputLink(),this.linkValid=!0):"object"==t.entity.PinType.PinCategory&&"object"==i.entity.PinType.PinCategory||t.pinType==i.pinType?(this.link.setMessageCorrect(),this.linkValid=!0):(this.link.setMessageTypesIncompatible(t,i),this.linkValid=!1)}};#Be=e=>{this.enteredPin==e.target&&(this.enteredPin=null,this.linkValid=!1,this.link?.setMessagePlaceNode())};link;enteredPin;linkValid=!1;constructor(e,t,i={}){i.scrollGraphEdge??=!0,super(e,t,i)}startDrag(e){this.target.nodeElement.getType()==re.paths.knot&&(this.#$e=this.target),this.link=ce.getConstructor("ueb-link").newObject(this.target,null),this.blueprint.template.linksContainerElement.prepend(this.link),this.link.setMessagePlaceNode(),this.#Ie=this.blueprint.querySelectorAll("ueb-pin"),this.#Ie.forEach((e=>{e!=this.target&&(e.addEventListener("mouseenter",this.#De),e.addEventListener("mouseleave",this.#Be))})),this.link.startDragging(),this.link.setDestinationLocation(e)}dragTo(e,t){this.link.setDestinationLocation(e)}endDrag(){if(this.#Ie.forEach((e=>{e.removeEventListener("mouseenter",this.#De),e.removeEventListener("mouseleave",this.#Be)})),this.#Ie=null,this.enteredPin&&this.linkValid){if(this.#$e){const e=this.#$e!==this.link.source?this.link.source:this.enteredPin;if(this.#$e.isInput()&&e.isInput()||this.#$e.isOutput()&&e.isOutput()){const e=this.#$e.template.getOppositePin();this.#$e===this.link.source?this.link.source=e:this.enteredPin=e}}else this.enteredPin.nodeElement.getType()===re.paths.knot&&(this.enteredPin=this.enteredPin.template.getOppositePin());this.link.source.getLinks().find((e=>e.equals(this.enteredPin.createPinReference())))?this.link.remove():(this.blueprint.addGraphElement(this.link),this.link.destination=this.enteredPin)}else this.link.remove();this.enteredPin=null,this.link.removeMessage(),this.link.finishDragging(),this.link=null}}class qt extends Wt{#Ve=!1;#He=!1;displayName="";static nodeStyleClasses=["ueb-node-style-glass"];initialize(e){super.initialize(e),this.displayName=this.element.nodeDisplayName}render(){return H`
${this.displayName?H`
${this.displayName}
`:R} ${this.#Ve?H`
`:R} ${this.#He?H`
`:R} ${this.pinInserter?H`
Add pin ${Be.plusCircle}
`:R}
`}createPinElements(){return this.element.getPinEntities().filter((e=>!e.isHidden())).map((e=>{this.#Ve||=e.isInput(),this.#He||=e.isOutput();return ce.getConstructor("ueb-pin").newObject(e,void 0,this.element)}))}}class Zt extends qt{static nodeStyleClasses=["ueb-node-style-metasound","ueb-node-style-operation"]}class Qt extends qt{static nodeStyleClasses=[...super.nodeStyleClasses,"ueb-node-style-conversion"]}class Jt extends qt{static nodeStyleClasses=[...super.nodeStyleClasses,"ueb-node-style-operation"]}class ei extends Dt{static canWrapInput=!0;#Oe;get iconElement(){return this.#Oe}#Re;get wrapperElement(){return this.#Re}isNameRendered=!0;initialize(e){if(super.initialize(e),this.element.nodeElement){const e=this.element.nodeElement.template;this.isNameRendered=!(e instanceof Qt||e instanceof Jt||e instanceof Zt)}}setup(){super.setup(),this.element.nodeElement=this.element.closest("ueb-node");const e=this.element.nodeElement.template;(e instanceof Qt||e instanceof Jt)&&(this.isNameRendered=!1,this.element.requestUpdate())}createInputObjects(){return[new Xt(this.element,this.blueprint,{moveEverywhere:!0,draggableElement:this.getClickableElement()})]}render(){const e=H`
${this.renderIcon()}
`,t=H`
${this.isNameRendered?this.renderName():R} ${this.isInputRendered()?this.renderInput():H``}
`;return H`
${this.element.isInput()?H`${e}${t}`:H`${t}${e}`}
`}renderIcon(){if(this.element.nodeElement.entity.isPcg())switch(this.element.entity.getType()){case"Any":return Be.pcgPin;case"Param":case"Param[]":return Be.pcgParamPin;case"Spatial":case"Spatial[]":return Be.pcgSpatialPin;case"Any[]":case"Point[]":case"Surface[]":case"Volume[]":if(this.element.isOutput())return Be.pcgPin;case"Point":case"Surface":case"Volume":return Be.pcgStackPin}switch(this.element.entity.PinType?.ContainerType?.toString()){case"Array":return Be.arrayPin;case"Set":return Be.setPin;case"Map":return Be.mapPin}return"delegate"===this.element.entity.PinType?.PinCategory?.toLocaleLowerCase()?Be.delegate:this.element.nodeElement?.template instanceof Jt?Be.operationPin:Be.genericPin}renderName(){let e=this.element.getPinDisplayName();const t=this.element.nodeElement,i=this.element.getPinName();return t.getType()==re.paths.makeStruct&&i==t.entity.StructType.getName()&&(e=i),H`${e}`}isInputRendered(){return this.element.isInput()&&!this.element.entity.bDefaultValueIsIgnored&&!this.element.entity.PinType.bIsReference}renderInput(){return H``}updated(e){if(super.updated(e),this.element.isInput()&&e.has("isLinked")){const e=this.element.nodeElement;this.element.requestUpdate(),this.element.updateComplete.then((()=>e.acknowledgeReflow()))}}firstUpdated(e){super.firstUpdated(e),this.element.style.setProperty("--ueb-pin-color-rgb",this.element.entity.pinColor().cssText),this.#Oe=this.element.querySelector(".ueb-pin-icon svg")??this.element,this.#Re=this.element.querySelector(".ueb-pin-wrapper")}getLinkLocation(){const e=this.iconElement.getBoundingClientRect(),t=[this.element.isInput()?e.left:e.right+1,(e.top+e.bottom)/2],i=ae.convertLocation(t,this.blueprint.template.gridElement);return this.blueprint.compensateTranslation(i[0],i[1])}getClickableElement(){return this.#Re??this.element}}class ti extends ei{render(){return H`
${this.renderIcon()}
`}}class ii extends Wt{static nodeStyleClasses=[...super.nodeStyleClasses,"ueb-node-style-event"];firstUpdated(e){super.firstUpdated(e),this.element.querySelector(".ueb-node-top").appendChild(this.createDelegatePinElement())}renderTop(){const e=this.renderNodeIcon(),t=this.renderNodeName(),i=this.element.getType()===re.paths.customEvent&&(this.element.entity.CustomFunctionName||this.element.entity.FunctionReference.MemberParent);return H`
${e?H`
${e}
`:R} ${t?H`
${t} ${i?H`
Custom Event
`:R}
`:R}
`}createDelegatePinElement(){const e=ce.getConstructor("ueb-pin").newObject(this.element.getPinEntities().find((e=>!e.isHidden()&&"delegate"===e.PinType.PinCategory)),new ti,this.element);return e.template.isNameRendered=!1,e}createPinElements(){return this.element.getPinEntities().filter((e=>!e.isHidden()&&"delegate"!==e.PinType.PinCategory)).map((e=>ce.getConstructor("ueb-pin").newObject(e,void 0,this.element)))}}class si extends ti{render(){return this.element.isOutput()?super.render():H``}getOppositePin(){const e=this.element.nodeElement.template;return this.element.isOutput()?e.inputPin:e.outputPin}getLinkLocation(){const e=(this.element.isInput()?this.element.nodeElement.template.outputPin.template:this).iconElement.getBoundingClientRect(),t=[this.element.isInput()?e.left:e.right+1,(e.top+e.bottom)/2],i=ae.convertLocation(t,this.blueprint.template.gridElement);return this.blueprint.compensateTranslation(i[0],i[1])}}class ni extends Wt{static#Ge=new Set;#ze=null;#_e;get inputPin(){return this.#_e}#Fe;get outputPin(){return this.#Fe}initialize(e){super.initialize(e),this.element.classList.add("ueb-node-style-minimal")}findDirectionaPin(e){if(e.nodeElement.getType()!==re.paths.knot||ni.#Ge.has(e))return ni.#Ge.clear(),!0;ni.#Ge.add(e);for(let t of e.getLinks().map((e=>this.blueprint.getPin(e))))if(this.findDirectionaPin(t))return!0;return!1}render(){return H`
`}setupPins(){this.element.getPinElements().forEach((e=>this.element.querySelector(".ueb-node-border").appendChild(e)))}getPinElements(e){return e.querySelectorAll("ueb-pin")}createPinElements(){const e=this.element.getPinEntities().filter((e=>!e.isHidden())),t=e[e[0].isInput()?0:1],i=e[e[0].isOutput()?0:1],s=ce.getConstructor("ueb-pin");return[this.#_e=s.newObject(t,new si,this.element),this.#Fe=s.newObject(i,new si,this.element)]}linksChanged(){}}class ri extends Wt{static nodeStyleClasses=["ueb-node-style-metasound"]}class ai extends qt{initialize(e){super.initialize(e);const t=e.getType();t===re.paths.variableGet||t===re.paths.self?(this.element.classList.add("ueb-node-style-getter"),this.displayName=""):t===re.paths.variableSet&&this.element.classList.add("ueb-node-style-setter")}setupPins(){super.setupPins();let e=this.element.getPinElements().find((e=>!e.entity.isHidden()&&!e.entity.isExecution()));this.element.style.setProperty("--ueb-node-color",e.getColor().cssText)}}function oi(e){if(e.getClass()===re.paths.callFunction||e.getClass()===re.paths.commutativeAssociativeBinaryOperator||e.getClass()===re.paths.callArrayFunction){const t=e.FunctionReference?.MemberParent?.path??"",i=e.FunctionReference?.MemberName;if(i&&(t===re.paths.kismetMathLibrary||t===re.paths.kismetArrayLibrary)){if(i.startsWith("Conv_"))return Qt;if(i.startsWith("Add_")||i.startsWith("And_")||i.startsWith("Boolean")||i.startsWith("Cross_")||i.startsWith("Dot_")||i.startsWith("Not_")||i.startsWith("Or_")||i.startsWith("Percent_")||i.startsWith("Xor_"))return Jt;switch(i){case"Abs":case"Array_Add":case"Array_AddUnique":case"Array_Identical":case"BMax":case"BMin":case"CrossProduct2D":case"DotProduct2D":case"Exp":case"FMax":case"FMin":case"GetPI":case"Max":case"MaxInt64":case"Min":case"MinInt64":case"Sqrt":case"Square":case"Vector4_CrossProduct3":case"Vector4_DotProduct":case"Vector4_DotProduct3":case"Acos":case"Asin":case"Cos":case"DegAcos":case"DegCos":case"DegSin":case"DegTan":case"Sin":case"Tan":return Jt}}if(t===re.paths.blueprintSetLibrary)return Jt;if(t===re.paths.blueprintMapLibrary)return Jt}switch(e.getClass()){case re.paths.comment:case re.paths.materialGraphNodeComment:return Yt;case re.paths.createDelegate:return Wt;case re.paths.metasoundEditorGraphExternalNode:return"Add"==e.ClassName?.Name?Zt:ri;case re.paths.niagaraNodeOp:if(["Boolean::LogicEq","Boolean::LogicNEq","Numeric::Abs","Numeric::Add","Numeric::Mul"].includes(e.OpName))return Jt;break;case re.paths.promotableOperator:return Jt;case re.paths.knot:return ni;case re.paths.literal:case re.paths.self:case re.paths.variableGet:case re.paths.variableSet:return ai}return e.isEvent()?ii:Wt}class li{static#je=new Map;static registerSerializer(e,t){li.#je.set(e,t)}static getSerializer(e){return li.#je.get(e)}}class ui extends Ot{static properties={...super.properties,selected:{type:Boolean,attribute:"data-selected",reflect:!0,converter:ae.booleanConverter}};dragHandler=e=>this.addLocation(...e.detail.value);constructor(){super(),this.selected=!1,this.listeningDrag=!1}setup(){super.setup(),this.setSelected(this.selected)}cleanup(){super.cleanup(),this.blueprint.removeEventListener(re.nodeDragGeneralEventName,this.dragHandler)}setSelected(e=!0){this.selected=e,this.blueprint&&(this.selected?(this.listeningDrag=!0,this.blueprint.addEventListener(re.nodeDragGeneralEventName,this.dragHandler)):(this.blueprint.removeEventListener(re.nodeDragGeneralEventName,this.dragHandler),this.listeningDrag=!1))}}class ci extends ui{static properties={...ui.properties,typePath:{type:String,attribute:"data-type",reflect:!0},nodeTitle:{type:String,attribute:"data-title",reflect:!0},advancedPinDisplay:{type:String,attribute:"data-advanced-display",converter:wt.attributeConverter,reflect:!0},enabledState:{type:String,attribute:"data-enabled-state",reflect:!0},nodeDisplayName:{type:String,attribute:!1},pureFunction:{type:Boolean,converter:ae.booleanConverter,attribute:"data-pure-function",reflect:!0}};static dragEventName=re.nodeDragEventName;static dragGeneralEventName=re.nodeDragGeneralEventName;get blueprint(){return super.blueprint}set blueprint(e){super.blueprint=e,this.#Ue.forEach((t=>t.blueprint=e))}#We;get nodeNameElement(){return this.#We}set nodeNameElement(e){this.#We=e}#Ue=[];boundComments=[];#Ke=!1;#Ye=e=>{this.selected||this.#Ke||(this.#Ke=!0,this.requestUpdate(),this.updateComplete.then((()=>this.#Ke=!1)),this.addLocation(...e.detail.value))};static fromSerializedObject(e){e=e.trim();let t=li.getSerializer(Pt).read(e);return ci.newObject(t)}static newObject(e=new Pt,t=new(oi(e))){const i=new ci;return i.initialize(e,t),i}#Xe(e){for(let t of this.getPinElements())for(let i of t.getLinks())this.blueprint.getPin(i).redirectLink(t,new at({objectName:e,pinGuid:t.entity.PinId}))}initialize(e=new Pt,t=new(oi(e))){this.typePath=e.getType(),this.nodeTitle=e.getObjectName(),this.advancedPinDisplay=e.AdvancedPinDisplay?.toString(),this.enabledState=e.EnabledState,this.nodeDisplayName=Oe(e),this.pureFunction=e.bIsPureFunc,this.dragLinkObjects=[],super.initialize(e,t),this.#Ue=this.template.createPinElements(),super.setLocation(this.entity.getNodePosX(),this.entity.getNodePosY()),this.entity.NodeWidth&&this.entity.NodeHeight?(this.sizeX=this.entity.NodeWidth.value,this.sizeY=this.entity.NodeHeight.value):this.updateComplete.then((()=>this.computeSizes())),e.listenAttribute("Name",(t=>{this.nodeTitle=e.Name,this.nodeDisplayName=Oe(e),this.#Xe(t)}))}async getUpdateComplete(){let e=await super.getUpdateComplete();for(const t of this.getPinElements())e&&=await t.updateComplete;return e}bindToComment(e){e==this||this.boundComments.includes(e)||(e.addEventListener(re.nodeDragEventName,this.#Ye),this.boundComments.push(e))}unbindFromComment(e){const t=this.boundComments.indexOf(e);t>=0&&(e.removeEventListener(re.nodeDragEventName,this.#Ye),this.boundComments[t]=this.boundComments[this.boundComments.length-1],this.boundComments.pop())}isInsideComment(e){return this.topBoundary()>=e.topBoundary()&&this.rightBoundary()<=e.rightBoundary()&&this.bottomBoundary()<=e.bottomBoundary()&&this.leftBoundary()>=e.leftBoundary()}getType(){return this.entity.getType()}getNodeName(){return this.entity.getObjectName()}computeNodeDisplayName(){this.nodeDisplayName=Oe(this.entity)}setNodeWidth(e){this.entity.setNodeWidth(e),this.sizeX=e,this.acknowledgeReflow()}setNodeHeight(e){this.entity.setNodeHeight(e),this.sizeY=e,this.acknowledgeReflow()}sanitizeLinks(e=[]){this.getPinElements().forEach((t=>t.sanitizeLinks(e)))}getPinElements(){return this.#Ue}getPinEntities(){return this.entity.getPinEntities()}setLocation(e=0,t=0,i=!0){this.entity.setNodePosX(e),this.entity.setNodePosY(t),super.setLocation(e,t,i)}acknowledgeReflow(){this.requestUpdate(),this.updateComplete.then((()=>this.computeSizes()));let e=new CustomEvent(re.nodeReflowEventName);this.dispatchEvent(e)}setShowAdvancedPinDisplay(e){this.entity.AdvancedPinDisplay=new wt(e?"Shown":"Hidden"),this.advancedPinDisplay=this.entity.AdvancedPinDisplay}toggleShowAdvancedPinDisplay(){this.setShowAdvancedPinDisplay("Shown"!=this.entity.AdvancedPinDisplay?.toString())}}class hi extends Pt{#qe=new Map;#Ze=[];get objectEntities(){return this.#Ze}getHomonymObjectEntity(e){const t=e.getObjectName(!1);return this.#Ze.find((e=>e.getObjectName()==t))}takeFreeName(e){e=e.replace(/_\d+$/,"");const t=(this.#qe.get(e)??-1)+1;return this.#qe.set(e,t),re.nodeTitle(e,t)}addObjectEntity(e){if(!this.#Ze.includes(e)){this.#Ze.push(e);const[t,i]=e.getNameAndCounter();return this.#qe.set(t,Math.max(this.#qe.get(t)??0,i)),!0}return!1}removeObjectEntity(e){const t=this.#Ze.indexOf(e);if(t>=0){const e=this.#Ze.pop();return te.OriginalChangeId.value==t.OriginalChangeId.value));if(t.length===this.ScriptVariables.length)return this;const i=t.concat(t).map(((i,s)=>{const n=re.subObjectAttributeNameFromReference(i.ScriptVariable,s>=t.length);return[n,this[n]??e[n]]}));return i.push(...Object.entries(this).filter((([e,t])=>!e.startsWith(re.subObjectAttributeNamePrefix)&&"ExportedNodes"!==e))),new hi(Object.fromEntries(i))}}class pi{static same=e=>e;static notWrapped=(e,t)=>t;static bracketsWrapped=(e,t)=>`(${t})`;constructor(e,t=((e,t)=>t),i=",",s=!1,n="=",r=pi.same){this.entityType=e,this.wrap=t,this.attributeSeparator=i,this.trailingSeparator=s,this.attributeValueConjunctionSign=n,this.attributeKeyPrinter=r}read(e){return this.doRead(e.trim())}write(e,t=!1){return this.doWrite(e,t)}doRead(e){const t=Ie.grammarFor(void 0,this.entityType).run(e);if(!t.status)throw new Error(this.entityType?`Error when trying to parse the entity ${this.entityType.prototype.constructor.name}`:"Error when trying to parse null");return t.value}doWrite(e,t=!1,i="",s=this.wrap,n=this.attributeSeparator,r=this.trailingSeparator,a=this.attributeValueConjunctionSign,o=this.attributeKeyPrinter){let l="";const u=e._keys??Object.keys(e);let c=!0;for(const s of u){const r=e[s];if(void 0!==r&&this.showProperty(e,s)){let u=e instanceof Array?`(${s})`:s;Ae.getAttribute(e,s,"quoted")&&(u=`"${u}"`);const h=Ae.getAttribute(e,s,"serialized");if(c?c=!1:l+=n,Ae.getAttribute(e,s,"inlined")){l+=this.doWrite(r,t,i,pi.notWrapped,n,!1,a,Ae.getAttribute(e,s,"type")instanceof Array?e=>o(`${u}${e}`):e=>o(`${u}.${e}`));continue}const p=o(u),d=n.includes("\n")?i:"";l+=(p.length?d+p+this.attributeValueConjunctionSign:"")+(h?`"${this.doWriteValue(r,!0,i)}"`:this.doWriteValue(r,t,i))}}return r&&l.length&&(l+=n),s(e,l)}doWriteValue(e,t,i=""){const s=ae.getType(e),n=li.getSerializer(s);if(!n)throw new Error(`Unknown value type "${s.name}", a serializer must be registered in the SerializerFactory class, check initializeSerializerFactory.js`);return n.doWrite(e,t,i)}showProperty(e,t){if(e instanceof Le){if(Ae.getAttribute(e,t,"ignored"))return!1;if(Ae.getAttribute(e,t,"silent")){let i=Ae.getAttribute(e,t,"default");if(i instanceof Function&&(i=i(e)),ae.equals(e[t],i))return!1}}return!0}}class di extends pi{constructor(e=Pt){super(e,void 0,"\n",!0,void 0,pi.same)}showProperty(e,t){switch(t){case"Class":case"Name":case"Archetype":case"ExportPath":case"CustomProperties":return!1}return super.showProperty(e,t)}write(e,t=!1){return this.doWrite(e,t)+"\n"}doRead(e){return Ie.grammarFor(void 0,this.entityType).parse(e)}readMultiple(e){return Pt.getMultipleObjectsGrammar().parse(e)}doWrite(e,t,i="",s=this.wrap,n=this.attributeSeparator,r=this.trailingSeparator,a=this.attributeValueConjunctionSign,o=this.attributeKeyPrinter){const l=i+re.indentation;if(!(e instanceof Pt))return super.doWrite(e,t,i,s,n,r,a,(t=>e[t]instanceof Pt?"":o(t)));return i+"Begin Object"+(e.Class?.type||e.Class?.path?` Class=${this.doWriteValue(e.Class,t)}`:"")+(e.Name?` Name=${this.doWriteValue(e.Name,t)}`:"")+(e.Archetype?` Archetype=${this.doWriteValue(e.Archetype,t)}`:"")+(e.ExportPath?.type||e.ExportPath?.path?` ExportPath=${this.doWriteValue(e.ExportPath,t)}`:"")+"\n"+super.doWrite(e,t,l,s,n,!0,a,(t=>e[t]instanceof Pt?"":o(t)))+(Ae.getAttribute(e,"CustomProperties","ignored")?"":e.getCustomproperties().map((e=>l+o("CustomProperties ")+li.getSerializer(ft).doWrite(e,t)+this.attributeSeparator)).join(""))+i+"End Object"}}class mi extends At{static#Qe=new di;#Je;constructor(e,t,i={}){i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,super(e,t,i);let s=this;this.#Je=()=>s.copied()}listenEvents(){window.addEventListener("copy",this.#Je)}unlistenEvents(){window.removeEventListener("copy",this.#Je)}getSerializedText(){const e=this.blueprint.getNodes(!0).map((e=>e.entity)),t=e.filter((e=>e.isExported)).map((e=>mi.#Qe.write(e,!1))),i=e.filter((e=>!e.isExported)).map((e=>mi.#Qe.write(e,!1)));return t.length&&(this.blueprint.entity.ExportedNodes=btoa(t.join("")),i.splice(0,0,mi.#Qe.write(this.blueprint.entity,!1)),delete this.blueprint.entity.ExportedNodes),i.join("")}copied(){const e=this.getSerializedText();return navigator.clipboard.writeText(e),e}}class gi extends At{static#Qe=new di;#et;constructor(e,t,i={}){i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,super(e,t,i);let s=this;this.#et=()=>s.cut()}listenEvents(){window.addEventListener("cut",this.#et)}unlistenEvents(){window.removeEventListener("cut",this.#et)}getSerializedText(){return this.blueprint.getNodes(!0).map((e=>gi.#Qe.write(e.entity,!1))).join("")}cut(){this.blueprint.template.getCopyInputObject().copied(),this.blueprint.removeGraphElement(...this.blueprint.getNodes(!0))}}class bi extends At{static#Qe=new di;#tt;constructor(e,t,i={}){i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,super(e,t,i);let s=this;this.#tt=e=>s.pasted(e.clipboardData.getData("Text"))}listenEvents(){window.addEventListener("paste",this.#tt)}unlistenEvents(){window.removeEventListener("paste",this.#tt)}pasted(e){let t=0,i=0,s=0,n=bi.#Qe.readMultiple(e).map((e=>{let n=ce.getConstructor("ueb-node").newObject(e);return t+=n.locationY,i+=n.locationX,++s,n}));t/=s,i/=s,n.length>0&&this.blueprint.unselectAll();let r=this.blueprint.mousePosition;return n.forEach((e=>{e.addLocation(r[0]-i,r[1]-t),e.snapToGrid(),e.setSelected(!0)})),this.blueprint.addGraphElement(...n),n}}class vi extends Tt{static#U=e=>{};#it=0;get variation(){return this.#it}#st=e=>{this.enablerKey&&!this.enablerActivated||(e.preventDefault(),this.#it=e.deltaY,this.setLocationFromEvent(e),this.wheel())};#nt=e=>e.preventDefault();constructor(e,t,i={},s=vi.#U){i.listenOnFocus=!0,i.strictTarget??=!1,super(e,t,i),this.strictTarget=i.strictTarget,this.onWheel=s}listenEvents(){this.movementSpace.addEventListener("wheel",this.#st,!1),this.movementSpace.parentElement?.addEventListener("wheel",this.#nt)}unlistenEvents(){this.movementSpace.removeEventListener("wheel",this.#st,!1),this.movementSpace.parentElement?.removeEventListener("wheel",this.#nt)}wheel(){this.onWheel(this)}}class fi extends vi{#rt=0;#at=!1;get enableZoonIn(){return this.#at}set enableZoonIn(e){e!=this.#at&&(this.#at=e)}wheel(){if(this.#rt+=-this.variation,Math.abs(this.#rt)0||(e+=Math.sign(this.#rt),this.blueprint.setZoom(e,this.location),this.#rt=0)}}class yi extends Mt{#ot;constructor(e,t,i={}){i.activationKeys=ue.enableZoomIn,super(e,t,i)}fire(){this.#ot=this.blueprint.template.getZoomInputObject(),this.#ot.enableZoonIn=!0}unfire(){this.#ot.enableZoonIn=!1}}class wi extends Rt{startDrag(){this.blueprint.scrolling=!0}dragTo(e,t){this.blueprint.scrollDelta(-t[0],-t[1])}endDrag(){this.blueprint.scrolling=!1}}class Si extends Tt{#lt=null;#ut=e=>{e.preventDefault(),this.setLocationFromEvent(e),this.blueprint.mousePosition=[...this.location]};#ct=e=>{this.#lt||(e.preventDefault(),this.#lt=e.detail.tracker,this.unlistenMouseMove())};#ht=e=>{this.#lt==e.detail.tracker&&(e.preventDefault(),this.#lt=null,this.listenMouseMove())};constructor(e,t,i={}){i.listenOnFocus=!0,super(e,t,i)}listenMouseMove(){this.target.addEventListener("mousemove",this.#ut)}unlistenMouseMove(){this.target.removeEventListener("mousemove",this.#ut)}listenEvents(){this.listenMouseMove(),this.blueprint.addEventListener(re.trackingMouseEventName.begin,this.#ct),this.blueprint.addEventListener(re.trackingMouseEventName.end,this.#ht)}unlistenEvents(){this.unlistenMouseMove(),this.blueprint.removeEventListener(re.trackingMouseEventName.begin,this.#ct),this.blueprint.removeEventListener(re.trackingMouseEventName.end,this.#ht)}}class Ei extends Rt{constructor(e,t,i={}){i.scrollGraphEdge??=!0,super(e,t,i),this.selectorElement=this.blueprint.template.selectorElement}startDrag(){this.selectorElement.beginSelect(this.clickedPosition)}dragTo(e,t){this.selectorElement.selectTo(e)}endDrag(){this.started&&this.selectorElement.endSelect()}unclicked(){this.started||this.blueprint.unselectAll()}}class Ci extends At{#pt=e=>this.clickedSomewhere(e.target);constructor(e,t,i={}){i.listenOnFocus=!0,super(e,t,i),this.blueprint.focus&&document.addEventListener("click",this.#pt)}clickedSomewhere(e){e.closest("ueb-blueprint")||this.blueprint.setFocused(!1)}listenEvents(){document.addEventListener("click",this.#pt)}unlistenEvents(){document.removeEventListener("click",this.#pt)}}class Ni extends Dt{static styleVariables={"--ueb-font-size":`${re.fontSize}`,"--ueb-grid-axis-line-color":`${re.gridAxisLineColor}`,"--ueb-grid-expand":`${re.expandGridSize}px`,"--ueb-grid-line-color":`${re.gridLineColor}`,"--ueb-grid-line-width":`${re.gridLineWidth}px`,"--ueb-grid-set-line-color":`${re.gridSetLineColor}`,"--ueb-grid-set":`${re.gridSet}`,"--ueb-grid-size":`${re.gridSize}px`,"--ueb-link-min-width":`${re.linkMinWidth}`,"--ueb-node-radius":`${re.nodeRadius}px`};#dt=new ResizeObserver((e=>{const t=e.find((e=>e.target===this.viewportElement))?.devicePixelContentBoxSize?.[0];t&&(this.viewportSize[0]=t.inlineSize,this.viewportSize[1]=t.blockSize)}));#mt;#gt;#ot;headerElement;overlayElement;viewportElement;selectorElement;gridElement;linksContainerElement;nodesContainerElement;viewportSize=[0,0];initialize(e){super.initialize(e),this.element.style.cssText=Object.entries(Ni.styleVariables).map((([e,t])=>`${e}:${t};`)).join("");const t=this.element.querySelector(":scope > template")?.content.textContent;t&&(this.element.requestUpdate(),this.element.updateComplete.then((()=>{this.blueprint.mousePosition=[Math.round(this.viewportSize[0]/2),Math.round(this.viewportSize[1]/2)],this.getPasteInputObject().pasted(t),this.blueprint.unselectAll()})))}setup(){super.setup(),this.#dt.observe(this.viewportElement,{box:"device-pixel-content-box"});const e=this.viewportElement.getBoundingClientRect();this.viewportSize[0]=e.width,this.viewportSize[1]=e.height,this.blueprint.nodes.length>0&&(this.blueprint.requestUpdate(),this.blueprint.updateComplete.then((()=>this.centerContentInViewport())))}cleanup(){super.cleanup(),this.#dt.unobserve(this.viewportElement)}createInputObjects(){const e=this.element.getGridDOMElement();return this.#mt=new mi(e,this.blueprint),this.#gt=new bi(e,this.blueprint),this.#ot=new fi(e,this.blueprint),[...super.createInputObjects(),this.#mt,this.#gt,this.#ot,new gi(e,this.blueprint),new Mt(e,this.blueprint,{activationKeys:ue.duplicateNodes},(()=>this.blueprint.template.getPasteInputObject().pasted(this.blueprint.template.getCopyInputObject().copied()))),new Mt(e,this.blueprint,{activationKeys:ue.deleteNodes},(()=>this.blueprint.removeGraphElement(...this.blueprint.getNodes(!0)))),new Mt(e,this.blueprint,{activationKeys:ue.selectAllNodes},(()=>this.blueprint.selectAll())),new Ei(e,this.blueprint,{clickButton:re.mouseClickButton,exitAnyButton:!0,moveEverywhere:!0}),new wi(e,this.blueprint,{clickButton:re.mouseRightClickButton,exitAnyButton:!1,moveEverywhere:!0}),new Ci(e,this.blueprint),new Si(e,this.blueprint),new yi(e,this.blueprint)]}render(){return H`
Zoom ${0==this.blueprint.zoom?"1:1":(this.blueprint.zoom>0?"+":"")+this.blueprint.zoom}
`}firstUpdated(e){super.firstUpdated(e),this.headerElement=this.blueprint.querySelector(".ueb-viewport-header"),this.overlayElement=this.blueprint.querySelector(".ueb-viewport-overlay"),this.viewportElement=this.blueprint.querySelector(".ueb-viewport-body"),this.selectorElement=this.blueprint.querySelector("ueb-selector"),this.gridElement=this.viewportElement.querySelector(".ueb-grid"),this.linksContainerElement=this.blueprint.querySelector("[data-links]"),this.linksContainerElement.append(...this.blueprint.getLinks()),this.nodesContainerElement=this.blueprint.querySelector("[data-nodes]"),this.nodesContainerElement.append(...this.blueprint.getNodes()),this.viewportElement.scroll(re.expandGridSize,re.expandGridSize)}willUpdate(e){super.willUpdate(e),this.headerElement&&e.has("zoom")&&(this.headerElement.classList.add("ueb-zoom-changed"),this.headerElement.addEventListener("animationend",(()=>this.headerElement.classList.remove("ueb-zoom-changed"))))}updated(e){if(super.updated(e),(e.has("scrollX")||e.has("scrollY"))&&this.viewportElement.scroll(this.blueprint.scrollX,this.blueprint.scrollY),e.has("zoom")){this.blueprint.style.setProperty("--ueb-scale",this.blueprint.getScale());const t=e.get("zoom"),i=Math.min(t,this.blueprint.zoom),s=Math.max(t,this.blueprint.zoom),n=ae.range(i,s),r=e=>`ueb-zoom-${e}`;te<0)).map(r)),this.blueprint.classList.add(...n.filter((e=>e>0)).map(r))):(this.blueprint.classList.remove(...n.filter((e=>e>0)).map(r)),this.blueprint.classList.add(...n.filter((e=>e<0)).map(r)))}}getCommentNodes(e=!1){return this.blueprint.querySelectorAll(`ueb-node[data-type="${re.paths.comment}"]${e?'[data-selected="true"]':""}, ueb-node[data-type="${re.paths.materialGraphNodeComment}"]${e?'[data-selected="true"]':""}`)}getPin(e){return this.blueprint.querySelector(`ueb-node[data-title="${e.objectName}"] ueb-pin[data-id="${e.pinGuid}"]`)}getCopyInputObject(){return this.#mt}getPasteInputObject(){return this.#gt}getZoomInputObject(){return this.#ot}isPointVisible(e,t){return!1}gridTopVisibilityBoundary(){return this.blueprint.scaleCorrect(this.blueprint.scrollY)-this.blueprint.translateY}gridRightVisibilityBoundary(){return this.gridLeftVisibilityBoundary()+this.blueprint.scaleCorrect(this.viewportSize[0])}gridBottomVisibilityBoundary(){return this.gridTopVisibilityBoundary()+this.blueprint.scaleCorrect(this.viewportSize[1])}gridLeftVisibilityBoundary(){return this.blueprint.scaleCorrect(this.blueprint.scrollX)-this.blueprint.translateX}centerViewport(e=0,t=0,i=!0){const s=this.gridLeftVisibilityBoundary()+this.blueprint.scaleCorrect(this.viewportSize[0]/2),n=this.gridTopVisibilityBoundary()+this.blueprint.scaleCorrect(this.viewportSize[1]/2);this.blueprint.scrollDelta(this.blueprint.scaleCorrectReverse(e-s),this.blueprint.scaleCorrectReverse(t-n),i)}centerContentInViewport(e=!0){let t=0,i=0,s=Number.MAX_SAFE_INTEGER,n=Number.MIN_SAFE_INTEGER,r=Number.MAX_SAFE_INTEGER,a=Number.MIN_SAFE_INTEGER;const o=this.blueprint.getNodes();for(const e of o)t+=e.leftBoundary()+e.rightBoundary(),i+=e.topBoundary()+e.bottomBoundary(),s=Math.min(s,e.leftBoundary()),n=Math.max(n,e.rightBoundary()),r=Math.min(r,e.topBoundary()),a=Math.max(a,e.bottomBoundary());t=Math.round(n-s<=this.viewportSize[0]?(n+s)/2:t/(2*o.length)),i=Math.round(a-r<=this.viewportSize[1]?(a+r)/2:i/(2*o.length)),this.centerViewport(t,i,e)}}class xi extends oe{static properties={selecting:{type:Boolean,attribute:"data-selecting",reflect:!0,converter:ae.booleanConverter},scrolling:{type:Boolean,attribute:"data-scrolling",reflect:!0,converter:ae.booleanConverter},focused:{type:Boolean,attribute:"data-focused",reflect:!0,converter:ae.booleanConverter},zoom:{type:Number,attribute:"data-zoom",reflect:!0},scrollX:{type:Number,attribute:!1},scrollY:{type:Number,attribute:!1},additionalX:{type:Number,attribute:!1},additionalY:{type:Number,attribute:!1},translateX:{type:Number,attribute:!1},translateY:{type:Number,attribute:!1}};static nodeBoundariesSupplier=e=>({primaryInf:e.leftBoundary(!0),primarySup:e.rightBoundary(!0),secondaryInf:e.topBoundary(!0),secondarySup:e.bottomBoundary(!0)});static nodeSelectToggleFunction=(e,t)=>{e.setSelected(t)};#bt=0;#vt=0;nodes=[];links=[];nodesNames=new Map;mousePosition=[0,0];waitingExpandUpdate=!1;constructor(){super(),this.selecting=!1,this.scrolling=!1,this.focused=!1,this.zoom=0,this.scrollX=re.expandGridSize,this.scrollY=re.expandGridSize,this.translateX=re.expandGridSize,this.translateY=re.expandGridSize,super.initialize(new hi,new Ni)}initialize(){}getGridDOMElement(){return this.template.gridElement}getScroll(){return[this.scrollX,this.scrollY]}setScroll(e,t){this.scrollX=e,this.scrollY=t}scrollDelta(e=0,t=0,i=!1,s=re.smoothScrollTime){if(i){let i=[0,0];this.#bt&&cancelAnimationFrame(this.#bt),this.#vt&&cancelAnimationFrame(this.#vt),ae.animate(0,e,s,(e=>{this.scrollDelta(e-i[0],0,!1),i[0]=e}),(e=>this.#bt=e)),ae.animate(0,t,s,(e=>{this.scrollDelta(0,e-i[1],!1),i[1]=e}),(e=>this.#vt=e))}else{const i=[2*re.expandGridSize,2*re.expandGridSize];let s=this.getScroll(),n=[s[0]+e,s[1]+t],r=[0,0];for(let e=0;e<2;++e)n[e]i[e]-re.gridExpandThreshold*re.expandGridSize&&(r[e]=1);0==r[0]&&0==r[1]||this.seamlessExpand(r[0],r[1]),s=this.getScroll(),n=[s[0]+e,s[1]+t],this.setScroll(n[0],n[1])}}scrollCenter(e=!1){const t=this.getScroll(),i=[this.translateX-t[0],this.translateY-t[1]],s=this.getViewportSize().map((e=>e/2)),n=[i[0]-s[0],i[1]-s[1]];this.scrollDelta(n[0],n[1],e)}getViewportSize(){return[this.template.viewportElement.clientWidth,this.template.viewportElement.clientHeight]}getScrollMax(){return[this.template.viewportElement.scrollWidth-this.template.viewportElement.clientWidth,this.template.viewportElement.scrollHeight-this.template.viewportElement.clientHeight]}snapToGrid(e,t){return ae.snapToGrid(e,t,re.gridSize)}seamlessExpand(e,t){e=Math.round(e),t=Math.round(t);let i=this.getScale();[e,t]=[-e*re.expandGridSize,-t*re.expandGridSize],0!=e&&(this.scrollX+=e,e/=i),0!=t&&(this.scrollY+=t,t/=i),this.translateX+=e,this.translateY+=t}progressiveSnapToGrid(e){return re.expandGridSize*Math.round(e/re.expandGridSize+.5*Math.sign(e))}getZoom(){return this.zoom}setZoom(e,t){if((e=ae.clamp(e,re.minZoom,re.maxZoom))==this.zoom)return;let i=this.getScale();if(this.zoom=e,t){t[0]+=this.translateX,t[1]+=this.translateY;let e=this.getScale()/i,s=[e*t[0],e*t[1]];this.scrollDelta((s[0]-t[0])*i,(s[1]-t[1])*i)}}getScale(){return re.scale[this.getZoom()]}scaleCorrect(e){return e/this.getScale()}scaleCorrectReverse(e){return e*this.getScale()}compensateTranslation(e,t){return[e-=this.translateX,t-=this.translateY]}getNodes(e=!1,[t,i,s,n]=[Number.MIN_SAFE_INTEGER,Number.MAX_SAFE_INTEGER,Number.MAX_SAFE_INTEGER,Number.MIN_SAFE_INTEGER]){let r=this.nodes;return e&&(r=r.filter((e=>e.selected))),(t>Number.MIN_SAFE_INTEGER||iNumber.MIN_SAFE_INTEGER)&&(r=r.filter((e=>e.topBoundary()>=t&&e.rightBoundary()<=i&&e.bottomBoundary()<=s&&e.leftBoundary()>=n))),r}getCommentNodes(e=!1){let t=[...this.template.getCommentNodes(e)];return 0===t.length&&(t=this.nodes.filter((t=>t.getType()===re.paths.comment&&(!e||t.selected)))),t}getPin(e){let t=this.template.getPin(e);return t&&t.nodeElement.getNodeName()==e.objectName.toString()||(t=[...this.nodes.find((t=>e.objectName.toString()==t.getNodeName()))?.getPinElements()??[]].find((t=>e.pinGuid.toString()==t.getPinId().toString()))),t}getLinks(e=null,t=null){if(null==e!=(null==t)){const i=e??t;return this.links.filter((e=>e.source==i||e.destination==i))}return null!=e&&null!=t?this.links.filter((i=>i.source==e&&i.destination==t||i.source==t&&i.destination==e)):this.links}getLink(e,t,i=!1){return this.links.find((s=>s.source==e&&s.destination==t||!i&&s.source==t&&s.destination==e))}selectAll(){this.getNodes().forEach((e=>xi.nodeSelectToggleFunction(e,!0)))}unselectAll(){this.getNodes().forEach((e=>xi.nodeSelectToggleFunction(e,!1)))}addGraphElement(...e){const t=e=>{const i=e.currentTarget;i.removeEventListener(re.removeEventName,t);const[s,n]=i instanceof ci?[this.nodes,i.entity]:i instanceof Ht?[this.links]:null,r=s?.indexOf(i);if(r>=0){const e=s.pop();re.entity._exported=!0));continue}const e=i.entity.getObjectName(),s=this.entity.getHomonymObjectEntity(i.entity);s&&(s.Name=this.entity.takeFreeName(e)),this.nodes.push(i),this.entity.addObjectEntity(i.entity),i.addEventListener(re.removeEventName,t),this.template.nodesContainerElement?.appendChild(i)}else i instanceof Ht&&!this.links.includes(i)&&(this.links.push(i),i.addEventListener(re.removeEventName,t),this.template.linksContainerElement&&!this.template.linksContainerElement.contains(i)&&this.template.linksContainerElement.appendChild(i));e.filter((e=>e instanceof ci)).forEach((t=>t.sanitizeLinks(e))),e.filter((e=>e instanceof ci&&e.getType()==re.paths.comment)).forEach((e=>e.updateComplete.then((()=>e.template.manageNodesBind()))))}removeGraphElement(...e){for(let t of e){if(t.closest("ueb-blueprint")!==this)return;t.remove()}}setFocused(e=!0){if(this.focused==e)return;let t=new CustomEvent(e?re.focusEventName.begin:re.focusEventName.end);this.focused=e,this.focused||this.unselectAll(),this.dispatchEvent(t)}acknowledgeEditText(e){const t=new CustomEvent(e?re.editTextEventName.begin:re.editTextEventName.end);this.dispatchEvent(t)}}customElements.define("ueb-blueprint",xi);class Pi extends Ft{#ft;get locationChangeCallback(){return this.#ft}set locationChangeCallback(e){this.#ft=e}movementSpace;movementSpaceSize=[0,0];firstUpdated(e){super.firstUpdated(e),this.movementSpace=this.element.parentElement}setup(){super.setup();const e=this.movementSpace.getBoundingClientRect();this.movementSpaceSize=[e.width,e.height]}createDraggableObject(){return new Gt(this.element,this.blueprint,{draggableElement:this.movementSpace,ignoreTranslateCompensate:!0,moveEverywhere:!0,movementSpace:this.movementSpace,repositionOnClick:!0,stepSize:1})}adjustLocation(e,t){return this.locationChangeCallback?.(e,t),[e,t]}}class ki extends Pi{adjustLocation(e,t){const i=Math.round(this.movementSpaceSize[0]/2);e-=i,t=-(t-i);let[s,n]=ae.getPolarCoordinates(e,t);return s=Math.min(s,i),[e,t]=ae.getCartesianCoordinates(s,n),this.locationChangeCallback?.(e/i,t/i),[e=Math.round(e+i),t=Math.round(-t+i)]}}class Ai extends Ot{windowElement;setup(){super.setup(),this.windowElement=this.closest("ueb-window")}setLocation(e,t){super.setLocation(...this.template.adjustLocation(e,t))}}class Li extends Ai{constructor(){super(),super.initialize({},new ki)}static newObject(){return new Li}initialize(){}}class Mi extends Pi{adjustLocation(e,t){return e=ae.clamp(e,0,this.movementSpaceSize[0]),t=ae.clamp(t,0,this.movementSpaceSize[1]),this.locationChangeCallback?.(e/this.movementSpaceSize[0],1-t/this.movementSpaceSize[1]),[e,t]}}class Ti extends Ai{constructor(){super(),super.initialize({},new Mi)}static newObject(){return new Ti}initialize(){}}class Ii extends Rt{constructor(e,t,i={}){i.consumeEvent=!0,super(e,t,i)}}class $i extends Dt{#yt;#wt;#St=e=>this.element.selectedOption=e.target.selectedOptions[0].value;render(){return H` `}firstUpdated(e){super.firstUpdated(e),this.#yt=this.element.querySelector("select:first-child"),this.#wt=this.element.querySelector("select:last-child");const t=new Event("input",{bubbles:!0});this.#yt.dispatchEvent(t)}updated(e){super.updated(e);const t=this.#wt.getBoundingClientRect();this.element.style.setProperty("--ueb-dropdown-width",t.width+"px")}createInputObjects(){return[...super.createInputObjects(),new Ii(this.element,this.blueprint)]}setSelectedValue(e){this.element.querySelector(`option[value="${e}"]`).defaultSelected=!0}getSelectedValue(){return this.#yt.value}}class Di extends oe{static properties={...super.properties,options:{type:Object},selectedOption:{type:String}};constructor(){super(),super.initialize({},new $i),this.options=[],this.selectedOption=""}static newObject(e){return new Di}initialize(){}getValue(){return this.template.getSelectedValue()}}class Bi extends Dt{#Et=()=>{this.blueprint.acknowledgeEditText(!0),this.element.selectOnFocus&&getSelection().selectAllChildren(this.element)};#Ct=()=>{this.blueprint.acknowledgeEditText(!1),getSelection().removeAllRanges()};#Nt=e=>e.target.querySelectorAll("br").forEach((e=>e.remove()));#xt=e=>{"Enter"!=e.code||e.shiftKey||e.target.blur()};initialize(e){super.initialize(e),this.element.classList.add("ueb-pin-input-content"),this.element.setAttribute("role","textbox"),this.element.contentEditable="true"}firstUpdated(e){super.firstUpdated(e);const t=new Event("input",{bubbles:!0});this.element.dispatchEvent(t)}createInputObjects(){return[...super.createInputObjects(),new Ii(this.element,this.blueprint)]}setup(){super.setup(),this.element.addEventListener("focus",this.#Et),this.element.addEventListener("focusout",this.#Ct),this.element.singleLine&&this.element.addEventListener("input",this.#Nt),this.element.blurOnEnter&&this.element.addEventListener("keydown",this.#xt)}cleanup(){super.cleanup(),this.element.removeEventListener("focus",this.#Et),this.element.removeEventListener("focusout",this.#Ct),this.element.removeEventListener("input",this.#Nt),this.element.removeEventListener("keydown",this.#xt)}}class Vi extends oe{static properties={...super.properties,singleLine:{type:Boolean,attribute:"data-single-line",converter:ae.booleanConverter,reflect:!0},selectOnFocus:{type:Boolean,attribute:"data-select-focus",converter:ae.booleanConverter,reflect:!0},blurOnEnter:{type:Boolean,attribute:"data-blur-enter",converter:ae.booleanConverter,reflect:!0}};constructor(){super(),this.singleLine=!1,this.selectOnFocus=!0,this.blurOnEnter=!0,super.initialize({},new Bi)}static newObject(){return new Vi}initialize(){}}class Hi extends ei{#Pt;#kt=()=>this.element.setDefaultValue(this.#Pt.checked);firstUpdated(e){super.firstUpdated(e),this.#Pt=this.element.querySelector(".ueb-pin-input")}setup(){super.setup(),this.#Pt?.addEventListener("change",this.#kt)}cleanup(){super.cleanup(),this.#Pt?.removeEventListener("change",this.#kt)}createInputObjects(){return[...super.createInputObjects(),new Ii(this.#Pt,this.blueprint)]}renderInput(){return H``}}class Oi extends ei{static singleLineInput=!1;static selectOnFocus=!0;static saveEachInputChange=!1;#At;get inputWrapper(){return this.#At}#Lt;static stringFromInputToUE(e){return e.replace(/(?=\n\s*)\n$/,"")}static stringFromUEToInput(e){return e.replaceAll(/(?:\r|(?<=(?:^|[^\\])(?:\\\\)*)\\r)(?=\n)/g,"").replace(/(?<=\n\s*)$/,"\n")}#Mt=()=>this.setInputs(this.getInputs(),!0);#Tt=e=>this.#It(e.target);#It(e){const t=this.blueprint.scaleCorrect(this.#At.getBoundingClientRect().width)+this.nameWidth,i=this.element.classList.contains("ueb-pin-input-wrap");!i&&t>re.pinInputWrapWidth?this.element.classList.add("ueb-pin-input-wrap"):i&&t<=re.pinInputWrapWidth&&this.element.classList.remove("ueb-pin-input-wrap")}firstUpdated(e){super.firstUpdated(e);this.constructor.canWrapInput&&this.isInputRendered()&&(this.element.addEventListener("input",this.#Tt),this.nameWidth=this.blueprint.scaleCorrect(this.element.querySelector(".ueb-pin-name")?.getBoundingClientRect().width??0)),this.#At=this.element.querySelector(".ueb-pin-input-wrapper"),this.#Lt=[...this.element.querySelectorAll("ueb-input")]}setup(){super.setup();const e=this.constructor;e.saveEachInputChange?this.element.addEventListener("input",this.#Mt):this.element.addEventListener("focusout",this.#Mt),e.canWrapInput&&this.isInputRendered()&&(this.element.addEventListener("input",this.#Tt),this.element.nodeElement.addEventListener(re.nodeReflowEventName,this.#Tt))}cleanup(){super.cleanup(),this.element.nodeElement.removeEventListener(re.nodeReflowEventName,this.#Tt),this.element.removeEventListener("input",this.#Tt),this.element.removeEventListener("input",this.#Mt),this.element.removeEventListener("focusout",this.#Mt)}getInput(){return this.getInputs().reduce(((e,t)=>e+t),"")}getInputs(){return this.#Lt.map((e=>ae.clearHTMLWhitespace(e.innerHTML)))}setInputs(e=[],t=!0){this.#Lt.forEach(this.constructor.singleLineInput?(t,i)=>t.innerText=e[i]:(t,i)=>t.innerText=e[i].replaceAll("\n","")),t&&this.setDefaultValue(e.map((e=>Oi.stringFromInputToUE(e))),e),this.element.requestUpdate(),this.element.nodeElement.acknowledgeReflow()}setDefaultValue(e=[],t=e){this.element.setDefaultValue(e.join(""))}renderInput(){const e=this.constructor,t=e.singleLineInput,i=e.selectOnFocus;return H`
`}}class Ri extends ei{renderIcon(){return Be.execPin}renderName(){let e=this.element.entity.PinName;if(this.element.entity.PinFriendlyName)e=this.element.entity.PinFriendlyName.toString();else if("execute"===e||"then"===e)return H``;return H`${this.element.getPinDisplayName()}`}}class Gi extends Oi{static singleLineInput=!0;setInputs(e=[],t=!1){if(e&&0!=e.length||(e=[this.getInput()]),super.setInputs(e,!1),t){let i=[];for(const s of e){let e=parseFloat(s);isNaN(e)&&(e=0,t=!1),i.push(e)}this.setDefaultValue(i,e)}}setDefaultValue(e=[],t){this.element.setDefaultValue(e[0]),this.element.requestUpdate()}}class zi extends Gi{setDefaultValue(e=[],t){this.element.setDefaultValue(new Ke(e[0])),this.element.requestUpdate()}renderInput(){return H`
`}} +var te,ie;class se extends b{constructor(){super(...arguments),this.renderOptions={host:this},this._$Do=void 0}createRenderRoot(){var e,t;const i=super.createRenderRoot();return null!==(e=(t=this.renderOptions).renderBefore)&&void 0!==e||(t.renderBefore=i.firstChild),i}update(e){const t=this.render();this.hasUpdated||(this.renderOptions.isConnected=this.isConnected),super.update(e),this._$Do=((e,t,i)=>{var s,n;const r=null!==(s=null==i?void 0:i.renderBefore)&&void 0!==s?s:t;let a=r._$litPart$;if(void 0===a){const e=null!==(n=null==i?void 0:i.renderBefore)&&void 0!==n?n:null;r._$litPart$=a=new K(t.insertBefore(P(),e),e,void 0,null!=i?i:{})}return a._$AI(e),a})(t,this.renderRoot,this.renderOptions)}connectedCallback(){var e;super.connectedCallback(),null===(e=this._$Do)||void 0===e||e.setConnected(!0)}disconnectedCallback(){var e;super.disconnectedCallback(),null===(e=this._$Do)||void 0===e||e.setConnected(!1)}render(){return H}}se.finalized=!0,se._$litElement$=!0,null===(te=globalThis.litElementHydrateSupport)||void 0===te||te.call(globalThis,{LitElement:se});const ne=globalThis.litElementPolyfillSupport;null==ne||ne({LitElement:se}),(null!==(ie=globalThis.litElementVersions)&&void 0!==ie?ie:globalThis.litElementVersions=[]).push("3.3.3");class re{static nodeColors={black:r``,blue:r``,darkBlue:r``,darkerBlue:r``,darkTurquoise:r``,gray:r``,green:r``,intenseGreen:r``,lime:r``,red:r``,turquoise:r``,violet:r``,yellow:r``};static alphaPattern="repeating-conic-gradient(#7c8184 0% 25%, #c2c3c4 0% 50%) 50% / 10px 10px";static colorDragEventName="ueb-color-drag";static colorPickEventName="ueb-color-pick";static colorWindowEventName="ueb-color-window";static colorWindowName="Color Picker";static defaultCommentHeight=96;static defaultCommentWidth=400;static distanceThreshold=5;static dragEventName="ueb-drag";static dragGeneralEventName="ueb-drag-general";static edgeScrollThreshold=50;static editTextEventName={begin:"ueb-edit-text-begin",end:"ueb-edit-text-end"};static expandGridSize=400;static focusEventName={begin:"blueprint-focus",end:"blueprint-unfocus"};static fontSize=r``;static gridAxisLineColor=r``;static gridExpandThreshold=.25;static gridLineColor=r``;static gridLineWidth=1;static gridSet=8;static gridSetLineColor=r``;static gridShrinkThreshold=4;static gridSize=16;static hexColorRegex=/^\s*#(?[0-9a-fA-F]{2})(?[0-9a-fA-F]{2})(?[0-9a-fA-F]{2})([0-9a-fA-F]{2})?|#(?[0-9a-fA-F])(?[0-9a-fA-F])(?[0-9a-fA-F])\s*$/;static indentation=" ";static keysSeparator=/[\.\(\)]/;static knotOffset=[-re.gridSize,-.5*re.gridSize];static lineTracePattern=/LineTrace(Single|Multi)(\w*)/;static linkCurveHeight=15;static linkCurveWidth=80;static linkMinWidth=100;static nameRegexSpaceReplacement=new RegExp("^K2(?:[Nn]ode)?_|(?<=[a-z])(?=[A-Z0-9])|(?<=[A-Z])(?{let s=100-e;return`M ${e} 0 C ${t.toFixed(3)} 0, ${i.toFixed(3)} 0, 50 50 S ${(s-t+e).toFixed(3)} 100, ${s.toFixed(3)} 100`};static maxZoom=7;static minZoom=-12;static mouseClickButton=0;static mouseRightClickButton=2;static mouseWheelZoomThreshold=80;static nodeDragEventName="ueb-node-drag";static nodeDragGeneralEventName="ueb-node-drag-general";static nodeTitle=(e,t)=>`${e}_${t}`;static nodeRadius=8;static nodeReflowEventName="ueb-node-reflow";static paths={actorBoundEvent:"/Script/BlueprintGraph.K2Node_ActorBoundEvent",addDelegate:"/Script/BlueprintGraph.K2Node_AddDelegate",ambientSound:"/Script/Engine.AmbientSound",asyncAction:"/Script/BlueprintGraph.K2Node_AsyncAction",blueprint:"/Script/Engine.Blueprint",blueprintGameplayTagLibrary:"/Script/GameplayTags.BlueprintGameplayTagLibrary",blueprintMapLibrary:"/Script/Engine.BlueprintMapLibrary",blueprintSetLibrary:"/Script/Engine.BlueprintSetLibrary",callArrayFunction:"/Script/BlueprintGraph.K2Node_CallArrayFunction",callDelegate:"/Script/BlueprintGraph.K2Node_CallDelegate",callFunction:"/Script/BlueprintGraph.K2Node_CallFunction",comment:"/Script/UnrealEd.EdGraphNode_Comment",commutativeAssociativeBinaryOperator:"/Script/BlueprintGraph.K2Node_CommutativeAssociativeBinaryOperator",componentBoundEvent:"/Script/BlueprintGraph.K2Node_ComponentBoundEvent",createDelegate:"/Script/BlueprintGraph.K2Node_CreateDelegate",customEvent:"/Script/BlueprintGraph.K2Node_CustomEvent",doN:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:Do N",doOnce:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:DoOnce",dynamicCast:"/Script/BlueprintGraph.K2Node_DynamicCast",eAttachmentRule:"/Script/Engine.EAttachmentRule",edGraph:"/Script/Engine.EdGraph",eDrawDebugTrace:"/Script/Engine.EDrawDebugTrace",eMaterialSamplerType:"/Script/Engine.EMaterialSamplerType",eNiagara_Float4Channel:"/Niagara/Enums/ENiagara_Float4Channel.ENiagara_Float4Channel",enum:"/Script/CoreUObject.Enum",enumLiteral:"/Script/BlueprintGraph.K2Node_EnumLiteral",eSamplerSourceMode:"/Script/Engine.ESamplerSourceMode",eSearchCase:"/Script/CoreUObject.ESearchCase",eSearchDir:"/Script/CoreUObject.ESearchDir",eSpawnActorCollisionHandlingMethod:"/Script/Engine.ESpawnActorCollisionHandlingMethod",eTextureMipValueMode:"/Script/Engine.ETextureMipValueMode",eTraceTypeQuery:"/Script/Engine.ETraceTypeQuery",event:"/Script/BlueprintGraph.K2Node_Event",executionSequence:"/Script/BlueprintGraph.K2Node_ExecutionSequence",flipflop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:FlipFlop",forEachElementInEnum:"/Script/BlueprintGraph.K2Node_ForEachElementInEnum",forEachLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ForEachLoop",forEachLoopWithBreak:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ForEachLoopWithBreak",forLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ForLoop",forLoopWithBreak:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ForLoopWithBreak",functionEntry:"/Script/BlueprintGraph.K2Node_FunctionEntry",functionResult:"/Script/BlueprintGraph.K2Node_FunctionResult",gameplayTag:"/Script/GameplayTags.GameplayTag",getInputAxisKeyValue:"/Script/BlueprintGraph.K2Node_GetInputAxisKeyValue",ifThenElse:"/Script/BlueprintGraph.K2Node_IfThenElse",inputAxisKeyEvent:"/Script/BlueprintGraph.K2Node_InputAxisKeyEvent",inputDebugKey:"/Script/InputBlueprintNodes.K2Node_InputDebugKey",inputKey:"/Script/BlueprintGraph.K2Node_InputKey",inputVectorAxisEvent:"/Script/BlueprintGraph.K2Node_InputVectorAxisEvent",isValid:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:IsValid",kismetArrayLibrary:"/Script/Engine.KismetArrayLibrary",kismetMathLibrary:"/Script/Engine.KismetMathLibrary",knot:"/Script/BlueprintGraph.K2Node_Knot",linearColor:"/Script/CoreUObject.LinearColor",literal:"/Script/BlueprintGraph.K2Node_Literal",macro:"/Script/BlueprintGraph.K2Node_MacroInstance",makeArray:"/Script/BlueprintGraph.K2Node_MakeArray",makeMap:"/Script/BlueprintGraph.K2Node_MakeMap",makeSet:"/Script/BlueprintGraph.K2Node_MakeSet",makeStruct:"/Script/BlueprintGraph.K2Node_MakeStruct",materialExpressionComponentMask:"/Script/Engine.MaterialExpressionComponentMask",materialExpressionConstant:"/Script/Engine.MaterialExpressionConstant",materialExpressionConstant2Vector:"/Script/Engine.MaterialExpressionConstant2Vector",materialExpressionConstant3Vector:"/Script/Engine.MaterialExpressionConstant3Vector",materialExpressionConstant4Vector:"/Script/Engine.MaterialExpressionConstant4Vector",materialExpressionFunctionInput:"/Script/Engine.MaterialExpressionFunctionInput",materialExpressionLogarithm:"/Script/InterchangeImport.MaterialExpressionLogarithm",materialExpressionLogarithm10:"/Script/Engine.MaterialExpressionLogarithm10",materialExpressionLogarithm2:"/Script/Engine.MaterialExpressionLogarithm2",materialExpressionMaterialFunctionCall:"/Script/Engine.MaterialExpressionMaterialFunctionCall",materialExpressionSquareRoot:"/Script/Engine.MaterialExpressionSquareRoot",materialExpressionTextureCoordinate:"/Script/Engine.MaterialExpressionTextureCoordinate",materialExpressionTextureSample:"/Script/Engine.MaterialExpressionTextureSample",materialGraphNode:"/Script/UnrealEd.MaterialGraphNode",materialGraphNodeComment:"/Script/UnrealEd.MaterialGraphNode_Comment",metasoundEditorGraphExternalNode:"/Script/MetasoundEditor.MetasoundEditorGraphExternalNode",multiGate:"/Script/BlueprintGraph.K2Node_MultiGate",niagaraBool:"/Script/Niagara.NiagaraBool",niagaraClipboardContent:"/Script/NiagaraEditor.NiagaraClipboardContent",niagaraDataInterfaceVolumeTexture:"/Script/Niagara.NiagaraDataInterfaceVolumeTexture",niagaraFloat:"/Script/Niagara.NiagaraFloat",niagaraMatrix:"/Script/Niagara.NiagaraMatrix",niagaraNodeFunctionCall:"/Script/NiagaraEditor.NiagaraNodeFunctionCall",niagaraNodeOp:"/Script/NiagaraEditor.NiagaraNodeOp",niagaraNumeric:"/Script/Niagara.NiagaraNumeric",niagaraPosition:"/Script/Niagara.NiagaraPosition",pawn:"/Script/Engine.Pawn",pcgEditorGraphNode:"/Script/PCGEditor.PCGEditorGraphNode",pcgEditorGraphNodeInput:"/Script/PCGEditor.PCGEditorGraphNodeInput",pcgEditorGraphNodeOutput:"/Script/PCGEditor.PCGEditorGraphNodeOutput",pcgHiGenGridSizeSettings:"/Script/PCG.PCGHiGenGridSizeSettings",pcgSubgraphSettings:"/Script/PCG.PCGSubgraphSettings",promotableOperator:"/Script/BlueprintGraph.K2Node_PromotableOperator",quat4f:"/Script/CoreUObject.Quat4f",reverseForEachLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:ReverseForEachLoop",rotator:"/Script/CoreUObject.Rotator",select:"/Script/BlueprintGraph.K2Node_Select",self:"/Script/BlueprintGraph.K2Node_Self",slateBlueprintLibrary:"/Script/UMG.SlateBlueprintLibrary",spawnActorFromClass:"/Script/BlueprintGraph.K2Node_SpawnActorFromClass",switchEnum:"/Script/BlueprintGraph.K2Node_SwitchEnum",switchGameplayTag:"/Script/GameplayTagsEditor.GameplayTagsK2Node_SwitchGameplayTag",switchInteger:"/Script/BlueprintGraph.K2Node_SwitchInteger",switchName:"/Script/BlueprintGraph.K2Node_SwitchName",switchString:"/Script/BlueprintGraph.K2Node_SwitchString",timeline:"/Script/BlueprintGraph.K2Node_Timeline",timeManagementBlueprintLibrary:"/Script/TimeManagement.TimeManagementBlueprintLibrary",transform:"/Script/CoreUObject.Transform",userDefinedEnum:"/Script/Engine.UserDefinedEnum",variableGet:"/Script/BlueprintGraph.K2Node_VariableGet",variableSet:"/Script/BlueprintGraph.K2Node_VariableSet",vector:"/Script/CoreUObject.Vector",vector2D:"/Script/CoreUObject.Vector2D",vector3f:"/Script/CoreUObject.Vector3f",vector4f:"/Script/CoreUObject.Vector4f",whileLoop:"/Engine/EditorBlueprintResources/StandardMacros.StandardMacros:WhileLoop"};static pinInputWrapWidth=143;static removeEventName="ueb-element-delete";static scale={[-12]:.133333,[-11]:.166666,[-10]:.2,[-9]:.233333,[-8]:.266666,[-7]:.3,[-6]:.333333,[-5]:.375,[-4]:.5,[-3]:.675,[-2]:.75,[-1]:.875,0:1,1:1.25,2:1.375,3:1.5,4:1.675,5:1.75,6:1.875,7:2};static smoothScrollTime=1e3;static stringEscapedCharacters=/["\\]/g;static subObjectAttributeNamePrefix="#SubObject";static subObjectAttributeNameFromEntity=(e,t=!1)=>this.subObjectAttributeNamePrefix+(!t&&e.Class?`_${e.Class.type}`:"")+"_"+e.Name;static subObjectAttributeNameFromReference=(e,t=!1)=>this.subObjectAttributeNamePrefix+(t?"":"_"+e.type)+"_"+e.path;static subObjectAttributeNameFromName=e=>this.subObjectAttributeNamePrefix+"_"+e;static switchTargetPattern=/\/Script\/[\w\.\/\:]+K2Node_Switch([A-Z]\w+)+/;static trackingMouseEventName={begin:"ueb-tracking-mouse-begin",end:"ueb-tracking-mouse-end"};static unescapedBackslash=/(?<=(?:[^\\]|^)(?:\\\\)*)\\(?!\\)/;static windowApplyEventName="ueb-window-apply";static windowApplyButtonText="OK";static windowCancelEventName="ueb-window-cancel";static windowCancelButtonText="Cancel";static windowCloseEventName="ueb-window-close";static CommonEnums={[this.paths.eAttachmentRule]:["KeepRelative","KeepWorld","SnapToTarget"],[this.paths.eMaterialSamplerType]:["Color","Grayscale","Alpha","Normal","Masks","Distance Field Font","Linear Color","Linear Grayscale","Data","External","Virtual Color","Virtual Grayscale","Virtual Alpha","Virtual Normal","Virtual Mask","Virtual Linear Color","Virtual Linear Grayscal"],[this.paths.eNiagara_Float4Channel]:[["NewEnumerator0","R"],["NewEnumerator1","G"],["NewEnumerator2","B"],["NewEnumerator3","A"]],[this.paths.eSamplerSourceMode]:["From texture asset","Shared: Wrap","Shared: Clamp","Hidden"],[this.paths.eSpawnActorCollisionHandlingMethod]:[["Undefined","Default"],["AlwaysSpawn","Always Spawn, Ignore Collisions"],["AdjustIfPossibleButAlwaysSpawn","Try To Adjust Location, But Always Spawn"],["AdjustIfPossibleButDontSpawnIfColliding","Try To Adjust Location, Don't Spawn If Still Colliding"],["DontSpawnIfColliding","Do Not Spawn"]],[this.paths.eSearchCase]:["CaseSensitive","IgnoreCase"],[this.paths.eSearchDir]:["FromStart","FromEnd"],[this.paths.eDrawDebugTrace]:["None","ForOneFrame","ForDuration","Persistent"],[this.paths.eTextureMipValueMode]:["None (use computed mip level)","MipLevel (absolute, 0 is full resolution)","MipBias (relative to the computed mip level)","Derivative (explicit derivative to compute mip level)"],[this.paths.eTraceTypeQuery]:[["TraceTypeQuery1","Visibility"],["TraceTypeQuery2","Camera"]]};static ModifierKeys=["Ctrl","Shift","Alt","Meta"];static rgba=["R","G","B","A"];static Keys={Backspace:"Backspace",Tab:"Tab",LeftControl:"ControlLeft",RightControl:"ControlRight",LeftShift:"ShiftLeft",RightShift:"ShiftRight",LeftAlt:"AltLeft",RightAlt:"AltRight",Enter:"Enter",Pause:"Pause",CapsLock:"CapsLock",Escape:"Escape",Space:"Space",PageUp:"PageUp",PageDown:"PageDown",End:"End",Home:"Home",ArrowLeft:"ArrowLeft",ArrowUp:"ArrowUp",ArrowRight:"ArrowRight",ArrowDown:"ArrowDown",PrintScreen:"PrintScreen",Insert:"Insert",Delete:"Delete",Zero:"Digit0",One:"Digit1",Two:"Digit2",Three:"Digit3",Four:"Digit4",Five:"Digit5",Six:"Digit6",Seven:"Digit7",Eight:"Digit8",Nine:"Digit9",A:"KeyA",B:"KeyB",C:"KeyC",D:"KeyD",E:"KeyE",F:"KeyF",G:"KeyG",H:"KeyH",I:"KeyI",K:"KeyK",L:"KeyL",M:"KeyM",N:"KeyN",O:"KeyO",P:"KeyP",Q:"KeyQ",R:"KeyR",S:"KeyS",T:"KeyT",U:"KeyU",V:"KeyV",W:"KeyW",X:"KeyX",Y:"KeyY",Z:"KeyZ",NumPadZero:"Numpad0",NumPadOne:"Numpad1",NumPadTwo:"Numpad2",NumPadThree:"Numpad3",NumPadFour:"Numpad4",NumPadFive:"Numpad5",NumPadSix:"Numpad6",NumPadSeven:"Numpad7",NumPadEight:"Numpad8",NumPadNine:"Numpad9",Multiply:"NumpadMultiply",Add:"NumpadAdd",Subtract:"NumpadSubtract",Decimal:"NumpadDecimal",Divide:"NumpadDivide",F1:"F1",F2:"F2",F3:"F3",F4:"F4",F5:"F5",F6:"F6",F7:"F7",F8:"F8",F9:"F9",F10:"F10",F11:"F11",F12:"F12",NumLock:"NumLock",ScrollLock:"ScrollLock"}}class ae{static booleanConverter={fromAttribute:(e,t)=>{},toAttribute:(e,t)=>!0===e?"true":!1===e?"false":""};static sigmoid(e,t=1.7){return 1/(1+e/(1-e)**-t)}static sigmoidPositive(e,t=3.7,i=1.1){return 1-Math.exp(-((e/i)**t))}static clamp(e,t=-1/0,i=1/0){return Math.min(Math.max(e,t),i)}static getScale(e){const t=e.blueprint?.getScale()??getComputedStyle(e).getPropertyValue("--ueb-scale");return""!=t?parseFloat(t):1}static minDecimals(e,t=1,i=1e-8){const s=e*10**t;return Math.abs(s%1)>i?e.toString():e.toFixed(t)}static numberFromText(e=""){switch(e=e.toLowerCase()){case"zero":return 0;case"one":return 1;case"two":return 2;case"three":return 3;case"four":return 4;case"five":return 5;case"six":return 6;case"seven":return 7;case"eight":return 8;case"nine":return 9}}static roundDecimals(e,t=1){const i=10**t;return Math.round(e*i)/i}static printNumber(e){return e==Number.POSITIVE_INFINITY?"inf":e==Number.NEGATIVE_INFINITY?"-inf":ae.minDecimals(e)}static printExponential(e){if(e==Number.POSITIVE_INFINITY)return"inf";if(e==Number.NEGATIVE_INFINITY)return"-inf";const t=Math.round(e);if(t>=1e3){const i=Math.floor(Math.log10(t));return`${Math.round(e/10**(i-2))/100}e+${i<10?"0":""}${i}`}return 0==Math.floor(e)?e.toString():this.roundDecimals(e,Math.max(0,3-Math.floor(e).toString().length)).toString()}static approximatelyEqual(e,t,i=1e-8){return!(Math.abs(e-t)>i)}static convertLocation(e,t,i=!1){const s=i?1:1/ae.getScale(t),n=t.getBoundingClientRect();return[Math.round((e[0]-n.x)*s),Math.round((e[1]-n.y)*s)]}static isSerialized(e,t){return e.attributes?.[t]?.serialized??e.constructor.attributes?.[t]?.serialized??!1}static objectGet(e,t,i=void 0){if(void 0!==e){if(!(t instanceof Array))throw new TypeError("UEBlueprint: Expected keys to be an array");return 0!=t.length&&t[0]in e&&void 0!==e[t[0]]?1==t.length?e[t[0]]:ae.objectGet(e[t[0]],t.slice(1),i):i}}static objectSet(e,t,i,s=Object){if(!(t instanceof Array))throw new TypeError("Expected keys to be an array.");if(1==t.length){if(t[0]in e||void 0===e[t[0]])return e[t[0]]=i,!0}else if(t.length>0)return e[t[0]]instanceof Object||(e[t[0]]=new s),ae.objectSet(e[t[0]],t.slice(1),i,s);return!1}static equals(e,t){for(;e instanceof MirroredEntity;)e=e.get();for(;t instanceof MirroredEntity;)t=t.get();return e?.equals&&t?.equals?e.equals(t):(e=ae.sanitize(e),t=ae.sanitize(t),e?.constructor===BigInt&&t?.constructor===Number?t=BigInt(t):e?.constructor===Number&&t?.constructor===BigInt&&(e=BigInt(e)),e===t||e instanceof Array&&t instanceof Array&&(e.length===t.length&&e.every(((e,i)=>ae.equals(e,t[i])))))}static getType(e){return null===e?null:e?.constructor===Object&&e?.type instanceof Function?e.type:e?.constructor}static isValueOfType(e,t,i=!1){return t instanceof MirroredEntity&&(t=t.getTargetType()),i&&null===e||e instanceof t||e?.constructor===t}static snapToGrid(e,t,i){return 1===i?[e,t]:[i*Math.floor(e/i),i*Math.floor(t/i)]}static mergeArrays(e=[],t=[],i=((e,t)=>e==t)){let s=[];e=[...e],t=[...t];e:for(;;){for(let n=0;n|
/g,"\n").replaceAll(/(\)/g,"")}static encodeHTMLWhitespace(e){return e.replaceAll(" "," ")}static capitalFirstLetter(e){return 0===e.length?e:e.charAt(0).toUpperCase()+e.slice(1)}static formatStringName(e=""){return e.replace(/^\s*b(?=[A-Z])/,"").replaceAll(re.nameRegexSpaceReplacement," ").trim().split(" ").map((e=>ae.capitalFirstLetter(e))).join(" ")}static getIdFromReference(e){return e.replace(/(?:.+\.)?([^\.]+)$/,"$1").replaceAll(/(?<=[a-z\d])(?=[A-Z])|(?<=[a-zA-Z])(?=\d)|(?<=[A-Z]{2})(?=[A-Z][a-z])/g,"-").toLowerCase()}static getNameFromPath(e,t=!1){const i=t?/([^\.\/]+?)(?:_\d+)$/:/([^\.\/]+)$/;return e.match(i)?.[1]??""}static printLinearColor(e){return`${Math.round(255*e.R.valueOf())}, ${Math.round(255*e.G.valueOf())}, ${Math.round(255*e.B.valueOf())}`}static getPolarCoordinates(e,t,i=!1){let s=Math.atan2(t,e);return i&&s<0&&(s=2*Math.PI+s),[Math.sqrt(e*e+t*t),s]}static getCartesianCoordinates(e,t){return[e*Math.cos(t),e*Math.sin(t)]}static range(e=0,t=0,i=(t>=e?1:-1)){return Array.from({length:Math.ceil((t-e)/i)},((t,s)=>e+s*i))}static getFirstWordOrder(e){return new RegExp(/\s*/.source+e.join(/[^\n]+\n\s*/.source)+/\s*/.source)}static paste(e,t){const i=new ClipboardEvent("paste",{bubbles:!0,cancelable:!0,clipboardData:new DataTransfer});i.clipboardData.setData("text",t),e.dispatchEvent(i)}static async copy(e){const t=new ClipboardEvent("copy",{bubbles:!0,cancelable:!0,clipboardData:new DataTransfer});e.dispatchEvent(t)}static animate(e,t,i,s,n=(e=>{}),r=(e=>{const t=e**3.5;return t/(t+(1-e)**3.5)})){let a;const o=l=>{void 0===a&&(a=l);let u=(l-a)/i;ae.approximatelyEqual(u,1)||u>1?u=1:n(requestAnimationFrame(o));const c=e+(t-e)*r(u);s(c)};n(requestAnimationFrame(o))}}class oe extends se{#e;get blueprint(){return this.#e}set blueprint(e){this.#e=e}#t;get entity(){return this.#t}set entity(e){this.#t=e}#i;get template(){return this.#i}isInitialized=!1;isSetup=!1;inputObjects=[];initialize(e,t){this.requestUpdate(),this.#t=e,this.#i=t,this.#i.initialize(this),this.isConnected&&this.updateComplete.then((()=>this.setup())),this.isInitialized=!0}connectedCallback(){super.connectedCallback(),this.blueprint=this.closest("ueb-blueprint"),this.isInitialized&&(this.requestUpdate(),this.updateComplete.then((()=>this.setup())))}disconnectedCallback(){super.disconnectedCallback(),this.isSetup&&this.updateComplete.then((()=>this.cleanup())),this.acknowledgeDelete()}createRenderRoot(){return this}setup(){this.template.setup(),this.isSetup=!0}cleanup(){this.template.cleanup(),this.isSetup=!1}willUpdate(e){super.willUpdate(e),this.template.willUpdate(e)}update(e){super.update(e),this.template.update(e)}render(){return this.template.render()}firstUpdated(e){super.firstUpdated(e),this.template.firstUpdated(e),this.template.inputSetup()}updated(e){super.updated(e),this.template.updated(e)}acknowledgeDelete(){let e=new CustomEvent(re.removeEventName);this.dispatchEvent(e)}isSameGraph(e){return this.blueprint&&this.blueprint==e?.blueprint}}class le extends oe{static properties={...super.properties,fromX:{type:Number,attribute:!1},fromY:{type:Number,attribute:!1},toX:{type:Number,attribute:!1},toY:{type:Number,attribute:!1}};constructor(){super(),this.fromX=0,this.fromY=0,this.toX=0,this.toY=0}setBothLocations([e,t]){this.fromX=e,this.fromY=t,this.toX=e,this.toY=t}addSourceLocation(e,t){this.fromX+=e,this.fromY+=t}addDestinationLocation(e,t){this.toX+=e,this.toY+=t}}class ue{static deleteNodes="Delete";static duplicateNodes="(bCtrl=True,Key=D)";static enableLinkDelete="LeftAlt";static enableZoomIn=["LeftControl","RightControl"];static selectAllNodes="(bCtrl=True,Key=A)"}class ce{static#s=new Map;static registerElement(e,t){ce.#s.set(e,t)}static getConstructor(e){return ce.#s.get(e)}}class he{static makeSuccess(e,t,i=null,s=0){return{status:!0,value:t,position:e,bestParser:i,bestPosition:s}}static makeFailure(e=0,t=null,i=0){return{status:!1,value:null,position:e,bestParser:t,bestPosition:i}}static makeContext(e=null,t=""){return{parsernostrum:e,input:t,highlighted:null}}static makePathNode(e,t=0,i=null){return{parent:i,current:e,index:t}}}class pe{static indentation=" ";static highlight="Last valid parser";Self;static frame(e,t="",i=""){t=e?"[ "+t+" ]":"";let s=e.split("\n");const n=Math.max(...s.map((e=>e.length))),r=n";const n=this.isVisited(i),r=this.isHighlighted(e,i);let a=n?"<...>":this.doToString(e,r?"":t,i,s);return r&&(a=pe.frame(a,pe.highlight,t)),a}doToString(e,t,i,s){return`${this.constructor.name} does not implement toString()`}}class de extends pe{#n;get value(){return this.#n}constructor(e){super(),this.#n=e}parse(e,t,i,s){i=this.makePath(i,s);const n=t+this.#n.length,r=e.input.substring(t,n);return this.#n===r?he.makeSuccess(n,this.#n,i,n):he.makeFailure()}doToString(e,t,i,s){return`"${this.value.replaceAll("\n","\\n").replaceAll('"','\\"')}"`}}class me extends pe{static instance=new me;parse(e,t,i,s){return i=this.makePath(i,s),he.makeSuccess(t,"",i,0)}doToString(e,t,i,s){return""}}class ge extends pe{#r;get parsers(){return this.#r}constructor(...e){super(),this.#r=e}parse(e,t,i,s){i=this.makePath(i,s);const n=he.makeSuccess(0,"");for(let s=0;sn.bestPosition&&(n.bestParser=r.bestParser,n.bestPosition=r.bestPosition),r.status)return n.value=r.value,n.position=r.position,n}return n.status=!1,n.value=null,n}doToString(e,t,i,s){if(2===this.#r.length&&this.#r[1]instanceof me){let s=this.#r[0].toString(e,t,i,0);return this.#r[0]instanceof de||(s="<"+s+">"),s+="?",s}const n=t+pe.indentation;let r="ALT<\n"+n+this.#r.map(((t,s)=>t.toString(e,n+" ".repeat(0===s?0:pe.indentation.length-2),i,s))).join("\n"+n+"| ")+"\n"+t+">";return r}}class be extends pe{#a;get parser(){return this.#a}#o;constructor(e,t){super(),this.#a=e,this.#o=t}parse(e,t,i,s){i=this.makePath(i,s);const n=this.#a.parse(e,t,i,0);if(!n.status)return n;const r=this.#o(n.value,e.input,n.position).getParser().parse(e,n.position,i,0);return n.bestPosition>r.bestPosition&&(r.bestParser=n.bestParser,r.bestPosition=n.bestPosition),r}doToString(e,t,i,s){return this.#a.toString(e,t,i,0)+" => chained"}}class ve extends pe{static instance=new ve;parse(e,t,i,s){return he.makeFailure()}doToString(e,t,i,s){return""}}class fe extends pe{#a;get parser(){return this.#a}#l="";constructor(e,t){super(),this.#a=e,this.#l=t}makePath(e,t){return e}parse(e,t,i,s){return this.parse=this.#a.parse.bind(this.#a),this.parse(e,t,i,s)}doToString(e,t,i,s){let n=this.#a.toString(e,"",i,s);return n=pe.frame(n,this.#l,t),n}}class ye extends pe{#a;#u;constructor(e){super(),this.#a=e}makePath(e,t){return e}isHighlighted(e,t){if(super.isHighlighted(e,t)){const i={parent:t,parser:this.#u,index:0};e.highlighted=e.highlighted instanceof pe?this.#u:i}return!1}resolve(){return this.#u||(this.#u=this.#a().getParser()),this.#u}parse(e,t,i,s){return this.resolve(),this.parse=this.#u.parse.bind(this.#u),this.parse(e,t,i,s)}doToString(e,t,i,s){return this.resolve(),this.doToString=this.#u.toString.bind(this.#u),this.doToString(e,t,i,s)}}class we extends pe{#a;get parser(){return this.#a}#c;get type(){return this.#c}static Type={NEGATIVE_AHEAD:"?!",NEGATIVE_BEHIND:"?String.raw`[^${e}\\]*(?:\\.[^${e}\\]*)*`;static#g=/[-\+]?(?:\d*\.)?\d+/;static common={number:new RegExp(this.#g.source+String.raw`(?!\.)`),numberInteger:/[\-\+]?\d+(?!\.\d)/,numberNatural:/\d+/,numberExponential:new RegExp(this.#g.source+String.raw`(?:[eE][\+\-]?\d+)?(?!\.)`),numberUnit:/\+?(?:0(?:\.\d+)?|1(?:\.0+)?)(?![\.\d])/,numberByte:/0*(?:25[0-5]|2[0-4]\d|1?\d?\d)(?!\d|\.)/,whitespace:/\s+/,whitespaceOpt:/\s*/,whitespaceInline:/[^\S\n]+/,whitespaceInlineOpt:/[^\S\n]*/,whitespaceMultiline:/\s*?\n\s*/,doubleQuotedString:new RegExp(`"(${this.#m('"')})"`),singleQuotedString:new RegExp(`'(${this.#m("'")})'`),backtickQuotedString:new RegExp("`("+this.#m("`")+")`")};constructor(e,t){super(),this.#h=e,this.#p=new RegExp(`^(?:${e.source})`,e.flags),this.#d=t}parse(e,t,i,s){i=this.makePath(i,s);const n=this.#p.exec(e.input.substring(t));n&&(t+=n[0].length);return n?he.makeSuccess(t,this.#d(n),i,t):he.makeFailure()}doToString(e,t,i,s){let n="/"+this.#h.source+"/";const r=Object.entries(Se.common).find((([e,t])=>t.source===this.#h.source))?.[0];return r&&(n="P."+r),n}}class Ee extends pe{#a;get parser(){return this.#a}#b;get mapper(){return this.#b}constructor(e,t){super(),this.#a=e,this.#b=t}isHighlighted(e,t){if(super.isHighlighted(e,t)){const i={parent:t,parser:this.#a,index:0};e.highlighted=e.highlighted instanceof pe?this.#a:i}return!1}parse(e,t,i,s){i=this.makePath(i,s);const n=this.#a.parse(e,t,i,0);return n.status&&(n.value=this.#b(n.value)),n}doToString(e,t,i,s){let n=this.#a.toString(e,t,i,0);if(this.#a instanceof Se&&Object.values(Se.common).includes(this.#a.regexp))return this.#a.regexp===Se.common.numberInteger&&this.#b===BigInt?"P.numberBigInteger":n;let r=this.#b.toString();return(r.length>60||r.includes("\n"))&&(r="(...) => { ... }"),n+=` -> map<${r}>`,n}}class Ce extends Se{static#b=e=>e;constructor(e){super(e,Ce.#b)}}class Ne extends Se{constructor(e,t=0){super(e,(e=>e[t]))}}class xe extends pe{#r;get parsers(){return this.#r}constructor(...e){super(),this.#r=e}parse(e,t,i,s){i=this.makePath(i,s);const n=new Array(this.#r.length),r=he.makeSuccess(t,n);for(let t=0;tr.bestPosition&&(r.bestParser=s.bestParser,r.bestPosition=s.bestPosition),!s.status){r.status=!1,r.value=null;break}r.value[t]=s.value,r.position=s.position}return r}doToString(e,t,i,s){const n=t+pe.indentation,r="SEQ<\n"+n+this.#r.map(((t,s)=>t.toString(e,n,i,s))).join("\n"+n)+"\n"+t+">";return r}}class Pe extends pe{#a;get parser(){return this.#a}#v;get min(){return this.#v}#f;get max(){return this.#f}constructor(e,t=0,i=Number.POSITIVE_INFINITY){if(super(),t>i)throw new Error("Min is greater than max");this.#a=e,this.#v=t,this.#f=i}parse(e,t,i,s){i=this.makePath(i,s);const n=he.makeSuccess(t,[],i);for(let t=0;tn.bestPosition&&(n.bestParser=s.bestParser,n.bestPosition=s.bestPosition),!s.status){te;static#w=([e,t])=>t;static#S=([e,t])=>[e,...t];static#E=e=>e instanceof Array?e.join(""):e;static number=this.reg(Se.common.number).map(Number);static numberInteger=this.reg(Se.common.numberInteger).map(Number);static numberBigInteger=this.reg(this.numberInteger.getParser().parser.regexp).map(BigInt);static numberNatural=this.reg(Se.common.numberNatural).map(Number);static numberExponential=this.reg(Se.common.numberExponential).map(Number);static numberUnit=this.reg(Se.common.numberUnit).map(Number);static numberByte=this.reg(Se.common.numberByte).map(Number);static whitespace=this.reg(Se.common.whitespace);static whitespaceOpt=this.reg(Se.common.whitespaceOpt);static whitespaceInline=this.reg(Se.common.whitespaceInline);static whitespaceInlineOpt=this.reg(Se.common.whitespaceInlineOpt);static whitespaceMultiline=this.reg(Se.common.whitespaceMultiline);static doubleQuotedString=this.reg(Se.common.doubleQuotedString,1);static singleQuotedString=this.reg(Se.common.singleQuotedString,1);static backtickQuotedString=this.reg(Se.common.backtickQuotedString,1);constructor(e,t=!1){this.#a=e}static#C(e){const t=[];for(;e;)t.push(e),e=e.parent;t.reverse();let i=new Map;for(let e=1;ei<=s||i>e))),i.set(t[e].current,s),t.splice(s+1,e-s),e=s):i.set(t[e].current,e)}return t[t.length-1]}getParser(){return this.#a}run(e){const t=this.#a.parse(he.makeContext(this,e),0,he.makePathNode(),0);return t.position!==e.length&&(t.status=!1),t}parse(e,t=!0){const i=this.run(e);if(i.status)return i.value;const s=[Math.ceil(30),Math.floor(30)],n=ke.lineColumnFromOffset(e,i.bestPosition);let r=i.bestPosition;const a=e.replaceAll(/^(\s)+|\s{6,}|\s*?\n\s*/g,((e,t,s)=>{let n=t?"...":" ... ";return s<=i.bestPosition&&(i.bestPosition0&&(c="..."+c,u+=3),s[1]e.getParser()))))}static alt(...e){return new this(new ge(...e.map((e=>e.getParser()))))}static lookahead(e){return new this(new we(e.getParser(),we.Type.POSITIVE_AHEAD))}static lazy(e){return new this(new ye(e))}times(e,t=e){return new ke(new Pe(this.#a,e,t))}many(){return this.times(0,Number.POSITIVE_INFINITY)}atLeast(e){return this.times(e,Number.POSITIVE_INFINITY)}atMost(e){return this.times(0,e)}opt(){return ke.alt(this,ke.success())}sepBy(e,t=!1){return ke.seq(this,ke.seq(e,this).map(ke.#w).many()).map(ke.#S)}skipSpace(){return ke.seq(this,ke.whitespaceOpt).map(ke.#y)}map(e){return new ke(new Ee(this.#a,e))}chain(e){return new ke(new be(this.#a,e))}assert(e){return this.chain(((t,i,s)=>e(t,i,s)?ke.success().map((()=>t)):ke.failure()))}join(e=""){return this.map(ke.#E)}label(e=""){return new ke(new fe(this.#a,e))}toString(e="",t=!1,i=null){i instanceof ke&&(i=i.getParser());const s=he.makeContext(this,"");s.highlighted=i;const n=he.makePathNode();return(t?"\n"+e:"")+this.#a.toString(s,e,n)}}class Ae{static#N={nullable:!1,ignored:!1,serialized:!1,expected:!1,inlined:!1,quoted:!1,silent:!1,uninitialized:!1};constructor(e){this.type=e.type??e.default?.constructor,this.default=e.default,this.nullable=e.nullable??null===e.default,this.ignored=e.ignored,this.serialized=e.serialized,this.expected=e.expected,this.inlined=e.inlined,this.quoted=e.quoted,this.silent=e.silent,this.uninitialized=e.uninitialized,this.predicate=e.predicate,this.type===Array&&this.default instanceof Array&&this.default.length>0&&(this.type=this.default.map((e=>e.constructor)).reduce(((e,t)=>(e.includes(t)||e.push(t),e)),[]))}static createType(e){return new Ae({type:e})}static createValue(e){return new Ae({default:e})}static hasAttribute(e,t,i,s=e.constructor){const n=e,r=n.attributes[t]?.[i];return r??s?.attributes?.[t]?.[i]??Ae.#N[i]}static getAttribute(e,t,i,s=e.constructor){let n=e.attributes?.[t]?.[i];return void 0!==n?n:(n=(s?.attributes)?.[t]?.[i],void 0!==n?n:(n=Ae.#N[i],void 0!==n?n:void 0))}get(e){return this[e]??Ae.#N[e]}}class Le{static same=e=>e;static notWrapped=(e,t)=>t;static defaultWrapped=(e,t)=>`${e.lookbehind}(${t})`;static wrap=this.defaultWrapped;static attributeSeparator=",";static printKey=e=>e;static grammar=ke.failure();static attributes={};static default;static nullable=!1;static ignored=!1;static serialized=!1;static expected=!1;static inlined=!1;static quoted=!1;static silent=!1;static trailing=!1;static lookbehind="";#x=this.Self().lookbehind;get lookbehind(){return this.#x}set lookbehind(e){this.#x=e}#P;get keys(){return this.#P??Object.keys(this)}set keys(e){this.#P=[...new Set(e)]}constructor(e={}){const t=ae.mergeArrays(Object.keys(e),Object.keys(this.Self().attributes));for(const i of t){if(void 0!==e[i]){this[i]=e[i];continue}const t=this.Self().attributes[i];void 0===t.default||(this[i]=t.default(t))}}static className(){let e=this;for(;!e.name;)e=Object.getPrototypeOf(e);return e.name}showProperty(e){let t=this[e];const i=t.Self();if(i.silent&&void 0!==i.default){void 0===i["#default"]&&(i["#default"]=i.default(i));const e=i["#default"];return!t.equals(e)}return!0}static asUniqueClass(){return this.name.length?class extends(this){}:this}static withLookbehind(e){const t=this.asUniqueClass();return t.lookbehind=e,t}static withDefault(e=(e=>new e)){const t=this.asUniqueClass();return t.default=e,t}static flagNullable(e=!0){const t=this.asUniqueClass();return t.nullable=e,t}static flagSerialized(e=!0){const t=this.asUniqueClass();return t.serialized=e,t}static flagInlined(e=!0){const t=this.asUniqueClass();return t.inlined=e,t}static flagQuoted(e=!0){const t=this.asUniqueClass();return t.quoted=e,t}static flagSilent(e=!0){const t=this.asUniqueClass();return t.silent=e,t}static flagTrailing(e=!0){const t=this.asUniqueClass();return t.trailing=e,t}Self(){return this.constructor}listenAttribute(e,t){const i=Object.getOwnPropertyDescriptor(this,e),s=i.set;s?(i.set=e=>{s(e),t(e)},Object.defineProperties(this,{[e]:i})):i.value&&Object.defineProperties(this,{["#"+e]:{value:i.value,writable:!0,enumerable:!1},[e]:{enumerable:!0,get(){return this["#"+e]},set(i){i!=this["#"+e]&&(t(i),this["#"+e]=i)}}})}equals(e){const t=Object.keys(this),i=Object.keys(e);if(t.length!=i.length)return!1;if(this.valueOf&&e.valueOf)return this.valueOf()===e.valueOf();for(let s=0;si(`${a}.${e}`)));continue}let l=i(a);l.length&&(s.quoted&&(l=`"${l}"`),n+=s.attributeSeparator.includes("\n")?t:"");let u=o.toString(e,t,i);s.serialized&&(u=`"${u.replaceAll(/(?<=(?:[^\\]|^)(?:\\\\)*?)"/,'\\"')}"`),n+=u}return s.trailing&&n.length&&(n+=s.attributeSeparator),s.wrap(this,n)}}class Me extends Le{static type;constructor(e=null){super(),this.getter=e}static of(e){const t=this.asUniqueClass();return t.type=e,t.grammar=t.getTargetType().grammar.map((e=>new this)),t}static getTargetType(){const e=this.type;return e.prototype instanceof Me?e.getTargetType():e}toString(e=!1,t="",i=this.Self().printKey){return this.getter().toString(e,t,i)}}class Te{static grammar=ke.failure()}class Ie{static numberRegexSource=ke.number.getParser().parser.regexp.source;static separatedBy=(e,t,i=1)=>new RegExp(e+"(?:"+t+e+")"+(1===i?"*":2===i?"+":`{${i},}`));static Regex=class{static HexDigit=/[0-9a-fA-F]/;static InsideString=/(?:[^"\\]|\\.)*/;static InsideSingleQuotedString=/(?:[^'\\]|\\.)*/;static Integer=/[\-\+]?\d+(?!\d|\.)/;static Number=/[-\+]?(?:\d*\.)?\d+(?!\d|\.)/;static RealUnit=/\+?(?:0(?:\.\d+)?|1(?:\.0+)?)(?![\.\d])/;static Word=Ie.separatedBy("[a-zA-Z]","_");static Symbol=/[a-zA-Z_]\w*/;static DotSeparatedSymbols=Ie.separatedBy(this.Symbol.source,"\\.");static MultipleWordsSymbols=Ie.separatedBy(this.Symbol.source,"(?:\\.|\\ +)");static PathFragment=Ie.separatedBy(this.Symbol.source,"[\\.:]");static PathSpaceFragment=Ie.separatedBy(this.Symbol.source,"[\\.:\\ ]");static Path=new RegExp(`(?:\\/${this.PathFragment.source}){2,}`)};static null=ke.reg(/\(\s*\)/).map((()=>null));static true=ke.reg(/true/i).map((()=>!0));static false=ke.reg(/false/i).map((()=>!1));static number=ke.regArray(new RegExp(`(${ke.number.getParser().parser.regexp.source})|(\\+?inf)|(-inf)`)).map((([e,t,i,s])=>t?Number(t):i?Number.POSITIVE_INFINITY:Number.NEGATIVE_INFINITY));static bigInt=ke.reg(new RegExp(ke.number.getParser().parser.regexp.source)).map(BigInt).map((e=>void 0!==e[2]?Number.POSITIVE_INFINITY:void 0!==e[3]?Number.NEGATIVE_INFINITY:Number(e[1])));static naturalNumber=ke.lazy((()=>ke.reg(/\d+/).map(Number)));static string=ke.doubleQuotedString.map((e=>ae.unescapeString(e)));static colorValue=ke.numberByte;static word=ke.reg(Ie.Regex.Word);static symbol=ke.reg(Ie.Regex.Symbol);static symbolQuoted=ke.reg(new RegExp('"('+Ie.Regex.Symbol.source+')"'),1);static attributeName=ke.reg(Ie.Regex.DotSeparatedSymbols);static attributeNameQuoted=ke.reg(new RegExp('"('+Ie.Regex.InsideString.source+')"'),1);static guid=ke.reg(new RegExp(`${Ie.Regex.HexDigit.source}{32}`));static commaSeparation=ke.reg(/\s*,\s*(?!\))/);static commaOrSpaceSeparation=ke.reg(/\s*,\s*(?!\))|\s+/);static equalSeparation=ke.reg(/\s*=\s*/);static hexColorChannel=ke.reg(new RegExp(Ie.Regex.HexDigit.source+"{2}"));static grammarFor(e,t=e?.type,i=this.unknownValue){let s=i;if(t===Array||t instanceof Array){if(e?.inlined)return this.grammarFor(void 0,t[0]);s=ke.seq(ke.reg(/\(\s*/),this.grammarFor(void 0,t[0]).sepBy(this.commaSeparation).opt(),ke.reg(/\s*(?:,\s*)?\)/)).map((([e,t,i])=>t instanceof Array?t:[]))}else if(t instanceof Union)s=t.values.map((e=>this.grammarFor(void 0,e))).reduce(((e,t)=>t&&t!==this.unknownValue&&e!==this.unknownValue?ke.alt(e,t):this.unknownValue));else{if(t instanceof Me)return this.grammarFor(void 0,t.getTargetType()).map((e=>new Me(t.type,(()=>e))));if(e?.constructor===Object)s=this.grammarFor(void 0,t);else switch(t){case Boolean:s=this.boolean;break;case null:s=this.null;break;case Number:s=this.number;break;case BigInt:s=this.bigInt;break;case String:s=this.string;break;default:t?.prototype instanceof Te&&(s=t.grammar)}}return e&&(e.serialized&&t.constructor!==String&&(s=s==this.unknownValue?this.string:ke.seq(ke.str('"'),s,ke.str('"')).map((([e,t,i])=>t))),e.nullable&&(s=ke.alt(s,this.null))),s}static getAttribute(e,t){let i,s;if(e instanceof Union)for(let s of e.values)if(i=this.getAttribute(s,t))return i;return e instanceof Le.constructor?(i=e.attributes[t[0]],s=i?.type):e instanceof Array&&(i=e[t[0]],s=i),t.length>1?this.getAttribute(s,t.slice(1)):i}static createAttributeGrammar(e,t=this.attributeName,i=this.equalSeparation,s=((e,t,i)=>{})){return ke.seq(t,i).chain((([t,i])=>{const n=t.split(re.keysSeparator),r=this.getAttribute(e,n);return this.grammarFor(r).map((e=>t=>{s(t,n,e),ae.objectSet(t,n,e)}))}))}static createEntityGrammar(e,t=this.commaSeparation){const i=e.lookbehind instanceof Array?e.lookbehind.join("|"):e.lookbehind;return ke.seq(ke.reg(new RegExp(String.raw`(${i})\s*\(\s*`),1),this.createAttributeGrammar(e).sepBy(t),ke.reg(/\s*(,\s*)?\)/,1)).map((([e,t,i])=>{let s={};return e.length&&(s["#lookbehind"]=e),t.forEach((e=>e(s))),s["#trailing"]=void 0!==i,s})).chain((t=>((e.lookbehind instanceof Array||e.lookbehind!==i)&&(e=e.withLookbehind(i)),e.trailing!==t["#trailing"]&&(e=e.flagTrailing(t["#trailing"])),ke.success().map((()=>new e(t))))))}static unknownValue}class $e extends Le{static grammar=ke.number.map((e=>new this(e)));constructor(e=0){super(),this.value=e}valueOf(){return this.value}toString(){return this.value.toFixed(6)}}class De extends Le{static attributes={...super.attributes,R:$e.withDefault(),G:$e.withDefault(),B:$e.withDefault(),A:$e.withDefault((e=>new e(1)))};static grammar=Ie.createEntityGrammar(this).label("LinearColorEntity");#k=new $e;get H(){return this.#k}set H(e){this.#k=e}#A=new $e;get S(){return this.#A}set S(e){this.#A=e}#L=new $e;get V(){return this.#L}set V(e){this.#L=e}constructor(e){super(e),e instanceof Array&&(e={R:e[0]??0,G:e[1]??0,B:e[2]??0,A:e[3]??1}),this.R,this.G,this.B,this.A,this.#M()}static linearToSRGB(e){return e<=0?0:e>=1?1:e<.0031308?12.92*e:1.055*Math.pow(e,1/2.4)-.055}static sRGBtoLinear(e){return e<=0?0:e>=1?1:e<.04045?e/12.92:Math.pow((e+.055)/1.055,2.4)}static getWhite(){return new De({R:1,G:1,B:1})}static getLinearColorFromHexGrammar(){const e=/[0-9a-fA-F]/;return ke.regArray(new RegExp("#("+e.source+"{2})("+e.source+"{2})("+e.source+"{2})("+e.source+"{2})?")).map((([e,t,i,s,n])=>new this({R:parseInt(t,16)/255,G:parseInt(i,16)/255,B:parseInt(s,16)/255,A:parseInt(n??"FF",16)/255})))}static getLinearColorRGBListGrammar(){return ke.seq(ke.numberByte,Ie.commaSeparation,ke.numberByte,Ie.commaSeparation,ke.numberByte).map((([e,t,i,s,n])=>new this({R:e/255,G:i/255,B:n/255,A:1})))}static getLinearColorRGBGrammar(){return ke.seq(ke.reg(/rgb\s*\(\s*/),this.getLinearColorRGBListGrammar(),ke.reg(/\s*\)/)).map((([e,t,i])=>t))}static getLinearColorRGBAGrammar(){return ke.seq(ke.reg(/rgba\s*\(\s*/),this.getLinearColorRGBListGrammar(),ke.reg(/\s*\)/)).map((([e,t,i])=>t))}static getLinearColorFromAnyFormat(){return ke.alt(this.getLinearColorFromHexGrammar(),this.getLinearColorRGBAGrammar(),this.getLinearColorRGBGrammar(),this.getLinearColorRGBListGrammar())}#M(){const e=this.R.value,t=this.G.value,i=this.B.value;if(ae.approximatelyEqual(e,t)&&ae.approximatelyEqual(e,i)&&ae.approximatelyEqual(t,i))return this.S.value=0,void(this.V.value=e);const s=Math.max(e,t,i),n=Math.min(e,t,i),r=s-n;let a;switch(s){case n:a=0;break;case e:a=(t-i)/r+(te.toString(16).toUpperCase().padStart(2,"0"))).join("")}toSRGBAString(){return this.toSRGBA().map((e=>e.toString(16).toUpperCase().padStart(2,"0"))).join("")}toHSVA(){return[this.H.value,this.S.value,this.V.value,this.A.value]}toNumber(){return(Math.round(255*this.R.value)<<24)+(Math.round(255*this.G.value)<<16)+(Math.round(255*this.B.value)<<8)+Math.round(255*this.A.value)}setFromRGBANumber(e){this.A.value=(255&e)/255,this.B.value=(e>>8&255)/255,this.G.value=(e>>16&255)/255,this.R.value=(e>>24&255)/255,this.#M()}setFromSRGBANumber(e){this.A.value=(255&e)/255,this.B.value=De.sRGBtoLinear((e>>8&255)/255),this.G.value=De.sRGBtoLinear((e>>16&255)/255),this.R.value=De.sRGBtoLinear((e>>24&255)/255),this.#M()}toArray(){return[this.R.value,this.G.value,this.B.value,this.A.value]}}class Ve{static arrayPin=O``;static branchNode=O``;static breakStruct=O``;static cast=O``;static close=O``;static convert=O``;static correct=O``;static delegate=O``;static doN=O``;static doOnce=O``;static enum=O``;static event=O``;static execPin=O``;static expandIcon=O``;static flipflop=O``;static forEachLoop=O``;static functionSymbol=O``;static gamepad=O``;static genericPin=O``;static keyboard=O``;static loop=O``;static macro=O``;static mapPin=O``;static makeArray=O``;static makeMap=O``;static makeSet=O``;static makeStruct=O``;static metasoundFunction=O``;static mouse=O``;static node=O``;static operationPin=O``;static pcgStackPin=O``;static pcgPin=O``;static pcgParamPin=O``;static pcgSpatialPin=O``;static plusCircle=O``;static questionMark=O``;static referencePin=O``;static reject=O``;static setPin=O``;static select=O``;static sequence=O``;static sound=O``;static spawnActor=O``;static switch=O``;static timer=O``;static touchpad=O``}const Be=/\/Script\/SequencerScripting\.MovieSceneScripting(.+)Channel/,Oe={A_AccentGrave:"à",Add:"Num +",C_Cedille:"ç",Decimal:"Num .",Divide:"Num /",E_AccentAigu:"é",E_AccentGrave:"è",F1:"F1",F10:"F10",F11:"F11",F12:"F12",F2:"F2",F3:"F3",F4:"F4",F5:"F5",F6:"F6",F7:"F7",F8:"F8",F9:"F9",Gamepad_Special_Left_X:"Touchpad Button X Axis",Gamepad_Special_Left_Y:"Touchpad Button Y Axis",Mouse2D:"Mouse XY 2D-Axis",Multiply:"Num *",Section:"§",Subtract:"Num -",Tilde:"`"};function He(e){let t;switch(e.getType()){case re.paths.asyncAction:if(e.ProxyFactoryFunctionName)return ae.formatStringName(e.ProxyFactoryFunctionName);case re.paths.actorBoundEvent:case re.paths.componentBoundEvent:return`${ae.formatStringName(e.DelegatePropertyName)} (${e.ComponentPropertyName??"Unknown"})`;case re.paths.callDelegate:return`Call ${e.DelegateReference?.MemberName??"None"}`;case re.paths.createDelegate:return"Create Event";case re.paths.customEvent:if(e.CustomFunctionName)return e.CustomFunctionName;case re.paths.dynamicCast:return e.TargetType?`Cast To ${e.TargetType?.getName()}`:"Bad cast node";case re.paths.enumLiteral:return`Literal enum ${e.Enum?.getName()}`;case re.paths.event:return`Event ${(e.EventReference?.MemberName??"").replace(/^Receive/,"")}`;case re.paths.executionSequence:return"Sequence";case re.paths.forEachElementInEnum:return`For Each ${e.Enum?.getName()}`;case re.paths.forEachLoopWithBreak:return"For Each Loop with Break";case re.paths.functionEntry:return"UserConstructionScript"===e.FunctionReference?.MemberName?"Construction Script":e.FunctionReference?.MemberName;case re.paths.functionResult:return"Return Node";case re.paths.ifThenElse:return"Branch";case re.paths.makeStruct:if(e.StructType)return`Make ${e.StructType.getName()}`;case re.paths.materialExpressionComponentMask:{const t=e.getMaterialSubobject();return`Mask ( ${re.rgba.filter((e=>!0===t[e].get())).map((e=>e+" ")).join("")})`}case re.paths.materialExpressionConstant:t??=[e.getCustomproperties().find((e=>"Value"==e.PinName))?.DefaultValue];case re.paths.materialExpressionConstant2Vector:t??=[e.getCustomproperties().find((e=>"X"==e.PinName))?.DefaultValue,e.getCustomproperties().find((e=>"Y"==e.PinName))?.DefaultValue];case re.paths.materialExpressionConstant3Vector:if(!t){const i=e.getCustomproperties().find((e=>"Constant"==e.PinName))?.DefaultValue;t=[i.X,i.Y,i.Z]}case re.paths.materialExpressionConstant4Vector:if(!t){const i=e.getCustomproperties().find((e=>"Constant"==e.PinName))?.DefaultValue;t=[i.R,i.G,i.B,i.A].map((e=>e.valueOf()))}if(t.length>0)return t.map((e=>ae.printExponential(e))).reduce(((e,t)=>e+","+t));break;case re.paths.materialExpressionFunctionInput:{const t=e.getMaterialSubobject();return`Input ${t?.InputName??"In"} (${t?.InputType?.value.match(/^.+?_(\w+)$/)?.[1]??"Vector3"})`}case re.paths.materialExpressionLogarithm:return"Ln";case re.paths.materialExpressionLogarithm10:return"Log10";case re.paths.materialExpressionLogarithm2:return"Log2";case re.paths.materialExpressionMaterialFunctionCall:const i=e.getMaterialSubobject()?.MaterialFunction;if(i)return i.getName();break;case re.paths.materialExpressionSquareRoot:return"Sqrt";case re.paths.metasoundEditorGraphExternalNode:{const t=e.ClassName?.Name;if(t)return"Add"===t?"+":t}case re.paths.pcgEditorGraphNodeInput:return"Input";case re.paths.pcgEditorGraphNodeOutput:return"Output";case re.paths.spawnActorFromClass:let s=e.getCustomproperties().find((e=>"ReturnValue"==e.PinName))?.PinType?.PinSubCategoryObject?.getName();return"Actor"===s&&(s=null),`SpawnActor ${ae.formatStringName(s??"NONE")}`;case re.paths.switchEnum:return`Switch on ${e.Enum?.getName()??"Enum"}`;case re.paths.switchInteger:return"Switch on Int";case re.paths.variableGet:return"";case re.paths.variableSet:return"SET"}let i=e.switchTarget();if(i)return"E"!==i[0]&&(i=ae.formatStringName(i)),`Switch on ${i}`;if(e.isComment())return e.NodeComment;const s=e.getHIDAttribute();if(s){const t=s.toString();let i=function(e){let t=Oe[e];if(t)return t;if(t=ae.numberFromText(e)?.toString(),t)return t;const i=e.match(/NumPad([a-zA-Z]+)/);return i&&(t=ae.numberFromText(i[1]).toString(),t)?"Num "+t:void 0}(t)??ae.formatStringName(t);return e.getClass()===re.paths.inputDebugKey?i="Debug Key "+i:e.getClass()===re.paths.getInputAxisKeyValue&&(i="Get "+i),i}if(e.getClass()===re.paths.macro)return ae.formatStringName(e.MacroGraphReference?.getMacroName());if(e.isMaterial()&&e.getMaterialSubobject()){let t=He(e.getMaterialSubobject());return t=t.match(/Material Expression (.+)/)?.[1]??t,t}if(e.isPcg()&&e.getPcgSubobject()){let t=e.getPcgSubobject();return t.NodeTitle?t.NodeTitle:He(t)}const n=e.getSubgraphObject();if(n)return n.Graph.getName();const r=e.getSettingsObject();if(r){if(r.ExportPath.type===re.paths.pcgHiGenGridSizeSettings)return`Grid Size: ${r.HiGenGridSize?.toString().match(/\d+/)?.[0]?.concat("00")??r.HiGenGridSize?.toString().match(/^\w+$/)?.[0]??"256"}`;if(r.BlueprintElementInstance)return ae.formatStringName(r.BlueprintElementType.getName());if(r.Operation){const e=r.Name.match(/PCGMetadata(\w+)Settings_\d+/);if(e)return ae.formatStringName(e[1]+": "+r.Operation)}const e=r.getSubgraphObject();if(e&&e.Graph)return e.Graph.getName()}let a=e.FunctionReference?.MemberName;if(a){const t=e.FunctionReference.MemberParent?.path??"";switch(a){case"AddKey":let e=t.match(Be);if(e)return`Add Key (${ae.formatStringName(e[1])})`;case"Concat_StrStr":return"Append"}const i=a.match(re.lineTracePattern);if(i)return"Line Trace"+("Multi"===i[1]?" Multi ":" ")+(""===i[2]?"By Channel":ae.formatStringName(i[2]));switch(t){case re.paths.blueprintGameplayTagLibrary:case re.paths.kismetMathLibrary:case re.paths.slateBlueprintLibrary:case re.paths.timeManagementBlueprintLibrary:const e=a.match(/[BF]([A-Z]\w+)/);switch(e&&(a=e[1]),a){case"Abs":return"ABS";case"BooleanAND":return"AND";case"BooleanNAND":return"NAND";case"BooleanOR":return"OR";case"Exp":return"e";case"LineTraceSingle":return"Line Trace By Channel";case"Max":case"MaxInt64":return"MAX";case"Min":case"MinInt64":return"MIN";case"Not_PreBool":return"NOT";case"Sin":return"SIN";case"Sqrt":return"SQRT";case"Square":return"^2";case"CrossProduct2D":return"cross";case"Vector4_CrossProduct3":return"cross3";case"DotProduct2D":case"Vector4_DotProduct":return"dot";case"Vector4_DotProduct3":return"dot3"}if(a.startsWith("Add_"))return"+";if(a.startsWith("And_"))return"&";if(a.startsWith("Conv_"))return"";if(a.startsWith("Cross_"))return"cross";if(a.startsWith("Divide_"))return String.fromCharCode(247);if(a.startsWith("Dot_"))return"dot";if(a.startsWith("EqualEqual_"))return"==";if(a.startsWith("Greater_"))return">";if(a.startsWith("GreaterEqual_"))return">=";if(a.startsWith("Less_"))return"<";if(a.startsWith("LessEqual_"))return"<=";if(a.startsWith("Multiply_"))return String.fromCharCode(10799);if(a.startsWith("Not_"))return"~";if(a.startsWith("NotEqual_"))return"!=";if(a.startsWith("Or_"))return"|";if(a.startsWith("Percent_"))return"%";if(a.startsWith("Subtract_"))return"-";if(a.startsWith("Xor_"))return"^";break;case re.paths.blueprintSetLibrary:{const e=a.match(/Set_(\w+)/);if(e)return ae.formatStringName(e[1]).toUpperCase()}break;case re.paths.blueprintMapLibrary:{const e=a.match(/Map_(\w+)/);if(e)return ae.formatStringName(e[1]).toUpperCase()}break;case re.paths.kismetArrayLibrary:{const e=a.match(/Array_(\w+)/);if(e)return e[1].toUpperCase()}}return ae.formatStringName(a)}if(e.OpName){switch(e.OpName){case"Boolean::LogicAnd":return"Logic AND";case"Boolean::LogicEq":return"==";case"Boolean::LogicNEq":return"!=";case"Boolean::LogicNot":return"Logic NOT";case"Boolean::LogicOr":return"Logic OR";case"Matrix::MatrixMultiply":return"Multiply (Matrix * Matrix)";case"Matrix::MatrixVectorMultiply":return"Multiply (Matrix * Vector4)";case"Numeric::Abs":return"Abs";case"Numeric::Add":return"+";case"Numeric::DistancePos":return"Distance";case"Numeric::Mul":return String.fromCharCode(10799)}return ae.formatStringName(e.OpName).replaceAll("::"," ")}return e.FunctionDisplayName?ae.formatStringName(e.FunctionDisplayName):e.ObjectRef?e.ObjectRef.getName():ae.formatStringName(e.getNameAndCounter()[0])}var Re;"undefined"==typeof window?import("crypto").then((e=>Re=e.default)).catch():Re=window.crypto;class Ge extends Le{static grammar=ke.reg(/[0-9A-F]{32}/i).map((e=>new this(e))).label("GuidEntity");static generateGuid(){let e=new Uint32Array(4);Re.getRandomValues(e);let t="";return e.forEach((e=>{t+=("0".repeat(8)+e.toString(16).toUpperCase()).slice(-8)})),t}constructor(e=Ge.generateGuid()){super(),this.value=e}valueOf(){return this.value}toString(){return this.value}}const _e={[re.paths.niagaraBool]:r``,[re.paths.niagaraDataInterfaceVolumeTexture]:r``,[re.paths.niagaraFloat]:r``,[re.paths.niagaraMatrix]:r``,[re.paths.niagaraNumeric]:r``,[re.paths.niagaraPosition]:r``,[re.paths.quat4f]:r``,[re.paths.rotator]:r``,[re.paths.transform]:r``,[re.paths.vector]:r``,[re.paths.vector3f]:r``,[re.paths.vector4f]:r``,Any:r``,"Any[]":r``,audio:r``,blue:r``,bool:r``,byte:r``,class:r``,default:r``,delegate:r``,enum:r``,exec:r``,float:r``,green:r``,int:r``,int32:r``,int64:r``,interface:r``,name:r``,object:r``,Param:r``,"Param[]":r``,Point:r``,"Point[]":r``,real:r``,red:r``,string:r``,struct:r``,Surface:r``,"Surface[]":r``,text:r``,time:r``,Volume:r``,"Volume[]":r``,wildcard:r``},Fe=r``;class ze extends Le{static alternatives=[];static className(){let e=super.className();return this.alternatives.length&&(e+=" (accepting: "+this.alternatives.map((e=>e.className())).join(", ")+")"),e}static createGrammar(){const e=this.alternatives.map((e=>e.grammar));return e.includes(Ie.unknownValue)?Ie.unknownValue:ke.alt(...e)}static accepting(...e){const t=this.asUniqueClass();return t.alternatives=e,t.grammar=t.createGrammar(),t}}class je extends Le{static type;static grammar=this.createGrammar();constructor(e=[]){super(),this.values=e}static createGrammar(e=this.type?.grammar??ke.lazy((()=>Ie.unknownValue))){return this.inlined?e:ke.seq(ke.reg(/\(\s*/),e.sepBy(Ie.commaSeparation).opt(),ke.reg(/\s*(,\s*)?\)/,1)).map((([e,t,i])=>{let s=this;const n=void 0!==i;return n!==s.trailing&&(s=s.flagTrailing(n)),new s(t=t instanceof Array?t:[])})).label(`ArrayEntity of ${this.type?.className()??"unknown values"}`)}static of(e){const t=this.asUniqueClass();return t.type=e,this.grammar=t.createGrammar(),t}valueOf(){return this.values}}class Ue extends Le{static grammar=ke.regArray(/(true)|false/i).map((e=>e[1]?new this(!0):new this(!1))).label("BooleanEntity");constructor(e=!1){super(),this.value=e}valueOf(){return this.value}toString(e=!1){return this.value?e?"true":"True":e?"false":"False"}}class We extends Le{static grammar=ke.regArray(new RegExp(`(${Ie.numberRegexSource})|(\\+?inf)|(-inf)`)).map((([e,t,i,s])=>new this(t?Number(t):i?Number.POSITIVE_INFINITY:Number.NEGATIVE_INFINITY))).label("NumberEntity");#n;get value(){return this.#n}set value(e){-0===e&&(e=0),this.#n=e}constructor(e=0){super(),this.value=e}valueOf(){return this.value}toString(){return this.value===Number.POSITIVE_INFINITY?"+inf":this.value===Number.NEGATIVE_INFINITY?"-inf":this.value.toString()}}class Ke extends We{static grammar=ke.numberInteger.map((e=>new this(e)));set value(e){e>=-(1<<31)&&e<1<<31&&(e=Math.floor(e),super.value=e)}}class Ye extends Ke{static grammar=ke.numberByte.map((e=>new this(e)));set value(e){e%1==0&&e>=0&&e<256&&(super.value=e)}}class qe extends Le{static f;static from(e){const t=this.asUniqueClass();return t.f=e,t}compute(e){return this.Self().f(e)}}class Xe extends Le{static grammar=Ie.symbol.map((e=>new this(e))).label("SymbolEntity");constructor(e=""){super(),this.value=e}valueOf(){return this.value}toString(){return this.value}}class Ze extends Xe{static grammar=Ie.symbol.map((e=>new this(e)))}class Qe extends Ze{static grammar=ke.reg(Ie.Regex.InsideString).map((e=>new this(e)))}class Je extends Le{print(){return this.toString()}}class et extends Je{static lookbehind="INVTEXT";static grammar=ke.alt(ke.seq(ke.reg(new RegExp(`${this.lookbehind}\\s*\\(`)),ke.doubleQuotedString,ke.reg(/\s*\)/)).map((([e,t,i])=>Number(t))),ke.reg(new RegExp(this.lookbehind)).map((()=>0))).map((e=>new this(e))).label("InvariantTextEntity");constructor(e=""){super(),this.value=e}print(){return ke.alt(ke.seq(ke.reg(new RegExp(`${this.lookbehind}\\s*\\(`)),ke.doubleQuotedString,ke.reg(/\s*\)/)).map((([e,t,i])=>Number(t))),ke.reg(new RegExp(this.lookbehind)).map((()=>0))),this.value}toString(){return this.lookbehind+"("+this.value+")"}}class tt extends Je{static lookbehind="NSLOCTEXT";static grammar=ke.regArray(new RegExp(String.raw`${this.lookbehind}\s*\(`+String.raw`\s*"(${Ie.Regex.InsideString.source})"\s*,`+String.raw`\s*"(${Ie.Regex.InsideString.source})"\s*,`+String.raw`\s*"(${Ie.Regex.InsideString.source})"\s*`+String.raw`(,\s+)?`+String.raw`\)`,"m")).map((e=>new(e[4]?this.flagTrailing():this)(ae.unescapeString(e[1]),ae.unescapeString(e[2]),ae.unescapeString(e[3])))).label("LocalizedTextEntity");#T;get namespace(){return this.#T}set namespace(e){this.#T=e}#I;get key(){return this.#I}set key(e){this.#I=e}#n;get value(){return this.#n}set value(e){this.#n=e}constructor(e="",t="",i=""){super(),this.namespace=e,this.key=t,this.value=i}print(){return ae.capitalFirstLetter(this.value)}toString(){const e=this.Self().trailing?", ":"";return`${this.lookbehind}(${this.namespace}, ${this.key}, ${this.value}${e})`}}class it extends Je{static grammar=ke.doubleQuotedString.map((e=>new this(ae.unescapeString(e)))).label("StringEntity");constructor(e=""){super(),this.value=e}print(){return this.value}valueOf(){return this.value}toString(e=!1){let t=ae.escapeString(this.value);return e||(t=`"${t}"`),t}}class st extends Je{static lookbehind=["LOCGEN_FORMAT_NAMED","LOCGEN_FORMAT_ORDERED"];static grammar=ke.seq(ke.reg(new RegExp(String.raw`(${this.lookbehind.reduce(((e,t)=>e+"|"+t))})\s*`),1),ke.alt(...[it,tt,et,st].map((e=>e.grammar))).sepBy(ke.reg(/\s*\,\s*/)),ke.reg(/\s*\)/)).map((([e,t])=>{const i=new this(t);return i.lookbehind=e,i})).label("FormatTextEntity");constructor(e){super(),this.values=e}print(){const e=this.values?.[0]?.toString();if(!e)return"";const t=this.values.slice(1).map((e=>e.toString()));let i="LOCGEN_FORMAT_NAMED"==this.Self().lookbehind?e.replaceAll(/\{([a-zA-Z]\w*)\}/g,((e,i)=>{const s=t.indexOf(i)+1;return s>0&&s{const s=Number(i);return snew this(e)));#n;get value(){return this.#n}set value(e){e>=-(1n<<63n)&&e<1n<<63n&&(this.#n=e)}constructor(e=0n){super(),this.value=BigInt(e)}valueOf(){return this.value}toString(){return this.value.toString()}}class rt extends Le{static#$=ke.regArray(new RegExp(`'"(${Ie.Regex.InsideString.source})"'|'(${Ie.Regex.InsideSingleQuotedString.source})'`)).map((([e,t,i])=>t??i));static typeReference=ke.reg(new RegExp(Ie.Regex.Path.source+"|"+Ie.symbol.getParser().regexp.source));static fullReferenceGrammar=ke.regArray(new RegExp("("+this.typeReference.getParser().regexp.source+")(?:"+this.#$.getParser().parser.regexp.source+")")).map((([e,t,...i])=>new this(t,i.find((e=>e)),e)));static fullReferenceSerializedGrammar=ke.regArray(new RegExp('"('+Ie.Regex.InsideString.source+"?)(?:'("+Ie.Regex.InsideSingleQuotedString.source+"?)')?\"")).map((([e,t,i])=>new this(t,i,e)));static typeReferenceGrammar=this.typeReference.map((e=>new this(e,"",e)));static grammar=ke.alt(this.fullReferenceSerializedGrammar,this.fullReferenceGrammar,this.typeReferenceGrammar).label("ObjectReferenceEntity");#c;get type(){return this.#c}set type(e){this.#c=e}#D;get path(){return this.#D}set path(e){this.#D=e}#V;get full(){return this.#V}set full(e){this.#V=e}constructor(e="None",t="",i=null){super(),this.#c=e,this.#D=t,this.#V=i??`"${this.type+(this.path?`'${this.path}'`:"")}"`}static createNoneInstance(){return new rt("None")}getName(e=!1){return ae.getNameFromPath(this.path.replace(/_C$/,""),e)}toString(e=!1,t="",i=this.Self().printKey){return this.full}}class at extends Le{static grammar=ke.seq(Xe.grammar,ke.whitespace,Ge.grammar).map((([e,t,i])=>new this(e,i))).label("PinReferenceEntity");constructor(e=null,t=null){super(),this.objectName=e,this.pinGuid=t}toString(e=!1,t="",i=this.Self().printKey){return this.objectName.toString()+" "+this.pinGuid.toString()}}class ot extends Le{static attributes={...super.attributes,MemberParent:rt,MemberName:it,MemberGuid:Ge};static grammar=Ie.createEntityGrammar(this);constructor(e){super(e),this.MemberParent,this.MemberName,this.MemberGuid}}class lt extends Le{static attributes={...super.attributes,PinCategory:it.withDefault(),PinSubCategory:it.withDefault(),PinSubCategoryObject:rt.withDefault(),PinSubCategoryMemberReference:ot.withDefault((e=>null)),PinValueType:lt.withDefault(),ContainerType:Xe,bIsReference:Ue.withDefault(),bIsConst:Ue.withDefault(),bIsWeakPointer:Ue.withDefault(),bIsUObjectWrapper:Ue.withDefault(),bSerializeAsSinglePrecisionFloat:Ue.withDefault()};static grammar=Ie.createEntityGrammar(this).label("PinTypeEntity");constructor(e={}){super(e),this.PinCategory,this.PinSubCategory,this.PinSubCategoryObject,this.PinSubCategoryMemberReference,this.PinValueType,this.ContainerType,this.bIsReference,this.bIsConst,this.bIsWeakPointer,this.bIsUObjectWrapper,this.bIsUObjectWrapper,this.bSerializeAsSinglePrecisionFloat}copyTypeFrom(e){for(const t of this.keys)void 0!==e[t]&&(this[t]=e[t])}}class ut extends Le{static attributes={...super.attributes,X:We.withDefault(),Y:We.withDefault()};static grammar=Ie.createEntityGrammar(this).label("Vector2DEntity");constructor(e){super(e),this.X,this.Y}toArray(){return[this.X.valueOf(),this.Y.valueOf()]}}class ct extends ut{static grammar=ke.alt(ke.regArray(new RegExp(/X\s*=\s*/.source+"(?"+Ie.numberRegexSource+")\\s+"+/Y\s*=\s*/.source+"(?"+Ie.numberRegexSource+")")).map((({groups:{x:e,y:t}})=>new this({X:Number(e),Y:Number(t)}))),ut.grammar).label("RBSerializationVector2DEntity")}class ht extends Le{static attributes={...super.attributes,R:We.withDefault(),P:We.withDefault(),Y:We.withDefault()};static grammar=Ie.createEntityGrammar(this).label("RotatorEntity");constructor(e){super(e),this.R,this.P,this.Y}getRoll(){return this.R}getPitch(){return this.P}getYaw(){return this.Y}}class pt extends ht{static grammar=ke.alt(ke.regArray(new RegExp(`(${Ie.numberRegexSource})`+String.raw`\s*,\s*`+`(${Ie.numberRegexSource})`+String.raw`\s*,\s*`+`(${Ie.numberRegexSource})`)).map((([e,t,i,s])=>new this({R:Number(s),P:Number(t),Y:Number(i)}))),ht.grammar)}class dt extends ut{static grammar=ke.alt(ke.regArray(new RegExp(`(${Ie.numberRegexSource})`+String.raw`\s*,\s*`+`(${Ie.numberRegexSource})`)).map((([e,t,i])=>new this({X:Number(t),Y:Number(i)}))),ut.grammar)}class mt extends Le{static attributes={...super.attributes,X:We.withDefault(),Y:We.withDefault(),Z:We.withDefault(),W:We.withDefault()};static grammar=Ie.createEntityGrammar(this).label("Vector4DEntity");constructor(e){super(e),this.X,this.Y,this.Z,this.W}toArray(){return[this.X.valueOf(),this.Y.valueOf(),this.Z.valueOf(),this.W.valueOf()]}}class gt extends mt{static grammar=this.createGrammar();static createGrammar(){return ke.alt(ke.regArray(new RegExp(`(${Ie.numberRegexSource})`+String.raw`\s*,\s*`+`(${Ie.numberRegexSource})`+String.raw`\s*,\s*`+`(${Ie.numberRegexSource})`+String.raw`\s*,\s*`+`(${Ie.numberRegexSource})`)).map((([e,t,i,s,n])=>new this({X:Number(t),Y:Number(i),Z:Number(s),W:Number(n)}))),mt.grammar)}}class bt extends Le{static attributes={...super.attributes,X:We.withDefault(),Y:We.withDefault(),Z:We.withDefault()};static grammar=Ie.createEntityGrammar(this).label("VectorEntity");constructor(e){super(e),this.X,this.Y,this.Z}toArray(){return[this.X.valueOf(),this.Y.valueOf(),this.Z.valueOf()]}}class vt extends bt{static grammar=ke.alt(ke.regArray(new RegExp(`(${Ie.numberRegexSource})`+String.raw`\s*,\s*`+`(${Ie.numberRegexSource})`+String.raw`\s*,\s*`+`(${Ie.numberRegexSource})`)).map((([e,t,i,s])=>new this({X:Number(t),Y:Number(i),Z:Number(s)}))),bt.grammar)}class ft extends Le{static lookbehind="INVTEXT";static#B={[re.paths.linearColor]:De,[re.paths.rotator]:ht,[re.paths.vector]:bt,[re.paths.vector2D]:ut,[re.paths.vector4f]:mt,bool:Ue,byte:Ye,enum:Ze,exec:it,int:Ke,int64:nt,name:it,real:We,string:it};static#O={enum:Qe,rg:ct,[re.paths.rotator]:pt,[re.paths.vector]:vt,[re.paths.vector2D]:dt,[re.paths.vector3f]:vt,[re.paths.vector4f]:gt};static attributes={...super.attributes,PinId:Ge.withDefault(),PinName:it.withDefault(),PinFriendlyName:ze.accepting(tt,st,et,it),PinToolTip:it,Direction:it,PinType:lt.withDefault().flagInlined(),LinkedTo:je.of(at),SubPins:je.of(at),ParentPin:at,DefaultValue:qe.from((e=>e.getEntityType(!0)??it)).flagSerialized(),AutogeneratedDefaultValue:it,DefaultObject:rt,PersistentGuid:Ge,bHidden:Ue.withDefault(),bNotConnectable:Ue.withDefault(),bDefaultValueIsReadOnly:Ue.withDefault(),bDefaultValueIsIgnored:Ue.withDefault(),bAdvancedView:Ue.withDefault(),bOrphanedPin:Ue.withDefault()};static grammar=Ie.createEntityGrammar(this);#H=!1;set recomputesNodeTitleOnChange(e){this.#H=e}get recomputesNodeTitleOnChange(){return this.#H}#R;get objectEntity(){return this.#R}set objectEntity(e){this.#R=e}#G;get pinIndex(){return this.#G}set pinIndex(e){this.#G=e}constructor(e={}){super(e),this.PinId,this.PinName,this.PinFriendlyName,this.PinToolTip,this.Direction,this.PinType,this.LinkedTo,this.DefaultValue,this.AutogeneratedDefaultValue,this.DefaultObject,this.PersistentGuid,this.bHidden,this.bNotConnectable,this.bDefaultValueIsReadOnly,this.bDefaultValueIsIgnored,this.bAdvancedView,this.bOrphanedPin}static fromLegacyObject(e){return new ft(e)}getType(){const e=this.PinType.PinCategory.toLocaleLowerCase();if("struct"===e||"class"===e||"object"===e||"type"===e)return this.PinType.PinSubCategoryObject.path;if(this.isEnum())return"enum";if(this.objectEntity?.isPcg()){const e=this.objectEntity.getPcgSubobject(),t=this.isInput()?e.InputPins?.[this.pinIndex]:e.OutputPins?.[this.pinIndex];if(t){const i=e[re.subObjectAttributeNameFromReference(t,!0)];let s=i.Properties?.AllowedTypes?.toString()??"";if(""==s&&(s=this.PinType.PinCategory??"",""==s&&(s="Any")),s)return!1!==i.Properties.bAllowMultipleData&&!1!==i.Properties.bAllowMultipleConnections&&(s+="[]"),s}}if("optional"===e)switch(this.PinType.PinSubCategory){case"red":return"real";case"rg":return"rg";case"rgb":return re.paths.vector;case"rgba":return re.paths.linearColor;default:return this.PinType.PinSubCategory}return e}getEntityType(e=!1){const t=this.getType(),i=ft.#B[t],s=ft.#O[t];return e&&void 0!==s?s:i}pinTitle(){return function(e){let t,i=e.PinFriendlyName?e.PinFriendlyName.toString():ae.formatStringName(e.PinName??"");return e.PinToolTip&&(t=e.PinToolTip.match(/\s*(.+?(?=\n)|.+\S)\s*/))&&t[1].toLowerCase()===i.toLowerCase()?t[1]:i}(this)}copyTypeFrom(e){this.PinType.PinCategory=e.PinType.PinCategory,this.PinType.PinSubCategory=e.PinType.PinSubCategory,this.PinType.PinSubCategoryObject=e.PinType.PinSubCategoryObject,this.PinType.PinSubCategoryMemberReference=e.PinType.PinSubCategoryMemberReference,this.PinType.PinValueType=e.PinType.PinValueType,this.PinType.ContainerType=e.PinType.ContainerType,this.PinType.bIsReference=e.PinType.bIsReference,this.PinType.bIsConst=e.PinType.bIsConst,this.PinType.bIsWeakPointer=e.PinType.bIsWeakPointer,this.PinType.bIsUObjectWrapper=e.PinType.bIsUObjectWrapper,this.PinType.bSerializeAsSinglePrecisionFloat=e.PinType.bSerializeAsSinglePrecisionFloat}getDefaultValue(e=!1){return void 0===this.DefaultValue&&e&&(this.DefaultValue=new(this.getEntityType(!0))),this.DefaultValue}isEnum(){const e=this.PinType.PinSubCategoryObject.type;return e===re.paths.enum||e===re.paths.userDefinedEnum||"enum"===e.toLowerCase()}isExecution(){return"exec"===this.PinType.PinCategory}isHidden(){return this.bHidden}isInput(){return!this.bHidden&&"EGPD_Output"!=this.Direction}isOutput(){return!this.bHidden&&"EGPD_Output"==this.Direction}isLinked(){return this.LinkedTo?.length>0??!1}linkTo(e,t){const i=this.LinkedTo?.some((i=>i.objectName.toString()==e&&i.pinGuid.valueOf()==t.PinId.valueOf()));return!i&&((this.LinkedTo??=[]).push(new at(e,t.PinId)),!0)}unlinkFrom(e,t){const i=this.LinkedTo?.findIndex((i=>i.objectName.toString()==e&&i.pinGuid.valueOf()==t.PinId.valueOf()));return i>=0&&(this.LinkedTo.splice(i,1),0===this.LinkedTo.length&&void 0===ft.attributes.LinkedTo.default&&(this.LinkedTo=void 0),!0)}getSubCategory(){return this.PinType.PinSubCategoryObject.path}pinColor(){return function(e){if("mask"==e.PinType.PinCategory){const t=_e[e.PinType.PinSubCategory];if(t)return t}else if("optional"==e.PinType.PinCategory)return Fe;return _e[e.getType()]??_e[e.PinType.PinCategory.toLowerCase()]??_e.default}(this)}}const yt=e=>e.PinName.match(/^\s*([A-Z])\s*$/)?.[1]?.charCodeAt(0)-"A".charCodeAt(0);class wt extends Le{static attributeConverter={fromAttribute:(e,t)=>new wt(e),toAttribute:(e,t)=>e.toString()};static grammar=Ie.symbol.map((e=>new this(e)));constructor(e){super(),this.value=e}valueOf(){return this.value}toString(){return this.value.toString()}}class St extends Le{static attributes={...super.attributes,MacroGraph:rt,GraphBlueprint:rt,GraphGuid:Ge};static grammar=Ie.createEntityGrammar(this);constructor(e){super(e),this.MacroGraph,this.GraphBlueprint,this.GraphGuid}getMacroName(){const e=this.MacroGraph.path.search(":");return this.MacroGraph.path.substring(e+1)}}class Et extends Ke{static grammar=ke.numberNatural.map((e=>new this(e)));set value(e){e=Math.round(ae.clamp(this.value,0)),super.value=e}constructor(e=0){super(e)}}class Ct extends Le{static attributes={...super.attributes,ScriptVariable:rt,OriginalChangeId:Ge};static grammar=Ie.createEntityGrammar(this).label("ScriptVariableEntity");constructor(e={}){super(e),this.ScriptVariable,this.OriginalChangeId}}class Nt extends ft{static grammar=ke.seq(ke.reg(new RegExp(`(${Ie.Regex.Symbol.source})\\s*\\(\\s*`),1),Ie.createAttributeGrammar(this).sepBy(Ie.commaSeparation),ke.reg(/\s*(?:,\s*)?\)/)).map((([e,t,i])=>{e??="";let s={};return e.length&&(s.lookbehind=e),t.forEach((e=>e(s))),new this(s)})).label("UnknownPinEntity")}class xt extends Le{static attributes={...super.attributes,MemberScope:it,MemberName:it.withDefault(),MemberGuid:Ge,bSelfContext:Ue};static grammar=Ie.createEntityGrammar(this).label("VariableReferenceEntity");constructor(e){super(e),this.MemberScope,this.MemberName,this.MemberGuid,this.bSelfContext}}class Pt extends Le{static trailing=!0;#_=!1;get exported(){return this.#_}set exported(e){this.#_=e}static attributes={...super.attributes,Class:rt,Name:it,Archetype:rt,ExportPath:rt,ObjectRef:rt,BlueprintElementType:rt,BlueprintElementInstance:rt,PinNames:je.of(it).flagInlined(),AxisKey:Xe,InputAxisKey:Xe,InputName:it,InputType:Xe,NumAdditionalInputs:Et,bIsPureFunc:Ue,bIsConstFunc:Ue,bIsCaseSensitive:Ue,VariableReference:xt,SelfContextInfo:Xe,DelegatePropertyName:it,DelegateOwnerClass:rt,ComponentPropertyName:it,EventReference:ot,FunctionReference:ot,FunctionScript:rt,CustomFunctionName:it,TargetType:rt,MacroGraphReference:St,Enum:rt,EnumEntries:je.of(it).flagInlined(),InputKey:Xe,OpName:it,CachedChangeId:Ge,FunctionDisplayName:it,AddedPins:je.of(Nt).withDefault().flagInlined().flagSilent(),ChangeId:Ge,MaterialFunction:rt,bOverrideFunction:Ue,bInternalEvent:Ue,bConsumeInput:Ue,bExecuteWhenPaused:Ue,bOverrideParentBinding:Ue,bControl:Ue,bAlt:Ue,bShift:Ue,bCommand:Ue,CommentColor:De,bCommentBubbleVisible_InDetailsPanel:Ue,bColorCommentBubble:Ue,ProxyFactoryFunctionName:it,ProxyFactoryClass:rt,ProxyClass:rt,StructType:rt,MaterialExpression:rt,MaterialExpressionComment:rt,MoveMode:Xe,TimelineName:it,TimelineGuid:Ge,SizeX:Me.of(Ke),SizeY:Me.of(Ke),Text:Me.of(it),MaterialExpressionEditorX:Me.of(Ke),MaterialExpressionEditorY:Me.of(Ke),NodeTitle:it,NodeTitleColor:De,PositionX:Me.of(Ke),PositionY:Me.of(Ke),SettingsInterface:rt,PCGNode:rt,HiGenGridSize:Xe,Operation:Xe,NodePosX:Ke,NodePosY:Ke,NodeHeight:Ke,NodeWidth:Ke,Graph:rt,SubgraphInstance:it,InputPins:je.of(rt).flagInlined(),OutputPins:je.of(rt).flagInlined(),bExposeToLibrary:Ue,bCanRenameNode:Ue,bCommentBubblePinned:Ue,bCommentBubbleVisible:Ue,NodeComment:it,AdvancedPinDisplay:wt,DelegateReference:xt,EnabledState:wt,NodeGuid:Ge,ErrorType:Ke,ErrorMsg:it,ScriptVariables:je.of(Ct),Node:Me.of(rt),ExportedNodes:it,CustomProperties:je.of(ze.accepting(ft,Nt)).withDefault().flagSilent()};static#F=/^(\w+?)(?:_(\d+))?$/;static customPropertyGrammar=ke.seq(ke.reg(/CustomProperties\s+/),this.attributes.CustomProperties.type.grammar).map((([e,t])=>e=>{(e.CustomProperties??=[]).push(t)}));static inlinedArrayEntryGrammar=ke.seq(ke.alt(Ie.symbolQuoted.map((e=>[e,!0])),Ie.symbol.map((e=>[e,!1]))),ke.reg(new RegExp(String.raw`\s*\(\s*(\d+)\s*\)\s*\=\s*`),1).map(Number)).chain((([[e,t],i])=>this.attributes[e].grammar.map((s=>n=>{if(void 0===n[e]){let i=je;t!=i.quoted&&(i=i.flagQuoted(t)),i.inlined||(i=i.flagInlined()),n[e]=new i}n[e].values[i]=s}))));static grammar=this.createGrammar();static createSubObjectGrammar(){return ke.lazy((()=>this.grammar)).map((e=>t=>t[re.subObjectAttributeNameFromEntity(e)]=e))}static createGrammar(){return ke.seq(ke.reg(/Begin +Object/),ke.seq(ke.whitespace,ke.alt(this.createSubObjectGrammar(),this.customPropertyGrammar,Ie.createAttributeGrammar(this,ke.reg(Ie.Regex.MultipleWordsSymbols)),Ie.createAttributeGrammar(this,Ie.attributeNameQuoted,void 0,((e,t,i)=>ae.objectSet(e,["attributes",...t,"quoted"],!0))),this.inlinedArrayEntryGrammar)).map((([e,t])=>t)).many(),ke.reg(/\s+End +Object/)).map((([e,t,i])=>{const s={};return t.forEach((e=>e(s))),new this(s)}))}static getMultipleObjectsGrammar(){return ke.seq(ke.whitespaceOpt,this.grammar,ke.seq(ke.whitespace,this.grammar).map((([e,t])=>t)).many(),ke.whitespaceOpt).map((([e,t,i,s])=>[t,...i]))}#z;constructor(e={}){if("NodePosX"in e!="NodePosY"in e){const t=Object.entries(e),[i,s]="NodePosX"in e?["NodePosY",Object.keys(e).indexOf("NodePosX")+1]:["NodePosX",Object.keys(e).indexOf("NodePosY")],n=[i,new(Ae.getAttribute(e,i,"type",Pt))];t.splice(s,0,n),e=Object.fromEntries(t)}super(e),this.AddedPins,this.AdvancedPinDisplay,this.Archetype,this.AxisKey,this.bIsPureFunc,this.BlueprintElementInstance,this.BlueprintElementType,this.Class,this.CommentColor,this.ComponentPropertyName,this.CustomFunctionName,this.CustomProperties,this.DelegatePropertyName,this.DelegateReference,this.EnabledState,this.Enum,this.EnumEntries,this.EventReference,this.ExportedNodes,this.ExportPath,this.FunctionDisplayName,this.FunctionReference,this.FunctionScript,this.Graph,this.HiGenGridSize,this.InputAxisKey,this.InputKey,this.InputName,this.InputPins,this.InputType,this.MacroGraphReference,this.MaterialExpression,this.MaterialExpressionComment,this.MaterialExpressionEditorX,this.MaterialExpressionEditorY,this.MaterialFunction,this.Name,this.Node,this.NodeComment,this.NodeHeight,this.NodePosX,this.NodePosY,this.NodeTitle,this.NodeTitleColor,this.NodeWidth,this.NumAdditionalInputs,this.ObjectRef,this.Operation,this.OpName,this.OutputPins,this.PCGNode,this.PinNames,this.PositionX,this.PositionY,this.ProxyFactoryFunctionName,this.ScriptVariables,this.SettingsInterface,this.SizeX,this.SizeY,this.StructType,this.SubgraphInstance,this.TargetType,this.Text,this.Text,this.VariableReference,this.Pins instanceof Array&&this.Pins.forEach((e=>{const t=this[re.subObjectAttributeNameFromReference(e,!0)];if(t){const e=ft.fromLegacyObject(t);e.LinkedTo=[],this.getCustomproperties(!0).push(e),ae.objectSet(this,["attributes","CustomProperties","ignored"],!0)}}));const t=this.getMaterialSubobject();if(t){const e=t;if(void 0!==e.SizeX&&(e.SizeX.getter=()=>this.NodeWidth),e.SizeY&&(e.SizeY.getter=()=>this.NodeHeight),e.Text&&(e.Text.getter=()=>this.NodeComment),e.MaterialExpressionEditorX&&(e.MaterialExpressionEditorX.getter=()=>this.NodePosX),e.MaterialExpressionEditorY&&(e.MaterialExpressionEditorY.getter=()=>this.NodePosY),this.getType()===re.paths.materialExpressionComponentMask){const t=re.rgba.map((e=>this.getPinEntities().find((t=>t.PinName===e&&(t.recomputesNodeTitleOnChange=!0)))));e.R=new(Me.of(Ue).withDefault().flagSilent())((()=>t[0].DefaultValue)),e.G=new(Me.of(Ue).withDefault().flagSilent())((()=>t[1].DefaultValue)),e.B=new(Me.of(Ue).withDefault().flagSilent())((()=>t[2].DefaultValue)),e.A=new(Me.of(Ue).withDefault().flagSilent())((()=>t[3].DefaultValue)),e.keys=[...re.rgba,...super.keys.filter((e=>!re.rgba.includes(e)))]}}const i=this.getPcgSubobject();i&&(i.PositionX&&(i.PositionX.getter=()=>this.NodePosX),i.PositionY&&(i.PositionY.getter=()=>this.NodePosY),i.getSubobjects().forEach((e=>{if(void 0!==e.Node){const t=e.Node.get();t.type===this.PCGNode.type&&t.path===`${this.Name}.${this.PCGNode.path}`&&(e.Node.getter=()=>new rt(this.PCGNode.type,`${this.Name}.${this.PCGNode.path}`))}})));let s=0,n=0;this.CustomProperties?.forEach(((e,t)=>{e.objectEntity=this,e.pinIndex=e.isInput()?s++:e.isOutput()?n++:t}))}getClass(){if(!this.#z&&(this.#z=(this.Class?.path?this.Class.path:this.Class?.type)??(this.ExportPath?.path?this.ExportPath.path:this.ExportPath?.type)??"",this.#z&&!this.#z.startsWith("/"))){let e=Object.values(re.paths).find((e=>e.endsWith("."+this.#z)));e&&(this.#z=e)}return this.#z}getType(){let e=this.getClass();return this.MacroGraphReference?.MacroGraph?.path?this.MacroGraphReference.MacroGraph.path:this.MaterialExpression?this.MaterialExpression.type:e}getObjectName(e=!1){return e?this.getNameAndCounter()[0]:this.Name}getNameAndCounter(){const e=this.getObjectName().match(Pt.#F);return e?[e[1]??"",parseInt(e[2]??"0")]:["",0]}getCounter(){return this.getNameAndCounter()[1]}getNodeWidth(){return this.NodeWidth??this.isComment()?re.defaultCommentWidth:void 0}setNodeWidth(e){this.NodeWidth||(this.NodeWidth=new Ke),this.NodeWidth.value=e}getNodeHeight(){return this.NodeHeight??this.isComment()?re.defaultCommentHeight:void 0}setNodeHeight(e){this.NodeHeight||(this.NodeHeight=new Ke),this.NodeHeight.value=e}getNodePosX(){return this.NodePosX?.value??0}setNodePosX(e){this.NodePosX||(this.NodePosX=new Ke),this.NodePosX.value=Math.round(e)}getNodePosY(){return this.NodePosY?.value??0}setNodePosY(e){this.NodePosY||(this.NodePosY=new Ke),this.NodePosY.value=Math.round(e)}getCustomproperties(e=!1){return this.CustomProperties.values}getPinEntities(){return this.getCustomproperties().filter((e=>e.constructor===ft))}getSubobjects(){return Object.keys(this).filter((e=>e.startsWith(re.subObjectAttributeNamePrefix))).flatMap((e=>[this[e],...this[e].getSubobjects()]))}switchTarget(){const e=this.getClass().match(re.switchTargetPattern);if(e)return e[1]}isEvent(){switch(this.getClass()){case re.paths.actorBoundEvent:case re.paths.componentBoundEvent:case re.paths.customEvent:case re.paths.event:case re.paths.inputAxisKeyEvent:case re.paths.inputVectorAxisEvent:return!0}return!1}isComment(){switch(this.getClass()){case re.paths.comment:case re.paths.materialGraphNodeComment:return!0}return!1}isMaterial(){return this.getClass()===re.paths.materialGraphNode}getMaterialSubobject(){const e=this.MaterialExpression??this.MaterialExpressionComment;return e?this[re.subObjectAttributeNameFromReference(e,!0)]:null}isPcg(){return this.getClass()===re.paths.pcgEditorGraphNode||this.getPcgSubobject()}isNiagara(){return this.Class&&(this.Class.type?this.Class.type:this.Class.path)?.startsWith("/Script/NiagaraEditor.")}getPcgSubobject(){const e=this.PCGNode;return e?this[re.subObjectAttributeNameFromReference(e,!0)]:null}getSettingsObject(){const e=this.SettingsInterface;return e?this[re.subObjectAttributeNameFromReference(e,!0)]:null}getSubgraphObject(){const e=this.SubgraphInstance;return e?this[re.subObjectAttributeNameFromName(e)]:null}isDevelopmentOnly(){const e=this.getClass();return"DevelopmentOnly"===this.EnabledState?.toString()||e.includes("Debug",Math.max(0,e.lastIndexOf(".")))}getHIDAttribute(){return this.InputKey??this.AxisKey??this.InputAxisKey}getDelegatePin(){return this.getCustomproperties().find((e=>"delegate"===e.PinType.PinCategory))}nodeColor(){return function(e){switch(e.getType()){case re.paths.materialExpressionConstant2Vector:case re.paths.materialExpressionConstant3Vector:case re.paths.materialExpressionConstant4Vector:return re.nodeColors.yellow;case re.paths.makeStruct:return re.nodeColors.darkBlue;case re.paths.materialExpressionMaterialFunctionCall:return re.nodeColors.blue;case re.paths.materialExpressionFunctionInput:return re.nodeColors.red;case re.paths.materialExpressionTextureSample:return re.nodeColors.darkTurquoise;case re.paths.materialExpressionTextureCoordinate:case re.paths.pcgEditorGraphNodeInput:case re.paths.pcgEditorGraphNodeOutput:return re.nodeColors.red}switch(e.getClass()){case re.paths.callFunction:return e.bIsPureFunc?re.nodeColors.green:re.nodeColors.blue;case re.paths.niagaraNodeFunctionCall:return re.nodeColors.darkerBlue;case re.paths.dynamicCast:return re.nodeColors.turquoise;case re.paths.inputDebugKey:case re.paths.inputKey:return re.nodeColors.red;case re.paths.createDelegate:case re.paths.enumLiteral:case re.paths.makeArray:case re.paths.makeMap:case re.paths.materialGraphNode:case re.paths.select:return re.nodeColors.green;case re.paths.executionSequence:case re.paths.ifThenElse:case re.paths.macro:case re.paths.multiGate:return re.nodeColors.gray;case re.paths.functionEntry:case re.paths.functionResult:return re.nodeColors.violet;case re.paths.timeline:return re.nodeColors.yellow}if(e.switchTarget())return re.nodeColors.lime;if(e.isEvent())return re.nodeColors.red;if(e.isComment())return(e.CommentColor?e.CommentColor:De.getWhite()).toDimmedColor().toCSSRGBValues();const t=e.getPcgSubobject();if(t){if(t.NodeTitleColor)return t.NodeTitleColor.toDimmedColor(.1).toCSSRGBValues();switch(e.PCGNode?.getName(!0)){case"Branch":case"Select":return re.nodeColors.intenseGreen}}return e.bIsPureFunc?re.nodeColors.green:re.nodeColors.blue}(this)}nodeIcon(){return function(e){if(e.isMaterial()||e.isPcg()||e.isNiagara())return null;switch(e.getType()){case re.paths.addDelegate:case re.paths.asyncAction:case re.paths.callDelegate:case re.paths.createDelegate:case re.paths.functionEntry:case re.paths.functionResult:return Ve.node;case re.paths.customEvent:return Ve.event;case re.paths.doN:return Ve.doN;case re.paths.doOnce:return Ve.doOnce;case re.paths.dynamicCast:return Ve.cast;case re.paths.enumLiteral:return Ve.enum;case re.paths.event:return Ve.event;case re.paths.executionSequence:case re.paths.multiGate:return Ve.sequence;case re.paths.flipflop:return Ve.flipflop;case re.paths.forEachElementInEnum:case re.paths.forLoop:case re.paths.forLoopWithBreak:case re.paths.whileLoop:return Ve.loop;case re.paths.forEachLoop:case re.paths.forEachLoopWithBreak:return Ve.forEachLoop;case re.paths.ifThenElse:return Ve.branchNode;case re.paths.isValid:return Ve.questionMark;case re.paths.makeArray:return Ve.makeArray;case re.paths.makeMap:return Ve.makeMap;case re.paths.makeSet:return Ve.makeSet;case re.paths.makeStruct:return Ve.makeStruct;case re.paths.metasoundEditorGraphExternalNode:return Ve.metasoundFunction;case re.paths.select:return Ve.select;case re.paths.spawnActorFromClass:return Ve.spawnActor;case re.paths.timeline:return Ve.timer}if(e.switchTarget())return Ve.switch;if(He(e).startsWith("Break"))return Ve.breakStruct;if(e.getClass()===re.paths.macro)return Ve.macro;const t=e.getHIDAttribute()?.toString();return t?t.includes("Mouse")?Ve.mouse:t.includes("Gamepad_Special")?Ve.keyboard:t.includes("Gamepad")||t.includes("Steam")?Ve.gamepad:t.includes("Touch")?Ve.touchpad:Ve.keyboard:e.getDelegatePin()?Ve.event:e.ObjectRef?.type===re.paths.ambientSound?Ve.sound:Ve.functionSymbol}(this)}additionalPinInserter(){return function(e){let t,i,s,n;switch(e.getType()){case re.paths.commutativeAssociativeBinaryOperator:case re.paths.promotableOperator:switch(n=e.FunctionReference?.MemberName,n){default:if(!(n?.startsWith("Add_")||n?.startsWith("Subtract_")||n?.startsWith("Multiply_")||n?.startsWith("Divide_")))break;case"And_Int64Int64":case"And_IntInt":case"BMax":case"BMin":case"BooleanAND":case"BooleanNAND":case"BooleanOR":case"Concat_StrStr":case"FMax":case"FMin":case"Max":case"MaxInt64":case"Min":case"MinInt64":case"Or_Int64Int64":case"Or_IntInt":t??=()=>e.getPinEntities().filter((e=>e.isInput())),i??=yt,s??=(i,s=-1,n=-1)=>{const r=String.fromCharCode(i>=0?i:n+"A".charCodeAt(0)+1);return e.NumAdditionalInputs=t().length-1,r}}break;case re.paths.multiGate:t??=()=>e.getPinEntities().filter((e=>e.isOutput())),i??=e=>Number(e.PinName.match(/^\s*Out[_\s]+(\d+)\s*$/i)?.[1]),s??=(e,t=-1,i=-1,s)=>`Out ${e>=0?e:t>0?"Out 0":i+1}`;break;case re.paths.switchInteger:t??=()=>e.getPinEntities().filter((e=>e.isOutput())),i??=e=>Number(e.PinName.match(/^\s*(\d+)\s*$/)?.[1]),s??=(e,t=-1,i=-1,s)=>(e<0?i+1:e).toString();break;case re.paths.switchGameplayTag:s??=(t,i=-1,s=-1,n)=>{const r=`Case_${t>=0?t:i>0?"0":s+1}`;return e.PinNames??=[],e.PinNames.push(r),delete e.PinTags[e.PinTags.length-1],e.PinTags[e.PinTags.length]=null,r};case re.paths.switchName:case re.paths.switchString:t??=()=>e.getPinEntities().filter((e=>e.isOutput())),i??=e=>Number(e.PinName.match(/^\s*Case[_\s]+(\d+)\s*$/i)?.[1]),s??=(t,i=-1,s=-1,n)=>{const r=`Case_${t>=0?t:i>0?"0":s+1}`;return e.PinNames??=[],e.PinNames.push(r),r}}if(t)return()=>{let n=Number.MAX_SAFE_INTEGER,r=Number.MIN_SAFE_INTEGER,a=[];const o=t().reduce(((e,t)=>{const s=i(t);if(isNaN(s)){if(void 0===e)return t}else if(a.push(s),n=Math.min(s,n),s>r)return r=s,t;return e}),void 0);if(n!==Number.MAX_SAFE_INTEGER&&r!==Number.MIN_SAFE_INTEGER||(n=void 0,r=void 0),!o)return null;a.sort(((e,t)=>e{const t=e-l>1;return l=e,t}));const c=new ft(o);return c.PinId=Ge.generateGuid(),c.PinName=s(u,n,r,c),c.PinToolTip=void 0,e.getCustomproperties(!0).push(c),c}}(this)}showProperty(e){switch(e){case"Class":case"Name":case"Archetype":case"ExportPath":case"CustomProperties":return!1}return super.showProperty(e)}toString(e=!1,t="",i=this.Self().printKey){const s=t+re.indentation;let n=t+"Begin Object"+(this.Class?.type||this.Class?.path?` Class=${this.Class.toString(e)}`:"")+(this.Name?` Name=${this.Name.toString(e)}`:"")+(this.Archetype?` Archetype=${this.Archetype.toString(e)}`:"")+(this.ExportPath?.type||this.ExportPath?.path?` ExportPath=${this.ExportPath.toString(e)}`:"")+"\n"+super.toString(e,s,(e=>this[e]instanceof Pt?"":e))+(this.CustomProperties.Self().ignored?"":this.getCustomproperties().map((t=>s+i("CustomProperties ")+t.toString(e)+this.Self().attributeSeparator)).join(""))+t+"End Object";return n}}class kt extends Pt{constructor(e={},t=void 0){e.Class=new rt(re.paths.knot),e.Name="K2Node_Knot";const i=new ft({PinName:"InputPin"}),s=new ft({PinName:"OutputPin",Direction:"EGPD_Output"});t&&(i.copyTypeFrom(t),s.copyTypeFrom(t)),e.CustomProperties=[i,s],super(e)}}class At{#j;get target(){return this.#j}#e;get blueprint(){return this.#e}consumeEvent;options;listenHandler=()=>this.listenEvents();unlistenHandler=()=>this.unlistenEvents();constructor(e,t,i={}){i.consumeEvent??=!1,i.listenOnFocus??=!1,i.unlistenOnTextEdit??=!1,this.#j=e,this.#e=t,this.consumeEvent=i.consumeEvent,this.options=i}setup(){this.options.listenOnFocus&&(this.blueprint.addEventListener(re.focusEventName.begin,this.listenHandler),this.blueprint.addEventListener(re.focusEventName.end,this.unlistenHandler)),this.options.unlistenOnTextEdit&&(this.blueprint.addEventListener(re.editTextEventName.begin,this.unlistenHandler),this.blueprint.addEventListener(re.editTextEventName.end,this.listenHandler)),this.blueprint.focused&&this.listenEvents()}cleanup(){this.unlistenEvents(),this.blueprint.removeEventListener(re.focusEventName.begin,this.listenHandler),this.blueprint.removeEventListener(re.focusEventName.end,this.unlistenHandler),this.blueprint.removeEventListener(re.editTextEventName.begin,this.unlistenHandler),this.blueprint.removeEventListener(re.editTextEventName.end,this.listenHandler)}listenEvents(){}unlistenEvents(){}}class Lt extends Le{static attributes={...super.attributes,ActionName:it,bShift:Ue,bCtrl:Ue,bAlt:Ue,bCmd:Ue,Key:wt};static grammar=ke.alt(wt.grammar.map((e=>{const t=new this;return t.Key=e,t})),Ie.createEntityGrammar(this));constructor(){super(),this.ActionName,this.bShift,this.bCtrl,this.bAlt,this.bCmd,this.Key}}class Mt extends At{static#U=e=>{};#W;pressedKey="";constructor(e,t,i={},s=Mt.#U,n=Mt.#U){i.activationKeys??=[],i.consumeEvent??=!0,i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,i.activationKeys instanceof Array||(i.activationKeys=[i.activationKeys]),i.activationKeys=i.activationKeys.map((e=>{if(e instanceof Lt)return e;if(e.constructor===String){const t=Lt.grammar.run(e);if(t.status)return t.value}throw new Error("Unexpected key value")})),super(e,t,i),this.onKeyDown=s,this.onKeyUp=n,this.#W=this.options.activationKeys??[];let r=this;this.keyDownHandler=e=>{r.#W.some((t=>(e=>e.bShift||"LeftShift"==e.Key||"RightShift"==e.Key)(t)==e.shiftKey&&(e=>e.bCtrl||"LeftControl"==e.Key||"RightControl"==e.Key)(t)==e.ctrlKey&&(e=>e.bAlt||"LeftAlt"==e.Key||"RightAlt"==e.Key)(t)==e.altKey&&re.Keys[t.Key.value]==e.code))&&(this.consumeEvent&&(e.preventDefault(),e.stopImmediatePropagation()),this.pressedKey=e.code,r.fire(),document.removeEventListener("keydown",r.keyDownHandler),document.addEventListener("keyup",r.keyUpHandler))},this.keyUpHandler=e=>{r.#W.some((t=>t.bShift&&"Shift"==e.key||t.bCtrl&&"Control"==e.key||t.bAlt&&"Alt"==e.key||t.bCmd&&"Meta"==e.key||re.Keys[t.Key.value]==e.code))&&(this.consumeEvent&&e.stopImmediatePropagation(),r.unfire(),this.pressedKey="",document.removeEventListener("keyup",this.keyUpHandler),document.addEventListener("keydown",this.keyDownHandler))}}listenEvents(){document.addEventListener("keydown",this.keyDownHandler)}unlistenEvents(){document.removeEventListener("keydown",this.keyDownHandler)}fire(){this.onKeyDown(this)}unfire(){this.onKeyUp(this)}}class Tt extends At{#K=[0,0];get location(){return this.#K}#Y;get enablerKey(){return this.#Y}#q=!0;get enablerActivated(){return this.#q}constructor(e,t,i={}){i.ignoreTranslateCompensate??=!1,i.ignoreScale??=!1,i.movementSpace??=t.getGridDOMElement()??document.documentElement,super(e,t,i),this.movementSpace=i.movementSpace,i.enablerKey&&(this.#Y=i.enablerKey,this.#Y.onKeyDown=()=>this.#q=!0,this.#Y.onKeyUp=()=>this.#q=!1,this.#Y.consumeEvent=!1,this.#Y.listenEvents(),this.#q=!1)}setLocationFromEvent(e){let t=ae.convertLocation([e.clientX,e.clientY],this.movementSpace,this.options.ignoreScale);return t=this.options.ignoreTranslateCompensate?t:this.blueprint.compensateTranslation(t[0],t[1]),this.#K=[...t],this.#K}}class It extends Tt{static#U=e=>{};#X=e=>{if(this.blueprint.setFocused(!0),!this.enablerKey||this.enablerActivated)if(e.button===this.options.clickButton)this.options.strictTarget&&e.target!==e.currentTarget||(this.consumeEvent&&e.stopImmediatePropagation(),document.addEventListener("mouseup",this.#Z),this.setLocationFromEvent(e),this.clickedPosition[0]=this.location[0],this.clickedPosition[1]=this.location[1],this.blueprint.mousePosition[0]=this.location[0],this.blueprint.mousePosition[1]=this.location[1],this.clicked(this.clickedPosition));else this.options.exitAnyButton||this.#Z(e)};#Z=e=>{this.options.exitAnyButton&&e.button!=this.options.clickButton||(this.consumeEvent&&e.stopImmediatePropagation(),document.removeEventListener("mouseup",this.#Z),this.unclicked())};clickedPosition=[0,0];constructor(e,t,i={},s=It.#U,n=It.#U){i.clickButton??=re.mouseClickButton,i.consumeEvent??=!0,i.exitAnyButton??=!0,i.strictTarget??=!1,super(e,t,i),this.onClick=s,this.onUnclick=n,this.listenEvents()}listenEvents(){this.target.addEventListener("mousedown",this.#X),this.options.clickButton===re.mouseRightClickButton&&this.target.addEventListener("contextmenu",(e=>e.preventDefault()))}unlistenEvents(){this.target.removeEventListener("mousedown",this.#X)}clicked(e){this.onClick(this)}unclicked(e){this.onUnclick(this)}}class $t extends Tt{static ignoreDbClick=e=>{};#Q=e=>{this.options.strictTarget&&e.target!==e.currentTarget||(this.consumeEvent&&e.stopImmediatePropagation(),this.clickedPosition=this.setLocationFromEvent(e),this.blueprint.mousePosition=[...this.clickedPosition],this.dbclicked(this.clickedPosition))};#J;get onDbClick(){return this.#J}set onDbClick(e){this.#J=e}clickedPosition=[0,0];constructor(e,t,i={},s=$t.ignoreDbClick){i.consumeEvent??=!0,i.strictTarget??=!1,super(e,t,i),this.#J=s,this.listenEvents()}listenEvents(){this.target.addEventListener("dblclick",this.#Q)}unlistenEvents(){this.target.removeEventListener("dblclick",this.#Q)}dbclicked(e){this.onDbClick(e)}}class Dt{element;get blueprint(){return this.element.blueprint}#ee=[];get inputObjects(){return this.#ee}initialize(e){this.element=e}createInputObjects(){return[]}setup(){this.#ee.forEach((e=>e.setup()))}cleanup(){this.#ee.forEach((e=>e.cleanup()))}willUpdate(e){}update(e){}render(){return O``}firstUpdated(e){}updated(e){}inputSetup(){this.#ee=this.createInputObjects()}}class Vt extends Dt{update(e){super.update(e);const[t,i,s,n]=[Math.round(this.element.fromX),Math.round(this.element.fromY),Math.round(this.element.toX),Math.round(this.element.toY)],[r,a,o,l]=[Math.min(t,s),Math.min(i,n),Math.abs(t-s),Math.abs(i-n)];(e.has("fromX")||e.has("toX"))&&(this.element.style.left=`${r}px`,this.element.style.width=`${o}px`),(e.has("fromY")||e.has("toY"))&&(this.element.style.top=`${a}px`,this.element.style.height=`${l}px`)}}class Bt extends Vt{static decreasingValue(e,t){const i=-e*t[0]**2,s=t[1]-i/t[0];return e=>i/e+s}static clampedLine(e,t){if(e[0]>t[0]){const i=e;e=t,t=i}const i=(t[1]-e[1])/(t[0]-e[0]),s=e[1]-i*e[0];return n=>nt[0]?t[1]:i*n+s}static c1DecreasingValue=Bt.decreasingValue(-.15,[100,15]);static c2DecreasingValue=Bt.decreasingValue(-.05,[500,130]);static c2Clamped=Bt.clampedLine([0,80],[200,40]);#te=`ueb-id-${Math.floor(1e12*Math.random())}`;#ie=e=>{const t=new kt({},this.element.source.entity),i=ce.getConstructor("ueb-node").newObject(t);i.setLocation(...this.blueprint.snapToGrid(...e));const s=i.template;this.blueprint.addGraphElement(i);const n=this.element.getInputPin(),r=this.element.getOutputPin();this.element.source=null,this.element.destination=null;const a=ce.getConstructor("ueb-link").newObject(r,s.inputPin);this.blueprint.addGraphElement(a),this.element.source=s.outputPin,this.element.destination=n};createInputObjects(){const e=this.element.querySelector(".ueb-link-area");return[...super.createInputObjects(),new $t(e,this.blueprint,void 0,(e=>{e[0]+=re.knotOffset[0],e[1]+=re.knotOffset[1],e=ae.snapToGrid(e[0],e[1],re.gridSize),this.#ie(e)})),new It(e,this.blueprint,{enablerKey:new Mt(this.blueprint,this.blueprint,{activationKeys:ue.enableLinkDelete})},(()=>this.blueprint.removeGraphElement(this.element)))]}willUpdate(e){super.willUpdate(e);const t=this.element.source,i=this.element.destination;if(e.has("fromX")||e.has("toX")){const e=this.element.fromX,s=this.element.toX,n=t?.nodeElement.getType()==re.paths.knot,r=i?.nodeElement.getType()==re.paths.knot;!n||i&&!r||(t?.isInput()&&s>e+re.distanceThreshold?this.element.source=t.nodeElement.template.outputPin:t?.isOutput()&&se+re.distanceThreshold&&(this.element.destination=i.nodeElement.template.inputPin))}const s=Math.max(Math.abs(this.element.fromX-this.element.toX),1),n=Math.max(Math.abs(this.element.fromY-this.element.toY),1),r=Math.max(s,re.linkMinWidth),a=s/r,o=this.element.originatesFromInput?this.element.fromXthis.element.toY?1:0)),this.element.style.setProperty("--ueb-start-percentage",`${Math.round(this.element.startPercentage)}%`),this.element.style.setProperty("--ueb-link-start",`${Math.round(this.element.startPixels)}`)}render(){return O` ${this.element.linkMessageIcon||this.element.linkMessageText?O``:R}`}}class Ot extends le{static properties={...super.properties,dragging:{type:Boolean,attribute:"data-dragging",converter:ae.booleanConverter,reflect:!0},originatesFromInput:{type:Boolean,attribute:!1},svgPathD:{type:String,attribute:!1},linkMessageIcon:{type:String,attribute:!1},linkMessageText:{type:String,attribute:!1}};#se;get source(){return this.#se}set source(e){this.#ne(e,!1)}#re;get destination(){return this.#re}set destination(e){this.#ne(e,!0)}#ae=()=>this.remove();#oe=e=>this.addSourceLocation(...e.detail.value);#le=e=>this.addDestinationLocation(...e.detail.value);#ue=e=>this.setSourceLocation();#ce=e=>this.setDestinationLocation();linkMessageIcon=R;linkMessageText=R;pathElement;constructor(){super(),this.dragging=!1,this.originatesFromInput=!1,this.startPercentage=0,this.svgPathD="",this.startPixels=0}static newObject(e,t){const i=new Ot;return i.initialize(e,t),i}initialize(e,t){super.initialize({},new Bt),e&&(this.source=e,t||(this.toX=this.fromX,this.toY=this.fromY)),t&&(this.destination=t,e||(this.fromX=this.toX,this.fromY=this.toY))}#ne(e,t){const i=()=>t?this.destination:this.source;if(i()!=e){if(i()){const e=i().getNodeElement();e.removeEventListener(re.removeEventName,this.#ae),e.removeEventListener(re.nodeDragEventName,t?this.#le:this.#oe),e.removeEventListener(re.nodeReflowEventName,t?this.#ce:this.#ue),this.#he()}if(t?this.#re=e:this.#se=e,i()){const e=i().getNodeElement();e.addEventListener(re.removeEventName,this.#ae),e.addEventListener(re.nodeDragEventName,t?this.#le:this.#oe),e.addEventListener(re.nodeReflowEventName,t?this.#ce:this.#ue),t?this.setDestinationLocation():(this.setSourceLocation(),this.originatesFromInput=this.source.isInput()),this.#pe()}}}#pe(){this.source&&this.destination&&(this.source.linkTo(this.destination),this.destination.linkTo(this.source))}#he(){this.source&&this.destination&&(this.source.unlinkFrom(this.destination,!1),this.destination.unlinkFrom(this.source,!1))}cleanup(){super.cleanup(),this.#he(),this.source=null,this.destination=null}setSourceLocation(e=null,t=!0){if(null==e){const i=this;if(t&&(!this.hasUpdated||!this.source.hasUpdated))return void Promise.all([this.updateComplete,this.source.updateComplete]).then((()=>i.setSourceLocation(null,!1)));e=this.source.template.getLinkLocation()}const[i,s]=e;this.fromX=i,this.fromY=s}setDestinationLocation(e=null,t=!0){if(null==e){const i=this;if(t&&(!this.hasUpdated||!this.destination.hasUpdated))return void Promise.all([this.updateComplete,this.destination.updateComplete]).then((()=>i.setDestinationLocation(null,!1)));e=this.destination.template.getLinkLocation()}this.toX=e[0],this.toY=e[1]}getInputPin(){return this.source?.isInput()?this.source:this.destination}setInputPin(e){this.source?.isInput()&&(this.source=e),this.destination=e}getOutputPin(){return this.destination?.isOutput()?this.destination:this.source}setOutputPin(e){this.destination?.isOutput()&&(this.destination=e),this.source=e}startDragging(){this.dragging=!0}finishDragging(){this.dragging=!1}removeMessage(){this.linkMessageIcon=R,this.linkMessageText=R}setMessageConvertType(){this.linkMessageIcon=Ve.convert,this.linkMessageText=O`Convert ${this.source.pinType} to ${this.destination.pinType}.`}setMessageCorrect(){this.linkMessageIcon=Ve.correct,this.linkMessageText=R}setMessageReplace(){this.linkMessageIcon=Ve.correct,this.linkMessageText=R}setMessageDirectionsIncompatible(){this.linkMessageIcon=Ve.reject,this.linkMessageText=O`Directions are not compatbile.`}setMessagePlaceNode(){this.linkMessageIcon=R,this.linkMessageText=O`Place a new node.`}setMessageReplaceLink(){this.linkMessageIcon=Ve.correct,this.linkMessageText=O`Replace existing input connections.`}setMessageReplaceOutputLink(){this.linkMessageIcon=Ve.correct,this.linkMessageText=O`Replace existing output connections.`}setMessageSameNode(){this.linkMessageIcon=Ve.reject,this.linkMessageText=O`Both are on the same node.`}setMessageTypesIncompatible(e,t){this.linkMessageIcon=Ve.reject,this.linkMessageText=O`${ae.capitalFirstLetter(e.pinType)} is not compatible with ${ae.capitalFirstLetter(t.pinType)}.`}}class Ht extends oe{static properties={...super.properties,locationX:{type:Number,attribute:!1},locationY:{type:Number,attribute:!1},sizeX:{type:Number,attribute:!1},sizeY:{type:Number,attribute:!1}};static dragEventName=re.dragEventName;static dragGeneralEventName=re.dragGeneralEventName;constructor(){super(),this.locationX=0,this.locationY=0,this.sizeX=0,this.sizeY=0}computeSizes(){const e=this.getBoundingClientRect();this.sizeX=this.blueprint.scaleCorrect(e.width),this.sizeY=this.blueprint.scaleCorrect(e.height)}firstUpdated(e){super.firstUpdated(e),this.computeSizes()}setLocation(e,t,i=!0){const s=e-this.locationX,n=t-this.locationY;if(this.locationX=e,this.locationY=t,this.blueprint&&i){const e=new CustomEvent(this.constructor.dragEventName,{detail:{value:[s,n]},bubbles:!1,cancelable:!0});this.dispatchEvent(e)}}addLocation(e,t,i=!0){this.setLocation(this.locationX+e,this.locationY+t,i)}acknowledgeDrag(e){const t=new CustomEvent(this.constructor.dragGeneralEventName,{detail:{value:e},bubbles:!0,cancelable:!0});this.dispatchEvent(t)}snapToGrid(){const e=ae.snapToGrid(this.locationX,this.locationY,re.gridSize);this.locationX==e[0]&&this.locationY==e[1]||this.setLocation(e[0],e[1])}topBoundary(e=!1){return this.template.topBoundary(e)}rightBoundary(e=!1){return this.template.rightBoundary(e)}bottomBoundary(e=!1){return this.template.bottomBoundary(e)}leftBoundary(e=!1){return this.template.leftBoundary(e)}}class Rt extends Tt{#X=e=>{if(this.blueprint.setFocused(!0),e.button===this.options.clickButton)this.options.strictTarget&&e.target!=e.currentTarget||(this.consumeEvent&&e.stopImmediatePropagation(),this.#de.addEventListener("mousemove",this.#me),document.addEventListener("mouseup",this.#Z),this.setLocationFromEvent(e),this.clickedPosition[0]=this.location[0],this.clickedPosition[1]=this.location[1],this.blueprint.mousePosition[0]=this.location[0],this.blueprint.mousePosition[1]=this.location[1],this.target instanceof Ht&&(this.clickedOffset=[this.clickedPosition[0]-this.target.locationX,this.clickedPosition[1]-this.target.locationY]),this.clicked(this.clickedPosition));else this.options.exitAnyButton||this.#Z(e)};#me=e=>{this.consumeEvent&&e.stopImmediatePropagation(),this.#de.removeEventListener("mousemove",this.#me),this.#de.addEventListener("mousemove",this.#ge);const t=this.getEvent(re.trackingMouseEventName.begin);this.#be=0==this.target.dispatchEvent(t),this.setLocationFromEvent(e),this.lastLocation=ae.snapToGrid(this.clickedPosition[0],this.clickedPosition[1],this.stepSize),this.startDrag(this.location),this.started=!0,this.#ge(e)};#ge=e=>{this.consumeEvent&&e.stopImmediatePropagation();const t=this.setLocationFromEvent(e),i=[e.movementX,e.movementY];if(this.dragTo(t,i),this.#be&&(this.blueprint.mousePosition=t),this.options.scrollGraphEdge){const e=Math.sqrt(i[0]*i[0]+i[1]*i[1]),s=this.blueprint.scaleCorrect(re.edgeScrollThreshold),n=this.blueprint.template.gridLeftVisibilityBoundary()+s,r=this.blueprint.template.gridRightVisibilityBoundary()-s;let a=0;t[0]r&&(a=t[0]-r);const o=this.blueprint.template.gridTopVisibilityBoundary()+s,l=this.blueprint.template.gridBottomVisibilityBoundary()-s;let u=0;t[1]l&&(u=t[1]-l),a=ae.clamp(this.blueprint.scaleCorrectReverse(a)**3*e*.6,-20,20),u=ae.clamp(this.blueprint.scaleCorrectReverse(u)**3*e*.6,-20,20),this.blueprint.scrollDelta(a,u)}};#Z=e=>{if(!this.options.exitAnyButton||e.button==this.options.clickButton){if(this.consumeEvent&&e.stopImmediatePropagation(),this.#de.removeEventListener("mousemove",this.#me),this.#de.removeEventListener("mousemove",this.#ge),document.removeEventListener("mouseup",this.#Z),this.started&&this.endDrag(),this.unclicked(),this.#be){const e=this.getEvent(re.trackingMouseEventName.end);this.target.dispatchEvent(e),this.#be=!1}this.started=!1}};#be=!1;#de;#ve;get draggableElement(){return this.#ve}clickedOffset=[0,0];clickedPosition=[0,0];lastLocation=[0,0];started=!1;stepSize=1;constructor(e,t,i={}){i.clickButton??=re.mouseClickButton,i.consumeEvent??=!0,i.draggableElement??=e,i.exitAnyButton??=!0,i.moveEverywhere??=!1,i.movementSpace??=t?.getGridDOMElement(),i.repositionOnClick??=!1,i.scrollGraphEdge??=!1,i.strictTarget??=!1,super(e,t,i),this.stepSize=Number(i.stepSize??re.gridSize),this.#de=this.options.moveEverywhere?document.documentElement:this.movementSpace,this.#ve=this.options.draggableElement,this.listenEvents()}listenEvents(){super.listenEvents(),this.#ve.addEventListener("mousedown",this.#X),this.options.clickButton===re.mouseRightClickButton&&this.#ve.addEventListener("contextmenu",(e=>e.preventDefault()))}unlistenEvents(){super.unlistenEvents(),this.#ve.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 Gt extends Rt{clicked(e){this.options.repositionOnClick&&(this.target.setLocation(...this.stepSize>1?ae.snapToGrid(e[0],e[1],this.stepSize):e),this.clickedOffset=[0,0])}dragTo(e,t){const i=[this.target.locationX??this.lastLocation[0],this.target.locationY??this.lastLocation[1]],[s,n]=this.stepSize>1?[ae.snapToGrid(e[0],e[1],this.stepSize),ae.snapToGrid(i[0],i[1],this.stepSize)]:[e,i];0==(t=[s[0]-this.lastLocation[0],s[1]-this.lastLocation[1]])[0]&&0==t[1]||(t[0]+=n[0]-i[0],t[1]+=n[1]-i[1],this.dragAction(s,t),this.lastLocation=s)}dragAction(e,t){this.target.setLocation(e[0]-this.clickedOffset[0],e[1]-this.clickedOffset[1])}}class _t extends Gt{#fe;#ye;#we;#Se;constructor(e,t,i={}){super(e,t,i),i.onClicked&&(this.#fe=i.onClicked),i.onStartDrag&&(this.#ye=i.onStartDrag),i.onDrag&&(this.#we=i.onDrag),i.onEndDrag&&(this.#Se=i.onEndDrag)}clicked(e){super.clicked(e),this.#fe?.()}startDrag(){super.startDrag(),this.#ye?.()}dragAction(e,t){this.#we?.(e,t)}endDrag(){super.endDrag(),this.#Se?.()}}class Ft extends Gt{constructor(e,t,i={}){super(e,t,i),this.draggableElement.classList.add("ueb-draggable")}startDrag(){this.target.selected||(this.blueprint.unselectAll(),this.target.setSelected(!0))}dragAction(e,t){this.target.acknowledgeDrag(t)}unclicked(){this.started?(this.blueprint.getNodes(!0).forEach((e=>e.boundComments.filter((t=>!e.isInsideComment(t))).forEach((t=>e.unbindFromComment(t))))),this.blueprint.getCommentNodes().forEach((e=>e.template.manageNodesBind()))):(this.blueprint.unselectAll(),this.target.setSelected(!0))}}class zt extends Dt{getDraggableElement(){return this.element}createDraggableObject(){const e=this.getDraggableElement();return new Gt(this.element,this.blueprint,{draggableElement:e})}createInputObjects(){return[...super.createInputObjects(),this.createDraggableObject(),new Mt(this.element,this.blueprint,{activationKeys:[re.Keys.ArrowUp,re.Keys.ArrowRight,re.Keys.ArrowDown,re.Keys.ArrowLeft]},(e=>e.target.acknowledgeDrag([e.pressedKey===re.Keys.ArrowLeft?-re.gridSize:e.pressedKey===re.Keys.ArrowRight?re.gridSize:0,e.pressedKey===re.Keys.ArrowUp?-re.gridSize:e.pressedKey===re.Keys.ArrowDown?re.gridSize:0])))]}topBoundary(e=!1){return this.element.locationY}rightBoundary(e=!1){return this.element.locationX+this.element.sizeX}bottomBoundary(e=!1){return this.element.locationY+this.element.sizeY}leftBoundary(e=!1){return this.element.locationX}centerInViewport(){const e=Math.min(this.blueprint.template.viewportSize[0]/10,this.blueprint.template.viewportSize[1]/10),t=this.leftBoundary()-this.blueprint.template.gridLeftVisibilityBoundary(),i=this.blueprint.template.gridRightVisibilityBoundary()-this.rightBoundary();let s=Math.max((t+i)/2,e);const n=this.topBoundary()-this.blueprint.template.gridTopVisibilityBoundary(),r=this.blueprint.template.gridBottomVisibilityBoundary()-this.bottomBoundary();let a=Math.max((n+r)/2,e);this.blueprint.scrollDelta(t-s,n-a,!0)}}class jt extends zt{update(e){super.update(e),e.has("locationX")&&(this.element.style.left=`${this.element.locationX}px`),e.has("locationY")&&(this.element.style.top=`${this.element.locationY}px`)}}class Ut extends jt{getDraggableElement(){return this.element}createDraggableObject(){return new Ft(this.element,this.blueprint,{draggableElement:this.getDraggableElement(),scrollGraphEdge:!0})}firstUpdated(e){super.firstUpdated(e),this.element.selected&&!this.element.listeningDrag&&this.element.setSelected(!0)}}class Wt extends Ut{static nodeStyleClasses=["ueb-node-style-default"];#Ee=!1;pinInserter;inputContainer;outputContainer;pinElement;addPinHandler=()=>{const e=this.pinInserter?.();e&&(this.defaultPin&&this.defaultPin.isInput()===e.isInput()?this.defaultPin.before(this.createPinElement(e)):(e.isInput()?this.inputContainer:this.outputContainer).appendChild(this.createPinElement(e)),this.element.acknowledgeReflow())};toggleAdvancedDisplayHandler=()=>{this.element.toggleShowAdvancedPinDisplay(),this.element.requestUpdate(),this.element.updateComplete.then((()=>this.element.acknowledgeReflow()))};createPinElement(e){const t=ce.getConstructor("ueb-pin").newObject(e,void 0,this.element);return this.pinInserter&&!this.defaultPin&&"Default"===t.getPinName()&&(this.defaultPin=t,this.defaultPin.classList.add("ueb-node-variadic-default")),t}initialize(e){super.initialize(e),this.element.classList.add(...this.constructor.nodeStyleClasses),this.element.style.setProperty("--ueb-node-color",this.getColor().cssText),this.pinInserter=this.element.entity.additionalPinInserter(),this.pinInserter&&this.element.classList.add("ueb-node-is-variadic")}getColor(){return this.element.entity.nodeColor()}render(){return O`
${this.renderTop()}
${this.pinInserter?O`
Add pin ${Ve.plusCircle}
`:R} ${this.element.entity.isDevelopmentOnly()?O`
Development Only
`:R} ${this.element.advancedPinDisplay?O`
${Ve.expandIcon}
`:R}
`}renderNodeIcon(){return this.element.entity.nodeIcon()}renderNodeName(){return this.element.nodeDisplayName}renderTop(){const e=this.renderNodeIcon(),t=this.renderNodeName();return O`
${e?O`
${e}
`:R} ${t?O`
${t} ${this.#Ee&&this.getTargetType().length>0?O`
Target is ${ae.formatStringName(this.getTargetType())}
`:R}
`:R}
`}firstUpdated(e){super.firstUpdated(e),this.inputContainer=this.element.querySelector(".ueb-node-inputs"),this.outputContainer=this.element.querySelector(".ueb-node-outputs"),this.setupPins(),this.element.updateComplete.then((()=>this.element.acknowledgeReflow()))}setupPins(){this.element.nodeNameElement=this.element.querySelector(".ueb-node-name-text");let e=!1,t=!1;for(const i of this.element.getPinElements())i!==this.defaultPin&&(i.isInput()?(this.inputContainer.appendChild(i),e=!0):i.isOutput()&&(this.outputContainer.appendChild(i),t=!0));this.defaultPin&&(this.defaultPin.isInput()?this.inputContainer:this.outputContainer).appendChild(this.defaultPin),e&&this.element.classList.add("ueb-node-has-inputs"),t&&this.element.classList.add("ueb-node-has-outputs")}createPinElements(){return this.element.getPinEntities().filter((e=>!e.isHidden())).map((e=>(this.#Ee=this.#Ee||"self"===e.PinName&&"Target"===e.pinTitle(),this.createPinElement(e))))}getTargetType(){return this.element.entity.FunctionReference?.MemberParent?.getName()??"Untitled"}getPinElements(e){return e.querySelectorAll("ueb-pin")}linksChanged(){}}class Kt extends Wt{#Ce=document.createElement("div");#Ne=document.createElement("div");#xe=document.createElement("div");#Pe=document.createElement("div");#ke=document.createElement("div");#Ae=document.createElement("div");#Le=document.createElement("div");#Me=document.createElement("div");initialize(e){super.initialize(e),this.element.classList.add("ueb-resizeable"),this.#Ce.classList.add("ueb-resizeable-top"),this.#Ne.classList.add("ueb-resizeable-right"),this.#xe.classList.add("ueb-resizeable-bottom"),this.#Pe.classList.add("ueb-resizeable-left"),this.#ke.classList.add("ueb-resizeable-top-right"),this.#Ae.classList.add("ueb-resizeable-bottom-right"),this.#Le.classList.add("ueb-resizeable-bottom-left"),this.#Me.classList.add("ueb-resizeable-top-left")}update(e){super.update(e),this.element.sizeX>=0&&e.has("sizeX")&&(this.element.style.width=`${this.element.sizeX}px`),this.element.sizeY>=0&&e.has("sizeY")&&(this.element.style.height=`${this.element.sizeY}px`)}firstUpdated(e){super.firstUpdated(e),this.element.append(this.#Ce,this.#Ne,this.#xe,this.#Pe,this.#ke,this.#Ae,this.#Le,this.#Me)}createInputObjects(){return[...super.createInputObjects(),new _t(this.#Ce,this.blueprint,{onDrag:(e,t)=>{t[1]=e[1]-this.element.topBoundary(),this.setSizeY(this.element.sizeY-t[1])&&this.element.addLocation(0,t[1],!1)},onEndDrag:()=>this.endResize()}),new _t(this.#Ne,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.rightBoundary(),this.setSizeX(this.element.sizeX+t[0])},onEndDrag:()=>this.endResize()}),new _t(this.#xe,this.blueprint,{onDrag:(e,t)=>{t[1]=e[1]-this.element.bottomBoundary(),this.setSizeY(this.element.sizeY+t[1])},onEndDrag:()=>this.endResize()}),new _t(this.#Pe,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.leftBoundary(),this.setSizeX(this.element.sizeX-t[0])&&this.element.addLocation(t[0],0,!1)},onEndDrag:()=>this.endResize()}),new _t(this.#ke,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.rightBoundary(),t[1]=e[1]-this.element.topBoundary(),this.setSizeX(this.element.sizeX+t[0]),this.setSizeY(this.element.sizeY-t[1])&&this.element.addLocation(0,t[1],!1)},onEndDrag:()=>this.endResize()}),new _t(this.#Ae,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.rightBoundary(),t[1]=e[1]-this.element.bottomBoundary(),this.setSizeX(this.element.sizeX+t[0]),this.setSizeY(this.element.sizeY+t[1])},onEndDrag:()=>this.endResize()}),new _t(this.#Le,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.leftBoundary(),t[1]=e[1]-this.element.bottomBoundary(),this.setSizeX(this.element.sizeX-t[0])&&this.element.addLocation(t[0],0,!1),this.setSizeY(this.element.sizeY+t[1])},onEndDrag:()=>this.endResize()}),new _t(this.#Me,this.blueprint,{onDrag:(e,t)=>{t[0]=e[0]-this.element.leftBoundary(),t[1]=e[1]-this.element.topBoundary(),this.setSizeX(this.element.sizeX-t[0])&&this.element.addLocation(t[0],0,!1),this.setSizeY(this.element.sizeY-t[1])&&this.element.addLocation(0,t[1],!1)},onEndDrag:()=>this.endResize()})]}setSizeX(e){return this.element.setNodeWidth(e),!0}setSizeY(e){return this.element.setNodeHeight(e),!0}endResize(){}}class Yt extends Kt{#Te=0;initialize(e){super.initialize(e),e.classList.add("ueb-node-style-comment","ueb-node-resizeable"),e.sizeX=25*re.gridSize,e.sizeY=6*re.gridSize,super.initialize(e)}getDraggableElement(){return this.element.querySelector(".ueb-node-top")}render(){return O`
`}firstUpdated(e){super.firstUpdated(e);const t=this.getDraggableElement().getBoundingClientRect();this.#Te=t.height}manageNodesBind(){let e=this.blueprint.getNodes();for(let t of e)t.topBoundary()>=this.element.topBoundary()&&t.rightBoundary()<=this.element.rightBoundary()&&t.bottomBoundary()<=this.element.bottomBoundary()&&t.leftBoundary()>=this.element.leftBoundary()?t.bindToComment(this.element):t.unbindFromComment(this.element)}setSizeX(e){return(e=Math.round(e))>=2*re.gridSize&&(this.element.setNodeWidth(e),!0)}setSizeY(e){return(e=Math.round(e))>=2*re.gridSize&&(this.element.setNodeHeight(e),!0)}endResize(){this.manageNodesBind()}topBoundary(e=!1){return this.element.locationY}rightBoundary(e=!1){return this.element.locationX+this.element.sizeX}bottomBoundary(e=!1){return e?this.element.locationY+this.#Te:super.bottomBoundary()}leftBoundary(e=!1){return this.element.locationX}}class qt extends Rt{#Ie;#$e=null;#De=e=>{if(!this.enteredPin){this.linkValid=!1,this.enteredPin=e.target;const t=this.link.source??this.target,i=this.enteredPin,s=t.isOutput()?t:i;t.nodeElement.getType()===re.paths.knot||i.nodeElement.getType()===re.paths.knot?(this.link.setMessageCorrect(),this.linkValid=!0):t.getNodeElement()===i.getNodeElement()?this.link.setMessageSameNode():t.isOutput()===i.isOutput()?this.link.setMessageDirectionsIncompatible():this.blueprint.getLinks(t,i).length?(this.link.setMessageReplaceLink(),this.linkValid=!0):"exec"===s.entity.getType()&&s.isLinked?(this.link.setMessageReplaceOutputLink(),this.linkValid=!0):"object"==t.entity.PinType.PinCategory&&"object"==i.entity.PinType.PinCategory||t.pinType==i.pinType?(this.link.setMessageCorrect(),this.linkValid=!0):(this.link.setMessageTypesIncompatible(t,i),this.linkValid=!1)}};#Ve=e=>{this.enteredPin==e.target&&(this.enteredPin=null,this.linkValid=!1,this.link?.setMessagePlaceNode())};link;enteredPin;linkValid=!1;constructor(e,t,i={}){i.scrollGraphEdge??=!0,super(e,t,i)}startDrag(e){this.target.nodeElement.getType()==re.paths.knot&&(this.#$e=this.target),this.link=ce.getConstructor("ueb-link").newObject(this.target,null),this.blueprint.template.linksContainerElement.prepend(this.link),this.link.setMessagePlaceNode(),this.#Ie=this.blueprint.querySelectorAll("ueb-pin"),this.#Ie.forEach((e=>{e!=this.target&&(e.addEventListener("mouseenter",this.#De),e.addEventListener("mouseleave",this.#Ve))})),this.link.startDragging(),this.link.setDestinationLocation(e)}dragTo(e,t){this.link.setDestinationLocation(e)}endDrag(){if(this.#Ie.forEach((e=>{e.removeEventListener("mouseenter",this.#De),e.removeEventListener("mouseleave",this.#Ve)})),this.#Ie=null,this.enteredPin&&this.linkValid){if(this.#$e){const e=this.#$e!==this.link.source?this.link.source:this.enteredPin;if(this.#$e.isInput()&&e.isInput()||this.#$e.isOutput()&&e.isOutput()){const e=this.#$e.template.getOppositePin();this.#$e===this.link.source?this.link.source=e:this.enteredPin=e}}else this.enteredPin.nodeElement.getType()===re.paths.knot&&(this.enteredPin=this.enteredPin.template.getOppositePin());this.link.source.getLinks().find((e=>e.equals(this.enteredPin.createPinReference())))?this.link.remove():(this.blueprint.addGraphElement(this.link),this.link.destination=this.enteredPin)}else this.link.remove();this.enteredPin=null,this.link.removeMessage(),this.link.finishDragging(),this.link=null}}class Xt extends Wt{#Be=!1;#Oe=!1;displayName="";static nodeStyleClasses=["ueb-node-style-glass"];initialize(e){super.initialize(e),this.displayName=this.element.nodeDisplayName}render(){return O`
${this.displayName?O`
${this.displayName}
`:R} ${this.#Be?O`
`:R} ${this.#Oe?O`
`:R} ${this.pinInserter?O`
Add pin ${Ve.plusCircle}
`:R}
`}createPinElements(){return this.element.getPinEntities().filter((e=>!e.isHidden())).map((e=>{this.#Be||=e.isInput(),this.#Oe||=e.isOutput();return ce.getConstructor("ueb-pin").newObject(e,void 0,this.element)}))}}class Zt extends Xt{static nodeStyleClasses=["ueb-node-style-metasound","ueb-node-style-operation"]}class Qt extends Xt{static nodeStyleClasses=[...super.nodeStyleClasses,"ueb-node-style-conversion"]}class Jt extends Xt{static nodeStyleClasses=[...super.nodeStyleClasses,"ueb-node-style-operation"]}class ei extends Dt{static canWrapInput=!0;#He;get iconElement(){return this.#He}#Re;get wrapperElement(){return this.#Re}isNameRendered=!0;initialize(e){if(super.initialize(e),this.element.nodeElement){const e=this.element.nodeElement.template;this.isNameRendered=!(e instanceof Qt||e instanceof Jt||e instanceof Zt)}}setup(){super.setup(),this.element.nodeElement=this.element.closest("ueb-node");const e=this.element.nodeElement.template;(e instanceof Qt||e instanceof Jt)&&(this.isNameRendered=!1,this.element.requestUpdate())}createInputObjects(){return[new qt(this.element,this.blueprint,{moveEverywhere:!0,draggableElement:this.getClickableElement()})]}render(){const e=O`
${this.renderIcon()}
`,t=O`
${this.isNameRendered?this.renderName():R} ${this.isInputRendered()?this.renderInput():O``}
`;return O`
${this.element.isInput()?O`${e}${t}`:O`${t}${e}`}
`}renderIcon(){if(this.element.nodeElement.entity.isPcg())switch(this.element.entity.getType()){case"Any":return Ve.pcgPin;case"Param":case"Param[]":return Ve.pcgParamPin;case"Spatial":case"Spatial[]":return Ve.pcgSpatialPin;case"Any[]":case"Point[]":case"Surface[]":case"Volume[]":if(this.element.isOutput())return Ve.pcgPin;case"Point":case"Surface":case"Volume":return Ve.pcgStackPin}switch(this.element.entity.PinType?.ContainerType?.toString()){case"Array":return Ve.arrayPin;case"Set":return Ve.setPin;case"Map":return Ve.mapPin}return"delegate"===this.element.entity.PinType?.PinCategory?.toLocaleLowerCase()?Ve.delegate:this.element.nodeElement?.template instanceof Jt?Ve.operationPin:Ve.genericPin}renderName(){let e=this.element.getPinDisplayName();const t=this.element.nodeElement,i=this.element.getPinName();return t.getType()==re.paths.makeStruct&&i==t.entity.StructType.getName()&&(e=i),O`${e}`}isInputRendered(){return this.element.isInput()&&!this.element.entity.bDefaultValueIsIgnored&&!this.element.entity.PinType.bIsReference}renderInput(){return O``}updated(e){if(super.updated(e),this.element.isInput()&&e.has("isLinked")){const e=this.element.nodeElement;this.element.requestUpdate(),this.element.updateComplete.then((()=>e.acknowledgeReflow()))}}firstUpdated(e){super.firstUpdated(e),this.element.style.setProperty("--ueb-pin-color-rgb",this.element.entity.pinColor().cssText),this.#He=this.element.querySelector(".ueb-pin-icon svg")??this.element,this.#Re=this.element.querySelector(".ueb-pin-wrapper")}getLinkLocation(){const e=this.iconElement.getBoundingClientRect(),t=[this.element.isInput()?e.left:e.right+1,(e.top+e.bottom)/2],i=ae.convertLocation(t,this.blueprint.template.gridElement);return this.blueprint.compensateTranslation(i[0],i[1])}getClickableElement(){return this.#Re??this.element}}class ti extends ei{render(){return O`
${this.renderIcon()}
`}}class ii extends Wt{static nodeStyleClasses=[...super.nodeStyleClasses,"ueb-node-style-event"];firstUpdated(e){super.firstUpdated(e),this.element.querySelector(".ueb-node-top").appendChild(this.createDelegatePinElement())}renderTop(){const e=this.renderNodeIcon(),t=this.renderNodeName(),i=this.element.getType()===re.paths.customEvent&&(this.element.entity.CustomFunctionName||this.element.entity.FunctionReference.MemberParent);return O`
${e?O`
${e}
`:R} ${t?O`
${t} ${i?O`
Custom Event
`:R}
`:R}
`}createDelegatePinElement(){const e=ce.getConstructor("ueb-pin").newObject(this.element.getPinEntities().find((e=>!e.isHidden()&&"delegate"===e.PinType.PinCategory)),new ti,this.element);return e.template.isNameRendered=!1,e}createPinElements(){return this.element.getPinEntities().filter((e=>!e.isHidden()&&"delegate"!==e.PinType.PinCategory)).map((e=>ce.getConstructor("ueb-pin").newObject(e,void 0,this.element)))}}class si extends ti{render(){return this.element.isOutput()?super.render():O``}getOppositePin(){const e=this.element.nodeElement.template;return this.element.isOutput()?e.inputPin:e.outputPin}getLinkLocation(){const e=(this.element.isInput()?this.element.nodeElement.template.outputPin.template:this).iconElement.getBoundingClientRect(),t=[this.element.isInput()?e.left:e.right+1,(e.top+e.bottom)/2],i=ae.convertLocation(t,this.blueprint.template.gridElement);return this.blueprint.compensateTranslation(i[0],i[1])}}class ni extends Wt{static#Ge=new Set;#_e=null;#Fe;get inputPin(){return this.#Fe}#ze;get outputPin(){return this.#ze}initialize(e){super.initialize(e),this.element.classList.add("ueb-node-style-minimal")}findDirectionaPin(e){if(e.nodeElement.getType()!==re.paths.knot||ni.#Ge.has(e))return ni.#Ge.clear(),!0;ni.#Ge.add(e);for(let t of e.getLinks().map((e=>this.blueprint.getPin(e))))if(this.findDirectionaPin(t))return!0;return!1}render(){return O`
`}setupPins(){this.element.getPinElements().forEach((e=>this.element.querySelector(".ueb-node-border").appendChild(e)))}getPinElements(e){return e.querySelectorAll("ueb-pin")}createPinElements(){const e=this.element.getPinEntities().filter((e=>!e.isHidden())),t=e[e[0].isInput()?0:1],i=e[e[0].isOutput()?0:1],s=ce.getConstructor("ueb-pin");return[this.#Fe=s.newObject(t,new si,this.element),this.#ze=s.newObject(i,new si,this.element)]}linksChanged(){}}class ri extends Wt{static nodeStyleClasses=["ueb-node-style-metasound"]}class ai extends Xt{initialize(e){super.initialize(e);const t=e.getType();t===re.paths.variableGet||t===re.paths.self?(this.element.classList.add("ueb-node-style-getter"),this.displayName=""):t===re.paths.variableSet&&this.element.classList.add("ueb-node-style-setter")}setupPins(){super.setupPins();let e=this.element.getPinElements().find((e=>!e.entity.isHidden()&&!e.entity.isExecution()));this.element.style.setProperty("--ueb-node-color",e.getColor().cssText)}}function oi(e){if(e.getClass()===re.paths.callFunction||e.getClass()===re.paths.commutativeAssociativeBinaryOperator||e.getClass()===re.paths.callArrayFunction){const t=e.FunctionReference?.MemberParent?.path??"",i=e.FunctionReference?.MemberName;if(i&&(t===re.paths.kismetMathLibrary||t===re.paths.kismetArrayLibrary)){if(i.startsWith("Conv_"))return Qt;if(i.startsWith("Add_")||i.startsWith("And_")||i.startsWith("Boolean")||i.startsWith("Cross_")||i.startsWith("Dot_")||i.startsWith("Not_")||i.startsWith("Or_")||i.startsWith("Percent_")||i.startsWith("Xor_"))return Jt;switch(i){case"Abs":case"Array_Add":case"Array_AddUnique":case"Array_Identical":case"BMax":case"BMin":case"CrossProduct2D":case"DotProduct2D":case"Exp":case"FMax":case"FMin":case"GetPI":case"Max":case"MaxInt64":case"Min":case"MinInt64":case"Sqrt":case"Square":case"Vector4_CrossProduct3":case"Vector4_DotProduct":case"Vector4_DotProduct3":case"Acos":case"Asin":case"Cos":case"DegAcos":case"DegCos":case"DegSin":case"DegTan":case"Sin":case"Tan":return Jt}}if(t===re.paths.blueprintSetLibrary)return Jt;if(t===re.paths.blueprintMapLibrary)return Jt}switch(e.getClass()){case re.paths.comment:case re.paths.materialGraphNodeComment:return Yt;case re.paths.createDelegate:return Wt;case re.paths.metasoundEditorGraphExternalNode:return"Add"==e.ClassName?.Name?Zt:ri;case re.paths.niagaraNodeOp:if(["Boolean::LogicEq","Boolean::LogicNEq","Numeric::Abs","Numeric::Add","Numeric::Mul"].includes(e.OpName))return Jt;break;case re.paths.promotableOperator:return Jt;case re.paths.knot:return ni;case re.paths.literal:case re.paths.self:case re.paths.variableGet:case re.paths.variableSet:return ai}return e.isEvent()?ii:Wt}class li{static#je=new Map;static registerSerializer(e,t){li.#je.set(e,t)}static getSerializer(e){return li.#je.get(e)}}class ui extends Ht{static properties={...super.properties,selected:{type:Boolean,attribute:"data-selected",reflect:!0,converter:ae.booleanConverter}};dragHandler=e=>this.addLocation(...e.detail.value);constructor(){super(),this.selected=!1,this.listeningDrag=!1}setup(){super.setup(),this.setSelected(this.selected)}cleanup(){super.cleanup(),this.blueprint.removeEventListener(re.nodeDragGeneralEventName,this.dragHandler)}setSelected(e=!0){this.selected=e,this.blueprint&&(this.selected?(this.listeningDrag=!0,this.blueprint.addEventListener(re.nodeDragGeneralEventName,this.dragHandler)):(this.blueprint.removeEventListener(re.nodeDragGeneralEventName,this.dragHandler),this.listeningDrag=!1))}}class ci extends ui{static properties={...ui.properties,typePath:{type:String,attribute:"data-type",reflect:!0},nodeTitle:{type:String,attribute:"data-title",reflect:!0},advancedPinDisplay:{type:String,attribute:"data-advanced-display",converter:wt.attributeConverter,reflect:!0},enabledState:{type:String,attribute:"data-enabled-state",reflect:!0},nodeDisplayName:{type:String,attribute:!1},pureFunction:{type:Boolean,converter:ae.booleanConverter,attribute:"data-pure-function",reflect:!0}};static dragEventName=re.nodeDragEventName;static dragGeneralEventName=re.nodeDragGeneralEventName;get blueprint(){return super.blueprint}set blueprint(e){super.blueprint=e,this.#Ue.forEach((t=>t.blueprint=e))}#We;get nodeNameElement(){return this.#We}set nodeNameElement(e){this.#We=e}#Ue=[];boundComments=[];#Ke=!1;#Ye=e=>{this.selected||this.#Ke||(this.#Ke=!0,this.requestUpdate(),this.updateComplete.then((()=>this.#Ke=!1)),this.addLocation(...e.detail.value))};static fromSerializedObject(e){e=e.trim();let t=li.getSerializer(Pt).read(e);return ci.newObject(t)}static newObject(e=new Pt,t=new(oi(e))){const i=new ci;return i.initialize(e,t),i}#qe(e){for(let t of this.getPinElements())for(let i of t.getLinks())this.blueprint.getPin(i).redirectLink(t,new at({objectName:e,pinGuid:t.entity.PinId}))}initialize(e=new Pt,t=new(oi(e))){this.typePath=e.getType(),this.nodeTitle=e.getObjectName(),this.advancedPinDisplay=e.AdvancedPinDisplay?.toString(),this.enabledState=e.EnabledState,this.nodeDisplayName=He(e),this.pureFunction=e.bIsPureFunc,this.dragLinkObjects=[],super.initialize(e,t),this.#Ue=this.template.createPinElements(),super.setLocation(this.entity.getNodePosX(),this.entity.getNodePosY()),this.entity.NodeWidth&&this.entity.NodeHeight?(this.sizeX=this.entity.NodeWidth.value,this.sizeY=this.entity.NodeHeight.value):this.updateComplete.then((()=>this.computeSizes())),e.listenAttribute("Name",(t=>{this.nodeTitle=e.Name,this.nodeDisplayName=He(e),this.#qe(t)}))}async getUpdateComplete(){let e=await super.getUpdateComplete();for(const t of this.getPinElements())e&&=await t.updateComplete;return e}bindToComment(e){e==this||this.boundComments.includes(e)||(e.addEventListener(re.nodeDragEventName,this.#Ye),this.boundComments.push(e))}unbindFromComment(e){const t=this.boundComments.indexOf(e);t>=0&&(e.removeEventListener(re.nodeDragEventName,this.#Ye),this.boundComments[t]=this.boundComments[this.boundComments.length-1],this.boundComments.pop())}isInsideComment(e){return this.topBoundary()>=e.topBoundary()&&this.rightBoundary()<=e.rightBoundary()&&this.bottomBoundary()<=e.bottomBoundary()&&this.leftBoundary()>=e.leftBoundary()}getType(){return this.entity.getType()}getNodeName(){return this.entity.getObjectName()}computeNodeDisplayName(){this.nodeDisplayName=He(this.entity)}setNodeWidth(e){this.entity.setNodeWidth(e),this.sizeX=e,this.acknowledgeReflow()}setNodeHeight(e){this.entity.setNodeHeight(e),this.sizeY=e,this.acknowledgeReflow()}sanitizeLinks(e=[]){this.getPinElements().forEach((t=>t.sanitizeLinks(e)))}getPinElements(){return this.#Ue}getPinEntities(){return this.entity.getPinEntities()}setLocation(e=0,t=0,i=!0){this.entity.setNodePosX(e),this.entity.setNodePosY(t),super.setLocation(e,t,i)}acknowledgeReflow(){this.requestUpdate(),this.updateComplete.then((()=>this.computeSizes()));let e=new CustomEvent(re.nodeReflowEventName);this.dispatchEvent(e)}setShowAdvancedPinDisplay(e){this.entity.AdvancedPinDisplay=new wt(e?"Shown":"Hidden"),this.advancedPinDisplay=this.entity.AdvancedPinDisplay}toggleShowAdvancedPinDisplay(){this.setShowAdvancedPinDisplay("Shown"!=this.entity.AdvancedPinDisplay?.toString())}}class hi extends Pt{#Xe=new Map;#Ze=[];get objectEntities(){return this.#Ze}getHomonymObjectEntity(e){const t=e.getObjectName(!1);return this.#Ze.find((e=>e.getObjectName()==t))}takeFreeName(e){e=e.replace(/_\d+$/,"");const t=(this.#Xe.get(e)??-1)+1;return this.#Xe.set(e,t),re.nodeTitle(e,t)}addObjectEntity(e){if(!this.#Ze.includes(e)){this.#Ze.push(e);const[t,i]=e.getNameAndCounter();return this.#Xe.set(t,Math.max(this.#Xe.get(t)??0,i)),!0}return!1}removeObjectEntity(e){const t=this.#Ze.indexOf(e);if(t>=0){const e=this.#Ze.pop();return te.OriginalChangeId.value==t.OriginalChangeId.value));if(t.length===this.ScriptVariables.values.length)return this;const i=t.concat(t).map(((i,s)=>{const n=re.subObjectAttributeNameFromReference(i.ScriptVariable,s>=t.length);return[n,this[n]??e[n]]}));return i.push(...Object.entries(this).filter((([e,t])=>!e.startsWith(re.subObjectAttributeNamePrefix)&&"ExportedNodes"!==e))),new hi(Object.fromEntries(i))}}class pi{static same=e=>e;static notWrapped=(e,t)=>t;static bracketsWrapped=(e,t)=>`(${t})`;constructor(e,t=((e,t)=>t),i=",",s=!1,n="=",r=pi.same){this.entityType=e,this.wrap=t,this.attributeSeparator=i,this.trailingSeparator=s,this.attributeValueConjunctionSign=n,this.attributeKeyPrinter=r}read(e){return this.doRead(e.trim())}write(e,t=!1){return this.doWrite(e,t)}doRead(e){const t=Ie.grammarFor(void 0,this.entityType).run(e);if(!t.status)throw new Error(this.entityType?`Error when trying to parse the entity ${this.entityType.prototype.constructor.name}`:"Error when trying to parse null");return t.value}doWrite(e,t=!1,i="",s=this.wrap,n=this.attributeSeparator,r=this.trailingSeparator,a=this.attributeValueConjunctionSign,o=this.attributeKeyPrinter){let l="";const u=e._keys??Object.keys(e);let c=!0;for(const s of u){const r=e[s];if(void 0!==r&&this.showProperty(e,s)){let u=e instanceof Array?`(${s})`:s;Ae.getAttribute(e,s,"quoted")&&(u=`"${u}"`);const h=Ae.getAttribute(e,s,"serialized");if(c?c=!1:l+=n,Ae.getAttribute(e,s,"inlined")){l+=this.doWrite(r,t,i,pi.notWrapped,n,!1,a,Ae.getAttribute(e,s,"type")instanceof Array?e=>o(`${u}${e}`):e=>o(`${u}.${e}`));continue}const p=o(u),d=n.includes("\n")?i:"";l+=(p.length?d+p+this.attributeValueConjunctionSign:"")+(h?`"${this.doWriteValue(r,!0,i)}"`:this.doWriteValue(r,t,i))}}return r&&l.length&&(l+=n),s(e,l)}doWriteValue(e,t,i=""){const s=ae.getType(e),n=li.getSerializer(s);if(!n)throw new Error(`Unknown value type "${s.name}", a serializer must be registered in the SerializerFactory class, check initializeSerializerFactory.js`);return n.doWrite(e,t,i)}showProperty(e,t){if(e instanceof Le){if(Ae.getAttribute(e,t,"ignored"))return!1;if(Ae.getAttribute(e,t,"silent")){let i=Ae.getAttribute(e,t,"default");if(i instanceof Function&&(i=i(e)),ae.equals(e[t],i))return!1}}return!0}}class di extends pi{constructor(e=Pt){super(e,void 0,"\n",!0,void 0,pi.same)}showProperty(e,t){switch(t){case"Class":case"Name":case"Archetype":case"ExportPath":case"CustomProperties":return!1}return super.showProperty(e,t)}write(e,t=!1){return this.doWrite(e,t)+"\n"}doRead(e){return Ie.grammarFor(void 0,this.entityType).parse(e)}readMultiple(e){return Pt.getMultipleObjectsGrammar().parse(e)}doWrite(e,t,i="",s=this.wrap,n=this.attributeSeparator,r=this.trailingSeparator,a=this.attributeValueConjunctionSign,o=this.attributeKeyPrinter){const l=i+re.indentation;if(!(e instanceof Pt))return super.doWrite(e,t,i,s,n,r,a,(t=>e[t]instanceof Pt?"":o(t)));return i+"Begin Object"+(e.Class?.type||e.Class?.path?` Class=${this.doWriteValue(e.Class,t)}`:"")+(e.Name?` Name=${this.doWriteValue(e.Name,t)}`:"")+(e.Archetype?` Archetype=${this.doWriteValue(e.Archetype,t)}`:"")+(e.ExportPath?.type||e.ExportPath?.path?` ExportPath=${this.doWriteValue(e.ExportPath,t)}`:"")+"\n"+super.doWrite(e,t,l,s,n,!0,a,(t=>e[t]instanceof Pt?"":o(t)))+(Ae.getAttribute(e,"CustomProperties","ignored")?"":e.getCustomproperties().map((e=>l+o("CustomProperties ")+li.getSerializer(ft).doWrite(e,t)+this.attributeSeparator)).join(""))+i+"End Object"}}class mi extends At{static#Qe=new di;#Je;constructor(e,t,i={}){i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,super(e,t,i);let s=this;this.#Je=()=>s.copied()}listenEvents(){window.addEventListener("copy",this.#Je)}unlistenEvents(){window.removeEventListener("copy",this.#Je)}getSerializedText(){const e=this.blueprint.getNodes(!0).map((e=>e.entity)),t=e.filter((e=>e.isExported)).map((e=>mi.#Qe.write(e,!1))),i=e.filter((e=>!e.isExported)).map((e=>mi.#Qe.write(e,!1)));return t.length&&(this.blueprint.entity.ExportedNodes=btoa(t.join("")),i.splice(0,0,mi.#Qe.write(this.blueprint.entity,!1)),delete this.blueprint.entity.ExportedNodes),i.join("")}copied(){const e=this.getSerializedText();return navigator.clipboard.writeText(e),e}}class gi extends At{static#Qe=new di;#et;constructor(e,t,i={}){i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,super(e,t,i);let s=this;this.#et=()=>s.cut()}listenEvents(){window.addEventListener("cut",this.#et)}unlistenEvents(){window.removeEventListener("cut",this.#et)}getSerializedText(){return this.blueprint.getNodes(!0).map((e=>gi.#Qe.write(e.entity,!1))).join("")}cut(){this.blueprint.template.getCopyInputObject().copied(),this.blueprint.removeGraphElement(...this.blueprint.getNodes(!0))}}class bi extends At{static#Qe=new di;#tt;constructor(e,t,i={}){i.listenOnFocus??=!0,i.unlistenOnTextEdit??=!0,super(e,t,i);let s=this;this.#tt=e=>s.pasted(e.clipboardData.getData("Text"))}listenEvents(){window.addEventListener("paste",this.#tt)}unlistenEvents(){window.removeEventListener("paste",this.#tt)}pasted(e){let t=0,i=0,s=0,n=bi.#Qe.readMultiple(e).map((e=>{let n=ce.getConstructor("ueb-node").newObject(e);return t+=n.locationY,i+=n.locationX,++s,n}));t/=s,i/=s,n.length>0&&this.blueprint.unselectAll();let r=this.blueprint.mousePosition;return n.forEach((e=>{e.addLocation(r[0]-i,r[1]-t),e.snapToGrid(),e.setSelected(!0)})),this.blueprint.addGraphElement(...n),n}}class vi extends Tt{static#U=e=>{};#it=0;get variation(){return this.#it}#st=e=>{this.enablerKey&&!this.enablerActivated||(e.preventDefault(),this.#it=e.deltaY,this.setLocationFromEvent(e),this.wheel())};#nt=e=>e.preventDefault();constructor(e,t,i={},s=vi.#U){i.listenOnFocus=!0,i.strictTarget??=!1,super(e,t,i),this.strictTarget=i.strictTarget,this.onWheel=s}listenEvents(){this.movementSpace.addEventListener("wheel",this.#st,!1),this.movementSpace.parentElement?.addEventListener("wheel",this.#nt)}unlistenEvents(){this.movementSpace.removeEventListener("wheel",this.#st,!1),this.movementSpace.parentElement?.removeEventListener("wheel",this.#nt)}wheel(){this.onWheel(this)}}class fi extends vi{#rt=0;#at=!1;get enableZoonIn(){return this.#at}set enableZoonIn(e){e!=this.#at&&(this.#at=e)}wheel(){if(this.#rt+=-this.variation,Math.abs(this.#rt)0||(e+=Math.sign(this.#rt),this.blueprint.setZoom(e,this.location),this.#rt=0)}}class yi extends Mt{#ot;constructor(e,t,i={}){i.activationKeys=ue.enableZoomIn,super(e,t,i)}fire(){this.#ot=this.blueprint.template.getZoomInputObject(),this.#ot.enableZoonIn=!0}unfire(){this.#ot.enableZoonIn=!1}}class wi extends Rt{startDrag(){this.blueprint.scrolling=!0}dragTo(e,t){this.blueprint.scrollDelta(-t[0],-t[1])}endDrag(){this.blueprint.scrolling=!1}}class Si extends Tt{#lt=null;#ut=e=>{e.preventDefault(),this.setLocationFromEvent(e),this.blueprint.mousePosition=[...this.location]};#ct=e=>{this.#lt||(e.preventDefault(),this.#lt=e.detail.tracker,this.unlistenMouseMove())};#ht=e=>{this.#lt==e.detail.tracker&&(e.preventDefault(),this.#lt=null,this.listenMouseMove())};constructor(e,t,i={}){i.listenOnFocus=!0,super(e,t,i)}listenMouseMove(){this.target.addEventListener("mousemove",this.#ut)}unlistenMouseMove(){this.target.removeEventListener("mousemove",this.#ut)}listenEvents(){this.listenMouseMove(),this.blueprint.addEventListener(re.trackingMouseEventName.begin,this.#ct),this.blueprint.addEventListener(re.trackingMouseEventName.end,this.#ht)}unlistenEvents(){this.unlistenMouseMove(),this.blueprint.removeEventListener(re.trackingMouseEventName.begin,this.#ct),this.blueprint.removeEventListener(re.trackingMouseEventName.end,this.#ht)}}class Ei extends Rt{constructor(e,t,i={}){i.scrollGraphEdge??=!0,super(e,t,i),this.selectorElement=this.blueprint.template.selectorElement}startDrag(){this.selectorElement.beginSelect(this.clickedPosition)}dragTo(e,t){this.selectorElement.selectTo(e)}endDrag(){this.started&&this.selectorElement.endSelect()}unclicked(){this.started||this.blueprint.unselectAll()}}class Ci extends At{#pt=e=>this.clickedSomewhere(e.target);constructor(e,t,i={}){i.listenOnFocus=!0,super(e,t,i),this.blueprint.focus&&document.addEventListener("click",this.#pt)}clickedSomewhere(e){e.closest("ueb-blueprint")||this.blueprint.setFocused(!1)}listenEvents(){document.addEventListener("click",this.#pt)}unlistenEvents(){document.removeEventListener("click",this.#pt)}}class Ni extends Dt{static styleVariables={"--ueb-font-size":`${re.fontSize}`,"--ueb-grid-axis-line-color":`${re.gridAxisLineColor}`,"--ueb-grid-expand":`${re.expandGridSize}px`,"--ueb-grid-line-color":`${re.gridLineColor}`,"--ueb-grid-line-width":`${re.gridLineWidth}px`,"--ueb-grid-set-line-color":`${re.gridSetLineColor}`,"--ueb-grid-set":`${re.gridSet}`,"--ueb-grid-size":`${re.gridSize}px`,"--ueb-link-min-width":`${re.linkMinWidth}`,"--ueb-node-radius":`${re.nodeRadius}px`};#dt=new ResizeObserver((e=>{const t=e.find((e=>e.target===this.viewportElement))?.devicePixelContentBoxSize?.[0];t&&(this.viewportSize[0]=t.inlineSize,this.viewportSize[1]=t.blockSize)}));#mt;#gt;#ot;headerElement;overlayElement;viewportElement;selectorElement;gridElement;linksContainerElement;nodesContainerElement;viewportSize=[0,0];initialize(e){super.initialize(e),this.element.style.cssText=Object.entries(Ni.styleVariables).map((([e,t])=>`${e}:${t};`)).join("");const t=this.element.querySelector(":scope > template")?.content.textContent;t&&(this.element.requestUpdate(),this.element.updateComplete.then((()=>{this.blueprint.mousePosition=[Math.round(this.viewportSize[0]/2),Math.round(this.viewportSize[1]/2)],this.getPasteInputObject().pasted(t),this.blueprint.unselectAll()})))}setup(){super.setup(),this.#dt.observe(this.viewportElement,{box:"device-pixel-content-box"});const e=this.viewportElement.getBoundingClientRect();this.viewportSize[0]=e.width,this.viewportSize[1]=e.height,this.blueprint.nodes.length>0&&(this.blueprint.requestUpdate(),this.blueprint.updateComplete.then((()=>this.centerContentInViewport())))}cleanup(){super.cleanup(),this.#dt.unobserve(this.viewportElement)}createInputObjects(){const e=this.element.getGridDOMElement();return this.#mt=new mi(e,this.blueprint),this.#gt=new bi(e,this.blueprint),this.#ot=new fi(e,this.blueprint),[...super.createInputObjects(),this.#mt,this.#gt,this.#ot,new gi(e,this.blueprint),new Mt(e,this.blueprint,{activationKeys:ue.duplicateNodes},(()=>this.blueprint.template.getPasteInputObject().pasted(this.blueprint.template.getCopyInputObject().copied()))),new Mt(e,this.blueprint,{activationKeys:ue.deleteNodes},(()=>this.blueprint.removeGraphElement(...this.blueprint.getNodes(!0)))),new Mt(e,this.blueprint,{activationKeys:ue.selectAllNodes},(()=>this.blueprint.selectAll())),new Ei(e,this.blueprint,{clickButton:re.mouseClickButton,exitAnyButton:!0,moveEverywhere:!0}),new wi(e,this.blueprint,{clickButton:re.mouseRightClickButton,exitAnyButton:!1,moveEverywhere:!0}),new Ci(e,this.blueprint),new Si(e,this.blueprint),new yi(e,this.blueprint)]}render(){return O`
Zoom ${0==this.blueprint.zoom?"1:1":(this.blueprint.zoom>0?"+":"")+this.blueprint.zoom}
`}firstUpdated(e){super.firstUpdated(e),this.headerElement=this.blueprint.querySelector(".ueb-viewport-header"),this.overlayElement=this.blueprint.querySelector(".ueb-viewport-overlay"),this.viewportElement=this.blueprint.querySelector(".ueb-viewport-body"),this.selectorElement=this.blueprint.querySelector("ueb-selector"),this.gridElement=this.viewportElement.querySelector(".ueb-grid"),this.linksContainerElement=this.blueprint.querySelector("[data-links]"),this.linksContainerElement.append(...this.blueprint.getLinks()),this.nodesContainerElement=this.blueprint.querySelector("[data-nodes]"),this.nodesContainerElement.append(...this.blueprint.getNodes()),this.viewportElement.scroll(re.expandGridSize,re.expandGridSize)}willUpdate(e){super.willUpdate(e),this.headerElement&&e.has("zoom")&&(this.headerElement.classList.add("ueb-zoom-changed"),this.headerElement.addEventListener("animationend",(()=>this.headerElement.classList.remove("ueb-zoom-changed"))))}updated(e){if(super.updated(e),(e.has("scrollX")||e.has("scrollY"))&&this.viewportElement.scroll(this.blueprint.scrollX,this.blueprint.scrollY),e.has("zoom")){this.blueprint.style.setProperty("--ueb-scale",this.blueprint.getScale());const t=e.get("zoom"),i=Math.min(t,this.blueprint.zoom),s=Math.max(t,this.blueprint.zoom),n=ae.range(i,s),r=e=>`ueb-zoom-${e}`;te<0)).map(r)),this.blueprint.classList.add(...n.filter((e=>e>0)).map(r))):(this.blueprint.classList.remove(...n.filter((e=>e>0)).map(r)),this.blueprint.classList.add(...n.filter((e=>e<0)).map(r)))}}getCommentNodes(e=!1){return this.blueprint.querySelectorAll(`ueb-node[data-type="${re.paths.comment}"]${e?'[data-selected="true"]':""}, ueb-node[data-type="${re.paths.materialGraphNodeComment}"]${e?'[data-selected="true"]':""}`)}getPin(e){return this.blueprint.querySelector(`ueb-node[data-title="${e.objectName}"] ueb-pin[data-id="${e.pinGuid}"]`)}getCopyInputObject(){return this.#mt}getPasteInputObject(){return this.#gt}getZoomInputObject(){return this.#ot}isPointVisible(e,t){return!1}gridTopVisibilityBoundary(){return this.blueprint.scaleCorrect(this.blueprint.scrollY)-this.blueprint.translateY}gridRightVisibilityBoundary(){return this.gridLeftVisibilityBoundary()+this.blueprint.scaleCorrect(this.viewportSize[0])}gridBottomVisibilityBoundary(){return this.gridTopVisibilityBoundary()+this.blueprint.scaleCorrect(this.viewportSize[1])}gridLeftVisibilityBoundary(){return this.blueprint.scaleCorrect(this.blueprint.scrollX)-this.blueprint.translateX}centerViewport(e=0,t=0,i=!0){const s=this.gridLeftVisibilityBoundary()+this.blueprint.scaleCorrect(this.viewportSize[0]/2),n=this.gridTopVisibilityBoundary()+this.blueprint.scaleCorrect(this.viewportSize[1]/2);this.blueprint.scrollDelta(this.blueprint.scaleCorrectReverse(e-s),this.blueprint.scaleCorrectReverse(t-n),i)}centerContentInViewport(e=!0){let t=0,i=0,s=Number.MAX_SAFE_INTEGER,n=Number.MIN_SAFE_INTEGER,r=Number.MAX_SAFE_INTEGER,a=Number.MIN_SAFE_INTEGER;const o=this.blueprint.getNodes();for(const e of o)t+=e.leftBoundary()+e.rightBoundary(),i+=e.topBoundary()+e.bottomBoundary(),s=Math.min(s,e.leftBoundary()),n=Math.max(n,e.rightBoundary()),r=Math.min(r,e.topBoundary()),a=Math.max(a,e.bottomBoundary());t=Math.round(n-s<=this.viewportSize[0]?(n+s)/2:t/(2*o.length)),i=Math.round(a-r<=this.viewportSize[1]?(a+r)/2:i/(2*o.length)),this.centerViewport(t,i,e)}}class xi extends oe{static properties={selecting:{type:Boolean,attribute:"data-selecting",reflect:!0,converter:ae.booleanConverter},scrolling:{type:Boolean,attribute:"data-scrolling",reflect:!0,converter:ae.booleanConverter},focused:{type:Boolean,attribute:"data-focused",reflect:!0,converter:ae.booleanConverter},zoom:{type:Number,attribute:"data-zoom",reflect:!0},scrollX:{type:Number,attribute:!1},scrollY:{type:Number,attribute:!1},additionalX:{type:Number,attribute:!1},additionalY:{type:Number,attribute:!1},translateX:{type:Number,attribute:!1},translateY:{type:Number,attribute:!1}};static nodeBoundariesSupplier=e=>({primaryInf:e.leftBoundary(!0),primarySup:e.rightBoundary(!0),secondaryInf:e.topBoundary(!0),secondarySup:e.bottomBoundary(!0)});static nodeSelectToggleFunction=(e,t)=>{e.setSelected(t)};#bt=0;#vt=0;nodes=[];links=[];nodesNames=new Map;mousePosition=[0,0];waitingExpandUpdate=!1;constructor(){super(),this.selecting=!1,this.scrolling=!1,this.focused=!1,this.zoom=0,this.scrollX=re.expandGridSize,this.scrollY=re.expandGridSize,this.translateX=re.expandGridSize,this.translateY=re.expandGridSize,super.initialize(new hi,new Ni)}initialize(){}getGridDOMElement(){return this.template.gridElement}getScroll(){return[this.scrollX,this.scrollY]}setScroll(e,t){this.scrollX=e,this.scrollY=t}scrollDelta(e=0,t=0,i=!1,s=re.smoothScrollTime){if(i){let i=[0,0];this.#bt&&cancelAnimationFrame(this.#bt),this.#vt&&cancelAnimationFrame(this.#vt),ae.animate(0,e,s,(e=>{this.scrollDelta(e-i[0],0,!1),i[0]=e}),(e=>this.#bt=e)),ae.animate(0,t,s,(e=>{this.scrollDelta(0,e-i[1],!1),i[1]=e}),(e=>this.#vt=e))}else{const i=[2*re.expandGridSize,2*re.expandGridSize];let s=this.getScroll(),n=[s[0]+e,s[1]+t],r=[0,0];for(let e=0;e<2;++e)n[e]i[e]-re.gridExpandThreshold*re.expandGridSize&&(r[e]=1);0==r[0]&&0==r[1]||this.seamlessExpand(r[0],r[1]),s=this.getScroll(),n=[s[0]+e,s[1]+t],this.setScroll(n[0],n[1])}}scrollCenter(e=!1){const t=this.getScroll(),i=[this.translateX-t[0],this.translateY-t[1]],s=this.getViewportSize().map((e=>e/2)),n=[i[0]-s[0],i[1]-s[1]];this.scrollDelta(n[0],n[1],e)}getViewportSize(){return[this.template.viewportElement.clientWidth,this.template.viewportElement.clientHeight]}getScrollMax(){return[this.template.viewportElement.scrollWidth-this.template.viewportElement.clientWidth,this.template.viewportElement.scrollHeight-this.template.viewportElement.clientHeight]}snapToGrid(e,t){return ae.snapToGrid(e,t,re.gridSize)}seamlessExpand(e,t){e=Math.round(e),t=Math.round(t);let i=this.getScale();[e,t]=[-e*re.expandGridSize,-t*re.expandGridSize],0!=e&&(this.scrollX+=e,e/=i),0!=t&&(this.scrollY+=t,t/=i),this.translateX+=e,this.translateY+=t}progressiveSnapToGrid(e){return re.expandGridSize*Math.round(e/re.expandGridSize+.5*Math.sign(e))}getZoom(){return this.zoom}setZoom(e,t){if((e=ae.clamp(e,re.minZoom,re.maxZoom))==this.zoom)return;let i=this.getScale();if(this.zoom=e,t){t[0]+=this.translateX,t[1]+=this.translateY;let e=this.getScale()/i,s=[e*t[0],e*t[1]];this.scrollDelta((s[0]-t[0])*i,(s[1]-t[1])*i)}}getScale(){return re.scale[this.getZoom()]}scaleCorrect(e){return e/this.getScale()}scaleCorrectReverse(e){return e*this.getScale()}compensateTranslation(e,t){return[e-=this.translateX,t-=this.translateY]}getNodes(e=!1,[t,i,s,n]=[Number.MIN_SAFE_INTEGER,Number.MAX_SAFE_INTEGER,Number.MAX_SAFE_INTEGER,Number.MIN_SAFE_INTEGER]){let r=this.nodes;return e&&(r=r.filter((e=>e.selected))),(t>Number.MIN_SAFE_INTEGER||iNumber.MIN_SAFE_INTEGER)&&(r=r.filter((e=>e.topBoundary()>=t&&e.rightBoundary()<=i&&e.bottomBoundary()<=s&&e.leftBoundary()>=n))),r}getCommentNodes(e=!1){let t=[...this.template.getCommentNodes(e)];return 0===t.length&&(t=this.nodes.filter((t=>t.getType()===re.paths.comment&&(!e||t.selected)))),t}getPin(e){let t=this.template.getPin(e);return t&&t.nodeElement.getNodeName()==e.objectName.toString()||(t=[...this.nodes.find((t=>e.objectName.toString()==t.getNodeName()))?.getPinElements()??[]].find((t=>e.pinGuid.toString()==t.getPinId().toString()))),t}getLinks(e=null,t=null){if(null==e!=(null==t)){const i=e??t;return this.links.filter((e=>e.source==i||e.destination==i))}return null!=e&&null!=t?this.links.filter((i=>i.source==e&&i.destination==t||i.source==t&&i.destination==e)):this.links}getLink(e,t,i=!1){return this.links.find((s=>s.source==e&&s.destination==t||!i&&s.source==t&&s.destination==e))}selectAll(){this.getNodes().forEach((e=>xi.nodeSelectToggleFunction(e,!0)))}unselectAll(){this.getNodes().forEach((e=>xi.nodeSelectToggleFunction(e,!1)))}addGraphElement(...e){const t=e=>{const i=e.currentTarget;i.removeEventListener(re.removeEventName,t);const[s,n]=i instanceof ci?[this.nodes,i.entity]:i instanceof Ot?[this.links]:null,r=s?.indexOf(i);if(r>=0){const e=s.pop();re.entity._exported=!0));continue}const e=i.entity.getObjectName(),s=this.entity.getHomonymObjectEntity(i.entity);s&&(s.Name=this.entity.takeFreeName(e)),this.nodes.push(i),this.entity.addObjectEntity(i.entity),i.addEventListener(re.removeEventName,t),this.template.nodesContainerElement?.appendChild(i)}else i instanceof Ot&&!this.links.includes(i)&&(this.links.push(i),i.addEventListener(re.removeEventName,t),this.template.linksContainerElement&&!this.template.linksContainerElement.contains(i)&&this.template.linksContainerElement.appendChild(i));e.filter((e=>e instanceof ci)).forEach((t=>t.sanitizeLinks(e))),e.filter((e=>e instanceof ci&&e.getType()==re.paths.comment)).forEach((e=>e.updateComplete.then((()=>e.template.manageNodesBind()))))}removeGraphElement(...e){for(let t of e){if(t.closest("ueb-blueprint")!==this)return;t.remove()}}setFocused(e=!0){if(this.focused==e)return;let t=new CustomEvent(e?re.focusEventName.begin:re.focusEventName.end);this.focused=e,this.focused||this.unselectAll(),this.dispatchEvent(t)}acknowledgeEditText(e){const t=new CustomEvent(e?re.editTextEventName.begin:re.editTextEventName.end);this.dispatchEvent(t)}}customElements.define("ueb-blueprint",xi);class Pi extends zt{#ft;get locationChangeCallback(){return this.#ft}set locationChangeCallback(e){this.#ft=e}movementSpace;movementSpaceSize=[0,0];firstUpdated(e){super.firstUpdated(e),this.movementSpace=this.element.parentElement}setup(){super.setup();const e=this.movementSpace.getBoundingClientRect();this.movementSpaceSize=[e.width,e.height]}createDraggableObject(){return new Gt(this.element,this.blueprint,{draggableElement:this.movementSpace,ignoreTranslateCompensate:!0,moveEverywhere:!0,movementSpace:this.movementSpace,repositionOnClick:!0,stepSize:1})}adjustLocation(e,t){return this.locationChangeCallback?.(e,t),[e,t]}}class ki extends Pi{adjustLocation(e,t){const i=Math.round(this.movementSpaceSize[0]/2);e-=i,t=-(t-i);let[s,n]=ae.getPolarCoordinates(e,t);return s=Math.min(s,i),[e,t]=ae.getCartesianCoordinates(s,n),this.locationChangeCallback?.(e/i,t/i),[e=Math.round(e+i),t=Math.round(-t+i)]}}class Ai extends Ht{windowElement;setup(){super.setup(),this.windowElement=this.closest("ueb-window")}setLocation(e,t){super.setLocation(...this.template.adjustLocation(e,t))}}class Li extends Ai{constructor(){super(),super.initialize({},new ki)}static newObject(){return new Li}initialize(){}}class Mi extends Pi{adjustLocation(e,t){return e=ae.clamp(e,0,this.movementSpaceSize[0]),t=ae.clamp(t,0,this.movementSpaceSize[1]),this.locationChangeCallback?.(e/this.movementSpaceSize[0],1-t/this.movementSpaceSize[1]),[e,t]}}class Ti extends Ai{constructor(){super(),super.initialize({},new Mi)}static newObject(){return new Ti}initialize(){}}class Ii extends Rt{constructor(e,t,i={}){i.consumeEvent=!0,super(e,t,i)}}class $i extends Dt{#yt;#wt;#St=e=>this.element.selectedOption=e.target.selectedOptions[0].value;render(){return O` `}firstUpdated(e){super.firstUpdated(e),this.#yt=this.element.querySelector("select:first-child"),this.#wt=this.element.querySelector("select:last-child");const t=new Event("input",{bubbles:!0});this.#yt.dispatchEvent(t)}updated(e){super.updated(e);const t=this.#wt.getBoundingClientRect();this.element.style.setProperty("--ueb-dropdown-width",t.width+"px")}createInputObjects(){return[...super.createInputObjects(),new Ii(this.element,this.blueprint)]}setSelectedValue(e){this.element.querySelector(`option[value="${e}"]`).defaultSelected=!0}getSelectedValue(){return this.#yt.value}}class Di extends oe{static properties={...super.properties,options:{type:Object},selectedOption:{type:String}};constructor(){super(),super.initialize({},new $i),this.options=[],this.selectedOption=""}static newObject(e){return new Di}initialize(){}getValue(){return this.template.getSelectedValue()}}class Vi extends Dt{#Et=()=>{this.blueprint.acknowledgeEditText(!0),this.element.selectOnFocus&&getSelection().selectAllChildren(this.element)};#Ct=()=>{this.blueprint.acknowledgeEditText(!1),getSelection().removeAllRanges()};#Nt=e=>e.target.querySelectorAll("br").forEach((e=>e.remove()));#xt=e=>{"Enter"!=e.code||e.shiftKey||e.target.blur()};initialize(e){super.initialize(e),this.element.classList.add("ueb-pin-input-content"),this.element.setAttribute("role","textbox"),this.element.contentEditable="true"}firstUpdated(e){super.firstUpdated(e);const t=new Event("input",{bubbles:!0});this.element.dispatchEvent(t)}createInputObjects(){return[...super.createInputObjects(),new Ii(this.element,this.blueprint)]}setup(){super.setup(),this.element.addEventListener("focus",this.#Et),this.element.addEventListener("focusout",this.#Ct),this.element.singleLine&&this.element.addEventListener("input",this.#Nt),this.element.blurOnEnter&&this.element.addEventListener("keydown",this.#xt)}cleanup(){super.cleanup(),this.element.removeEventListener("focus",this.#Et),this.element.removeEventListener("focusout",this.#Ct),this.element.removeEventListener("input",this.#Nt),this.element.removeEventListener("keydown",this.#xt)}}class Bi extends oe{static properties={...super.properties,singleLine:{type:Boolean,attribute:"data-single-line",converter:ae.booleanConverter,reflect:!0},selectOnFocus:{type:Boolean,attribute:"data-select-focus",converter:ae.booleanConverter,reflect:!0},blurOnEnter:{type:Boolean,attribute:"data-blur-enter",converter:ae.booleanConverter,reflect:!0}};constructor(){super(),this.singleLine=!1,this.selectOnFocus=!0,this.blurOnEnter=!0,super.initialize({},new Vi)}static newObject(){return new Bi}initialize(){}}class Oi extends ei{#Pt;#kt=()=>this.element.setDefaultValue(this.#Pt.checked);firstUpdated(e){super.firstUpdated(e),this.#Pt=this.element.querySelector(".ueb-pin-input")}setup(){super.setup(),this.#Pt?.addEventListener("change",this.#kt)}cleanup(){super.cleanup(),this.#Pt?.removeEventListener("change",this.#kt)}createInputObjects(){return[...super.createInputObjects(),new Ii(this.#Pt,this.blueprint)]}renderInput(){return O``}}class Hi extends ei{static singleLineInput=!1;static selectOnFocus=!0;static saveEachInputChange=!1;#At;get inputWrapper(){return this.#At}#Lt;static stringFromInputToUE(e){return e.replace(/(?=\n\s*)\n$/,"")}static stringFromUEToInput(e){return e.replaceAll(/(?:\r|(?<=(?:^|[^\\])(?:\\\\)*)\\r)(?=\n)/g,"").replace(/(?<=\n\s*)$/,"\n")}#Mt=()=>this.setInputs(this.getInputs(),!0);#Tt=e=>this.#It(e.target);#It(e){const t=this.blueprint.scaleCorrect(this.#At.getBoundingClientRect().width)+this.nameWidth,i=this.element.classList.contains("ueb-pin-input-wrap");!i&&t>re.pinInputWrapWidth?this.element.classList.add("ueb-pin-input-wrap"):i&&t<=re.pinInputWrapWidth&&this.element.classList.remove("ueb-pin-input-wrap")}firstUpdated(e){super.firstUpdated(e);this.constructor.canWrapInput&&this.isInputRendered()&&(this.element.addEventListener("input",this.#Tt),this.nameWidth=this.blueprint.scaleCorrect(this.element.querySelector(".ueb-pin-name")?.getBoundingClientRect().width??0)),this.#At=this.element.querySelector(".ueb-pin-input-wrapper"),this.#Lt=[...this.element.querySelectorAll("ueb-input")]}setup(){super.setup();const e=this.constructor;e.saveEachInputChange?this.element.addEventListener("input",this.#Mt):this.element.addEventListener("focusout",this.#Mt),e.canWrapInput&&this.isInputRendered()&&(this.element.addEventListener("input",this.#Tt),this.element.nodeElement.addEventListener(re.nodeReflowEventName,this.#Tt))}cleanup(){super.cleanup(),this.element.nodeElement.removeEventListener(re.nodeReflowEventName,this.#Tt),this.element.removeEventListener("input",this.#Tt),this.element.removeEventListener("input",this.#Mt),this.element.removeEventListener("focusout",this.#Mt)}getInput(){return this.getInputs().reduce(((e,t)=>e+t),"")}getInputs(){return this.#Lt.map((e=>ae.clearHTMLWhitespace(e.innerHTML)))}setInputs(e=[],t=!0){this.#Lt.forEach(this.constructor.singleLineInput?(t,i)=>t.innerText=e[i]:(t,i)=>t.innerText=e[i].replaceAll("\n","")),t&&this.setDefaultValue(e.map((e=>Hi.stringFromInputToUE(e))),e),this.element.requestUpdate(),this.element.nodeElement.acknowledgeReflow()}setDefaultValue(e=[],t=e){this.element.setDefaultValue(e.join(""))}renderInput(){const e=this.constructor,t=e.singleLineInput,i=e.selectOnFocus;return O`
`}}class Ri extends ei{renderIcon(){return Ve.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 O``;return O`${this.element.getPinDisplayName()}`}}class Gi extends Hi{static singleLineInput=!0;setInputs(e=[],t=!1){if(e&&0!=e.length||(e=[this.getInput()]),super.setInputs(e,!1),t){let i=[];for(const s of e){let e=parseFloat(s);isNaN(e)&&(e=0,t=!1),i.push(e)}this.setDefaultValue(i,e)}}setDefaultValue(e=[],t){this.element.setDefaultValue(e[0]),this.element.requestUpdate()}}class _i extends Gi{setDefaultValue(e=[],t){this.element.setDefaultValue(new Ke(e[0])),this.element.requestUpdate()}renderInput(){return O`
`}} /** * @license * Copyright 2017 Google LLC * SPDX-License-Identifier: BSD-3-Clause - */const _i=1;class Fi{constructor(e){}get _$AU(){return this._$AM._$AU}_$AT(e,t,i){this._$Ct=e,this._$AM=t,this._$Ci=i}_$AS(e,t){return this.update(e,t)}update(e,t){return this.render(...t)}} + */const Fi=1;class zi{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 ji="important",Ui=" !"+ji,Wi=(e=>(...t)=>({_$litDirective$:e,values:t}))(class extends Fi{constructor(e){var t;if(super(e),e.type!==_i||"style"!==e.name||(null===(t=e.strings)||void 0===t?void 0:t.length)>2)throw Error("The `styleMap` directive must be used in the `style` attribute and must be the only part in the attribute.")}render(e){return Object.keys(e).reduce(((t,i)=>{const s=e[i];return null==s?t:t+`${i=i.includes("-")?i:i.replace(/(?:^(webkit|moz|ms|o)|)(?=[A-Z])/g,"-$&").toLowerCase()}:${s};`}),"")}update(e,[t]){const{style:i}=e.element;if(void 0===this.ht){this.ht=new Set;for(const e in t)this.ht.add(e);return this.render(t)}this.ht.forEach((e=>{null==t[e]&&(this.ht.delete(e),e.includes("-")?i.removeProperty(e):i[e]="")}));for(const e in t){const s=t[e];if(null!=s){this.ht.add(e);const t="string"==typeof s&&s.endsWith(Ui);e.includes("-")||t?i.setProperty(e,t?s.slice(0,-11):s,t?ji:""):i[e]=s}}return O}});class Ki extends jt{toggleAdvancedDisplayHandler;getDraggableElement(){return this.element.querySelector(".ueb-window-top")}createDraggableObject(){return new Gt(this.element,this.blueprint,{draggableElement:this.getDraggableElement(),ignoreScale:!0,ignoreTranslateCompensate:!1,movementSpace:this.blueprint,stepSize:1})}setup(){const e=this.blueprint.template.gridLeftVisibilityBoundary(),t=this.blueprint.template.gridTopVisibilityBoundary();this.element.locationX=this.blueprint.scaleCorrectReverse(this.blueprint.mousePosition[0]-e),this.element.locationY=this.blueprint.scaleCorrectReverse(this.blueprint.mousePosition[1]-t),this.element.updateComplete.then((()=>{const e=this.blueprint.getBoundingClientRect();this.element.locationX+this.element.sizeX>e.width&&(this.element.locationX=e.width-this.element.sizeX),this.element.locationX=Math.max(0,this.element.locationX),this.element.locationY+this.element.sizeY>e.height&&(this.element.locationY=e.height-this.element.sizeY),this.element.locationY=Math.max(0,this.element.locationY)}))}render(){return H`
${this.renderWindowName()}
${Be.close}
${this.renderContent()}
`}renderWindowName(){return H`Window`}renderContent(){return H``}apply(){this.element.dispatchEvent(new CustomEvent(re.windowApplyEventName)),this.element.remove()}cancel(){this.element.dispatchEvent(new CustomEvent(re.windowCancelEventName)),this.element.remove()}}class Yi extends Ki{#$t;#Dt;#Bt;#Vt;#Ht;#Ot;#Rt;#Gt;#zt;#_t;#Ft=e=>{const t=ae.clearHTMLWhitespace(e.target.innerHTML),i=parseInt(t,16);isNaN(i)||(this.color.setFromRGBANumber(i),this.element.requestUpdate())};#jt=e=>{const t=ae.clearHTMLWhitespace(e.target.innerHTML),i=parseInt(t,16);isNaN(i)||(this.color.setFromSRGBANumber(i),this.element.requestUpdate())};#Ut=e=>t=>{"Enter"==t.code&&(t.preventDefault(),e(t))};#Wt=new De;get color(){return this.#Wt}set color(e){e.toNumber()!=this.color?.toNumber()&&(this.element.requestUpdate("color",this.#Wt),this.#Wt=e)}#Kt=new De;get fullColor(){return this.#Kt}#Yt;get initialColor(){return this.#Yt}#Xt=new De;#qt(e,t,i=!1){const s=this.color.toRGBAString(),n=`${s.substring(0,2*e)}${t}${s.substring(2+2*e)}`;return i?`${n.substring(0,6)}FF`:n}initialize(e){super.initialize(e),this.#Yt=this.element.windowOptions.getPinColor(),this.color.setFromHSVA(this.initialColor.H.value,this.initialColor.S.value,this.initialColor.V.value,this.initialColor.A.value),this.fullColor.setFromHSVA(this.color.H.value,1,1,1)}firstUpdated(e){this.#$t=this.element.querySelector(".ueb-color-picker-wheel ueb-color-handler"),this.#Dt=this.element.querySelector(".ueb-color-picker-saturation ueb-ui-slider"),this.#Bt=this.element.querySelector(".ueb-color-picker-value ueb-ui-slider"),this.#Vt=this.element.querySelector(".ueb-color-picker-r ueb-ui-slider"),this.#Ht=this.element.querySelector(".ueb-color-picker-g ueb-ui-slider"),this.#Ot=this.element.querySelector(".ueb-color-picker-b ueb-ui-slider"),this.#Rt=this.element.querySelector(".ueb-color-picker-a ueb-ui-slider"),this.#Gt=this.element.querySelector(".ueb-color-picker-h ueb-ui-slider"),this.#zt=this.element.querySelector(".ueb-color-picker-s ueb-ui-slider"),this.#_t=this.element.querySelector(".ueb-color-picker-v ueb-ui-slider"),this.#$t.template.locationChangeCallback=(e,t)=>{this.color.setFromWheelLocation(e,t,this.color.V.value,this.color.A.value),this.fullColor.setFromHSVA(this.color.H.value,1,1,1),this.element.requestUpdate()},this.#Dt.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,t,this.color.V.value,this.color.A.value),this.element.requestUpdate()},this.#Bt.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,this.color.S.value,t,this.color.A.value),this.element.requestUpdate()},this.#Vt.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(e,this.color.G.value,this.color.B.value,this.color.A.value),this.element.requestUpdate()},this.#Ht.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(this.color.R.value,e,this.color.B.value,this.color.A.value),this.element.requestUpdate()},this.#Ot.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(this.color.R.value,this.color.G.value,e,this.color.A.value),this.element.requestUpdate()},this.#Rt.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(this.color.R.value,this.color.G.value,this.color.B.value,e),this.element.requestUpdate()},this.#Gt.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(e,this.color.S.value,this.color.V.value,this.color.A.value),this.element.requestUpdate()},this.#zt.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,e,this.color.V.value,this.color.A.value),this.element.requestUpdate()},this.#_t.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,this.color.S.value,e,this.color.A.value),this.element.requestUpdate()}}renderSlider(e){let t="",i=0,s="";const n=e=>`linear-gradient(to right, #${this.#qt(e,"00",!0)}, #${this.#qt(e,"ff",!0)})`;switch(e){case 0:t="r",i=this.color.R.value,s=n(e);break;case 1:t="g",i=this.color.G.value,s=n(e);break;case 2:t="b",i=this.color.B.value,s=n(e);break;case 3:t="a",i=this.color.A.value,s=`${re.alphaPattern}, ${n(e)}`;break;case 4:t="h",i=360*this.color.H.value,s="linear-gradient(to right, #f00 0%, #ff0 16.666%, #0f0 33.333%, #0ff 50%, #00f 66.666%, #f0f 83.333%, #f00 100%)";break;case 5:t="s",i=this.color.S.value,s=`linear-gradient(to right,#${this.#Xt.setFromHSVA(this.color.H.value,0,this.color.V.value,1),this.#Xt.toRGBAString()},#${this.#Xt.setFromHSVA(this.color.H.value,1,this.color.V.value,1),this.#Xt.toRGBAString()})`;break;case 6:t="v",i=this.color.V.value,s=`linear-gradient(to right, #000, #${this.fullColor.toRGBAString()})`}return s=`background: ${s};`,H`
${t.toUpperCase()}
`}renderContent(){const e=2*this.color.H.value*Math.PI,t={"--ueb-color-r":this.color.R.toString(),"--ueb-color-g":this.color.G.toString(),"--ueb-color-b":this.color.B.toString(),"--ueb-color-a":this.color.A.toString(),"--ueb-color-h":this.color.H.toString(),"--ueb-color-s":this.color.S.toString(),"--ueb-color-v":this.color.V.toString(),"--ueb-color-wheel-x":100*(this.color.S.value*Math.cos(e)*.5+.5)+"%","--ueb-color-wheel-y":100*(this.color.S.value*Math.sin(e)*.5+.5)+"%"},i=this.color.toRGBAString(),s=this.color.toSRGBAString(),n=this.fullColor.toRGBAString();return H`
Old
New
Advanced
${this.renderSlider(0)} ${this.renderSlider(1)} ${this.renderSlider(2)} ${this.renderSlider(3)}
${this.renderSlider(4)} ${this.renderSlider(5)} ${this.renderSlider(6)}
Hex Linear
Hex sRGB
${re.windowApplyButtonText}
${re.windowCancelButtonText}
`}renderWindowName(){return H`${re.colorWindowName}`}}class Xi extends Gi{#Zt(){return ae.printNumber(this.element.getDefaultValue()?.X??0)}#Qt(){return ae.printNumber(this.element.getDefaultValue()?.Y??0)}setDefaultValue(e,t){const i=this.element.getDefaultValue(!0);if(!(i instanceof ut))throw new TypeError("Expected DefaultValue to be a Vector2DEntity");i.X=e[0],i.Y=e[1],this.element.requestUpdate("DefaultValue",i)}renderInput(){return H`
X
Y
`}}class qi extends Gi{#Zt(){return ae.printNumber(this.element.getDefaultValue()?.X??0)}#Qt(){return ae.printNumber(this.element.getDefaultValue()?.Y??0)}#Jt(){return ae.printNumber(this.element.getDefaultValue()?.Z??0)}setDefaultValue(e,t){const i=this.element.getDefaultValue(!0);if(!(i instanceof bt))throw new TypeError("Expected DefaultValue to be a VectorEntity");i.X=e[0],i.Y=e[1],i.Z=e[2],this.element.requestUpdate("DefaultValue",i)}renderInput(){return H`
X
Y
Z
`}}const Zi={[re.paths.linearColor]:class extends ei{#ei;#ti=e=>{e.preventDefault(),this.blueprint.setFocused(!0),this.#ei=ce.getConstructor("ueb-window").newObject({type:new Yi,windowOptions:{getPinColor:()=>this.element.defaultValue,setPinColor:e=>this.element.setDefaultValue(e)}}),this.blueprint.append(this.#ei);const t=()=>{this.element.setDefaultValue(this.#ei.template.color)},i=()=>{this.#ei.removeEventListener(re.windowApplyEventName,t),this.#ei.removeEventListener(re.windowCloseEventName,i),this.#ei=null};this.#ei.addEventListener(re.windowApplyEventName,t),this.#ei.addEventListener(re.windowCloseEventName,i)};renderInput(){return H``}},[re.paths.niagaraBool]:Hi,[re.paths.niagaraPosition]:qi,[re.paths.rotator]:class extends Gi{#ii(){return ae.printNumber(this.element.getDefaultValue()?.R??0)}#si(){return ae.printNumber(this.element.getDefaultValue()?.P??0)}#Qt(){return ae.printNumber(this.element.getDefaultValue()?.Y??0)}setDefaultValue(e=[],t=e){const i=this.element.getDefaultValue(!0);if(!(i instanceof ht))throw new TypeError("Expected DefaultValue to be a RotatorEntity");i.R=e[0],i.P=e[1],i.Y=e[2],this.element.requestUpdate("DefaultValue",i)}renderInput(){return H`
X
Y
Z
`}},[re.paths.vector]:qi,[re.paths.vector2D]:Xi,[re.paths.vector3f]:qi,[re.paths.vector4f]:class extends Gi{#Zt(){return ae.printNumber(this.element.getDefaultValue()?.X??0)}#Qt(){return ae.printNumber(this.element.getDefaultValue()?.Y??0)}#Jt(){return ae.printNumber(this.element.getDefaultValue()?.Z??0)}#ni(){return ae.printNumber(this.element.getDefaultValue()?.W??0)}setDefaultValue(e,t){const i=this.element.getDefaultValue(!0);if(!(i instanceof mt))throw new TypeError("Expected DefaultValue to be a Vector4DEntity");i.X=e[0],i.Y=e[1],i.Z=e[2],i.W=e[3],this.element.requestUpdate("DefaultValue",i)}renderInput(){return H`
X
Y
Z
W
`}},bool:Hi,byte:zi,enum:class extends Oi{static saveEachInputChange=!0;#ri;#ai=[];setup(){super.setup();const e=this.element.nodeElement.entity.EnumEntries;this.#ai=e?.map((e=>(""===e&&(e="None"),[e,this.element.nodeElement.getPinEntities().find((t=>e===t.PinName))?.PinFriendlyName.toString()??e])))??re.CommonEnums[this.element.entity.getSubCategory()]?.map((e=>e instanceof Array?e:[e,ae.formatStringName(e)]))??[];const t=this.element.getDefaultValue().toString();this.#ai.find((([e,i])=>e===t))||this.#ai.push([t,ae.formatStringName(t)]),this.element.requestUpdate()}renderInput(){return this.element.nodeElement.entity,H``}firstUpdated(e){super.firstUpdated(e),this.#ri=this.element.querySelector("ueb-dropdown")}getInputs(){return[this.#ri.getValue()]}},int:zi,int64:class extends Gi{setDefaultValue(e=[],t){this.element.setDefaultValue(new st(e[0])),this.element.requestUpdate()}renderInput(){return H`
`}},MUTABLE_REFERENCE:class extends ei{renderIcon(){return Be.referencePin}},name:class extends Oi{static singleLineInput=!0},rg:Xi,real:class extends Gi{setDefaultValue(e=[],t=e){this.element.setDefaultValue(e[0])}renderInput(){return H`
`}},string:class extends Oi{}};function Qi(e){return"Array"===e.PinType.ContainerType?.toString()?ei:e.PinType.bIsReference&&!e.PinType.bIsConst?Zi.MUTABLE_REFERENCE:"exec"===e.getType()?Ri:(e.isInput()?Zi[e.getType()]:ei)??ei}class Ji extends oe{static properties={pinId:{type:Ge,converter:{fromAttribute:(e,t)=>e?Ge.grammar.parse(e):null,toAttribute:(e,t)=>e?.toString()},attribute:"data-id",reflect:!0},pinType:{type:String,attribute:"data-type",reflect:!0},advancedView:{type:String,attribute:"data-advanced-view",reflect:!0},color:{type:De,converter:{fromAttribute:(e,t)=>e?De.getLinearColorFromAnyFormat().parse(e):null,toAttribute:(e,t)=>e?ae.printLinearColor(e):null},attribute:"data-color",reflect:!0},defaultValue:{type:String,attribute:!1},isLinked:{type:Boolean,converter:ae.booleanConverter,attribute:"data-linked",reflect:!0},pinDirection:{type:String,attribute:"data-direction",reflect:!0},connectable:{type:Boolean,converter:ae.booleanConverter,attribute:"data-connectable",reflect:!0}};nodeElement;static newObject(e=new ft,t=new(Qi(e)),i=void 0){const s=new Ji;return s.initialize(e,t,i),s}initialize(e=new ft,t=new(Qi(e)),i=void 0){this.nodeElement=i,this.advancedView=e.bAdvancedView,this.isLinked=!1,this.connectable=!e.bNotConnectable,super.initialize(e,t),this.pinType=this.entity.getType(),this.defaultValue=this.entity.getDefaultValue(),this.color=Ji.properties.color.converter.fromAttribute(this.getColor().toString()),this.pinDirection=e.isInput()?"input":e.isOutput()?"output":"hidden"}setup(){super.setup(),this.nodeElement=this.closest("ueb-node")}createPinReference(){return new at({objectName:this.nodeElement.getNodeName(),pinGuid:this.getPinId()})}getPinId(){return this.entity.PinId}getPinName(){return this.entity.PinName}getPinDisplayName(){return this.entity.pinTitle()}getColor(){return this.entity.pinColor()}isInput(){return this.entity.isInput()}isOutput(){return this.entity.isOutput()}getLinkLocation(){return this.template.getLinkLocation()}getNodeElement(){return this.nodeElement}getLinks(){return this.entity.LinkedTo??[]}getDefaultValue(e=!1){return this.defaultValue=this.entity.getDefaultValue(e)}setDefaultValue(e){this.entity.DefaultValue=e,this.defaultValue=e,this.entity.recomputesNodeTitleOnChange&&this.nodeElement?.computeNodeDisplayName()}sanitizeLinks(e=[]){this.entity.LinkedTo=this.entity.LinkedTo?.filter((t=>{let i=this.blueprint.getPin(t);if(i){if(e.length&&!e.includes(i.nodeElement))return!1;let t=this.blueprint.getLink(this,i);t||(t=ce.getConstructor("ueb-link").newObject(this,i),this.blueprint.addGraphElement(t))}return i})),this.isLinked=this.entity.isLinked()}linkTo(e){const t=this.createPinReference();!this.isLinked||!this.isOutput()||"exec"!==this.pinType&&"exec"!==e.pinType||this.getLinks().some((e=>t.equals(e)))||this.unlinkFromAll(),this.entity.linkTo(e.getNodeElement().getNodeName(),e.entity)&&(this.isLinked=this.entity.isLinked(),this.nodeElement?.template.linksChanged(),this.entity.recomputesNodeTitleOnChange&&this.nodeElement?.computeNodeDisplayName())}unlinkFrom(e,t=!0){this.entity.unlinkFrom(e.getNodeElement().getNodeName(),e.entity)&&(this.isLinked=this.entity.isLinked(),this.nodeElement?.template.linksChanged(),t&&this.blueprint.getLink(this,e)?.remove(),this.entity.recomputesNodeTitleOnChange&&this.nodeElement?.computeNodeDisplayName())}unlinkFromAll(){const e=this.getLinks().length;this.getLinks().map((e=>this.blueprint.getPin(e))).forEach((e=>this.unlinkFrom(e))),e&&this.nodeElement?.template.linksChanged()}redirectLink(e,t){const i=this.getLinks().findIndex((t=>t.objectName.toString()==e.getNodeElement().getNodeName()&&t.pinGuid.valueOf()==e.entity.PinId.valueOf()));return i>=0&&(this.entity.LinkedTo[i]=t,!0)}}class es{constructor(e=(e=>e),t=null){this.array=new Uint32Array(t),this.comparisonValueSupplier=e,this.length=0,this.currentPosition=0}get(e){return e>=0&&e=0&&this.currentPosition=0&&this.currentPosition0?this.get(this.currentPosition-1):null}getPrevValue(){return this.currentPosition>0?this.comparisonValueSupplier(this.get(this.currentPosition-1)):Number.MIN_SAFE_INTEGER}shiftLeft(e,t=1){this.array.set(this.array.subarray(e+t),e)}shiftRight(e,t=1){this.array.set(this.array.subarray(e,-t),e+t)}}class ts{constructor(e,t,i,s){this.initialPosition=e,this.finalPosition=e,this.metadata=new Array(t.length),this.primaryOrder=new es((e=>this.metadata[e].primaryBoundary)),this.secondaryOrder=new es((e=>this.metadata[e].secondaryBoundary)),this.selectFunc=s,this.rectangles=t,this.primaryOrder.reserve(this.rectangles.length),this.secondaryOrder.reserve(this.rectangles.length),t.forEach(((e,t)=>{let n={primaryBoundary:this.initialPosition[0],secondaryBoundary:this.initialPosition[1],rectangle:t,onSecondaryAxis:!1};this.metadata[t]=n,s(e,!1);const r=i(e);this.initialPosition[1]{if(this.metadata[i].onSecondaryAxis)this.selectFunc(this.rectangles[i],s);else if(s){this.secondaryOrder.insert(i,e[1]);const s=this.metadata[i].secondaryBoundary;Math.sign(e[1]-s)==t[1]&&Math.sign(s-this.initialPosition[1])==t[1]&&this.selectFunc(this.rectangles[i],!0)}else this.selectFunc(this.rectangles[i],!1),this.secondaryOrder.remove(i);this.computeBoundaries(),this.selectTo(e)};e[0]this.boundaries.primaryN.v&&e[0]this.boundaries.primaryP.v&&(++this.primaryOrder.currentPosition,i(this.boundaries.primaryP.i,this.initialPosition[0]{this.selectFunc(this.rectangles[t],i),this.computeBoundaries(),this.selectTo(e)};e[1]this.boundaries.secondaryN.v&&e[1]this.boundaries.secondaryP.v&&(++this.secondaryOrder.currentPosition,s(this.boundaries.secondaryP.i,this.initialPosition[1]ns.#oi[e],toAttribute:(e,t)=>Object.entries(ns.#oi).find((([t,i])=>e.constructor===i))?.[0]}}};static newObject(e={},t=e.type??new Ki){const i=new ns;return i.initialize(e,t),i}initialize(e={},t=e.type??new Ki){e.windowOptions??={},this.type=e.type,this.windowOptions=e.windowOptions,super.initialize(e,t)}computeSizes(){const e=this.getBoundingClientRect();this.sizeX=e.width,this.sizeY=e.height}cleanup(){super.cleanup(),this.acknowledgeClose()}acknowledgeClose(){let e=new CustomEvent(re.windowCloseEventName);this.dispatchEvent(e)}}class rs extends Le{static attributes={...super.attributes,TerminalCategory:tt,TerminalSubCategory:tt,bTerminalIsConst:Ue,bTerminalIsWeakPointer:Ue,bTerminalIsUObjectWrapper:Ue};constructor(e){super(e),this.TerminalCategory,this.TerminalSubCategory,this.bTerminalIsConst,this.bTerminalIsWeakPointer,this.bTerminalIsUObjectWrapper}}class as extends Le{static grammar=ke.seq(ke.reg(new RegExp(`(${Ie.Regex.Path.source}|${Ie.Regex.Symbol.source}\\s*)?\\(\\s*`),1),ke.seq(Ie.attributeName,Ie.equalSeparation).map((([e,t])=>e)).chain((e=>Ie.unknownValue.map((t=>i=>i[e]=t)))).sepBy(Ie.commaSeparation),ke.reg(/\s*(?:,\s*)?\)/)).map((([e,t,i])=>{e??="";let s={};return e.length&&(s.lookbehind=e),t.forEach((e=>e(s))),new this(s)}));constructor(e={}){super(e)}}class os extends pi{#li;constructor(e,t){super(t),this.#li=e}doWrite(e,t,i=""){return this.#li(e,t)}}class ls extends pi{constructor(e,t=!0){super(e),t&&(this.wrap=(e,t)=>ae.escapeString(t))}doWrite(e,t,i=""){return t||e.constructor!==String?this.wrap(e,e.toString()):`"${this.wrap(e,e.toString())}"`}}Ie.unknownValue=ke.alt(Ue.grammar,Ge.grammar,ke.str("None").map((()=>nt.createNoneInstance())),Ie.null,We.grammar,nt.fullReferenceGrammar,tt.grammar,et.grammar,Je.grammar,it.grammar,at.grammar,mt.grammar,bt.grammar,ht.grammar,De.grammar,ut.grammar,as.grammar,qe.grammar,je.of(at).grammar,je.of(Fe.accepting(We,tt,qe)).grammar,ke.lazy((()=>je.createGrammar(Ie.unknownValue)))),li.registerSerializer(null,new os(((e,t)=>"()"),null)),li.registerSerializer(Array,new os(((e,t)=>`(${e.map((e=>li.getSerializer(ae.getType(e)).write(e,t))).join(",")})`),Array)),li.registerSerializer(BigInt,new ls(BigInt)),li.registerSerializer(hi,new di(hi)),li.registerSerializer(Boolean,new os(((e,t)=>e?t?"true":"True":t?"false":"False"),Boolean)),li.registerSerializer(Ye,new ls(Ye)),li.registerSerializer($e,new ls($e)),li.registerSerializer(Qe,new ls(Qe)),li.registerSerializer(Ze,new ls(Ze)),li.registerSerializer(it,new os(((e,t)=>e.getLookbehind()+"("+e.value.map((e=>li.getSerializer(ae.getType(e)).write(e,t))).join(", ")+")"),it)),li.registerSerializer(ot,new pi(ot,pi.bracketsWrapped)),li.registerSerializer(Ge,new ls(Ge)),li.registerSerializer(wt,new ls(wt)),li.registerSerializer(st,new ls(st)),li.registerSerializer(Ke,new ls(Ke)),li.registerSerializer(Je,new pi(Je,((e,t)=>`${e.getLookbehind()}(${t})`),", ",!1,"",(()=>""))),li.registerSerializer(Lt,new pi(Lt,pi.bracketsWrapped)),li.registerSerializer(De,new pi(De,pi.bracketsWrapped)),li.registerSerializer(et,new pi(et,((e,t)=>`${e.getLookbehind()}(${t})`),", ",!1,"",(()=>""))),li.registerSerializer(St,new pi(St,pi.bracketsWrapped)),li.registeOrSerializer(Me,new os(((e,t)=>li.getSerializer(e.getTargetType()).write(e.get(),t)),Me)),li.registerSerializer(Number,new ls(Number)),li.registerSerializer(Pt,new di),li.registerSerializer(nt,new ls(nt,!1)),li.registerSerializer(rt,new ls(rt)),li.registerSerializer(ft,new pi(ft,((e,t)=>`${e.getLookbehind()} (${t})`),",",!0)),li.registerSerializer(at,new pi(at,void 0," ",!1,"",(()=>""))),li.registerSerializer(lt,new pi(lt)),li.registerSerializer(rs,new pi(rs,pi.bracketsWrapped)),li.registerSerializer(ct,new os(((e,t)=>`X=${e.X} Y=${e.Y}`),ct)),li.registerSerializer(ht,new pi(ht,pi.bracketsWrapped)),li.registerSerializer(Ct,new pi(Ct,pi.bracketsWrapped)),li.registerSerializer(String,new os(((e,t)=>t?ae.escapeString(e):`"${ae.escapeString(e)}"`),String)),li.registerSerializer(pt,new os(((e,t)=>`${e.P}, ${e.Y}, ${e.R}`),pt)),li.registerSerializer(dt,new os(((e,t)=>`${e.X}, ${e.Y}`),dt)),li.registerSerializer(vt,new os(((e,t)=>`${e.X}, ${e.Y}, ${e.Z}`),vt)),li.registerSerializer(gt,new os(((e,t)=>`${e.X}, ${e.Y}, ${e.Z}, ${e.W}`),gt)),li.registerSerializer(qe,new ls(qe)),li.registerSerializer(as,new pi(as,((e,t)=>`${e.getLookbehind()??""}(${t})`))),li.registerSerializer(xt,new pi(xt,pi.bracketsWrapped)),li.registerSerializer(ut,new pi(ut,pi.bracketsWrapped)),li.registerSerializer(bt,new pi(bt,pi.bracketsWrapped)),li.registerSerializer(mt,new pi(mt,pi.bracketsWrapped)),function(){const e=(e,t)=>{customElements.define(e,t),ce.registerElement(e,t)};e("ueb-color-handler",Li),e("ueb-dropdown",Di),e("ueb-input",Vi),e("ueb-link",Ht),e("ueb-node",ci),e("ueb-pin",Ji),e("ueb-selector",ss),e("ueb-ui-slider",Ti),e("ueb-window",ns)}();export{xi as Blueprint,re as Configuration,Ht as LinkElement,ci as NodeElement,ae as Utility}; + */const ji="important",Ui=" !"+ji,Wi=(e=>(...t)=>({_$litDirective$:e,values:t}))(class extends zi{constructor(e){var t;if(super(e),e.type!==Fi||"style"!==e.name||(null===(t=e.strings)||void 0===t?void 0:t.length)>2)throw Error("The `styleMap` directive must be used in the `style` attribute and must be the only part in the attribute.")}render(e){return Object.keys(e).reduce(((t,i)=>{const s=e[i];return null==s?t:t+`${i=i.includes("-")?i:i.replace(/(?:^(webkit|moz|ms|o)|)(?=[A-Z])/g,"-$&").toLowerCase()}:${s};`}),"")}update(e,[t]){const{style:i}=e.element;if(void 0===this.ht){this.ht=new Set;for(const e in t)this.ht.add(e);return this.render(t)}this.ht.forEach((e=>{null==t[e]&&(this.ht.delete(e),e.includes("-")?i.removeProperty(e):i[e]="")}));for(const e in t){const s=t[e];if(null!=s){this.ht.add(e);const t="string"==typeof s&&s.endsWith(Ui);e.includes("-")||t?i.setProperty(e,t?s.slice(0,-11):s,t?ji:""):i[e]=s}}return H}});class Ki extends jt{toggleAdvancedDisplayHandler;getDraggableElement(){return this.element.querySelector(".ueb-window-top")}createDraggableObject(){return new Gt(this.element,this.blueprint,{draggableElement:this.getDraggableElement(),ignoreScale:!0,ignoreTranslateCompensate:!1,movementSpace:this.blueprint,stepSize:1})}setup(){const e=this.blueprint.template.gridLeftVisibilityBoundary(),t=this.blueprint.template.gridTopVisibilityBoundary();this.element.locationX=this.blueprint.scaleCorrectReverse(this.blueprint.mousePosition[0]-e),this.element.locationY=this.blueprint.scaleCorrectReverse(this.blueprint.mousePosition[1]-t),this.element.updateComplete.then((()=>{const e=this.blueprint.getBoundingClientRect();this.element.locationX+this.element.sizeX>e.width&&(this.element.locationX=e.width-this.element.sizeX),this.element.locationX=Math.max(0,this.element.locationX),this.element.locationY+this.element.sizeY>e.height&&(this.element.locationY=e.height-this.element.sizeY),this.element.locationY=Math.max(0,this.element.locationY)}))}render(){return O`
${this.renderWindowName()}
${Ve.close}
${this.renderContent()}
`}renderWindowName(){return O`Window`}renderContent(){return O``}apply(){this.element.dispatchEvent(new CustomEvent(re.windowApplyEventName)),this.element.remove()}cancel(){this.element.dispatchEvent(new CustomEvent(re.windowCancelEventName)),this.element.remove()}}class Yi extends Ki{#$t;#Dt;#Vt;#Bt;#Ot;#Ht;#Rt;#Gt;#_t;#Ft;#zt=e=>{const t=ae.clearHTMLWhitespace(e.target.innerHTML),i=parseInt(t,16);isNaN(i)||(this.color.setFromRGBANumber(i),this.element.requestUpdate())};#jt=e=>{const t=ae.clearHTMLWhitespace(e.target.innerHTML),i=parseInt(t,16);isNaN(i)||(this.color.setFromSRGBANumber(i),this.element.requestUpdate())};#Ut=e=>t=>{"Enter"==t.code&&(t.preventDefault(),e(t))};#Wt=new De;get color(){return this.#Wt}set color(e){e.toNumber()!=this.color?.toNumber()&&(this.element.requestUpdate("color",this.#Wt),this.#Wt=e)}#Kt=new De;get fullColor(){return this.#Kt}#Yt;get initialColor(){return this.#Yt}#qt=new De;#Xt(e,t,i=!1){const s=this.color.toRGBAString(),n=`${s.substring(0,2*e)}${t}${s.substring(2+2*e)}`;return i?`${n.substring(0,6)}FF`:n}initialize(e){super.initialize(e),this.#Yt=this.element.windowOptions.getPinColor(),this.color.setFromHSVA(this.initialColor.H.value,this.initialColor.S.value,this.initialColor.V.value,this.initialColor.A.value),this.fullColor.setFromHSVA(this.color.H.value,1,1,1)}firstUpdated(e){this.#$t=this.element.querySelector(".ueb-color-picker-wheel ueb-color-handler"),this.#Dt=this.element.querySelector(".ueb-color-picker-saturation ueb-ui-slider"),this.#Vt=this.element.querySelector(".ueb-color-picker-value ueb-ui-slider"),this.#Bt=this.element.querySelector(".ueb-color-picker-r ueb-ui-slider"),this.#Ot=this.element.querySelector(".ueb-color-picker-g ueb-ui-slider"),this.#Ht=this.element.querySelector(".ueb-color-picker-b ueb-ui-slider"),this.#Rt=this.element.querySelector(".ueb-color-picker-a ueb-ui-slider"),this.#Gt=this.element.querySelector(".ueb-color-picker-h ueb-ui-slider"),this.#_t=this.element.querySelector(".ueb-color-picker-s ueb-ui-slider"),this.#Ft=this.element.querySelector(".ueb-color-picker-v ueb-ui-slider"),this.#$t.template.locationChangeCallback=(e,t)=>{this.color.setFromWheelLocation(e,t,this.color.V.value,this.color.A.value),this.fullColor.setFromHSVA(this.color.H.value,1,1,1),this.element.requestUpdate()},this.#Dt.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,t,this.color.V.value,this.color.A.value),this.element.requestUpdate()},this.#Vt.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,this.color.S.value,t,this.color.A.value),this.element.requestUpdate()},this.#Bt.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(e,this.color.G.value,this.color.B.value,this.color.A.value),this.element.requestUpdate()},this.#Ot.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(this.color.R.value,e,this.color.B.value,this.color.A.value),this.element.requestUpdate()},this.#Ht.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(this.color.R.value,this.color.G.value,e,this.color.A.value),this.element.requestUpdate()},this.#Rt.template.locationChangeCallback=(e,t)=>{this.color.setFromRGBA(this.color.R.value,this.color.G.value,this.color.B.value,e),this.element.requestUpdate()},this.#Gt.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(e,this.color.S.value,this.color.V.value,this.color.A.value),this.element.requestUpdate()},this.#_t.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,e,this.color.V.value,this.color.A.value),this.element.requestUpdate()},this.#Ft.template.locationChangeCallback=(e,t)=>{this.color.setFromHSVA(this.color.H.value,this.color.S.value,e,this.color.A.value),this.element.requestUpdate()}}renderSlider(e){let t="",i=0,s="";const n=e=>`linear-gradient(to right, #${this.#Xt(e,"00",!0)}, #${this.#Xt(e,"ff",!0)})`;switch(e){case 0:t="r",i=this.color.R.value,s=n(e);break;case 1:t="g",i=this.color.G.value,s=n(e);break;case 2:t="b",i=this.color.B.value,s=n(e);break;case 3:t="a",i=this.color.A.value,s=`${re.alphaPattern}, ${n(e)}`;break;case 4:t="h",i=360*this.color.H.value,s="linear-gradient(to right, #f00 0%, #ff0 16.666%, #0f0 33.333%, #0ff 50%, #00f 66.666%, #f0f 83.333%, #f00 100%)";break;case 5:t="s",i=this.color.S.value,s=`linear-gradient(to right,#${this.#qt.setFromHSVA(this.color.H.value,0,this.color.V.value,1),this.#qt.toRGBAString()},#${this.#qt.setFromHSVA(this.color.H.value,1,this.color.V.value,1),this.#qt.toRGBAString()})`;break;case 6:t="v",i=this.color.V.value,s=`linear-gradient(to right, #000, #${this.fullColor.toRGBAString()})`}return s=`background: ${s};`,O`
${t.toUpperCase()}
`}renderContent(){const e=2*this.color.H.value*Math.PI,t={"--ueb-color-r":this.color.R.toString(),"--ueb-color-g":this.color.G.toString(),"--ueb-color-b":this.color.B.toString(),"--ueb-color-a":this.color.A.toString(),"--ueb-color-h":this.color.H.toString(),"--ueb-color-s":this.color.S.toString(),"--ueb-color-v":this.color.V.toString(),"--ueb-color-wheel-x":100*(this.color.S.value*Math.cos(e)*.5+.5)+"%","--ueb-color-wheel-y":100*(this.color.S.value*Math.sin(e)*.5+.5)+"%"},i=this.color.toRGBAString(),s=this.color.toSRGBAString(),n=this.fullColor.toRGBAString();return O`
Old
New
Advanced
${this.renderSlider(0)} ${this.renderSlider(1)} ${this.renderSlider(2)} ${this.renderSlider(3)}
${this.renderSlider(4)} ${this.renderSlider(5)} ${this.renderSlider(6)}
Hex Linear
Hex sRGB
${re.windowApplyButtonText}
${re.windowCancelButtonText}
`}renderWindowName(){return O`${re.colorWindowName}`}}class qi extends Gi{#Zt(){return ae.printNumber(this.element.getDefaultValue()?.X??0)}#Qt(){return ae.printNumber(this.element.getDefaultValue()?.Y??0)}setDefaultValue(e,t){const i=this.element.getDefaultValue(!0);if(!(i instanceof ut))throw new TypeError("Expected DefaultValue to be a Vector2DEntity");i.X=e[0],i.Y=e[1],this.element.requestUpdate("DefaultValue",i)}renderInput(){return O`
X
Y
`}}class Xi extends Gi{#Zt(){return ae.printNumber(this.element.getDefaultValue()?.X??0)}#Qt(){return ae.printNumber(this.element.getDefaultValue()?.Y??0)}#Jt(){return ae.printNumber(this.element.getDefaultValue()?.Z??0)}setDefaultValue(e,t){const i=this.element.getDefaultValue(!0);if(!(i instanceof bt))throw new TypeError("Expected DefaultValue to be a VectorEntity");i.X=e[0],i.Y=e[1],i.Z=e[2],this.element.requestUpdate("DefaultValue",i)}renderInput(){return O`
X
Y
Z
`}}const Zi={[re.paths.linearColor]:class extends ei{#ei;#ti=e=>{e.preventDefault(),this.blueprint.setFocused(!0),this.#ei=ce.getConstructor("ueb-window").newObject({type:new Yi,windowOptions:{getPinColor:()=>this.element.defaultValue,setPinColor:e=>this.element.setDefaultValue(e)}}),this.blueprint.append(this.#ei);const t=()=>{this.element.setDefaultValue(this.#ei.template.color)},i=()=>{this.#ei.removeEventListener(re.windowApplyEventName,t),this.#ei.removeEventListener(re.windowCloseEventName,i),this.#ei=null};this.#ei.addEventListener(re.windowApplyEventName,t),this.#ei.addEventListener(re.windowCloseEventName,i)};renderInput(){return O``}},[re.paths.niagaraBool]:Oi,[re.paths.niagaraPosition]:Xi,[re.paths.rotator]:class extends Gi{#ii(){return ae.printNumber(this.element.getDefaultValue()?.R??0)}#si(){return ae.printNumber(this.element.getDefaultValue()?.P??0)}#Qt(){return ae.printNumber(this.element.getDefaultValue()?.Y??0)}setDefaultValue(e=[],t=e){const i=this.element.getDefaultValue(!0);if(!(i instanceof ht))throw new TypeError("Expected DefaultValue to be a RotatorEntity");i.R=e[0],i.P=e[1],i.Y=e[2],this.element.requestUpdate("DefaultValue",i)}renderInput(){return O`
X
Y
Z
`}},[re.paths.vector]:Xi,[re.paths.vector2D]:qi,[re.paths.vector3f]:Xi,[re.paths.vector4f]:class extends Gi{#Zt(){return ae.printNumber(this.element.getDefaultValue()?.X??0)}#Qt(){return ae.printNumber(this.element.getDefaultValue()?.Y??0)}#Jt(){return ae.printNumber(this.element.getDefaultValue()?.Z??0)}#ni(){return ae.printNumber(this.element.getDefaultValue()?.W??0)}setDefaultValue(e,t){const i=this.element.getDefaultValue(!0);if(!(i instanceof mt))throw new TypeError("Expected DefaultValue to be a Vector4DEntity");i.X=e[0],i.Y=e[1],i.Z=e[2],i.W=e[3],this.element.requestUpdate("DefaultValue",i)}renderInput(){return O`
X
Y
Z
W
`}},bool:Oi,byte:_i,enum:class extends Hi{static saveEachInputChange=!0;#ri;#ai=[];setup(){super.setup();const e=this.element.nodeElement.entity.EnumEntries;this.#ai=e?.map((e=>(""===e&&(e="None"),[e,this.element.nodeElement.getPinEntities().find((t=>e===t.PinName))?.PinFriendlyName.toString()??e])))??re.CommonEnums[this.element.entity.getSubCategory()]?.map((e=>e instanceof Array?e:[e,ae.formatStringName(e)]))??[];const t=this.element.getDefaultValue().toString();this.#ai.find((([e,i])=>e===t))||this.#ai.push([t,ae.formatStringName(t)]),this.element.requestUpdate()}renderInput(){return this.element.nodeElement.entity,O``}firstUpdated(e){super.firstUpdated(e),this.#ri=this.element.querySelector("ueb-dropdown")}getInputs(){return[this.#ri.getValue()]}},int:_i,int64:class extends Gi{setDefaultValue(e=[],t){this.element.setDefaultValue(new nt(e[0])),this.element.requestUpdate()}renderInput(){return O`
`}},MUTABLE_REFERENCE:class extends ei{renderIcon(){return Ve.referencePin}},name:class extends Hi{static singleLineInput=!0},rg:qi,real:class extends Gi{setDefaultValue(e=[],t=e){this.element.setDefaultValue(e[0])}renderInput(){return O`
`}},string:class extends Hi{}};function Qi(e){return"Array"===e.PinType.ContainerType?.toString()?ei:e.PinType.bIsReference&&!e.PinType.bIsConst?Zi.MUTABLE_REFERENCE:"exec"===e.getType()?Ri:(e.isInput()?Zi[e.getType()]:ei)??ei}class Ji extends oe{static properties={pinId:{type:Ge,converter:{fromAttribute:(e,t)=>e?Ge.grammar.parse(e):null,toAttribute:(e,t)=>e?.toString()},attribute:"data-id",reflect:!0},pinType:{type:String,attribute:"data-type",reflect:!0},advancedView:{type:String,attribute:"data-advanced-view",reflect:!0},color:{type:De,converter:{fromAttribute:(e,t)=>e?De.getLinearColorFromAnyFormat().parse(e):null,toAttribute:(e,t)=>e?ae.printLinearColor(e):null},attribute:"data-color",reflect:!0},defaultValue:{type:String,attribute:!1},isLinked:{type:Boolean,converter:ae.booleanConverter,attribute:"data-linked",reflect:!0},pinDirection:{type:String,attribute:"data-direction",reflect:!0},connectable:{type:Boolean,converter:ae.booleanConverter,attribute:"data-connectable",reflect:!0}};nodeElement;static newObject(e=new ft,t=new(Qi(e)),i=void 0){const s=new Ji;return s.initialize(e,t,i),s}initialize(e=new ft,t=new(Qi(e)),i=void 0){this.nodeElement=i,this.advancedView=e.bAdvancedView,this.isLinked=!1,this.connectable=!e.bNotConnectable,super.initialize(e,t),this.pinType=this.entity.getType(),this.defaultValue=this.entity.getDefaultValue(),this.color=Ji.properties.color.converter.fromAttribute(this.getColor().toString()),this.pinDirection=e.isInput()?"input":e.isOutput()?"output":"hidden"}setup(){super.setup(),this.nodeElement=this.closest("ueb-node")}createPinReference(){return new at({objectName:this.nodeElement.getNodeName(),pinGuid:this.getPinId()})}getPinId(){return this.entity.PinId}getPinName(){return this.entity.PinName}getPinDisplayName(){return this.entity.pinTitle()}getColor(){return this.entity.pinColor()}isInput(){return this.entity.isInput()}isOutput(){return this.entity.isOutput()}getLinkLocation(){return this.template.getLinkLocation()}getNodeElement(){return this.nodeElement}getLinks(){return this.entity.LinkedTo??[]}getDefaultValue(e=!1){return this.defaultValue=this.entity.getDefaultValue(e)}setDefaultValue(e){this.entity.DefaultValue=e,this.defaultValue=e,this.entity.recomputesNodeTitleOnChange&&this.nodeElement?.computeNodeDisplayName()}sanitizeLinks(e=[]){this.entity.LinkedTo=this.entity.LinkedTo?.filter((t=>{let i=this.blueprint.getPin(t);if(i){if(e.length&&!e.includes(i.nodeElement))return!1;let t=this.blueprint.getLink(this,i);t||(t=ce.getConstructor("ueb-link").newObject(this,i),this.blueprint.addGraphElement(t))}return i})),this.isLinked=this.entity.isLinked()}linkTo(e){const t=this.createPinReference();!this.isLinked||!this.isOutput()||"exec"!==this.pinType&&"exec"!==e.pinType||this.getLinks().some((e=>t.equals(e)))||this.unlinkFromAll(),this.entity.linkTo(e.getNodeElement().getNodeName(),e.entity)&&(this.isLinked=this.entity.isLinked(),this.nodeElement?.template.linksChanged(),this.entity.recomputesNodeTitleOnChange&&this.nodeElement?.computeNodeDisplayName())}unlinkFrom(e,t=!0){this.entity.unlinkFrom(e.getNodeElement().getNodeName(),e.entity)&&(this.isLinked=this.entity.isLinked(),this.nodeElement?.template.linksChanged(),t&&this.blueprint.getLink(this,e)?.remove(),this.entity.recomputesNodeTitleOnChange&&this.nodeElement?.computeNodeDisplayName())}unlinkFromAll(){const e=this.getLinks().length;this.getLinks().map((e=>this.blueprint.getPin(e))).forEach((e=>this.unlinkFrom(e))),e&&this.nodeElement?.template.linksChanged()}redirectLink(e,t){const i=this.getLinks().findIndex((t=>t.objectName.toString()==e.getNodeElement().getNodeName()&&t.pinGuid.valueOf()==e.entity.PinId.valueOf()));return i>=0&&(this.entity.LinkedTo[i]=t,!0)}}class es{constructor(e=(e=>e),t=null){this.array=new Uint32Array(t),this.comparisonValueSupplier=e,this.length=0,this.currentPosition=0}get(e){return e>=0&&e=0&&this.currentPosition=0&&this.currentPosition0?this.get(this.currentPosition-1):null}getPrevValue(){return this.currentPosition>0?this.comparisonValueSupplier(this.get(this.currentPosition-1)):Number.MIN_SAFE_INTEGER}shiftLeft(e,t=1){this.array.set(this.array.subarray(e+t),e)}shiftRight(e,t=1){this.array.set(this.array.subarray(e,-t),e+t)}}class ts{constructor(e,t,i,s){this.initialPosition=e,this.finalPosition=e,this.metadata=new Array(t.length),this.primaryOrder=new es((e=>this.metadata[e].primaryBoundary)),this.secondaryOrder=new es((e=>this.metadata[e].secondaryBoundary)),this.selectFunc=s,this.rectangles=t,this.primaryOrder.reserve(this.rectangles.length),this.secondaryOrder.reserve(this.rectangles.length),t.forEach(((e,t)=>{let n={primaryBoundary:this.initialPosition[0],secondaryBoundary:this.initialPosition[1],rectangle:t,onSecondaryAxis:!1};this.metadata[t]=n,s(e,!1);const r=i(e);this.initialPosition[1]{if(this.metadata[i].onSecondaryAxis)this.selectFunc(this.rectangles[i],s);else if(s){this.secondaryOrder.insert(i,e[1]);const s=this.metadata[i].secondaryBoundary;Math.sign(e[1]-s)==t[1]&&Math.sign(s-this.initialPosition[1])==t[1]&&this.selectFunc(this.rectangles[i],!0)}else this.selectFunc(this.rectangles[i],!1),this.secondaryOrder.remove(i);this.computeBoundaries(),this.selectTo(e)};e[0]this.boundaries.primaryN.v&&e[0]this.boundaries.primaryP.v&&(++this.primaryOrder.currentPosition,i(this.boundaries.primaryP.i,this.initialPosition[0]{this.selectFunc(this.rectangles[t],i),this.computeBoundaries(),this.selectTo(e)};e[1]this.boundaries.secondaryN.v&&e[1]this.boundaries.secondaryP.v&&(++this.secondaryOrder.currentPosition,s(this.boundaries.secondaryP.i,this.initialPosition[1]ns.#oi[e],toAttribute:(e,t)=>Object.entries(ns.#oi).find((([t,i])=>e.constructor===i))?.[0]}}};static newObject(e={},t=e.type??new Ki){const i=new ns;return i.initialize(e,t),i}initialize(e={},t=e.type??new Ki){e.windowOptions??={},this.type=e.type,this.windowOptions=e.windowOptions,super.initialize(e,t)}computeSizes(){const e=this.getBoundingClientRect();this.sizeX=e.width,this.sizeY=e.height}cleanup(){super.cleanup(),this.acknowledgeClose()}acknowledgeClose(){let e=new CustomEvent(re.windowCloseEventName);this.dispatchEvent(e)}}class rs extends Le{static attributes={...super.attributes,TerminalCategory:it,TerminalSubCategory:it,bTerminalIsConst:Ue,bTerminalIsWeakPointer:Ue,bTerminalIsUObjectWrapper:Ue};constructor(e){super(e),this.TerminalCategory,this.TerminalSubCategory,this.bTerminalIsConst,this.bTerminalIsWeakPointer,this.bTerminalIsUObjectWrapper}}class as extends Le{static grammar=ke.seq(ke.reg(new RegExp(`(${Ie.Regex.Path.source}|${Ie.Regex.Symbol.source}\\s*)?\\(\\s*`),1),ke.seq(Ie.attributeName,Ie.equalSeparation).map((([e,t])=>e)).chain((e=>Ie.unknownValue.map((t=>i=>i[e]=t)))).sepBy(Ie.commaSeparation),ke.reg(/\s*(?:,\s*)?\)/)).map((([e,t,i])=>{e??="";let s={};return e.length&&(s.lookbehind=e),t.forEach((e=>e(s))),new this(s)})).label("UnknownKeysEntity");constructor(e={}){super(e)}}class os extends pi{#li;constructor(e,t){super(t),this.#li=e}doWrite(e,t,i=""){return this.#li(e,t)}}class ls extends pi{constructor(e,t=!0){super(e),t&&(this.wrap=(e,t)=>ae.escapeString(t))}doWrite(e,t,i=""){return t||e.constructor!==String?this.wrap(e,e.toString()):`"${this.wrap(e,e.toString())}"`}}Ie.unknownValue=ke.alt(Ue.grammar,Ge.grammar,ke.str("None").map((()=>rt.createNoneInstance())),Ie.null,We.grammar,rt.fullReferenceGrammar,it.grammar,tt.grammar,et.grammar,st.grammar,at.grammar,mt.grammar,bt.grammar,ht.grammar,De.grammar,ut.grammar,as.grammar,Xe.grammar,je.of(at).grammar,je.of(ze.accepting(We,it,Xe)).grammar,ke.lazy((()=>je.createGrammar(Ie.unknownValue)))),li.registerSerializer(null,new os(((e,t)=>"()"),null)),li.registerSerializer(Array,new os(((e,t)=>`(${e.map((e=>li.getSerializer(ae.getType(e)).write(e,t))).join(",")})`),Array)),li.registerSerializer(BigInt,new ls(BigInt)),li.registerSerializer(hi,new di(hi)),li.registerSerializer(Boolean,new os(((e,t)=>e?t?"true":"True":t?"false":"False"),Boolean)),li.registerSerializer(st,new os(((e,t)=>e.getLookbehind()+"("+e.value.map((e=>li.getSerializer(ae.getType(e)).write(e,t))).join(", ")+")"),st)),li.registerSerializer(ft,new pi(ft,((e,t)=>`${e.getLookbehind()} (${t})`),",",!0)),li.registerSerializer(lt,new pi(lt)),li.registerSerializer(rs,new pi(rs,pi.bracketsWrapped)),li.registerSerializer(ct,new os(((e,t)=>`X=${e.X} Y=${e.Y}`),ct)),li.registerSerializer(ht,new pi(ht,pi.bracketsWrapped)),li.registerSerializer(Ct,new pi(Ct,pi.bracketsWrapped)),li.registerSerializer(String,new os(((e,t)=>t?ae.escapeString(e):`"${ae.escapeString(e)}"`),String)),li.registerSerializer(pt,new os(((e,t)=>`${e.P}, ${e.Y}, ${e.R}`),pt)),li.registerSerializer(dt,new os(((e,t)=>`${e.X}, ${e.Y}`),dt)),li.registerSerializer(vt,new os(((e,t)=>`${e.X}, ${e.Y}, ${e.Z}`),vt)),li.registerSerializer(gt,new os(((e,t)=>`${e.X}, ${e.Y}, ${e.Z}, ${e.W}`),gt)),li.registerSerializer(Xe,new ls(Xe)),li.registerSerializer(as,new pi(as,((e,t)=>`${e.getLookbehind()??""}(${t})`))),li.registerSerializer(xt,new pi(xt,pi.bracketsWrapped)),li.registerSerializer(ut,new pi(ut,pi.bracketsWrapped)),li.registerSerializer(bt,new pi(bt,pi.bracketsWrapped)),li.registerSerializer(mt,new pi(mt,pi.bracketsWrapped)),function(){const e=(e,t)=>{customElements.define(e,t),ce.registerElement(e,t)};e("ueb-color-handler",Li),e("ueb-dropdown",Di),e("ueb-input",Bi),e("ueb-link",Ot),e("ueb-node",ci),e("ueb-pin",Ji),e("ueb-selector",ss),e("ueb-ui-slider",Ti),e("ueb-window",ns)}();export{xi as Blueprint,re as Configuration,Ot as LinkElement,ci as NodeElement,ae as Utility}; diff --git a/js/entity/AlternativesEntity.js b/js/entity/AlternativesEntity.js index 5ab7893..892bf8a 100644 --- a/js/entity/AlternativesEntity.js +++ b/js/entity/AlternativesEntity.js @@ -7,13 +7,20 @@ export default class AlternativesEntity extends IEntity { /** @type {(typeof IEntity)[]} */ static alternatives = [] + static className() { + let result = super.className() + if (this.alternatives.length) { + result += " (accepting: " + this.alternatives.map(v => v.className()).join(", ") + ")" + } + return result + } + static createGrammar() { - return this.alternatives - .map(entity => entity.grammar) - .reduce((acc, cur) => !cur || cur === Grammar.unknownValue || acc === Grammar.unknownValue - ? Grammar.unknownValue - : P.alt(acc, cur) - ) + const grammars = this.alternatives.map(entity => entity.grammar) + if (grammars.includes(Grammar.unknownValue)) { + return Grammar.unknownValue + } + return P.alt(...grammars) } /** diff --git a/js/entity/ArrayEntity.js b/js/entity/ArrayEntity.js index 963268c..0665511 100644 --- a/js/entity/ArrayEntity.js +++ b/js/entity/ArrayEntity.js @@ -7,21 +7,30 @@ export default class ArrayEntity extends IEntity { /** @type {typeof IEntity} */ static type + static grammar = this.createGrammar() - /** @param {InstanceType[]} values */ + /** @param {ExtractType[]} values */ constructor(values = []) { super() this.values = values } - static createGrammar(elementGrammar = this.type.grammar) { + static createGrammar(elementGrammar = this.type?.grammar ?? P.lazy(() => Grammar.unknownValue)) { return this.inlined ? elementGrammar : P.seq( P.reg(/\(\s*/), elementGrammar.sepBy(Grammar.commaSeparation).opt(), - P.reg(/\s*(?:,\s*)?\)/), - ).map(([_0, values, _3]) => new this(values instanceof Array ? values : [])) + P.reg(/\s*(,\s*)?\)/, 1), + ).map(([_0, values, trailing]) => { + let self = this + const hasTrailing = trailing !== undefined + if (hasTrailing !== self.trailing) { + self = self.flagTrailing(hasTrailing) + } + values = values instanceof Array ? values : [] + return new self(values) + }).label(`ArrayEntity of ${this.type?.className() ?? "unknown values"}`) } /** @@ -29,8 +38,10 @@ export default class ArrayEntity extends IEntity { * @param {NonNullable} type */ static of(type) { - const result = /** @type {(typeof ArrayEntity) & { type: T }} */(this.asUniqueClass()) - result.type = type + const result = /** @type {typeof ArrayEntity & { type: ExtractType, grammar: P> }} */( + this.asUniqueClass() + ) + result.type = /** @type {ExtractType} */(type) this.grammar = result.createGrammar() return result } diff --git a/js/entity/BlueprintEntity.js b/js/entity/BlueprintEntity.js index 85663fd..1a9b3ae 100644 --- a/js/entity/BlueprintEntity.js +++ b/js/entity/BlueprintEntity.js @@ -56,18 +56,18 @@ export default class BlueprintEntity extends ObjectEntity { /** @param {ObjectEntity} entity */ mergeWith(entity) { - if (!entity.ScriptVariables || entity.ScriptVariables.length === 0) { + if (!entity.ScriptVariables || entity.ScriptVariables.values.length === 0) { return this } - if (!this.ScriptVariables || this.ScriptVariables.length === 0) { + if (!this.ScriptVariables || this.ScriptVariables.values.length === 0) { this.ScriptVariables = entity.ScriptVariables } let scriptVariables = Utility.mergeArrays( - this.ScriptVariables, - entity.ScriptVariables, + this.ScriptVariables.values, + entity.ScriptVariables.values, (l, r) => l.OriginalChangeId.value == r.OriginalChangeId.value ) - if (scriptVariables.length === this.ScriptVariables.length) { + if (scriptVariables.length === this.ScriptVariables.values.length) { return this } const entries = scriptVariables.concat(scriptVariables).map((v, i) => { diff --git a/js/entity/BooleanEntity.js b/js/entity/BooleanEntity.js index b9044d7..8a8d527 100755 --- a/js/entity/BooleanEntity.js +++ b/js/entity/BooleanEntity.js @@ -3,7 +3,9 @@ import IEntity from "./IEntity.js" export default class BooleanEntity extends IEntity { - static grammar = P.regArray(/(true)|false/i).map(v => v[1] ? new this(true) : new this(false)) + static grammar = P.regArray(/(true)|false/i) + .map(v => v[1] ? new this(true) : new this(false)) + .label("BooleanEntity") constructor(value = false) { super() @@ -14,7 +16,13 @@ export default class BooleanEntity extends IEntity { return this.value } - toString() { - return this.value.toString() + toString(insideString = false) { + return this.value + ? insideString + ? "true" + : "True" + : insideString + ? "false" + : "False" } } diff --git a/js/entity/FormatTextEntity.js b/js/entity/FormatTextEntity.js index 9ef4197..e380f5c 100644 --- a/js/entity/FormatTextEntity.js +++ b/js/entity/FormatTextEntity.js @@ -1,15 +1,15 @@ import P from "parsernostrum" -import IEntity from "./IEntity.js" +import IPrintableEntity from "./IPrintableEntity.js" import InvariantTextEntity from "./InvariantTextEntity.js" import LocalizedTextEntity from "./LocalizedTextEntity.js" import StringEntity from "./StringEntity.js" -export default class FormatTextEntity extends IEntity { +export default class FormatTextEntity extends IPrintableEntity { static lookbehind = ["LOCGEN_FORMAT_NAMED", "LOCGEN_FORMAT_ORDERED"] static grammar = P.seq( // Resulting regex: /(LOCGEN_FORMAT_NAMED|LOCGEN_FORMAT_ORDERED)\s*/ - P.reg(new RegExp(String.raw`(${this.lookbehind.reduce((acc, cur) => acc + "|" + cur)})\s*\(\s*)`), 1), + P.reg(new RegExp(String.raw`(${this.lookbehind.reduce((acc, cur) => acc + "|" + cur)})\s*`), 1), P.alt( ...[StringEntity, LocalizedTextEntity, InvariantTextEntity, FormatTextEntity].map(type => type.grammar) ).sepBy(P.reg(/\s*\,\s*/)), @@ -20,6 +20,7 @@ export default class FormatTextEntity extends IEntity { result.lookbehind = lookbehind return result }) + .label("FormatTextEntity") /** @param {(StringEntity | LocalizedTextEntity | InvariantTextEntity | FormatTextEntity)[]} values */ constructor(values) { @@ -27,20 +28,21 @@ export default class FormatTextEntity extends IEntity { this.values = values } - toString() { + print() { const pattern = this.values?.[0]?.toString() // The pattern is always the first element of the array if (!pattern) { return "" } + const values = this.values.slice(1).map(v => v.toString()) - return this.lookbehind == "LOCGEN_FORMAT_NAMED" + let result = this.Self().lookbehind == "LOCGEN_FORMAT_NAMED" ? pattern.replaceAll(/\{([a-zA-Z]\w*)\}/g, (substring, arg) => { const argLocation = values.indexOf(arg) + 1 return argLocation > 0 && argLocation < values.length ? values[argLocation] : substring }) - : this.lookbehind == "LOCGEN_FORMAT_ORDERED" + : this.Self().lookbehind == "LOCGEN_FORMAT_ORDERED" ? pattern.replaceAll(/\{(\d+)\}/g, (substring, arg) => { const argValue = Number(arg) return argValue < values.length @@ -48,5 +50,6 @@ export default class FormatTextEntity extends IEntity { : substring }) : "" + result = this.Self().lookbehind + "(" + result + ")" } } diff --git a/js/entity/FunctionReferenceEntity.js b/js/entity/FunctionReferenceEntity.js index 362e8d0..2cc09ea 100755 --- a/js/entity/FunctionReferenceEntity.js +++ b/js/entity/FunctionReferenceEntity.js @@ -16,8 +16,8 @@ export default class FunctionReferenceEntity extends IEntity { constructor(values) { super(values) - /** @type {ObjectReferenceEntity} */ this.MemberParent - /** @type {String} */ this.MemberName - /** @type {GuidEntity} */ this.MemberGuid + /** @type {InstanceType} */ this.MemberParent + /** @type {InstanceType} */ this.MemberName + /** @type {InstanceType} */ this.MemberGuid } } diff --git a/js/entity/GuidEntity.js b/js/entity/GuidEntity.js index 8b23f2a..a4be325 100755 --- a/js/entity/GuidEntity.js +++ b/js/entity/GuidEntity.js @@ -10,7 +10,7 @@ if (typeof window === "undefined") { export default class GuidEntity extends IEntity { - static grammar = P.reg(/[0-9a-fA-F]{32}/).map(v => new this(v)) + static grammar = P.reg(/[0-9A-F]{32}/i).map(v => new this(v)).label("GuidEntity") static generateGuid() { let values = new Uint32Array(4) diff --git a/js/entity/IEntity.js b/js/entity/IEntity.js index 95ab97e..af5754b 100644 --- a/js/entity/IEntity.js +++ b/js/entity/IEntity.js @@ -10,45 +10,22 @@ export default class IEntity { /** @type {(entity: Attribute, serialized: String) => String} */ static notWrapped = (entity, serialized) => serialized - /** @type {(entity: Attribute, serialized: String) => String} */ - static bracketsWrapped = (entity, serialized) => `(${serialized})` + /** @type {(entity: IEntity, serialized: String) => String} */ + static defaultWrapped = (entity, serialized) => `${entity.lookbehind}(${serialized})` - static wrap = this.notWrapped + static wrap = this.defaultWrapped static attributeSeparator = "," - static trailingSeparator = false - /** @type {(k: String) => String} */ static printKey = k => k - /** @type {P} */ - static grammar = P.failure() + /** @type {P>} */ + static grammar = /** @type {any} */(P.failure()) /** @type {{ [key: String]: typeof IEntity }} */ static attributes = {} - /** @type {String | String[]} */ - static lookbehind = "" - - /** @type {typeof IEntity.lookbehind} */ - #lookbehind = this.Self().lookbehind - get lookbehind() { - return this.#lookbehind - } - set lookbehind(value) { - throw this.#lookbehind = value - } - - /** @type {String[]} */ - #keys - get keys() { - return this.#keys ?? Object.keys(this.Self().attributes) - } - set keys(value) { - this.#keys = [... new Set(value)] - } - /** @type {(type: typeof IEntity) => InstanceType} */ static default static nullable = false @@ -58,10 +35,30 @@ export default class IEntity { static inlined = false // The key is a subobject or array and printed as inlined (A.B=123, A(0)=123) static quoted = false // Key is serialized with quotes static silent = false // Do not serialize if default - static uninitialized = false // Do not initialize with default + static trailing = false // Add attribute separator after the last attribute when serializing + + /** @type {String | String[]} */ + static lookbehind = "" + + #lookbehind = /** @type {String} */(this.Self().lookbehind) + get lookbehind() { + return this.#lookbehind + } + set lookbehind(value) { + this.#lookbehind = value + } + + /** @type {String[]} */ + #keys + get keys() { + return this.#keys ?? Object.keys(this) + } + set keys(value) { + this.#keys = [... new Set(value)] + } constructor(values = {}) { - const keys = Utility.mergeArrays(Object.keys(values.attributes), Object.keys(this.Self().attributes)) + const keys = Utility.mergeArrays(Object.keys(values), Object.keys(this.Self().attributes)) for (const key of keys) { if (values[key] !== undefined) { this[key] = values[key] @@ -75,6 +72,14 @@ export default class IEntity { } } + static className() { + let self = this + while (!self.name) { + self = Object.getPrototypeOf(self) + } + return self.name + } + /** @param {String} key */ showProperty(key) { /** @type {IEntity} */ @@ -104,6 +109,17 @@ export default class IEntity { return this } + /** + * @template {typeof IEntity} T + * @this {T} + * @param {String} value + */ + static withLookbehind(value) { + const result = this.asUniqueClass() + result.lookbehind = value + return result + } + /** * @template {typeof IEntity} T * @this {T} @@ -144,6 +160,16 @@ export default class IEntity { return result } + /** + * @template {typeof IEntity} T + * @this {T} + */ + static flagQuoted(value = true) { + const result = this.asUniqueClass() + result.quoted = value + return result + } + /** * @template {typeof IEntity} T * @this {T} @@ -154,6 +180,16 @@ export default class IEntity { return result } + /** + * @template {typeof IEntity} T + * @this {T} + */ + static flagTrailing(value = true) { + const result = this.asUniqueClass() + result.trailing = value + return result + } + /** * @template {typeof IEntity} T * @this {InstanceType} @@ -206,6 +242,9 @@ export default class IEntity { if (thisKeys.length != otherKeys.length) { return false } + if (this.valueOf && other.valueOf) { + return this.valueOf() === other.valueOf() + } for (let i = 0; i < thisKeys.length; ++i) { if (!(this[thisKeys[i]] instanceof IEntity && this[thisKeys[i]].equals(other[otherKeys[i]]))) { return false @@ -250,7 +289,7 @@ export default class IEntity { } result += serialization } - if (Self.trailingSeparator && result.length) { + if (Self.trailing && result.length) { result += Self.attributeSeparator } return Self.wrap(this, result) diff --git a/js/entity/IPrintableEntity.js b/js/entity/IPrintableEntity.js new file mode 100644 index 0000000..dd58bf0 --- /dev/null +++ b/js/entity/IPrintableEntity.js @@ -0,0 +1,8 @@ +import IEntity from "./IEntity.js" + +export default class IPrintableEntity extends IEntity { + + print() { + return this.toString() + } +} diff --git a/js/entity/IntegerEntity.js b/js/entity/IntegerEntity.js index 0073cc8..9e464cc 100755 --- a/js/entity/IntegerEntity.js +++ b/js/entity/IntegerEntity.js @@ -1,7 +1,6 @@ import P from "parsernostrum" import NumberEntity from "./NumberEntity.js" -// @ts-expect-error export default class IntegerEntity extends NumberEntity { static grammar = P.numberInteger.map(v => new this(v)) diff --git a/js/entity/InvariantTextEntity.js b/js/entity/InvariantTextEntity.js index 445fef5..e72dc33 100644 --- a/js/entity/InvariantTextEntity.js +++ b/js/entity/InvariantTextEntity.js @@ -1,25 +1,39 @@ -import P from "parsernostrum" -import IEntity from "./IEntity.js" +import Parsernostrum from "parsernostrum" +import IPrintableEntity from "./IPrintableEntity.js" -export default class InvariantTextEntity extends IEntity { +export default class InvariantTextEntity extends IPrintableEntity { static lookbehind = "INVTEXT" - static grammar = P.alt( - P.seq( - P.reg(new RegExp(`${this.lookbehind}\\s*\\(`)), - P.doubleQuotedString, - P.reg(/\s*\)/) - ).map(([_0, value, _2]) => new this(value)), - P.reg(new RegExp(this.lookbehind)).map(() => new this()) // InvariantTextEntity can not have arguments - ).map(value => new this(value)) + static grammar = Parsernostrum.alt( + Parsernostrum.seq( + Parsernostrum.reg(new RegExp(`${this.lookbehind}\\s*\\(`)), + Parsernostrum.doubleQuotedString, + Parsernostrum.reg(/\s*\)/) + ).map(([_0, value, _2]) => Number(value)), + Parsernostrum.reg(new RegExp(this.lookbehind)).map(() => 0) // InvariantTextEntity can not have arguments + ) + .map(value => new this(value)) + .label("InvariantTextEntity") constructor(value = "") { super() this.value = value } - toString() { + print() { + let xxxx = Parsernostrum.alt( + Parsernostrum.seq( + Parsernostrum.reg(new RegExp(`${this.lookbehind}\\s*\\(`)), + Parsernostrum.doubleQuotedString, + Parsernostrum.reg(/\s*\)/) + ).map(([_0, value, _2]) => Number(value)), + Parsernostrum.reg(new RegExp(this.lookbehind)).map(() => 0) // InvariantTextEntity can not have arguments + ) return this.value } + + toString() { + return this.lookbehind + "(" + this.value + ")" + } } diff --git a/js/entity/KeyBindingEntity.js b/js/entity/KeyBindingEntity.js index 3302167..a54ecaf 100644 --- a/js/entity/KeyBindingEntity.js +++ b/js/entity/KeyBindingEntity.js @@ -27,11 +27,11 @@ export default class KeyBindingEntity extends IEntity { constructor() { super() - /** @type {String} */ this.ActionName - /** @type {Boolean} */ this.bShift - /** @type {Boolean} */ this.bCtrl - /** @type {Boolean} */ this.bAlt - /** @type {Boolean} */ this.bCmd - /** @type {IdentifierEntity} */ this.Key + /** @type {InstanceType} */ this.ActionName + /** @type {InstanceType} */ this.bShift + /** @type {InstanceType} */ this.bCtrl + /** @type {InstanceType} */ this.bAlt + /** @type {InstanceType} */ this.bCmd + /** @type {InstanceType} */ this.Key } } diff --git a/js/entity/LinearColorEntity.js b/js/entity/LinearColorEntity.js index e56641f..4e59cb0 100644 --- a/js/entity/LinearColorEntity.js +++ b/js/entity/LinearColorEntity.js @@ -14,7 +14,7 @@ export default class LinearColorEntity extends IEntity { B: ColorChannelEntity.withDefault(), A: ColorChannelEntity.withDefault(type => new type(1)), } - static grammar = Grammar.createEntityGrammar(this, false) + static grammar = Grammar.createEntityGrammar(this).label("LinearColorEntity") #H = new ColorChannelEntity() get H() { @@ -26,18 +26,35 @@ export default class LinearColorEntity extends IEntity { #S = new ColorChannelEntity() get S() { - return this.#H + return this.#S } set S(value) { - this.#H = value + this.#S = value } #V = new ColorChannelEntity() get V() { - return this.#H + return this.#V } set V(value) { - this.#H = value + this.#V = value + } + + constructor(values) { + super(values) + if (values instanceof Array) { + values = { + R: values[0] ?? 0, + G: values[1] ?? 0, + B: values[2] ?? 0, + A: values[3] ?? 1, + } + } + /** @type {InstanceType} */ this.R + /** @type {InstanceType} */ this.G + /** @type {InstanceType} */ this.B + /** @type {InstanceType} */ this.A + this.#updateHSV() } /** @param {Number} x */ @@ -129,23 +146,6 @@ export default class LinearColorEntity extends IEntity { ) } - constructor(values) { - super(values) - if (values instanceof Array) { - values = { - R: values[0] ?? 0, - G: values[1] ?? 0, - B: values[2] ?? 0, - A: values[3] ?? 1, - } - } - /** @type {ColorChannelEntity} */ this.R - /** @type {ColorChannelEntity} */ this.G - /** @type {ColorChannelEntity} */ this.B - /** @type {ColorChannelEntity} */ this.A - this.#updateHSV() - } - #updateHSV() { const r = this.R.value const g = this.G.value @@ -311,8 +311,4 @@ export default class LinearColorEntity extends IEntity { toArray() { return [this.R.value, this.G.value, this.B.value, this.A.value] } - - toString() { - return Utility.printLinearColor(this) - } } diff --git a/js/entity/LocalizedTextEntity.js b/js/entity/LocalizedTextEntity.js index 6f5d28f..65f9e85 100755 --- a/js/entity/LocalizedTextEntity.js +++ b/js/entity/LocalizedTextEntity.js @@ -1,24 +1,27 @@ import P from "parsernostrum" import Utility from "../Utility.js" import Grammar from "../serialization/Grammar.js" -import IEntity from "./IEntity.js" +import IPrintableEntity from "./IPrintableEntity.js" -export default class LocalizedTextEntity extends IEntity { +export default class LocalizedTextEntity extends IPrintableEntity { static lookbehind = "NSLOCTEXT" static grammar = P.regArray(new RegExp( - String.raw`${this.attributes.lookbehind.default}\s*\(` + String.raw`${this.lookbehind}\s*\(` + String.raw`\s*"(${Grammar.Regex.InsideString.source})"\s*,` + String.raw`\s*"(${Grammar.Regex.InsideString.source})"\s*,` + String.raw`\s*"(${Grammar.Regex.InsideString.source})"\s*` - + String.raw`(?:,\s+)?` + + String.raw`(,\s+)?` + String.raw`\)`, "m" - )).map(matchResult => new this( - Utility.unescapeString(matchResult[1]), - Utility.unescapeString(matchResult[2]), - Utility.unescapeString(matchResult[3]), - )) + )).map(matchResult => { + const self = matchResult[4] ? this.flagTrailing() : this + return new self( + Utility.unescapeString(matchResult[1]), + Utility.unescapeString(matchResult[2]), + Utility.unescapeString(matchResult[3]), + ) + }).label("LocalizedTextEntity") #namespace get namespace() { @@ -44,7 +47,6 @@ export default class LocalizedTextEntity extends IEntity { this.#value = value } - constructor(namespace = "", key = "", value = "") { super() this.namespace = namespace @@ -52,7 +54,12 @@ export default class LocalizedTextEntity extends IEntity { this.value = value } - toString() { + print() { return Utility.capitalFirstLetter(this.value) } + + toString() { + const trailer = this.Self().trailing ? ", " : "" + return `${this.lookbehind}(${this.namespace}, ${this.key}, ${this.value}${trailer})` + } } diff --git a/js/entity/MacroGraphReferenceEntity.js b/js/entity/MacroGraphReferenceEntity.js index 10095f6..dbfdacf 100755 --- a/js/entity/MacroGraphReferenceEntity.js +++ b/js/entity/MacroGraphReferenceEntity.js @@ -15,9 +15,9 @@ export default class MacroGraphReferenceEntity extends IEntity { constructor(values) { super(values) - /** @type {ObjectReferenceEntity} */ this.MacroGraph - /** @type {ObjectReferenceEntity} */ this.GraphBlueprint - /** @type {GuidEntity} */ this.GuidEntity + /** @type {InstanceType} */ this.MacroGraph + /** @type {InstanceType} */ this.GraphBlueprint + /** @type {InstanceType} */ this.GraphGuid } getMacroName() { diff --git a/js/entity/MirroredEntity.js b/js/entity/MirroredEntity.js index 7a628a2..0964922 100644 --- a/js/entity/MirroredEntity.js +++ b/js/entity/MirroredEntity.js @@ -6,7 +6,7 @@ export default class MirroredEntity extends IEntity { /** @type {typeof IEntity} */ static type - /** @param {() => T} getter */ + /** @param {() => InstanceType} getter */ constructor(getter = null) { super() this.getter = getter @@ -32,7 +32,11 @@ export default class MirroredEntity extends IEntity { return result } - toString() { - return this.getter().toString() + toString( + insideString = false, + indentation = "", + printKey = this.Self().printKey, + ) { + return this.getter().toString(insideString, indentation, printKey) } } diff --git a/js/entity/NumberEntity.js b/js/entity/NumberEntity.js index ec020b1..3818e2b 100755 --- a/js/entity/NumberEntity.js +++ b/js/entity/NumberEntity.js @@ -1,13 +1,14 @@ import P from "parsernostrum" +import Grammar from "../serialization/Grammar.js" import IEntity from "./IEntity.js" export default class NumberEntity extends IEntity { static grammar = P.regArray( - new RegExp(`(${P.number.getParser().parser.regexp.source})|(\\+?inf)|(-inf)`) + new RegExp(`(${Grammar.numberRegexSource})|(\\+?inf)|(-inf)`) ).map(([_0, n, plusInf, minusInf]) => new this( n ? Number(n) : plusInf ? Number.POSITIVE_INFINITY : Number.NEGATIVE_INFINITY - )) + )).label("NumberEntity") /** @type {Number} */ #value @@ -31,6 +32,12 @@ export default class NumberEntity extends IEntity { } toString() { + if (this.value === Number.POSITIVE_INFINITY) { + return "+inf" + } + if (this.value === Number.NEGATIVE_INFINITY) { + return "-inf" + } return this.value.toString() } } diff --git a/js/entity/ObjectEntity.js b/js/entity/ObjectEntity.js index 5a0a181..1d4898b 100755 --- a/js/entity/ObjectEntity.js +++ b/js/entity/ObjectEntity.js @@ -28,12 +28,14 @@ import VariableReferenceEntity from "./VariableReferenceEntity.js" export default class ObjectEntity extends IEntity { - #_exported = false - get _exported() { - return this.#_exported + static trailing = true + + #exported = false + get exported() { + return this.#exported } - set _exported(value) { - this.#_exported = value + set exported(value) { + this.#exported = value } static attributes = { @@ -130,7 +132,7 @@ export default class ObjectEntity extends IEntity { ScriptVariables: ArrayEntity.of(ScriptVariableEntity), Node: MirroredEntity.of(ObjectReferenceEntity), ExportedNodes: StringEntity, - CustomProperties: ArrayEntity.of(AlternativesEntity.accepting(PinEntity, UnknownPinEntity)), + CustomProperties: ArrayEntity.of(AlternativesEntity.accepting(PinEntity, UnknownPinEntity)).withDefault().flagSilent(), } static #nameRegex = /^(\w+?)(?:_(\d+))?$/ static customPropertyGrammar = P.seq( @@ -144,28 +146,28 @@ export default class ObjectEntity extends IEntity { Grammar.symbolQuoted.map(v => [v, true]), Grammar.symbol.map(v => [v, false]), ), - P.reg( - new RegExp(`\\s*\\(\\s*(\\d+)\\s*\\)\\s*\\=\\s*`), - 1 - ).map(Number) + P.reg(new RegExp(String.raw`\s*\(\s*(\d+)\s*\)\s*\=\s*`), 1).map(Number) ) .chain( - /** @param {[[String, Boolean], Number]} param */ + /** @param {[[keyof ObjectEntity.attributes, Boolean], Number]} param */ ([[symbol, quoted], index]) => - Grammar.grammarFor(this.attributes[symbol]) - .map(currentValue => - values => { - (values[symbol] ??= [])[index] = currentValue - Utility.objectSet(values, ["attributes", symbol, "quoted"], quoted) - if (!this.attributes[symbol]?.inlined) { - if (!values.attributes) { - IEntity.defineAttributes(values, {}) - } - Utility.objectSet(values, ["attributes", symbol, "type"], [currentValue.constructor]) - Utility.objectSet(values, ["attributes", symbol, "inlined"], true) + this.attributes[symbol].grammar.map(currentValue => + values => { + if (values[symbol] === undefined) { + let arrayEntity = ArrayEntity + if (quoted != arrayEntity.quoted) { + arrayEntity = arrayEntity.flagQuoted(quoted) } + if (!arrayEntity.inlined) { + arrayEntity = arrayEntity.flagInlined() + } + values[symbol] = new arrayEntity() } - ) + /** @type {ArrayEntity} */ + const target = values[symbol] + target.values[index] = currentValue + } + ) ) static grammar = this.createGrammar() @@ -233,73 +235,71 @@ export default class ObjectEntity extends IEntity { super(values) // Attributes - /** @type {(PinEntity | UnknownPinEntity)[]} */ this.CustomProperties - /** @type {Boolean} */ this.bIsPureFunc - /** @type {Boolean} */ this.isExported - /** @type {FunctionReferenceEntity} */ this.ComponentPropertyName - /** @type {FunctionReferenceEntity} */ this.EventReference - /** @type {FunctionReferenceEntity} */ this.FunctionReference - /** @type {IdentifierEntity} */ this.AdvancedPinDisplay - /** @type {IdentifierEntity} */ this.EnabledState - /** @type {IntegerEntity} */ this.NodeHeight - /** @type {IntegerEntity} */ this.NodePosX - /** @type {IntegerEntity} */ this.NodePosY - /** @type {IntegerEntity} */ this.NodeWidth - /** @type {LinearColorEntity} */ this.CommentColor - /** @type {LinearColorEntity} */ this.NodeTitleColor - /** @type {MacroGraphReferenceEntity} */ this.MacroGraphReference - /** @type {MirroredEntity} */ this.MaterialExpressionEditorX - /** @type {MirroredEntity} */ this.MaterialExpressionEditorY - /** @type {MirroredEntity} */ this.SizeX - /** @type {MirroredEntity} */ this.SizeY - /** @type {MirroredEntity} */ this.Text - /** @type {MirroredEntity} */ this.PositionX - /** @type {MirroredEntity} */ this.PositionY - /** @type {MirroredEntity} */ this.Node - /** @type {null[]} */ this.PinTags - /** @type {Number} */ this.NumAdditionalInputs - /** @type {ObjectReferenceEntity[]} */ this.InputPins - /** @type {ObjectReferenceEntity[]} */ this.OutputPins - /** @type {ObjectReferenceEntity} */ this.Archetype - /** @type {ObjectReferenceEntity} */ this.BlueprintElementInstance - /** @type {ObjectReferenceEntity} */ this.BlueprintElementType - /** @type {ObjectReferenceEntity} */ this.Class - /** @type {ObjectReferenceEntity} */ this.Enum - /** @type {ObjectReferenceEntity} */ this.ExportPath - /** @type {ObjectReferenceEntity} */ this.FunctionScript - /** @type {ObjectReferenceEntity} */ this.Graph - /** @type {ObjectReferenceEntity} */ this.MaterialExpression - /** @type {ObjectReferenceEntity} */ this.MaterialExpressionComment - /** @type {ObjectReferenceEntity} */ this.MaterialFunction - /** @type {ObjectReferenceEntity} */ this.ObjectRef - /** @type {ObjectReferenceEntity} */ this.PCGNode - /** @type {ObjectReferenceEntity} */ this.SettingsInterface - /** @type {ObjectReferenceEntity} */ this.StructType - /** @type {ObjectReferenceEntity} */ this.TargetType - /** @type {ScriptVariableEntity[]} */ this.ScriptVariables - /** @type {String[]} */ this.EnumEntries - /** @type {String[]} */ this.PinNames - /** @type {String} */ this.CustomFunctionName - /** @type {String} */ this.DelegatePropertyName - /** @type {String} */ this.ExportedNodes - /** @type {String} */ this.FunctionDisplayName - /** @type {String} */ this.InputName - /** @type {String} */ this.Name - /** @type {String} */ this.NodeComment - /** @type {String} */ this.NodeTitle - /** @type {String} */ this.Operation - /** @type {String} */ this.OpName - /** @type {String} */ this.ProxyFactoryFunctionName - /** @type {String} */ this.SubgraphInstance - /** @type {String} */ this.Text - /** @type {SymbolEntity} */ this.AxisKey - /** @type {SymbolEntity} */ this.HiGenGridSize - /** @type {SymbolEntity} */ this.InputAxisKey - /** @type {SymbolEntity} */ this.InputKey - /** @type {SymbolEntity} */ this.InputType - /** @type {UnknownPinEntity[]} */ this.AddedPins - /** @type {VariableReferenceEntity} */ this.DelegateReference - /** @type {VariableReferenceEntity} */ this.VariableReference + /** @type {InstanceType} */ this.AddedPins + /** @type {InstanceType} */ this.AdvancedPinDisplay + /** @type {InstanceType} */ this.Archetype + /** @type {InstanceType} */ this.AxisKey + /** @type {InstanceType} */ this.bIsPureFunc + /** @type {InstanceType} */ this.BlueprintElementInstance + /** @type {InstanceType} */ this.BlueprintElementType + /** @type {InstanceType} */ this.Class + /** @type {InstanceType} */ this.CommentColor + /** @type {InstanceType} */ this.ComponentPropertyName + /** @type {InstanceType} */ this.CustomFunctionName + /** @type {InstanceType} */ this.CustomProperties + /** @type {InstanceType} */ this.DelegatePropertyName + /** @type {InstanceType} */ this.DelegateReference + /** @type {InstanceType} */ this.EnabledState + /** @type {InstanceType} */ this.Enum + /** @type {InstanceType} */ this.EnumEntries + /** @type {InstanceType} */ this.EventReference + /** @type {InstanceType} */ this.ExportedNodes + /** @type {InstanceType} */ this.ExportPath + /** @type {InstanceType} */ this.FunctionDisplayName + /** @type {InstanceType} */ this.FunctionReference + /** @type {InstanceType} */ this.FunctionScript + /** @type {InstanceType} */ this.Graph + /** @type {InstanceType} */ this.HiGenGridSize + /** @type {InstanceType} */ this.InputAxisKey + /** @type {InstanceType} */ this.InputKey + /** @type {InstanceType} */ this.InputName + /** @type {InstanceType} */ this.InputPins + /** @type {InstanceType} */ this.InputType + /** @type {InstanceType} */ this.MacroGraphReference + /** @type {InstanceType} */ this.MaterialExpression + /** @type {InstanceType} */ this.MaterialExpressionComment + /** @type {InstanceType} */ this.MaterialExpressionEditorX + /** @type {InstanceType} */ this.MaterialExpressionEditorY + /** @type {InstanceType} */ this.MaterialFunction + /** @type {InstanceType} */ this.Name + /** @type {InstanceType} */ this.Node + /** @type {InstanceType} */ this.NodeComment + /** @type {InstanceType} */ this.NodeHeight + /** @type {InstanceType} */ this.NodePosX + /** @type {InstanceType} */ this.NodePosY + /** @type {InstanceType} */ this.NodeTitle + /** @type {InstanceType} */ this.NodeTitleColor + /** @type {InstanceType} */ this.NodeWidth + /** @type {InstanceType} */ this.NumAdditionalInputs + /** @type {InstanceType} */ this.ObjectRef + /** @type {InstanceType} */ this.Operation + /** @type {InstanceType} */ this.OpName + /** @type {InstanceType} */ this.OutputPins + /** @type {InstanceType} */ this.PCGNode + /** @type {InstanceType} */ this.PinNames + /** @type {InstanceType} */ this.PositionX + /** @type {InstanceType} */ this.PositionY + /** @type {InstanceType} */ this.ProxyFactoryFunctionName + /** @type {InstanceType} */ this.ScriptVariables + /** @type {InstanceType} */ this.SettingsInterface + /** @type {InstanceType} */ this.SizeX + /** @type {InstanceType} */ this.SizeY + /** @type {InstanceType} */ this.StructType + /** @type {InstanceType} */ this.SubgraphInstance + /** @type {InstanceType} */ this.TargetType + /** @type {InstanceType} */ this.Text + /** @type {InstanceType} */ this.Text + /** @type {InstanceType} */ this.VariableReference // Legacy nodes pins if (this["Pins"] instanceof Array) { @@ -481,10 +481,7 @@ export default class ObjectEntity extends IEntity { } getCustomproperties(canCreate = false) { - if (canCreate && !this.CustomProperties) { - this.CustomProperties = [] - } - return this.CustomProperties ?? [] + return this.CustomProperties.values } /** @returns {PinEntity[]} */ @@ -615,4 +612,44 @@ export default class ObjectEntity extends IEntity { additionalPinInserter() { return nodeVariadic(this) } + + /** @param {String} key */ + showProperty(key) { + switch (key) { + case "Class": + case "Name": + case "Archetype": + case "ExportPath": + case "CustomProperties": + // Serielized separately, check doWrite() + return false + } + return super.showProperty(key) + } + + toString( + insideString = false, + indentation = "", + printKey = this.Self().printKey, + ) { + const moreIndentation = indentation + Configuration.indentation + let result = indentation + "Begin Object" + + (this.Class?.type || this.Class?.path ? ` Class=${this.Class.toString(insideString)}` : "") + + (this.Name ? ` Name=${this.Name.toString(insideString)}` : "") + + (this.Archetype ? ` Archetype=${this.Archetype.toString(insideString)}` : "") + + (this.ExportPath?.type || this.ExportPath?.path ? ` ExportPath=${this.ExportPath.toString(insideString)}` : "") + + "\n" + + super.toString(insideString, moreIndentation, k => this[k] instanceof ObjectEntity ? "" : k) + + (!this.CustomProperties.Self().ignored + ? this.getCustomproperties().map(pin => + moreIndentation + + printKey("CustomProperties ") + + pin.toString(insideString) + + this.Self().attributeSeparator + ).join("") + : "" + ) + + indentation + "End Object" + return result + } } diff --git a/js/entity/ObjectReferenceEntity.js b/js/entity/ObjectReferenceEntity.js index e8164c5..8e73de7 100755 --- a/js/entity/ObjectReferenceEntity.js +++ b/js/entity/ObjectReferenceEntity.js @@ -11,11 +11,14 @@ export default class ObjectReferenceEntity extends IEntity { + `'(${Grammar.Regex.InsideSingleQuotedString.source})'` )).map(([_0, a, b]) => a ?? b) static typeReference = P.reg( + // @ts-expect-error new RegExp(Grammar.Regex.Path.source + "|" + Grammar.symbol.getParser().regexp.source) ) static fullReferenceGrammar = P.regArray( new RegExp( + // @ts-expect-error "(" + this.typeReference.getParser().regexp.source + ")" + // @ts-expect-error + "(?:" + this.#quotedParser.getParser().parser.regexp.source + ")" ) ).map(([full, type, ...path]) => new this(type, path.find(v => v), full)) @@ -30,7 +33,7 @@ export default class ObjectReferenceEntity extends IEntity { this.fullReferenceSerializedGrammar, this.fullReferenceGrammar, this.typeReferenceGrammar, - ) + ).label("ObjectReferenceEntity") #type get type() { @@ -72,7 +75,11 @@ export default class ObjectReferenceEntity extends IEntity { return Utility.getNameFromPath(this.path.replace(/_C$/, ""), dropCounter) } - toString() { + toString( + insideString = false, + indentation = "", + printKey = this.Self().printKey, + ) { return this.full } } diff --git a/js/entity/PathSymbolEntity.js b/js/entity/PathSymbolEntity.js deleted file mode 100755 index 573ef8a..0000000 --- a/js/entity/PathSymbolEntity.js +++ /dev/null @@ -1,20 +0,0 @@ -import Grammar from "../serialization/Grammar.js" -import IEntity from "./IEntity.js" - -export default class PathSymbolEntity extends IEntity { - - static grammar = Grammar.symbol.map(v => new this(v)) - - constructor(value = "") { - super() - this.value = value - } - - valueOf() { - return this.value - } - - toString() { - return this.value.toString() - } -} diff --git a/js/entity/PinEntity.js b/js/entity/PinEntity.js index d8dbe3f..c5b8f3e 100755 --- a/js/entity/PinEntity.js +++ b/js/entity/PinEntity.js @@ -32,7 +32,7 @@ import Vector2DEntity from "./Vector2DEntity.js" import Vector4DEntity from "./Vector4DEntity.js" import VectorEntity from "./VectorEntity.js" -/** @template {TerminalAttribute} T */ +/** @template {IEntity} T */ export default class PinEntity extends IEntity { static lookbehind = "INVTEXT" @@ -120,25 +120,23 @@ export default class PinEntity extends IEntity { constructor(values = {}) { super(values) - /** @type {ObjectEntity} */ this.objectEntity - /** @type {Number} */ this.pinIndex - /** @type {GuidEntity} */ this.PinId - /** @type {String} */ this.PinName - /** @type {LocalizedTextEntity | String} */ this.PinFriendlyName - /** @type {String} */ this.PinToolTip - /** @type {String} */ this.Direction - /** @type {PinTypeEntity} */ this.PinType - /** @type {PinReferenceEntity[]} */ this.LinkedTo - /** @type {T} */ this.DefaultValue - /** @type {String} */ this.AutogeneratedDefaultValue - /** @type {ObjectReferenceEntity} */ this.DefaultObject - /** @type {GuidEntity} */ this.PersistentGuid - /** @type {Boolean} */ this.bHidden - /** @type {Boolean} */ this.bNotConnectable - /** @type {Boolean} */ this.bDefaultValueIsReadOnly - /** @type {Boolean} */ this.bDefaultValueIsIgnored - /** @type {Boolean} */ this.bAdvancedView - /** @type {Boolean} */ this.bOrphanedPin + /** @type {InstanceType} */ this.PinId + /** @type {InstanceType} */ this.PinName + /** @type {InstanceType} */ this.PinFriendlyName + /** @type {InstanceType} */ this.PinToolTip + /** @type {InstanceType} */ this.Direction + /** @type {InstanceType} */ this.PinType + /** @type {InstanceType} */ this.LinkedTo + /** @type {InstanceType} */ this.DefaultValue + /** @type {InstanceType} */ this.AutogeneratedDefaultValue + /** @type {InstanceType} */ this.DefaultObject + /** @type {InstanceType} */ this.PersistentGuid + /** @type {InstanceType} */ this.bHidden + /** @type {InstanceType} */ this.bNotConnectable + /** @type {InstanceType} */ this.bDefaultValueIsReadOnly + /** @type {InstanceType} */ this.bDefaultValueIsIgnored + /** @type {InstanceType} */ this.bAdvancedView + /** @type {InstanceType} */ this.bOrphanedPin } /** @param {ObjectEntity} objectEntity */ @@ -227,7 +225,6 @@ export default class PinEntity extends IEntity { getDefaultValue(maybeCreate = false) { if (this.DefaultValue === undefined && maybeCreate) { - // @ts-expect-error this.DefaultValue = new (this.getEntityType(true))() } return this.DefaultValue @@ -271,10 +268,7 @@ export default class PinEntity extends IEntity { && pinReferenceEntity.pinGuid.valueOf() == targetPinEntity.PinId.valueOf() ) if (!linkFound) { - (this.LinkedTo ??= []).push(new PinReferenceEntity({ - objectName: targetObjectName, - pinGuid: targetPinEntity.PinId, - })) + (this.LinkedTo ??= []).push(new PinReferenceEntity(targetObjectName, targetPinEntity.PinId,)) return true } return false // Already linked diff --git a/js/entity/PinReferenceEntity.js b/js/entity/PinReferenceEntity.js index b3e9764..48ab076 100755 --- a/js/entity/PinReferenceEntity.js +++ b/js/entity/PinReferenceEntity.js @@ -1,18 +1,20 @@ import P from "parsernostrum" import GuidEntity from "./GuidEntity.js" import IEntity from "./IEntity.js" -import PathSymbolEntity from "./PathSymbolEntity.js" +import SymbolEntity from "./SymbolEntity.js" export default class PinReferenceEntity extends IEntity { static grammar = P.seq( - PathSymbolEntity.grammar, + SymbolEntity.grammar, P.whitespace, GuidEntity.grammar - ).map(([objectName, _1, pinGuid]) => new this(objectName, pinGuid)) + ) + .map(([objectName, _1, pinGuid]) => new this(objectName, pinGuid)) + .label("PinReferenceEntity") /** - * @param {PathSymbolEntity} objectName + * @param {SymbolEntity} objectName * @param {GuidEntity} pinGuid */ constructor(objectName = null, pinGuid = null) { @@ -20,4 +22,12 @@ export default class PinReferenceEntity extends IEntity { this.objectName = objectName this.pinGuid = pinGuid } + + toString( + insideString = false, + indentation = "", + printKey = this.Self().printKey, + ) { + return this.objectName.toString() + " " + this.pinGuid.toString() + } } diff --git a/js/entity/PinTypeEntity.js b/js/entity/PinTypeEntity.js index c94ed78..c4bcd60 100755 --- a/js/entity/PinTypeEntity.js +++ b/js/entity/PinTypeEntity.js @@ -3,8 +3,8 @@ import BooleanEntity from "./BooleanEntity.js" import FunctionReferenceEntity from "./FunctionReferenceEntity.js" import IEntity from "./IEntity.js" import ObjectReferenceEntity from "./ObjectReferenceEntity.js" -import PathSymbolEntity from "./PathSymbolEntity.js" import StringEntity from "./StringEntity.js" +import SymbolEntity from "./SymbolEntity.js" export default class PinTypeEntity extends IEntity { @@ -15,29 +15,29 @@ export default class PinTypeEntity extends IEntity { PinSubCategoryObject: ObjectReferenceEntity.withDefault(), PinSubCategoryMemberReference: FunctionReferenceEntity.withDefault(type => null), PinValueType: PinTypeEntity.withDefault(), - ContainerType: PathSymbolEntity, + ContainerType: SymbolEntity, bIsReference: BooleanEntity.withDefault(), bIsConst: BooleanEntity.withDefault(), bIsWeakPointer: BooleanEntity.withDefault(), bIsUObjectWrapper: BooleanEntity.withDefault(), bSerializeAsSinglePrecisionFloat: BooleanEntity.withDefault(), } - static grammar = Grammar.createEntityGrammar(this) + static grammar = Grammar.createEntityGrammar(this).label("PinTypeEntity") constructor(values = {}) { super(values) - /** @type {String} */ this.PinCategory - /** @type {String} */ this.PinSubCategory - /** @type {ObjectReferenceEntity} */ this.PinSubCategoryObject - /** @type {FunctionReferenceEntity} */ this.PinSubCategoryMemberReference - /** @type {PinTypeEntity} */ this.PinValueType - /** @type {PathSymbolEntity} */ this.ContainerType - /** @type {Boolean} */ this.bIsReference - /** @type {Boolean} */ this.bIsConst - /** @type {Boolean} */ this.bIsWeakPointer - /** @type {Boolean} */ this.bIsUObjectWrapper - /** @type {Boolean} */ this.bIsUObjectWrapper - /** @type {Boolean} */ this.bSerializeAsSinglePrecisionFloat + /** @type {InstanceType} */ this.PinCategory + /** @type {InstanceType} */ this.PinSubCategory + /** @type {InstanceType} */ this.PinSubCategoryObject + /** @type {InstanceType} */ this.PinSubCategoryMemberReference + /** @type {InstanceType} */ this.PinValueType + /** @type {InstanceType} */ this.ContainerType + /** @type {InstanceType} */ this.bIsReference + /** @type {InstanceType} */ this.bIsConst + /** @type {InstanceType} */ this.bIsWeakPointer + /** @type {InstanceType} */ this.bIsUObjectWrapper + /** @type {InstanceType} */ this.bIsUObjectWrapper + /** @type {InstanceType} */ this.bSerializeAsSinglePrecisionFloat } /** @param {PinTypeEntity} other */ diff --git a/js/entity/RBSerializationVector2DEntity.js b/js/entity/RBSerializationVector2DEntity.js index aa42f6d..ee3f7fb 100644 --- a/js/entity/RBSerializationVector2DEntity.js +++ b/js/entity/RBSerializationVector2DEntity.js @@ -1,17 +1,18 @@ import P from "parsernostrum" +import Grammar from "../serialization/Grammar.js" import Vector2DEntity from "./Vector2DEntity.js" export default class RBSerializationVector2DEntity extends Vector2DEntity { static grammar = P.alt( P.regArray(new RegExp( - /X\s*=\s*/.source + "(?" + P.number.getParser().parser.regexp.source + ")" + /X\s*=\s*/.source + "(?" + Grammar.numberRegexSource + ")" + "\\s+" - + /Y\s*=\s*/.source + "(?" + P.number.getParser().parser.regexp.source + ")" + + /Y\s*=\s*/.source + "(?" + Grammar.numberRegexSource + ")" )).map(({ groups: { x, y } }) => new this({ X: Number(x), Y: Number(y), })), Vector2DEntity.grammar - ) + ).label("RBSerializationVector2DEntity") } diff --git a/js/entity/RotatorEntity.js b/js/entity/RotatorEntity.js index 3a9b995..34b1942 100644 --- a/js/entity/RotatorEntity.js +++ b/js/entity/RotatorEntity.js @@ -10,13 +10,13 @@ export default class RotatorEntity extends IEntity { P: NumberEntity.withDefault(), Y: NumberEntity.withDefault(), } - static grammar = Grammar.createEntityGrammar(this, false) + static grammar = Grammar.createEntityGrammar(this).label("RotatorEntity") constructor(values) { super(values) - /** @type {NumberEntity} */ this.R - /** @type {NumberEntity} */ this.P - /** @type {NumberEntity} */ this.Y + /** @type {InstanceType} */ this.R + /** @type {InstanceType} */ this.P + /** @type {InstanceType} */ this.Y } getRoll() { diff --git a/js/entity/ScriptVariableEntity.js b/js/entity/ScriptVariableEntity.js index a6aeeec..4c839f9 100644 --- a/js/entity/ScriptVariableEntity.js +++ b/js/entity/ScriptVariableEntity.js @@ -10,11 +10,11 @@ export default class ScriptVariableEntity extends IEntity { ScriptVariable: ObjectReferenceEntity, OriginalChangeId: GuidEntity, } - static grammar = Grammar.createEntityGrammar(this) + static grammar = Grammar.createEntityGrammar(this).label("ScriptVariableEntity") constructor(values = {}) { super(values) - /** @type {ObjectReferenceEntity} */ this.ScriptVariable - /** @type {GuidEntity} */ this.OriginalChangeId + /** @type {InstanceType} */ this.ScriptVariable + /** @type {InstanceType} */ this.OriginalChangeId } } diff --git a/js/entity/SimpleSerializationRotatorEntity.js b/js/entity/SimpleSerializationRotatorEntity.js index 006482a..6eddd79 100644 --- a/js/entity/SimpleSerializationRotatorEntity.js +++ b/js/entity/SimpleSerializationRotatorEntity.js @@ -1,15 +1,16 @@ import P from "parsernostrum" +import Grammar from "../serialization/Grammar.js" import RotatorEntity from "./RotatorEntity.js" export default class SimpleSerializationRotatorEntity extends RotatorEntity { static grammar = P.alt( P.regArray(new RegExp( - `(${P.number.getParser().parser.regexp.source})` + `(${Grammar.numberRegexSource})` + String.raw`\s*,\s*` - + `(${P.number.getParser().parser.regexp.source})` + + `(${Grammar.numberRegexSource})` + String.raw`\s*,\s*` - + `(${P.number.getParser().parser.regexp.source})` + + `(${Grammar.numberRegexSource})` )).map(([_, p, y, r]) => new this({ R: Number(r), P: Number(p), diff --git a/js/entity/SimpleSerializationVector2DEntity.js b/js/entity/SimpleSerializationVector2DEntity.js index 0d4f333..00951ce 100644 --- a/js/entity/SimpleSerializationVector2DEntity.js +++ b/js/entity/SimpleSerializationVector2DEntity.js @@ -1,13 +1,14 @@ import P from "parsernostrum" +import Grammar from "../serialization/Grammar.js" import Vector2DEntity from "./Vector2DEntity.js" export default class SimpleSerializationVector2DEntity extends Vector2DEntity { static grammar = P.alt( P.regArray(new RegExp( - `(${P.number.getParser().parser.regexp.source})` + `(${Grammar.numberRegexSource})` + String.raw`\s*,\s*` - + `(${P.number.getParser().parser.regexp.source})` + + `(${Grammar.numberRegexSource})` )).map(([_, x, y]) => new this({ X: Number(x), Y: Number(y), diff --git a/js/entity/SimpleSerializationVector4DEntity.js b/js/entity/SimpleSerializationVector4DEntity.js index 79f721b..9921ba6 100644 --- a/js/entity/SimpleSerializationVector4DEntity.js +++ b/js/entity/SimpleSerializationVector4DEntity.js @@ -1,4 +1,5 @@ import P from "parsernostrum" +import Grammar from "../serialization/Grammar.js" import Vector4DEntity from "./Vector4DEntity.js" export default class SimpleSerializationVector4DEntity extends Vector4DEntity { @@ -6,16 +7,16 @@ export default class SimpleSerializationVector4DEntity extends Vector4DEntity { static grammar = this.createGrammar() static createGrammar() { - const number = P.number.getParser().parser.regexp.source + const number = Grammar.numberRegexSource return P.alt( P.regArray(new RegExp( - `(${P.number.getParser().parser.regexp.source})` + `(${Grammar.numberRegexSource})` + String.raw`\s*,\s*` - + `(${P.number.getParser().parser.regexp.source})` + + `(${Grammar.numberRegexSource})` + String.raw`\s*,\s*` - + `(${P.number.getParser().parser.regexp.source})` + + `(${Grammar.numberRegexSource})` + String.raw`\s*,\s*` - + `(${P.number.getParser().parser.regexp.source})` + + `(${Grammar.numberRegexSource})` )) .map(([_0, x, y, z, w]) => new this({ X: Number(x), diff --git a/js/entity/SimpleSerializationVectorEntity.js b/js/entity/SimpleSerializationVectorEntity.js index 8c737f5..b722b3c 100644 --- a/js/entity/SimpleSerializationVectorEntity.js +++ b/js/entity/SimpleSerializationVectorEntity.js @@ -1,15 +1,16 @@ import P from "parsernostrum" +import Grammar from "../serialization/Grammar.js" import VectorEntity from "./VectorEntity.js" export default class SimpleSerializationVectorEntity extends VectorEntity { static grammar = P.alt( P.regArray(new RegExp( - `(${P.number.getParser().parser.regexp.source})` + `(${Grammar.numberRegexSource})` + String.raw`\s*,\s*` - + `(${P.number.getParser().parser.regexp.source})` + + `(${Grammar.numberRegexSource})` + String.raw`\s*,\s*` - + `(${P.number.getParser().parser.regexp.source})` + + `(${Grammar.numberRegexSource})` )) .map(([_0, x, y, z]) => new this({ X: Number(x), diff --git a/js/entity/StringEntity.js b/js/entity/StringEntity.js index fbf7e54..3ccddf1 100755 --- a/js/entity/StringEntity.js +++ b/js/entity/StringEntity.js @@ -1,10 +1,12 @@ import P from "parsernostrum" -import IEntity from "./IEntity.js" import Utility from "../Utility.js" +import IPrintableEntity from "./IPrintableEntity.js" -export default class StringEntity extends IEntity { +export default class StringEntity extends IPrintableEntity { - static grammar = P.doubleQuotedString.map(insideString => Utility.unescapeString(insideString)) + static grammar = P.doubleQuotedString + .map(insideString => new this(Utility.unescapeString(insideString))) + .label("StringEntity") /** @param {String} value */ constructor(value = "") { @@ -12,11 +14,19 @@ export default class StringEntity extends IEntity { this.value = value } + print() { + return this.value + } + valueOf() { return this.value } - toString() { - return this.value.toString() + toString(insideString = false) { + let result = Utility.escapeString(this.value) + if (!insideString) { + result = `"${result}"` + } + return result } } diff --git a/js/entity/SymbolEntity.js b/js/entity/SymbolEntity.js index 7986b25..4df1d6d 100644 --- a/js/entity/SymbolEntity.js +++ b/js/entity/SymbolEntity.js @@ -3,7 +3,7 @@ import IEntity from "./IEntity.js" export default class SymbolEntity extends IEntity { - static grammar = Grammar.symbol.map(v => new this(v)) + static grammar = Grammar.symbol.map(v => new this(v)).label("SymbolEntity") /** @param {String} value */ constructor(value = "") { diff --git a/js/entity/UnknownKeysEntity.js b/js/entity/UnknownKeysEntity.js index 0545822..1902b57 100644 --- a/js/entity/UnknownKeysEntity.js +++ b/js/entity/UnknownKeysEntity.js @@ -4,7 +4,6 @@ import IEntity from "./IEntity.js" export default class UnknownKeysEntity extends IEntity { - static grammar = P.seq( // Lookbehind P.reg(new RegExp(`(${Grammar.Regex.Path.source}|${Grammar.Regex.Symbol.source}\\s*)?\\(\\s*`), 1), @@ -24,7 +23,7 @@ export default class UnknownKeysEntity extends IEntity { } attributes.forEach(attributeSetter => attributeSetter(values)) return new this(values) - }) + }).label("UnknownKeysEntity") constructor(values = {}) { super(values) diff --git a/js/entity/UnknownPinEntity.js b/js/entity/UnknownPinEntity.js index 105221f..68b9738 100755 --- a/js/entity/UnknownPinEntity.js +++ b/js/entity/UnknownPinEntity.js @@ -16,5 +16,5 @@ export default class UnknownPinEntity extends PinEntity { } attributes.forEach(attributeSetter => attributeSetter(values)) return new this(values) - }) + }).label("UnknownPinEntity") } diff --git a/js/entity/VariableReferenceEntity.js b/js/entity/VariableReferenceEntity.js index cb25bb5..7614079 100755 --- a/js/entity/VariableReferenceEntity.js +++ b/js/entity/VariableReferenceEntity.js @@ -13,12 +13,13 @@ export default class VariableReferenceEntity extends IEntity { MemberGuid: GuidEntity, bSelfContext: BooleanEntity, } - static grammar = Grammar.createEntityGrammar(this) + static grammar = Grammar.createEntityGrammar(this).label("VariableReferenceEntity") constructor(values) { super(values) - /** @type {String} */ this.MemberName - /** @type {GuidEntity} */ this.GuidEntity - /** @type {Boolean} */ this.bSelfContext + /** @type {InstanceType} */ this.MemberScope + /** @type {InstanceType} */ this.MemberName + /** @type {InstanceType} */ this.MemberGuid + /** @type {InstanceType} */ this.bSelfContext } } diff --git a/js/entity/Vector2DEntity.js b/js/entity/Vector2DEntity.js index 288a2e0..06568ed 100644 --- a/js/entity/Vector2DEntity.js +++ b/js/entity/Vector2DEntity.js @@ -9,12 +9,12 @@ export default class Vector2DEntity extends IEntity { X: NumberEntity.withDefault(), Y: NumberEntity.withDefault(), } - static grammar = Grammar.createEntityGrammar(this, false) + static grammar = Grammar.createEntityGrammar(this).label("Vector2DEntity") constructor(values) { super(values) - /** @type {NumberEntity} */ this.X - /** @type {NumberEntity} */ this.Y + /** @type {InstanceType} */ this.X + /** @type {InstanceType} */ this.Y } /** @returns {[Number, Number]} */ diff --git a/js/entity/Vector4DEntity.js b/js/entity/Vector4DEntity.js index 0cda8e0..84650c6 100644 --- a/js/entity/Vector4DEntity.js +++ b/js/entity/Vector4DEntity.js @@ -11,14 +11,14 @@ export default class Vector4DEntity extends IEntity { Z: NumberEntity.withDefault(), W: NumberEntity.withDefault(), } - static grammar = Grammar.createEntityGrammar(Vector4DEntity, false) + static grammar = Grammar.createEntityGrammar(this).label("Vector4DEntity") constructor(values) { super(values) - /** @type {NumberEntity} */ this.X - /** @type {NumberEntity} */ this.Y - /** @type {NumberEntity} */ this.Z - /** @type {NumberEntity} */ this.W + /** @type {InstanceType} */ this.X + /** @type {InstanceType} */ this.Y + /** @type {InstanceType} */ this.Z + /** @type {InstanceType} */ this.W } /** @returns {[Number, Number, Number, Number]} */ diff --git a/js/entity/VectorEntity.js b/js/entity/VectorEntity.js index e01a9b2..91fb7d7 100644 --- a/js/entity/VectorEntity.js +++ b/js/entity/VectorEntity.js @@ -10,13 +10,13 @@ export default class VectorEntity extends IEntity { Y: NumberEntity.withDefault(), Z: NumberEntity.withDefault(), } - static grammar = Grammar.createEntityGrammar(VectorEntity, false) + static grammar = Grammar.createEntityGrammar(this).label("VectorEntity") constructor(values) { super(values) - /** @type {NumberEntity} */ this.X - /** @type {NumberEntity} */ this.Y - /** @type {NumberEntity} */ this.Z + /** @type {InstanceType} */ this.X + /** @type {InstanceType} */ this.Y + /** @type {InstanceType} */ this.Z } /** @returns {[Number, Number, Number]} */ diff --git a/js/serialization/Grammar.js b/js/serialization/Grammar.js index 1485d95..a12028f 100755 --- a/js/serialization/Grammar.js +++ b/js/serialization/Grammar.js @@ -8,6 +8,10 @@ import Serializable from "./Serializable.js" export default class Grammar { + /** @type {String} */ + // @ts-expect-error + static numberRegexSource = Parsernostrum.number.getParser().parser.regexp.source + static separatedBy = (source, separator, min = 1) => new RegExp( source + "(?:" + separator + source + ")" @@ -188,46 +192,32 @@ export default class Grammar { /** * @template {IEntity} T - * @param {(new (...args: any) => T) & EntityConstructor} entityType - * @param {Boolean | Number} acceptUnknownKeys Number to specify the limit or true, to let it be a reasonable value + * @param {new (...args: any) => T} entityType + * @return {Parsernostrum} */ - static createEntityGrammar(entityType, acceptUnknownKeys = true, entriesSeparator = this.commaSeparation) { - const lookbehind = entityType.attributes.lookbehind.default + static createEntityGrammar(entityType, entriesSeparator = this.commaSeparation) { + const lookbehind = entityType.lookbehind instanceof Array ? entityType.lookbehind.join("|") : entityType.lookbehind return Parsernostrum.seq( - Parsernostrum.reg( - lookbehind instanceof Union - ? new RegExp(`(${lookbehind.values.reduce((acc, cur) => acc + "|" + cur)})\\s*\\(\\s*`) - : lookbehind.constructor == String && lookbehind.length > 0 - ? new RegExp(`(${lookbehind})\\s*\\(\\s*`) - : /()\(\s*/, - 1 - ), + Parsernostrum.reg(new RegExp(String.raw`(${lookbehind})\s*\(\s*`), 1), this.createAttributeGrammar(entityType).sepBy(entriesSeparator), - Parsernostrum.reg(/\s*(?:,\s*)?\)/), // trailing comma + Parsernostrum.reg(/\s*(,\s*)?\)/, 1), // optional trailing comma ) - .map(([lookbehind, attributes, _2]) => { + .map(([lookbehind, attributes, trailing]) => { let values = {} - attributes.forEach(attributeSetter => attributeSetter(values)) if (lookbehind.length) { - values.lookbehind = lookbehind + values["#lookbehind"] = lookbehind } + attributes.forEach(attributeSetter => attributeSetter(values)) + values["#trailing"] = trailing !== undefined return values }) // Decide if we accept the entity or not. It is accepted if it doesn't have too many unexpected keys .chain(values => { - let totalKeys = Object.keys(values) - let missingKey - // Check missing values - if ( - Object.keys(/** @type {AttributeDeclarations} */(entityType.attributes)) - .filter(key => entityType.attributes[key].expected) - .find(key => !totalKeys.includes(key) && (missingKey = key)) - ) { - return Parsernostrum.failure() + if (entityType.lookbehind instanceof Array || entityType.lookbehind !== lookbehind) { + entityType = entityType.withLookbehind(lookbehind) } - const unknownKeys = Object.keys(values).filter(key => !(key in entityType.attributes)).length - if (!acceptUnknownKeys && unknownKeys > 0) { - return Parsernostrum.failure() + if (entityType.trailing !== values["#trailing"]) { + entityType = entityType.flagTrailing(values["#trailing"]) } return Parsernostrum.success().map(() => new entityType(values)) }) diff --git a/js/serialization/initializeSerializerFactory.js b/js/serialization/initializeSerializerFactory.js index 323fbd0..90141fc 100755 --- a/js/serialization/initializeSerializerFactory.js +++ b/js/serialization/initializeSerializerFactory.js @@ -19,7 +19,6 @@ import MacroGraphReferenceEntity from "../entity/MacroGraphReferenceEntity.js" import MirroredEntity from "../entity/MirroredEntity.js" import ObjectEntity from "../entity/ObjectEntity.js" import ObjectReferenceEntity from "../entity/ObjectReferenceEntity.js" -import PathSymbolEntity from "../entity/PathSymbolEntity.js" import PinEntity from "../entity/PinEntity.js" import PinReferenceEntity from "../entity/PinReferenceEntity.js" import PinTypeEntity from "../entity/PinTypeEntity.js" @@ -49,34 +48,34 @@ import StringEntity from "../entity/StringEntity.js" import ArrayEntity from "../entity/ArrayEntity.js" import AlternativesEntity from "../entity/AlternativesEntity.js" -Grammar.unknownValue = - Parsernostrum.alt( - // Remember to keep the order, otherwise parsing might fail - BooleanEntity.grammar, - GuidEntity.grammar, - Parsernostrum.str("None").map(() => ObjectReferenceEntity.createNoneInstance()), - Grammar.null, - NumberEntity.grammar, - ObjectReferenceEntity.fullReferenceGrammar, - StringEntity.grammar, - LocalizedTextEntity.grammar, - InvariantTextEntity.grammar, - FormatTextEntity.grammar, - PinReferenceEntity.grammar, - Vector4DEntity.grammar, - VectorEntity.grammar, - RotatorEntity.grammar, - LinearColorEntity.grammar, - Vector2DEntity.grammar, - UnknownKeysEntity.grammar, - SymbolEntity.grammar, - ArrayEntity.of(PinReferenceEntity).grammar, - ArrayEntity.of(AlternativesEntity.accepting(NumberEntity, StringEntity, SymbolEntity)).grammar, - Parsernostrum.lazy(() => ArrayEntity.createGrammar(Grammar.unknownValue)), - ) - export default function initializeSerializerFactory() { + Grammar.unknownValue = + Parsernostrum.alt( + // Remember to keep the order, otherwise parsing might fail + BooleanEntity.grammar, + GuidEntity.grammar, + Parsernostrum.str("None").map(() => ObjectReferenceEntity.createNoneInstance()), + Grammar.null, + NumberEntity.grammar, + ObjectReferenceEntity.fullReferenceGrammar, + StringEntity.grammar, + LocalizedTextEntity.grammar, + InvariantTextEntity.grammar, + FormatTextEntity.grammar, + PinReferenceEntity.grammar, + Vector4DEntity.grammar, + VectorEntity.grammar, + RotatorEntity.grammar, + LinearColorEntity.grammar, + Vector2DEntity.grammar, + UnknownKeysEntity.grammar, + SymbolEntity.grammar, + ArrayEntity.of(PinReferenceEntity).grammar, + ArrayEntity.of(AlternativesEntity.accepting(NumberEntity, StringEntity, SymbolEntity)).grammar, + Parsernostrum.lazy(() => ArrayEntity.createGrammar(Grammar.unknownValue)), + ) + SerializerFactory.registerSerializer( null, new CustomSerializer( @@ -122,26 +121,6 @@ export default function initializeSerializerFactory() { ) ) - SerializerFactory.registerSerializer( - ByteEntity, - new ToStringSerializer(ByteEntity) - ) - - SerializerFactory.registerSerializer( - ColorChannelEntity, - new ToStringSerializer(ColorChannelEntity) - ) - - SerializerFactory.registerSerializer( - EnumDisplayValueEntity, - new ToStringSerializer(EnumDisplayValueEntity) - ) - - SerializerFactory.registerSerializer( - EnumEntity, - new ToStringSerializer(EnumEntity) - ) - SerializerFactory.registerSerializer( FormatTextEntity, new CustomSerializer( @@ -156,94 +135,11 @@ export default function initializeSerializerFactory() { FormatTextEntity) ) - SerializerFactory.registerSerializer( - FunctionReferenceEntity, - new Serializer(FunctionReferenceEntity, Serializer.bracketsWrapped) - ) - - SerializerFactory.registerSerializer( - GuidEntity, - new ToStringSerializer(GuidEntity) - ) - - SerializerFactory.registerSerializer( - IdentifierEntity, - new ToStringSerializer(IdentifierEntity) - ) - - SerializerFactory.registerSerializer( - Integer64Entity, - new ToStringSerializer(Integer64Entity) - ) - - SerializerFactory.registerSerializer( - IntegerEntity, - new ToStringSerializer(IntegerEntity) - ) - - SerializerFactory.registerSerializer( - InvariantTextEntity, - new Serializer(InvariantTextEntity, (entity, v) => `${entity.getLookbehind()}(${v})`, ", ", false, "", () => "") - ) - - SerializerFactory.registerSerializer( - KeyBindingEntity, - new Serializer(KeyBindingEntity, Serializer.bracketsWrapped) - ) - - SerializerFactory.registerSerializer( - LinearColorEntity, - new Serializer(LinearColorEntity, Serializer.bracketsWrapped) - ) - - SerializerFactory.registerSerializer( - LocalizedTextEntity, - new Serializer(LocalizedTextEntity, (entity, v) => `${entity.getLookbehind()}(${v})`, ", ", false, "", () => "") - ) - - SerializerFactory.registerSerializer( - MacroGraphReferenceEntity, - new Serializer(MacroGraphReferenceEntity, Serializer.bracketsWrapped) - ) - - SerializerFactory.registeOrSerializer( - MirroredEntity, - new CustomSerializer( - (v, insideString) => SerializerFactory.getSerializer(v.getTargetType()).write(v.get(), insideString), - MirroredEntity - ) - ) - - SerializerFactory.registerSerializer( - Number, - new ToStringSerializer(Number) - ) - - SerializerFactory.registerSerializer( - ObjectEntity, - new ObjectSerializer() - ) - - SerializerFactory.registerSerializer( - ObjectReferenceEntity, - new ToStringSerializer(ObjectReferenceEntity, false) - ) - - SerializerFactory.registerSerializer( - PathSymbolEntity, - new ToStringSerializer(PathSymbolEntity) - ) - SerializerFactory.registerSerializer( PinEntity, new Serializer(PinEntity, (entity, v) => `${entity.getLookbehind()} (${v})`, ",", true) ) - SerializerFactory.registerSerializer( - PinReferenceEntity, - new Serializer(PinReferenceEntity, undefined, " ", false, "", () => "") - ) - SerializerFactory.registerSerializer( PinTypeEntity, new Serializer(PinTypeEntity) diff --git a/tests/parsing.spec.js b/tests/parsing.spec.js index a92f386..c5200c9 100644 --- a/tests/parsing.spec.js +++ b/tests/parsing.spec.js @@ -1,16 +1,19 @@ import { expect, test } from "@playwright/test" import Utility from "../js/Utility.js" +import ArrayEntity from "../js/entity/ArrayEntity.js" import FormatTextEntity from "../js/entity/FormatTextEntity.js" import GuidEntity from "../js/entity/GuidEntity.js" import IntegerEntity from "../js/entity/IntegerEntity.js" import KeyBindingEntity from "../js/entity/KeyBindingEntity.js" import LinearColorEntity from "../js/entity/LinearColorEntity.js" +import NumberEntity from "../js/entity/NumberEntity.js" import ObjectReferenceEntity from "../js/entity/ObjectReferenceEntity.js" import PinEntity from "../js/entity/PinEntity.js" import RotatorEntity from "../js/entity/RotatorEntity.js" import SimpleSerializationRotatorEntity from "../js/entity/SimpleSerializationRotatorEntity.js" import SimpleSerializationVector2DEntity from "../js/entity/SimpleSerializationVector2DEntity.js" import SimpleSerializationVectorEntity from "../js/entity/SimpleSerializationVectorEntity.js" +import StringEntity from "../js/entity/StringEntity.js" import SymbolEntity from "../js/entity/SymbolEntity.js" import UnknownKeysEntity from "../js/entity/UnknownKeysEntity.js" import Vector2DEntity from "../js/entity/Vector2DEntity.js" @@ -23,30 +26,48 @@ test.beforeAll(() => initializeSerializerFactory()) test.describe.configure({ mode: "parallel" }) -test("Array", () => { - const serializer = SerializerFactory.getSerializer(Array) +test("ArrayEntity", () => { + let grammar = ArrayEntity.grammar - expect(serializer.read("()")).toStrictEqual([]) - expect(serializer.read("( )")).toStrictEqual([]) - expect(serializer.read("(1, 2, 3, 4, 5, 6)")).toStrictEqual([1, 2, 3, 4, 5, 6]) - expect(serializer.read(`( + expect(grammar.parse("()")).toEqual(new ArrayEntity([])) + expect(grammar.parse("( )")).toEqual(new ArrayEntity([])) + expect(grammar.parse("(1, 2, 3, 4, 5, 6)")).toEqual(new ArrayEntity([ + new NumberEntity(1), + new NumberEntity(2), + new NumberEntity(3), + new NumberEntity(4), + new NumberEntity(5), + new NumberEntity(6), + ])) + expect(ArrayEntity.of(NumberEntity).grammar.parse("(2,4,6,8)")).toEqual(new ArrayEntity([ + new NumberEntity(2), + new NumberEntity(4), + new NumberEntity(6), + new NumberEntity(8), + ])) + expect(ArrayEntity.of(IntegerEntity).grammar.parse("(-0, -1, -2)")).toEqual(new ArrayEntity([ + new IntegerEntity(0), + new IntegerEntity(-1), + new IntegerEntity(-2), + ])) + expect(() => ArrayEntity.of(IntegerEntity).grammar.parse("(-1, -2.1, -3)")).toThrowError() + expect(grammar.parse(`( "alpha", "beta", 123, 3BEF2168446CAA32D5B54289FAB2F0BA, Some(a=1, b="2") - )`)).toStrictEqual([ - "alpha", - "beta", - 123, + )`)).toStrictEqual(new ArrayEntity([ + new StringEntity("alpha"), + new StringEntity("beta"), + new NumberEntity(123), new GuidEntity("3BEF2168446CAA32D5B54289FAB2F0BA"), - new UnknownKeysEntity({ - lookbehind: "Some", + new (UnknownKeysEntity.withLookbehind("Some"))({ a: 1, b: "2", }) - ]) - expect(serializer.read(`( + ])) + expect(grammar.parse(`( A(first = (9,8,7,6,5), second = 00000000000000000000000000000000), B(key="hello"), )`)).toStrictEqual([ @@ -62,9 +83,9 @@ test("Array", () => { ]) // Nested - expect(serializer.read("((1, 2), (3, 4))")).toStrictEqual([[1, 2], [3, 4]]) - expect(serializer.read('(((1, 2), (3, 4)), 5)')).toStrictEqual([[[1, 2], [3, 4]], 5]) - expect(serializer.read(`( + expect(grammar.parse("((1, 2), (3, 4))")).toStrictEqual([[1, 2], [3, 4]]) + expect(grammar.parse('(((1, 2), (3, 4)), 5)')).toStrictEqual([[[1, 2], [3, 4]], 5]) + expect(grammar.parse(`( One(a = (1,(2,(3,(4)))), b = ()), )`)).toStrictEqual([ new UnknownKeysEntity({ diff --git a/tests/resources/EntityF.js b/tests/resources/EntityF.js index 9d19ef5..f6ff1ba 100644 --- a/tests/resources/EntityF.js +++ b/tests/resources/EntityF.js @@ -1,25 +1,17 @@ -import AttributeInfo from "../../js/entity/AttributeInfo.js" import IEntity from "../../js/entity/IEntity.js" -import Union from "../../js/entity/Union.js" +import NumberEntity from "../../js/entity/NumberEntity.js" +import StringEntity from "../../js/entity/StringEntity.js" import Grammar from "../../js/serialization/Grammar.js" export default class EntityF extends IEntity { + static lookbehind = ["Foo", "Bar"] static attributes = { ...super.attributes, - arg1: AttributeInfo.createType(Number), - arg2: AttributeInfo.createType(String), - lookbehind: new AttributeInfo({ - ...super.attributes.lookbehind, - default: new Union("Foo", "Bar"), - }) - } - - static grammar = this.createGrammar() - - static createGrammar() { - return Grammar.createEntityGrammar(this, false) + arg1: NumberEntity, + arg2: StringEntity, } + static grammar = Grammar.createEntityGrammar(this) constructor(values = {}) { super(values) diff --git a/types.js b/types.js index a729bad..ec9f374 100644 --- a/types.js +++ b/types.js @@ -96,6 +96,19 @@ * (value: T): typeof value.constructor, * }} TypeGetter */ +/** + * @template T + * @typedef {T extends [infer A extends EntityConstructor] ? InstanceType + * : T extends [infer A extends EntityConstructor, ...infer B] ? InstanceType | UnionFromArray + * : never + * } UnionFromArray + */ +/** + * @template {EntityConstructor} T + * @typedef {T extends AlternativesEntityConstructor & { alternatives: infer R } ? UnionFromArray + * : InstanceType + * } ExtractType + */ /** * @typedef {typeof import("./js/Blueprint.js").default} BlueprintConstructor * @typedef {typeof import("./js/element/LinkElement.js").default} LinkElementConstructor @@ -103,6 +116,7 @@ * @typedef {typeof import("./js/element/PinElement.js").default} PinElementConstructor * @typedef {typeof import("./js/element/WindowElement.js").default} WindowElementConstructor * @typedef {typeof import("./js/entity/IEntity.js").default} EntityConstructor + * @typedef {typeof import("./js/entity/AlternativesEntity.js").default} AlternativesEntityConstructor * @typedef {typeof import("./js/entity/ObjectEntity.js").default} ObjectEntityConstructor */ /** @@ -207,20 +221,11 @@ * @typedef {import("lit").CSSResult} CSSResult * @typedef {import("lit").PropertyValues} PropertyValues * @typedef {import("lit").TemplateResult} TemplateResult - * @typedef {import("parsernostrum/src/parser/Parser.js").default} Parser */ /** * @template {AttributeConstructor} T * @typedef {import("./js/serialization/Serializer.js").default} Serializer */ -/** - * @template {Attribute} T - * @typedef {import("./js/entity/MirroredEntity.js").default} MirroredEntity - */ -/** - * @template {Attribute} T - * @typedef {typeof import("./js/entity/MirroredEntity.js").default} MirroredEntityConstructor - */ /** * @template T * @typedef {{ @@ -228,3 +233,7 @@ * evaluate(pageFunction: (node: T) => R, options?: { timeout?: number }): Promise * } & import("@playwright/test").Locator} Locator */ +/** + * @template T + * @typedef {import("parsernostrum").ProducerParser} Parser + */