var re = Object.defineProperty; var ae = (e, t, s) => t in e ? re(e, t, { enumerable: !0, configurable: !0, writable: !0, value: s }) : e[t] = s; var b = (e, t, s) => ae(e, typeof t != "symbol" ? t + "" : t, s); import { g as ne, s as le } from "./chunk-RZ5BOZE2-C6qYYKQn.js"; import { _ as p, l as v, S as oe, d as A, e as j, t as ce, g as he, s as ue, b as de, c as fe, n as pe, o as Se, z as ye, u as ge } from "./mermaid.core-Cmyps_S7.js"; var bt = function() { var e = /* @__PURE__ */ p(function(P, l, h, a) { for (h = h || {}, a = P.length; a--; h[P[a]] = l) ; return h; }, "o"), t = [1, 2], s = [1, 3], n = [1, 4], o = [2, 4], c = [1, 9], r = [1, 11], d = [1, 16], f = [1, 17], g = [1, 18], E = [1, 19], m = [1, 32], I = [1, 20], G = [1, 21], R = [1, 22], S = [1, 23], L = [1, 24], O = [1, 26], Y = [1, 27], F = [1, 28], w = [1, 29], $ = [1, 30], et = [1, 31], st = [1, 34], it = [1, 35], rt = [1, 36], at = [1, 37], X = [1, 33], y = [1, 4, 5, 16, 17, 19, 21, 22, 24, 25, 26, 27, 28, 29, 33, 35, 37, 38, 42, 45, 48, 49, 50, 51, 54], nt = [1, 4, 5, 14, 15, 16, 17, 19, 21, 22, 24, 25, 26, 27, 28, 29, 33, 35, 37, 38, 42, 45, 48, 49, 50, 51, 54], At = [4, 5, 16, 17, 19, 21, 22, 24, 25, 26, 27, 28, 29, 33, 35, 37, 38, 42, 45, 48, 49, 50, 51, 54], St = { trace: /* @__PURE__ */ p(function() { }, "trace"), yy: {}, symbols_: { error: 2, start: 3, SPACE: 4, NL: 5, SD: 6, document: 7, line: 8, statement: 9, classDefStatement: 10, styleStatement: 11, cssClassStatement: 12, idStatement: 13, DESCR: 14, "-->": 15, HIDE_EMPTY: 16, scale: 17, WIDTH: 18, COMPOSIT_STATE: 19, STRUCT_START: 20, STRUCT_STOP: 21, STATE_DESCR: 22, AS: 23, ID: 24, FORK: 25, JOIN: 26, CHOICE: 27, CONCURRENT: 28, note: 29, notePosition: 30, NOTE_TEXT: 31, direction: 32, acc_title: 33, acc_title_value: 34, acc_descr: 35, acc_descr_value: 36, acc_descr_multiline_value: 37, classDef: 38, CLASSDEF_ID: 39, CLASSDEF_STYLEOPTS: 40, DEFAULT: 41, style: 42, STYLE_IDS: 43, STYLEDEF_STYLEOPTS: 44, class: 45, CLASSENTITY_IDS: 46, STYLECLASS: 47, direction_tb: 48, direction_bt: 49, direction_rl: 50, direction_lr: 51, eol: 52, ";": 53, EDGE_STATE: 54, STYLE_SEPARATOR: 55, left_of: 56, right_of: 57, $accept: 0, $end: 1 }, terminals_: { 2: "error", 4: "SPACE", 5: "NL", 6: "SD", 14: "DESCR", 15: "-->", 16: "HIDE_EMPTY", 17: "scale", 18: "WIDTH", 19: "COMPOSIT_STATE", 20: "STRUCT_START", 21: "STRUCT_STOP", 22: "STATE_DESCR", 23: "AS", 24: "ID", 25: "FORK", 26: "JOIN", 27: "CHOICE", 28: "CONCURRENT", 29: "note", 31: "NOTE_TEXT", 33: "acc_title", 34: "acc_title_value", 35: "acc_descr", 36: "acc_descr_value", 37: "acc_descr_multiline_value", 38: "classDef", 39: "CLASSDEF_ID", 40: "CLASSDEF_STYLEOPTS", 41: "DEFAULT", 42: "style", 43: "STYLE_IDS", 44: "STYLEDEF_STYLEOPTS", 45: "class", 46: "CLASSENTITY_IDS", 47: "STYLECLASS", 48: "direction_tb", 49: "direction_bt", 50: "direction_rl", 51: "direction_lr", 53: ";", 54: "EDGE_STATE", 55: "STYLE_SEPARATOR", 56: "left_of", 57: "right_of" }, productions_: [0, [3, 2], [3, 2], [3, 2], [7, 0], [7, 2], [8, 2], [8, 1], [8, 1], [9, 1], [9, 1], [9, 1], [9, 1], [9, 2], [9, 3], [9, 4], [9, 1], [9, 2], [9, 1], [9, 4], [9, 3], [9, 6], [9, 1], [9, 1], [9, 1], [9, 1], [9, 4], [9, 4], [9, 1], [9, 2], [9, 2], [9, 1], [10, 3], [10, 3], [11, 3], [12, 3], [32, 1], [32, 1], [32, 1], [32, 1], [52, 1], [52, 1], [13, 1], [13, 1], [13, 3], [13, 3], [30, 1], [30, 1]], performAction: /* @__PURE__ */ p(function(l, h, a, T, _, i, K) { var u = i.length - 1; switch (_) { case 3: return T.setRootDoc(i[u]), i[u]; case 4: this.$ = []; break; case 5: i[u] != "nl" && (i[u - 1].push(i[u]), this.$ = i[u - 1]); break; case 6: case 7: this.$ = i[u]; break; case 8: this.$ = "nl"; break; case 12: this.$ = i[u]; break; case 13: const J = i[u - 1]; J.description = T.trimColon(i[u]), this.$ = J; break; case 14: this.$ = { stmt: "relation", state1: i[u - 2], state2: i[u] }; break; case 15: const yt = T.trimColon(i[u]); this.$ = { stmt: "relation", state1: i[u - 3], state2: i[u - 1], description: yt }; break; case 19: this.$ = { stmt: "state", id: i[u - 3], type: "default", description: "", doc: i[u - 1] }; break; case 20: var V = i[u], H = i[u - 2].trim(); if (i[u].match(":")) { var ot = i[u].split(":"); V = ot[0], H = [H, ot[1]]; } this.$ = { stmt: "state", id: V, type: "default", description: H }; break; case 21: this.$ = { stmt: "state", id: i[u - 3], type: "default", description: i[u - 5], doc: i[u - 1] }; break; case 22: this.$ = { stmt: "state", id: i[u], type: "fork" }; break; case 23: this.$ = { stmt: "state", id: i[u], type: "join" }; break; case 24: this.$ = { stmt: "state", id: i[u], type: "choice" }; break; case 25: this.$ = { stmt: "state", id: T.getDividerId(), type: "divider" }; break; case 26: this.$ = { stmt: "state", id: i[u - 1].trim(), note: { position: i[u - 2].trim(), text: i[u].trim() } }; break; case 29: this.$ = i[u].trim(), T.setAccTitle(this.$); break; case 30: case 31: this.$ = i[u].trim(), T.setAccDescription(this.$); break; case 32: case 33: this.$ = { stmt: "classDef", id: i[u - 1].trim(), classes: i[u].trim() }; break; case 34: this.$ = { stmt: "style", id: i[u - 1].trim(), styleClass: i[u].trim() }; break; case 35: this.$ = { stmt: "applyClass", id: i[u - 1].trim(), styleClass: i[u].trim() }; break; case 36: T.setDirection("TB"), this.$ = { stmt: "dir", value: "TB" }; break; case 37: T.setDirection("BT"), this.$ = { stmt: "dir", value: "BT" }; break; case 38: T.setDirection("RL"), this.$ = { stmt: "dir", value: "RL" }; break; case 39: T.setDirection("LR"), this.$ = { stmt: "dir", value: "LR" }; break; case 42: case 43: this.$ = { stmt: "state", id: i[u].trim(), type: "default", description: "" }; break; case 44: this.$ = { stmt: "state", id: i[u - 2].trim(), classes: [i[u].trim()], type: "default", description: "" }; break; case 45: this.$ = { stmt: "state", id: i[u - 2].trim(), classes: [i[u].trim()], type: "default", description: "" }; break; } }, "anonymous"), table: [{ 3: 1, 4: t, 5: s, 6: n }, { 1: [3] }, { 3: 5, 4: t, 5: s, 6: n }, { 3: 6, 4: t, 5: s, 6: n }, e([1, 4, 5, 16, 17, 19, 22, 24, 25, 26, 27, 28, 29, 33, 35, 37, 38, 42, 45, 48, 49, 50, 51, 54], o, { 7: 7 }), { 1: [2, 1] }, { 1: [2, 2] }, { 1: [2, 3], 4: c, 5: r, 8: 8, 9: 10, 10: 12, 11: 13, 12: 14, 13: 15, 16: d, 17: f, 19: g, 22: E, 24: m, 25: I, 26: G, 27: R, 28: S, 29: L, 32: 25, 33: O, 35: Y, 37: F, 38: w, 42: $, 45: et, 48: st, 49: it, 50: rt, 51: at, 54: X }, e(y, [2, 5]), { 9: 38, 10: 12, 11: 13, 12: 14, 13: 15, 16: d, 17: f, 19: g, 22: E, 24: m, 25: I, 26: G, 27: R, 28: S, 29: L, 32: 25, 33: O, 35: Y, 37: F, 38: w, 42: $, 45: et, 48: st, 49: it, 50: rt, 51: at, 54: X }, e(y, [2, 7]), e(y, [2, 8]), e(y, [2, 9]), e(y, [2, 10]), e(y, [2, 11]), e(y, [2, 12], { 14: [1, 39], 15: [1, 40] }), e(y, [2, 16]), { 18: [1, 41] }, e(y, [2, 18], { 20: [1, 42] }), { 23: [1, 43] }, e(y, [2, 22]), e(y, [2, 23]), e(y, [2, 24]), e(y, [2, 25]), { 30: 44, 31: [1, 45], 56: [1, 46], 57: [1, 47] }, e(y, [2, 28]), { 34: [1, 48] }, { 36: [1, 49] }, e(y, [2, 31]), { 39: [1, 50], 41: [1, 51] }, { 43: [1, 52] }, { 46: [1, 53] }, e(nt, [2, 42], { 55: [1, 54] }), e(nt, [2, 43], { 55: [1, 55] }), e(y, [2, 36]), e(y, [2, 37]), e(y, [2, 38]), e(y, [2, 39]), e(y, [2, 6]), e(y, [2, 13]), { 13: 56, 24: m, 54: X }, e(y, [2, 17]), e(At, o, { 7: 57 }), { 24: [1, 58] }, { 24: [1, 59] }, { 23: [1, 60] }, { 24: [2, 46] }, { 24: [2, 47] }, e(y, [2, 29]), e(y, [2, 30]), { 40: [1, 61] }, { 40: [1, 62] }, { 44: [1, 63] }, { 47: [1, 64] }, { 24: [1, 65] }, { 24: [1, 66] }, e(y, [2, 14], { 14: [1, 67] }), { 4: c, 5: r, 8: 8, 9: 10, 10: 12, 11: 13, 12: 14, 13: 15, 16: d, 17: f, 19: g, 21: [1, 68], 22: E, 24: m, 25: I, 26: G, 27: R, 28: S, 29: L, 32: 25, 33: O, 35: Y, 37: F, 38: w, 42: $, 45: et, 48: st, 49: it, 50: rt, 51: at, 54: X }, e(y, [2, 20], { 20: [1, 69] }), { 31: [1, 70] }, { 24: [1, 71] }, e(y, [2, 32]), e(y, [2, 33]), e(y, [2, 34]), e(y, [2, 35]), e(nt, [2, 44]), e(nt, [2, 45]), e(y, [2, 15]), e(y, [2, 19]), e(At, o, { 7: 72 }), e(y, [2, 26]), e(y, [2, 27]), { 4: c, 5: r, 8: 8, 9: 10, 10: 12, 11: 13, 12: 14, 13: 15, 16: d, 17: f, 19: g, 21: [1, 73], 22: E, 24: m, 25: I, 26: G, 27: R, 28: S, 29: L, 32: 25, 33: O, 35: Y, 37: F, 38: w, 42: $, 45: et, 48: st, 49: it, 50: rt, 51: at, 54: X }, e(y, [2, 21])], defaultActions: { 5: [2, 1], 6: [2, 2], 46: [2, 46], 47: [2, 47] }, parseError: /* @__PURE__ */ p(function(l, h) { if (h.recoverable) this.trace(l); else { var a = new Error(l); throw a.hash = h, a; } }, "parseError"), parse: /* @__PURE__ */ p(function(l) { var h = this, a = [0], T = [], _ = [null], i = [], K = this.table, u = "", V = 0, H = 0, ot = 2, J = 1, yt = i.slice.call(arguments, 1), D = Object.create(this.lexer), M = { yy: {} }; for (var gt in this.yy) Object.prototype.hasOwnProperty.call(this.yy, gt) && (M.yy[gt] = this.yy[gt]); D.setInput(l, M.yy), M.yy.lexer = D, M.yy.parser = this, typeof D.yylloc > "u" && (D.yylloc = {}); var Tt = D.yylloc; i.push(Tt); var se = D.options && D.options.ranges; typeof M.yy.parseError == "function" ? this.parseError = M.yy.parseError : this.parseError = Object.getPrototypeOf(this).parseError; function ie(C) { a.length = a.length - 2 * C, _.length = _.length - C, i.length = i.length - C; } p(ie, "popStack"); function Lt() { var C; return C = T.pop() || D.lex() || J, typeof C != "number" && (C instanceof Array && (T = C, C = T.pop()), C = h.symbols_[C] || C), C; } p(Lt, "lex"); for (var k, U, x, _t, W = {}, ct, N, It, ht; ; ) { if (U = a[a.length - 1], this.defaultActions[U] ? x = this.defaultActions[U] : ((k === null || typeof k > "u") && (k = Lt()), x = K[U] && K[U][k]), typeof x > "u" || !x.length || !x[0]) { var Et = ""; ht = []; for (ct in K[U]) this.terminals_[ct] && ct > ot && ht.push("'" + this.terminals_[ct] + "'"); D.showPosition ? Et = "Parse error on line " + (V + 1) + `: ` + D.showPosition() + ` Expecting ` + ht.join(", ") + ", got '" + (this.terminals_[k] || k) + "'" : Et = "Parse error on line " + (V + 1) + ": Unexpected " + (k == J ? "end of input" : "'" + (this.terminals_[k] || k) + "'"), this.parseError(Et, { text: D.match, token: this.terminals_[k] || k, line: D.yylineno, loc: Tt, expected: ht }); } if (x[0] instanceof Array && x.length > 1) throw new Error("Parse Error: multiple actions possible at state: " + U + ", token: " + k); switch (x[0]) { case 1: a.push(k), _.push(D.yytext), i.push(D.yylloc), a.push(x[1]), k = null, H = D.yyleng, u = D.yytext, V = D.yylineno, Tt = D.yylloc; break; case 2: if (N = this.productions_[x[1]][1], W.$ = _[_.length - N], W._$ = { first_line: i[i.length - (N || 1)].first_line, last_line: i[i.length - 1].last_line, first_column: i[i.length - (N || 1)].first_column, last_column: i[i.length - 1].last_column }, se && (W._$.range = [ i[i.length - (N || 1)].range[0], i[i.length - 1].range[1] ]), _t = this.performAction.apply(W, [ u, H, V, M.yy, x[1], _, i ].concat(yt)), typeof _t < "u") return _t; N && (a = a.slice(0, -1 * N * 2), _ = _.slice(0, -1 * N), i = i.slice(0, -1 * N)), a.push(this.productions_[x[1]][0]), _.push(W.$), i.push(W._$), It = K[a[a.length - 2]][a[a.length - 1]], a.push(It); break; case 3: return !0; } } return !0; }, "parse") }, ee = /* @__PURE__ */ function() { var P = { EOF: 1, parseError: /* @__PURE__ */ p(function(h, a) { if (this.yy.parser) this.yy.parser.parseError(h, a); else throw new Error(h); }, "parseError"), // resets the lexer, sets new input setInput: /* @__PURE__ */ p(function(l, h) { return this.yy = h || this.yy || {}, this._input = l, this._more = this._backtrack = this.done = !1, this.yylineno = this.yyleng = 0, this.yytext = this.matched = this.match = "", this.conditionStack = ["INITIAL"], this.yylloc = { first_line: 1, first_column: 0, last_line: 1, last_column: 0 }, this.options.ranges && (this.yylloc.range = [0, 0]), this.offset = 0, this; }, "setInput"), // consumes and returns one char from the input input: /* @__PURE__ */ p(function() { var l = this._input[0]; this.yytext += l, this.yyleng++, this.offset++, this.match += l, this.matched += l; var h = l.match(/(?:\r\n?|\n).*/g); return h ? (this.yylineno++, this.yylloc.last_line++) : this.yylloc.last_column++, this.options.ranges && this.yylloc.range[1]++, this._input = this._input.slice(1), l; }, "input"), // unshifts one char (or a string) into the input unput: /* @__PURE__ */ p(function(l) { var h = l.length, a = l.split(/(?:\r\n?|\n)/g); this._input = l + this._input, this.yytext = this.yytext.substr(0, this.yytext.length - h), this.offset -= h; var T = this.match.split(/(?:\r\n?|\n)/g); this.match = this.match.substr(0, this.match.length - 1), this.matched = this.matched.substr(0, this.matched.length - 1), a.length - 1 && (this.yylineno -= a.length - 1); var _ = this.yylloc.range; return this.yylloc = { first_line: this.yylloc.first_line, last_line: this.yylineno + 1, first_column: this.yylloc.first_column, last_column: a ? (a.length === T.length ? this.yylloc.first_column : 0) + T[T.length - a.length].length - a[0].length : this.yylloc.first_column - h }, this.options.ranges && (this.yylloc.range = [_[0], _[0] + this.yyleng - h]), this.yyleng = this.yytext.length, this; }, "unput"), // When called from action, caches matched text and appends it on next action more: /* @__PURE__ */ p(function() { return this._more = !0, this; }, "more"), // When called from action, signals the lexer that this rule fails to match the input, so the next matching rule (regex) should be tested instead. reject: /* @__PURE__ */ p(function() { if (this.options.backtrack_lexer) this._backtrack = !0; else return this.parseError("Lexical error on line " + (this.yylineno + 1) + `. You can only invoke reject() in the lexer when the lexer is of the backtracking persuasion (options.backtrack_lexer = true). ` + this.showPosition(), { text: "", token: null, line: this.yylineno }); return this; }, "reject"), // retain first n characters of the match less: /* @__PURE__ */ p(function(l) { this.unput(this.match.slice(l)); }, "less"), // displays already matched input, i.e. for error messages pastInput: /* @__PURE__ */ p(function() { var l = this.matched.substr(0, this.matched.length - this.match.length); return (l.length > 20 ? "..." : "") + l.substr(-20).replace(/\n/g, ""); }, "pastInput"), // displays upcoming input, i.e. for error messages upcomingInput: /* @__PURE__ */ p(function() { var l = this.match; return l.length < 20 && (l += this._input.substr(0, 20 - l.length)), (l.substr(0, 20) + (l.length > 20 ? "..." : "")).replace(/\n/g, ""); }, "upcomingInput"), // displays the character position where the lexing error occurred, i.e. for error messages showPosition: /* @__PURE__ */ p(function() { var l = this.pastInput(), h = new Array(l.length + 1).join("-"); return l + this.upcomingInput() + ` ` + h + "^"; }, "showPosition"), // test the lexed token: return FALSE when not a match, otherwise return token test_match: /* @__PURE__ */ p(function(l, h) { var a, T, _; if (this.options.backtrack_lexer && (_ = { yylineno: this.yylineno, yylloc: { first_line: this.yylloc.first_line, last_line: this.last_line, first_column: this.yylloc.first_column, last_column: this.yylloc.last_column }, yytext: this.yytext, match: this.match, matches: this.matches, matched: this.matched, yyleng: this.yyleng, offset: this.offset, _more: this._more, _input: this._input, yy: this.yy, conditionStack: this.conditionStack.slice(0), done: this.done }, this.options.ranges && (_.yylloc.range = this.yylloc.range.slice(0))), T = l[0].match(/(?:\r\n?|\n).*/g), T && (this.yylineno += T.length), this.yylloc = { first_line: this.yylloc.last_line, last_line: this.yylineno + 1, first_column: this.yylloc.last_column, last_column: T ? T[T.length - 1].length - T[T.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + l[0].length }, this.yytext += l[0], this.match += l[0], this.matches = l, this.yyleng = this.yytext.length, this.options.ranges && (this.yylloc.range = [this.offset, this.offset += this.yyleng]), this._more = !1, this._backtrack = !1, this._input = this._input.slice(l[0].length), this.matched += l[0], a = this.performAction.call(this, this.yy, this, h, this.conditionStack[this.conditionStack.length - 1]), this.done && this._input && (this.done = !1), a) return a; if (this._backtrack) { for (var i in _) this[i] = _[i]; return !1; } return !1; }, "test_match"), // return next match in input next: /* @__PURE__ */ p(function() { if (this.done) return this.EOF; this._input || (this.done = !0); var l, h, a, T; this._more || (this.yytext = "", this.match = ""); for (var _ = this._currentRules(), i = 0; i < _.length; i++) if (a = this._input.match(this.rules[_[i]]), a && (!h || a[0].length > h[0].length)) { if (h = a, T = i, this.options.backtrack_lexer) { if (l = this.test_match(a, _[i]), l !== !1) return l; if (this._backtrack) { h = !1; continue; } else return !1; } else if (!this.options.flex) break; } return h ? (l = this.test_match(h, _[T]), l !== !1 ? l : !1) : this._input === "" ? this.EOF : this.parseError("Lexical error on line " + (this.yylineno + 1) + `. Unrecognized text. ` + this.showPosition(), { text: "", token: null, line: this.yylineno }); }, "next"), // return next match that has a token lex: /* @__PURE__ */ p(function() { var h = this.next(); return h || this.lex(); }, "lex"), // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack) begin: /* @__PURE__ */ p(function(h) { this.conditionStack.push(h); }, "begin"), // pop the previously active lexer condition state off the condition stack popState: /* @__PURE__ */ p(function() { var h = this.conditionStack.length - 1; return h > 0 ? this.conditionStack.pop() : this.conditionStack[0]; }, "popState"), // produce the lexer rule set which is active for the currently active lexer condition state _currentRules: /* @__PURE__ */ p(function() { return this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1] ? this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules : this.conditions.INITIAL.rules; }, "_currentRules"), // return the currently active lexer condition state; when an index argument is provided it produces the N-th previous condition state, if available topState: /* @__PURE__ */ p(function(h) { return h = this.conditionStack.length - 1 - Math.abs(h || 0), h >= 0 ? this.conditionStack[h] : "INITIAL"; }, "topState"), // alias for begin(condition) pushState: /* @__PURE__ */ p(function(h) { this.begin(h); }, "pushState"), // return the number of states currently on the stack stateStackSize: /* @__PURE__ */ p(function() { return this.conditionStack.length; }, "stateStackSize"), options: { "case-insensitive": !0 }, performAction: /* @__PURE__ */ p(function(h, a, T, _) { switch (T) { case 0: return 41; case 1: return 48; case 2: return 49; case 3: return 50; case 4: return 51; case 5: break; case 6: break; case 7: return 5; case 8: break; case 9: break; case 10: break; case 11: break; case 12: return this.pushState("SCALE"), 17; case 13: return 18; case 14: this.popState(); break; case 15: return this.begin("acc_title"), 33; case 16: return this.popState(), "acc_title_value"; case 17: return this.begin("acc_descr"), 35; case 18: return this.popState(), "acc_descr_value"; case 19: this.begin("acc_descr_multiline"); break; case 20: this.popState(); break; case 21: return "acc_descr_multiline_value"; case 22: return this.pushState("CLASSDEF"), 38; case 23: return this.popState(), this.pushState("CLASSDEFID"), "DEFAULT_CLASSDEF_ID"; case 24: return this.popState(), this.pushState("CLASSDEFID"), 39; case 25: return this.popState(), 40; case 26: return this.pushState("CLASS"), 45; case 27: return this.popState(), this.pushState("CLASS_STYLE"), 46; case 28: return this.popState(), 47; case 29: return this.pushState("STYLE"), 42; case 30: return this.popState(), this.pushState("STYLEDEF_STYLES"), 43; case 31: return this.popState(), 44; case 32: return this.pushState("SCALE"), 17; case 33: return 18; case 34: this.popState(); break; case 35: this.pushState("STATE"); break; case 36: return this.popState(), a.yytext = a.yytext.slice(0, -8).trim(), 25; case 37: return this.popState(), a.yytext = a.yytext.slice(0, -8).trim(), 26; case 38: return this.popState(), a.yytext = a.yytext.slice(0, -10).trim(), 27; case 39: return this.popState(), a.yytext = a.yytext.slice(0, -8).trim(), 25; case 40: return this.popState(), a.yytext = a.yytext.slice(0, -8).trim(), 26; case 41: return this.popState(), a.yytext = a.yytext.slice(0, -10).trim(), 27; case 42: return 48; case 43: return 49; case 44: return 50; case 45: return 51; case 46: this.pushState("STATE_STRING"); break; case 47: return this.pushState("STATE_ID"), "AS"; case 48: return this.popState(), "ID"; case 49: this.popState(); break; case 50: return "STATE_DESCR"; case 51: return 19; case 52: this.popState(); break; case 53: return this.popState(), this.pushState("struct"), 20; case 54: break; case 55: return this.popState(), 21; case 56: break; case 57: return this.begin("NOTE"), 29; case 58: return this.popState(), this.pushState("NOTE_ID"), 56; case 59: return this.popState(), this.pushState("NOTE_ID"), 57; case 60: this.popState(), this.pushState("FLOATING_NOTE"); break; case 61: return this.popState(), this.pushState("FLOATING_NOTE_ID"), "AS"; case 62: break; case 63: return "NOTE_TEXT"; case 64: return this.popState(), "ID"; case 65: return this.popState(), this.pushState("NOTE_TEXT"), 24; case 66: return this.popState(), a.yytext = a.yytext.substr(2).trim(), 31; case 67: return this.popState(), a.yytext = a.yytext.slice(0, -8).trim(), 31; case 68: return 6; case 69: return 6; case 70: return 16; case 71: return 54; case 72: return 24; case 73: return a.yytext = a.yytext.trim(), 14; case 74: return 15; case 75: return 28; case 76: return 55; case 77: return 5; case 78: return "INVALID"; } }, "anonymous"), rules: [/^(?:default\b)/i, /^(?:.*direction\s+TB[^\n]*)/i, /^(?:.*direction\s+BT[^\n]*)/i, /^(?:.*direction\s+RL[^\n]*)/i, /^(?:.*direction\s+LR[^\n]*)/i, /^(?:%%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n]+)/i, /^(?:[\s]+)/i, /^(?:((?!\n)\s)+)/i, /^(?:#[^\n]*)/i, /^(?:%[^\n]*)/i, /^(?:scale\s+)/i, /^(?:\d+)/i, /^(?:\s+width\b)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?:classDef\s+)/i, /^(?:DEFAULT\s+)/i, /^(?:\w+\s+)/i, /^(?:[^\n]*)/i, /^(?:class\s+)/i, /^(?:(\w+)+((,\s*\w+)*))/i, /^(?:[^\n]*)/i, /^(?:style\s+)/i, /^(?:[\w,]+\s+)/i, /^(?:[^\n]*)/i, /^(?:scale\s+)/i, /^(?:\d+)/i, /^(?:\s+width\b)/i, /^(?:state\s+)/i, /^(?:.*<>)/i, /^(?:.*<>)/i, /^(?:.*<>)/i, /^(?:.*\[\[fork\]\])/i, /^(?:.*\[\[join\]\])/i, /^(?:.*\[\[choice\]\])/i, /^(?:.*direction\s+TB[^\n]*)/i, /^(?:.*direction\s+BT[^\n]*)/i, /^(?:.*direction\s+RL[^\n]*)/i, /^(?:.*direction\s+LR[^\n]*)/i, /^(?:["])/i, /^(?:\s*as\s+)/i, /^(?:[^\n\{]*)/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:[^\n\s\{]+)/i, /^(?:\n)/i, /^(?:\{)/i, /^(?:%%(?!\{)[^\n]*)/i, /^(?:\})/i, /^(?:[\n])/i, /^(?:note\s+)/i, /^(?:left of\b)/i, /^(?:right of\b)/i, /^(?:")/i, /^(?:\s*as\s*)/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:[^\n]*)/i, /^(?:\s*[^:\n\s\-]+)/i, /^(?:\s*:[^:\n;]+)/i, /^(?:[\s\S]*?end note\b)/i, /^(?:stateDiagram\s+)/i, /^(?:stateDiagram-v2\s+)/i, /^(?:hide empty description\b)/i, /^(?:\[\*\])/i, /^(?:[^:\n\s\-\{]+)/i, /^(?:\s*:[^:\n;]+)/i, /^(?:-->)/i, /^(?:--)/i, /^(?::::)/i, /^(?:$)/i, /^(?:.)/i], conditions: { LINE: { rules: [9, 10], inclusive: !1 }, struct: { rules: [9, 10, 22, 26, 29, 35, 42, 43, 44, 45, 54, 55, 56, 57, 71, 72, 73, 74, 75], inclusive: !1 }, FLOATING_NOTE_ID: { rules: [64], inclusive: !1 }, FLOATING_NOTE: { rules: [61, 62, 63], inclusive: !1 }, NOTE_TEXT: { rules: [66, 67], inclusive: !1 }, NOTE_ID: { rules: [65], inclusive: !1 }, NOTE: { rules: [58, 59, 60], inclusive: !1 }, STYLEDEF_STYLEOPTS: { rules: [], inclusive: !1 }, STYLEDEF_STYLES: { rules: [31], inclusive: !1 }, STYLE_IDS: { rules: [], inclusive: !1 }, STYLE: { rules: [30], inclusive: !1 }, CLASS_STYLE: { rules: [28], inclusive: !1 }, CLASS: { rules: [27], inclusive: !1 }, CLASSDEFID: { rules: [25], inclusive: !1 }, CLASSDEF: { rules: [23, 24], inclusive: !1 }, acc_descr_multiline: { rules: [20, 21], inclusive: !1 }, acc_descr: { rules: [18], inclusive: !1 }, acc_title: { rules: [16], inclusive: !1 }, SCALE: { rules: [13, 14, 33, 34], inclusive: !1 }, ALIAS: { rules: [], inclusive: !1 }, STATE_ID: { rules: [48], inclusive: !1 }, STATE_STRING: { rules: [49, 50], inclusive: !1 }, FORK_STATE: { rules: [], inclusive: !1 }, STATE: { rules: [9, 10, 36, 37, 38, 39, 40, 41, 46, 47, 51, 52, 53], inclusive: !1 }, ID: { rules: [9, 10], inclusive: !1 }, INITIAL: { rules: [0, 1, 2, 3, 4, 5, 6, 7, 8, 10, 11, 12, 15, 17, 19, 22, 26, 29, 32, 35, 53, 57, 68, 69, 70, 71, 72, 73, 74, 76, 77, 78], inclusive: !0 } } }; return P; }(); St.lexer = ee; function lt() { this.yy = {}; } return p(lt, "Parser"), lt.prototype = St, St.Parser = lt, new lt(); }(); bt.parser = bt; var Xe = bt, Te = "TB", Mt = "TB", Rt = "dir", dt = "state", vt = "relation", _e = "classDef", Ee = "style", me = "applyClass", Z = "default", Ut = "divider", jt = "fill:none", zt = "fill: #333", Ht = "c", Wt = "text", Xt = "normal", mt = "rect", Dt = "rectWithTitle", De = "stateStart", be = "stateEnd", Ot = "divider", Nt = "roundedWithTitle", ve = "note", ke = "noteGroup", tt = "statediagram", Ce = "state", xe = `${tt}-${Ce}`, Kt = "transition", Ae = "note", Le = "note-edge", Ie = `${Kt} ${Le}`, Re = `${tt}-${Ae}`, Oe = "cluster", Ne = `${tt}-${Oe}`, we = "cluster-alt", $e = `${tt}-${we}`, Jt = "parent", qt = "note", Pe = "state", xt = "----", Be = `${xt}${qt}`, wt = `${xt}${Jt}`, Qt = /* @__PURE__ */ p((e, t = Mt) => { if (!e.doc) return t; let s = t; for (const n of e.doc) n.stmt === "dir" && (s = n.value); return s; }, "getDir"), Ge = /* @__PURE__ */ p(function(e, t) { return t.db.getClasses(); }, "getClasses"), Ye = /* @__PURE__ */ p(async function(e, t, s, n) { v.info("REF0:"), v.info("Drawing state diagram (v2)", t); const { securityLevel: o, state: c, layout: r } = A(); n.db.extract(n.db.getRootDocV2()); const d = n.db.getData(), f = ne(t, o); d.type = n.type, d.layoutAlgorithm = r, d.nodeSpacing = (c == null ? void 0 : c.nodeSpacing) || 50, d.rankSpacing = (c == null ? void 0 : c.rankSpacing) || 50, d.markers = ["barb"], d.diagramId = t, await ye(d, f); const g = 8; ge.insertTitle( f, "statediagramTitleText", (c == null ? void 0 : c.titleTopMargin) ?? 25, n.db.getDiagramTitle() ), le(f, g, tt, (c == null ? void 0 : c.useMaxWidth) ?? !0); }, "draw"), Ke = { getClasses: Ge, draw: Ye, getDir: Qt }, ft = /* @__PURE__ */ new Map(), B = 0; function pt(e = "", t = 0, s = "", n = xt) { const o = s !== null && s.length > 0 ? `${n}${s}` : ""; return `${Pe}-${e}${o}-${t}`; } p(pt, "stateDomId"); var Fe = /* @__PURE__ */ p((e, t, s, n, o, c, r, d) => { v.trace("items", t), t.forEach((f) => { switch (f.stmt) { case dt: Q(e, f, s, n, o, c, r, d); break; case Z: Q(e, f, s, n, o, c, r, d); break; case vt: { Q( e, f.state1, s, n, o, c, r, d ), Q( e, f.state2, s, n, o, c, r, d ); const g = { id: "edge" + B, start: f.state1.id, end: f.state2.id, arrowhead: "normal", arrowTypeEnd: "arrow_barb", style: jt, labelStyle: "", label: j.sanitizeText(f.description, A()), arrowheadStyle: zt, labelpos: Ht, labelType: Wt, thickness: Xt, classes: Kt, look: r }; o.push(g), B++; } break; } }); }, "setupDoc"), $t = /* @__PURE__ */ p((e, t = Mt) => { let s = t; if (e.doc) for (const n of e.doc) n.stmt === "dir" && (s = n.value); return s; }, "getDir"); function q(e, t, s) { if (!t.id || t.id === "" || t.id === "") return; t.cssClasses && (Array.isArray(t.cssCompiledStyles) || (t.cssCompiledStyles = []), t.cssClasses.split(" ").forEach((o) => { if (s.get(o)) { const c = s.get(o); t.cssCompiledStyles = [...t.cssCompiledStyles, ...c.styles]; } })); const n = e.find((o) => o.id === t.id); n ? Object.assign(n, t) : e.push(t); } p(q, "insertOrUpdateNode"); function Zt(e) { var t; return ((t = e == null ? void 0 : e.classes) == null ? void 0 : t.join(" ")) ?? ""; } p(Zt, "getClassesFromDbInfo"); function te(e) { return (e == null ? void 0 : e.styles) ?? []; } p(te, "getStylesFromDbInfo"); var Q = /* @__PURE__ */ p((e, t, s, n, o, c, r, d) => { var I, G; const f = t.id, g = s.get(f), E = Zt(g), m = te(g); if (v.info("dataFetcher parsedItem", t, g, m), f !== "root") { let R = mt; t.start === !0 ? R = De : t.start === !1 && (R = be), t.type !== Z && (R = t.type), ft.get(f) || ft.set(f, { id: f, shape: R, description: j.sanitizeText(f, A()), cssClasses: `${E} ${xe}`, cssStyles: m }); const S = ft.get(f); t.description && (Array.isArray(S.description) ? (S.shape = Dt, S.description.push(t.description)) : ((I = S.description) == null ? void 0 : I.length) > 0 ? (S.shape = Dt, S.description === f ? S.description = [t.description] : S.description = [S.description, t.description]) : (S.shape = mt, S.description = t.description), S.description = j.sanitizeTextOrArray(S.description, A())), ((G = S.description) == null ? void 0 : G.length) === 1 && S.shape === Dt && (S.type === "group" ? S.shape = Nt : S.shape = mt), !S.type && t.doc && (v.info("Setting cluster for XCX", f, $t(t)), S.type = "group", S.isGroup = !0, S.dir = $t(t), S.shape = t.type === Ut ? Ot : Nt, S.cssClasses = `${S.cssClasses} ${Ne} ${c ? $e : ""}`); const L = { labelStyle: "", shape: S.shape, label: S.description, cssClasses: S.cssClasses, cssCompiledStyles: [], cssStyles: S.cssStyles, id: f, dir: S.dir, domId: pt(f, B), type: S.type, isGroup: S.type === "group", padding: 8, rx: 10, ry: 10, look: r }; if (L.shape === Ot && (L.label = ""), e && e.id !== "root" && (v.trace("Setting node ", f, " to be child of its parent ", e.id), L.parentId = e.id), L.centerLabel = !0, t.note) { const O = { labelStyle: "", shape: ve, label: t.note.text, cssClasses: Re, // useHtmlLabels: false, cssStyles: [], cssCompilesStyles: [], id: f + Be + "-" + B, domId: pt(f, B, qt), type: S.type, isGroup: S.type === "group", padding: A().flowchart.padding, look: r, position: t.note.position }, Y = f + wt, F = { labelStyle: "", shape: ke, label: t.note.text, cssClasses: S.cssClasses, cssStyles: [], id: f + wt, domId: pt(f, B, Jt), type: "group", isGroup: !0, padding: 16, //getConfig().flowchart.padding look: r, position: t.note.position }; B++, F.id = Y, O.parentId = Y, q(n, F, d), q(n, O, d), q(n, L, d); let w = f, $ = O.id; t.note.position === "left of" && (w = O.id, $ = f), o.push({ id: w + "-" + $, start: w, end: $, arrowhead: "none", arrowTypeEnd: "", style: jt, labelStyle: "", classes: Ie, arrowheadStyle: zt, labelpos: Ht, labelType: Wt, thickness: Xt, look: r }); } else q(n, L, d); } t.doc && (v.trace("Adding nodes children "), Fe(t, t.doc, s, n, o, !c, r, d)); }, "dataFetcher"), Ve = /* @__PURE__ */ p(() => { ft.clear(), B = 0; }, "reset"), kt = "[*]", Pt = "start", Bt = kt, Gt = "end", Yt = "color", Ft = "fill", Me = "bgFill", Ue = ","; function Ct() { return /* @__PURE__ */ new Map(); } p(Ct, "newClassesList"); var Vt = /* @__PURE__ */ p(() => ({ /** @type {{ id1: string, id2: string, relationTitle: string }[]} */ relations: [], states: /* @__PURE__ */ new Map(), documents: {} }), "newDoc"), ut = /* @__PURE__ */ p((e) => JSON.parse(JSON.stringify(e)), "clone"), z, Je = (z = class { /** * @param {1 | 2} version - v1 renderer or v2 renderer. */ constructor(t) { /** * @private * @type {1 | 2} */ b(this, "version"); /** * @private * @type {Array} */ b(this, "nodes", []); /** * @private * @type {Array} */ b(this, "edges", []); /** * @private * @type {Array} */ b(this, "rootDoc", []); /** * @private * @type {Map} */ b(this, "classes", Ct()); // style classes defined by a classDef /** * @private * @type {Object} */ b(this, "documents", { root: Vt() }); /** * @private * @type {Object} */ b(this, "currentDocument", this.documents.root); /** * @private * @type {number} */ b(this, "startEndCount", 0); /** * @private * @type {number} */ b(this, "dividerCnt", 0); b(this, "getAccTitle", he); b(this, "setAccTitle", ue); b(this, "getAccDescription", de); b(this, "setAccDescription", fe); b(this, "setDiagramTitle", pe); b(this, "getDiagramTitle", Se); this.clear(), this.version = t, this.setRootDoc = this.setRootDoc.bind(this), this.getDividerId = this.getDividerId.bind(this), this.setDirection = this.setDirection.bind(this), this.trimColon = this.trimColon.bind(this); } setRootDoc(t) { v.info("Setting root doc", t), this.rootDoc = t, this.version === 1 ? this.extract(t) : this.extract(this.getRootDocV2()); } getRootDoc() { return this.rootDoc; } /** * @private * @param {Object} parent * @param {Object} node * @param {boolean} first */ docTranslator(t, s, n) { if (s.stmt === vt) this.docTranslator(t, s.state1, !0), this.docTranslator(t, s.state2, !1); else if (s.stmt === dt && (s.id === "[*]" ? (s.id = n ? t.id + "_start" : t.id + "_end", s.start = n) : s.id = s.id.trim()), s.doc) { const o = []; let c = [], r; for (r = 0; r < s.doc.length; r++) if (s.doc[r].type === Ut) { const d = ut(s.doc[r]); d.doc = ut(c), o.push(d), c = []; } else c.push(s.doc[r]); if (o.length > 0 && c.length > 0) { const d = { stmt: dt, id: oe(), type: "divider", doc: ut(c) }; o.push(ut(d)), s.doc = o; } s.doc.forEach((d) => this.docTranslator(s, d, !0)); } } /** * @private */ getRootDocV2() { return this.docTranslator({ id: "root" }, { id: "root", doc: this.rootDoc }, !0), { id: "root", doc: this.rootDoc }; } /** * Convert all of the statements (stmts) that were parsed into states and relationships. * This is done because a state diagram may have nested sections, * where each section is a 'document' and has its own set of statements. * Ex: the section within a fork has its own statements, and incoming and outgoing statements * refer to the fork as a whole (document). * See the parser grammar: the definition of a document is a document then a 'line', where a line can be a statement. * This will push the statement into the list of statements for the current document. * @private * @param _doc */ extract(t) { let s; t.doc ? s = t.doc : s = t, v.info(s), this.clear(!0), v.info("Extract initial document:", s), s.forEach((r) => { switch (v.warn("Statement", r.stmt), r.stmt) { case dt: this.addState( r.id.trim(), r.type, r.doc, r.description, r.note, r.classes, r.styles, r.textStyles ); break; case vt: this.addRelation(r.state1, r.state2, r.description); break; case _e: this.addStyleClass(r.id.trim(), r.classes); break; case Ee: { const d = r.id.trim().split(","), f = r.styleClass.split(","); d.forEach((g) => { let E = this.getState(g); if (E === void 0) { const m = g.trim(); this.addState(m), E = this.getState(m); } E.styles = f.map((m) => { var I; return (I = m.replace(/;/g, "")) == null ? void 0 : I.trim(); }); }); } break; case me: this.setCssClass(r.id.trim(), r.styleClass); break; } }); const n = this.getStates(), c = A().look; Ve(), Q( void 0, this.getRootDocV2(), n, this.nodes, this.edges, !0, c, this.classes ), this.nodes.forEach((r) => { if (Array.isArray(r.label)) { if (r.description = r.label.slice(1), r.isGroup && r.description.length > 0) throw new Error( "Group nodes can only have label. Remove the additional description for node [" + r.id + "]" ); r.label = r.label[0]; } }); } /** * Function called by parser when a node definition has been found. * * @param {null | string} id * @param {null | string} type * @param {null | string} doc * @param {null | string | string[]} descr - description for the state. Can be a string or a list or strings * @param {null | string} note * @param {null | string | string[]} classes - class styles to apply to this state. Can be a string (1 style) or an array of styles. If it's just 1 class, convert it to an array of that 1 class. * @param {null | string | string[]} styles - styles to apply to this state. Can be a string (1 style) or an array of styles. If it's just 1 style, convert it to an array of that 1 style. * @param {null | string | string[]} textStyles - text styles to apply to this state. Can be a string (1 text test) or an array of text styles. If it's just 1 text style, convert it to an array of that 1 text style. */ addState(t, s = Z, n = null, o = null, c = null, r = null, d = null, f = null) { const g = t == null ? void 0 : t.trim(); if (this.currentDocument.states.has(g) ? (this.currentDocument.states.get(g).doc || (this.currentDocument.states.get(g).doc = n), this.currentDocument.states.get(g).type || (this.currentDocument.states.get(g).type = s)) : (v.info("Adding state ", g, o), this.currentDocument.states.set(g, { id: g, descriptions: [], type: s, doc: n, note: c, classes: [], styles: [], textStyles: [] })), o && (v.info("Setting state description", g, o), typeof o == "string" && this.addDescription(g, o.trim()), typeof o == "object" && o.forEach((E) => this.addDescription(g, E.trim()))), c) { const E = this.currentDocument.states.get(g); E.note = c, E.note.text = j.sanitizeText(E.note.text, A()); } r && (v.info("Setting state classes", g, r), (typeof r == "string" ? [r] : r).forEach((m) => this.setCssClass(g, m.trim()))), d && (v.info("Setting state styles", g, d), (typeof d == "string" ? [d] : d).forEach((m) => this.setStyle(g, m.trim()))), f && (v.info("Setting state styles", g, d), (typeof f == "string" ? [f] : f).forEach((m) => this.setTextStyle(g, m.trim()))); } clear(t) { this.nodes = [], this.edges = [], this.documents = { root: Vt() }, this.currentDocument = this.documents.root, this.startEndCount = 0, this.classes = Ct(), t || ce(); } getState(t) { return this.currentDocument.states.get(t); } getStates() { return this.currentDocument.states; } logDocuments() { v.info("Documents = ", this.documents); } getRelations() { return this.currentDocument.relations; } /** * If the id is a start node ( [*] ), then return a new id constructed from * the start node name and the current start node count. * else return the given id * * @param {string} id * @returns {string} - the id (original or constructed) * @private */ startIdIfNeeded(t = "") { let s = t; return t === kt && (this.startEndCount++, s = `${Pt}${this.startEndCount}`), s; } /** * If the id is a start node ( [*] ), then return the start type ('start') * else return the given type * * @param {string} id * @param {string} type * @returns {string} - the type that should be used * @private */ startTypeIfNeeded(t = "", s = Z) { return t === kt ? Pt : s; } /** * If the id is an end node ( [*] ), then return a new id constructed from * the end node name and the current start_end node count. * else return the given id * * @param {string} id * @returns {string} - the id (original or constructed) * @private */ endIdIfNeeded(t = "") { let s = t; return t === Bt && (this.startEndCount++, s = `${Gt}${this.startEndCount}`), s; } /** * If the id is an end node ( [*] ), then return the end type * else return the given type * * @param {string} id * @param {string} type * @returns {string} - the type that should be used * @private */ endTypeIfNeeded(t = "", s = Z) { return t === Bt ? Gt : s; } /** * * @param item1 * @param item2 * @param relationTitle */ addRelationObjs(t, s, n) { let o = this.startIdIfNeeded(t.id.trim()), c = this.startTypeIfNeeded(t.id.trim(), t.type), r = this.startIdIfNeeded(s.id.trim()), d = this.startTypeIfNeeded(s.id.trim(), s.type); this.addState( o, c, t.doc, t.description, t.note, t.classes, t.styles, t.textStyles ), this.addState( r, d, s.doc, s.description, s.note, s.classes, s.styles, s.textStyles ), this.currentDocument.relations.push({ id1: o, id2: r, relationTitle: j.sanitizeText(n, A()) }); } /** * Add a relation between two items. The items may be full objects or just the string id of a state. * * @param {string | object} item1 * @param {string | object} item2 * @param {string} title */ addRelation(t, s, n) { if (typeof t == "object") this.addRelationObjs(t, s, n); else { const o = this.startIdIfNeeded(t.trim()), c = this.startTypeIfNeeded(t), r = this.endIdIfNeeded(s.trim()), d = this.endTypeIfNeeded(s); this.addState(o, c), this.addState(r, d), this.currentDocument.relations.push({ id1: o, id2: r, title: j.sanitizeText(n, A()) }); } } addDescription(t, s) { const n = this.currentDocument.states.get(t), o = s.startsWith(":") ? s.replace(":", "").trim() : s; n.descriptions.push(j.sanitizeText(o, A())); } cleanupLabel(t) { return t.substring(0, 1) === ":" ? t.substr(2).trim() : t.trim(); } getDividerId() { return this.dividerCnt++, "divider-id-" + this.dividerCnt; } /** * Called when the parser comes across a (style) class definition * @example classDef my-style fill:#f96; * * @param {string} id - the id of this (style) class * @param {string | null} styleAttributes - the string with 1 or more style attributes (each separated by a comma) */ addStyleClass(t, s = "") { this.classes.has(t) || this.classes.set(t, { id: t, styles: [], textStyles: [] }); const n = this.classes.get(t); s != null && s.split(Ue).forEach((o) => { const c = o.replace(/([^;]*);/, "$1").trim(); if (RegExp(Yt).exec(o)) { const d = c.replace(Ft, Me).replace(Yt, Ft); n.textStyles.push(d); } n.styles.push(c); }); } /** * Return all of the style classes * @returns {{} | any | classes} */ getClasses() { return this.classes; } /** * Add a (style) class or css class to a state with the given id. * If the state isn't already in the list of known states, add it. * Might be called by parser when a style class or CSS class should be applied to a state * * @param {string | string[]} itemIds The id or a list of ids of the item(s) to apply the css class to * @param {string} cssClassName CSS class name */ setCssClass(t, s) { t.split(",").forEach((n) => { let o = this.getState(n); if (o === void 0) { const c = n.trim(); this.addState(c), o = this.getState(c); } o.classes.push(s); }); } /** * Add a style to a state with the given id. * @example style stateId fill:#f9f,stroke:#333,stroke-width:4px * where 'style' is the keyword * stateId is the id of a state * the rest of the string is the styleText (all of the attributes to be applied to the state) * * @param itemId The id of item to apply the style to * @param styleText - the text of the attributes for the style */ setStyle(t, s) { const n = this.getState(t); n !== void 0 && n.styles.push(s); } /** * Add a text style to a state with the given id * * @param itemId The id of item to apply the css class to * @param cssClassName CSS class name */ setTextStyle(t, s) { const n = this.getState(t); n !== void 0 && n.textStyles.push(s); } /** * Finds the direction statement in the root document. * @private * @returns {{ value: string } | undefined} - the direction statement if present */ getDirectionStatement() { return this.rootDoc.find((t) => t.stmt === Rt); } getDirection() { var t; return ((t = this.getDirectionStatement()) == null ? void 0 : t.value) ?? Te; } setDirection(t) { const s = this.getDirectionStatement(); s ? s.value = t : this.rootDoc.unshift({ stmt: Rt, value: t }); } trimColon(t) { return t && t[0] === ":" ? t.substr(1).trim() : t.trim(); } getData() { const t = A(); return { nodes: this.nodes, edges: this.edges, other: {}, config: t, direction: Qt(this.getRootDocV2()) }; } getConfig() { return A().state; } }, p(z, "StateDB"), b(z, "relationType", { AGGREGATION: 0, EXTENSION: 1, COMPOSITION: 2, DEPENDENCY: 3 }), z), je = /* @__PURE__ */ p((e) => ` defs #statediagram-barbEnd { fill: ${e.transitionColor}; stroke: ${e.transitionColor}; } g.stateGroup text { fill: ${e.nodeBorder}; stroke: none; font-size: 10px; } g.stateGroup text { fill: ${e.textColor}; stroke: none; font-size: 10px; } g.stateGroup .state-title { font-weight: bolder; fill: ${e.stateLabelColor}; } g.stateGroup rect { fill: ${e.mainBkg}; stroke: ${e.nodeBorder}; } g.stateGroup line { stroke: ${e.lineColor}; stroke-width: 1; } .transition { stroke: ${e.transitionColor}; stroke-width: 1; fill: none; } .stateGroup .composit { fill: ${e.background}; border-bottom: 1px } .stateGroup .alt-composit { fill: #e0e0e0; border-bottom: 1px } .state-note { stroke: ${e.noteBorderColor}; fill: ${e.noteBkgColor}; text { fill: ${e.noteTextColor}; stroke: none; font-size: 10px; } } .stateLabel .box { stroke: none; stroke-width: 0; fill: ${e.mainBkg}; opacity: 0.5; } .edgeLabel .label rect { fill: ${e.labelBackgroundColor}; opacity: 0.5; } .edgeLabel { background-color: ${e.edgeLabelBackground}; p { background-color: ${e.edgeLabelBackground}; } rect { opacity: 0.5; background-color: ${e.edgeLabelBackground}; fill: ${e.edgeLabelBackground}; } text-align: center; } .edgeLabel .label text { fill: ${e.transitionLabelColor || e.tertiaryTextColor}; } .label div .edgeLabel { color: ${e.transitionLabelColor || e.tertiaryTextColor}; } .stateLabel text { fill: ${e.stateLabelColor}; font-size: 10px; font-weight: bold; } .node circle.state-start { fill: ${e.specialStateColor}; stroke: ${e.specialStateColor}; } .node .fork-join { fill: ${e.specialStateColor}; stroke: ${e.specialStateColor}; } .node circle.state-end { fill: ${e.innerEndBackground}; stroke: ${e.background}; stroke-width: 1.5 } .end-state-inner { fill: ${e.compositeBackground || e.background}; // stroke: ${e.background}; stroke-width: 1.5 } .node rect { fill: ${e.stateBkg || e.mainBkg}; stroke: ${e.stateBorder || e.nodeBorder}; stroke-width: 1px; } .node polygon { fill: ${e.mainBkg}; stroke: ${e.stateBorder || e.nodeBorder};; stroke-width: 1px; } #statediagram-barbEnd { fill: ${e.lineColor}; } .statediagram-cluster rect { fill: ${e.compositeTitleBackground}; stroke: ${e.stateBorder || e.nodeBorder}; stroke-width: 1px; } .cluster-label, .nodeLabel { color: ${e.stateLabelColor}; // line-height: 1; } .statediagram-cluster rect.outer { rx: 5px; ry: 5px; } .statediagram-state .divider { stroke: ${e.stateBorder || e.nodeBorder}; } .statediagram-state .title-state { rx: 5px; ry: 5px; } .statediagram-cluster.statediagram-cluster .inner { fill: ${e.compositeBackground || e.background}; } .statediagram-cluster.statediagram-cluster-alt .inner { fill: ${e.altBackground ? e.altBackground : "#efefef"}; } .statediagram-cluster .inner { rx:0; ry:0; } .statediagram-state rect.basic { rx: 5px; ry: 5px; } .statediagram-state rect.divider { stroke-dasharray: 10,10; fill: ${e.altBackground ? e.altBackground : "#efefef"}; } .note-edge { stroke-dasharray: 5; } .statediagram-note rect { fill: ${e.noteBkgColor}; stroke: ${e.noteBorderColor}; stroke-width: 1px; rx: 0; ry: 0; } .statediagram-note rect { fill: ${e.noteBkgColor}; stroke: ${e.noteBorderColor}; stroke-width: 1px; rx: 0; ry: 0; } .statediagram-note text { fill: ${e.noteTextColor}; } .statediagram-note .nodeLabel { color: ${e.noteTextColor}; } .statediagram .edgeLabel { color: red; // ${e.noteTextColor}; } #dependencyStart, #dependencyEnd { fill: ${e.lineColor}; stroke: ${e.lineColor}; stroke-width: 1; } .statediagramTitleText { text-anchor: middle; font-size: 18px; fill: ${e.textColor}; } `, "getStyles"), qe = je; export { Je as S, qe as a, Ke as b, Xe as s };