mirror of
https://github.com/HumanAIGC-Engineering/gradio-webrtc.git
synced 2026-02-05 18:09:23 +08:00
1416 lines
54 KiB
JavaScript
1416 lines
54 KiB
JavaScript
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, /^(?:.*<<fork>>)/i, /^(?:.*<<join>>)/i, /^(?:.*<<choice>>)/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 === "</join></fork>" || t.id === "</choice>")
|
|
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<string, any>}
|
|
*/
|
|
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
|
|
};
|