mirror of
https://github.com/HumanAIGC-Engineering/gradio-webrtc.git
synced 2026-02-05 18:09:23 +08:00
719 lines
30 KiB
JavaScript
719 lines
30 KiB
JavaScript
import { _ as c, l as te, d as W, H as fe, ae as ye, af as be, ag as me, V as _e, C as K, i as G, p as Ee, J as ke, W as Se, X as le, Y as ce } from "./mermaid.core-Cmyps_S7.js";
|
|
var $ = function() {
|
|
var t = /* @__PURE__ */ c(function(_, s, n, a) {
|
|
for (n = n || {}, a = _.length; a--; n[_[a]] = s) ;
|
|
return n;
|
|
}, "o"), g = [1, 4], d = [1, 13], r = [1, 12], p = [1, 15], E = [1, 16], f = [1, 20], h = [1, 19], L = [6, 7, 8], C = [1, 26], w = [1, 24], N = [1, 25], i = [6, 7, 11], H = [1, 31], x = [6, 7, 11, 24], P = [1, 6, 13, 16, 17, 20, 23], M = [1, 35], U = [1, 36], A = [1, 6, 7, 11, 13, 16, 17, 20, 23], j = [1, 38], V = {
|
|
trace: /* @__PURE__ */ c(function() {
|
|
}, "trace"),
|
|
yy: {},
|
|
symbols_: { error: 2, start: 3, mindMap: 4, spaceLines: 5, SPACELINE: 6, NL: 7, KANBAN: 8, document: 9, stop: 10, EOF: 11, statement: 12, SPACELIST: 13, node: 14, shapeData: 15, ICON: 16, CLASS: 17, nodeWithId: 18, nodeWithoutId: 19, NODE_DSTART: 20, NODE_DESCR: 21, NODE_DEND: 22, NODE_ID: 23, SHAPE_DATA: 24, $accept: 0, $end: 1 },
|
|
terminals_: { 2: "error", 6: "SPACELINE", 7: "NL", 8: "KANBAN", 11: "EOF", 13: "SPACELIST", 16: "ICON", 17: "CLASS", 20: "NODE_DSTART", 21: "NODE_DESCR", 22: "NODE_DEND", 23: "NODE_ID", 24: "SHAPE_DATA" },
|
|
productions_: [0, [3, 1], [3, 2], [5, 1], [5, 2], [5, 2], [4, 2], [4, 3], [10, 1], [10, 1], [10, 1], [10, 2], [10, 2], [9, 3], [9, 2], [12, 3], [12, 2], [12, 2], [12, 2], [12, 1], [12, 2], [12, 1], [12, 1], [12, 1], [12, 1], [14, 1], [14, 1], [19, 3], [18, 1], [18, 4], [15, 2], [15, 1]],
|
|
performAction: /* @__PURE__ */ c(function(s, n, a, o, u, e, B) {
|
|
var l = e.length - 1;
|
|
switch (u) {
|
|
case 6:
|
|
case 7:
|
|
return o;
|
|
case 8:
|
|
o.getLogger().trace("Stop NL ");
|
|
break;
|
|
case 9:
|
|
o.getLogger().trace("Stop EOF ");
|
|
break;
|
|
case 11:
|
|
o.getLogger().trace("Stop NL2 ");
|
|
break;
|
|
case 12:
|
|
o.getLogger().trace("Stop EOF2 ");
|
|
break;
|
|
case 15:
|
|
o.getLogger().info("Node: ", e[l - 1].id), o.addNode(e[l - 2].length, e[l - 1].id, e[l - 1].descr, e[l - 1].type, e[l]);
|
|
break;
|
|
case 16:
|
|
o.getLogger().info("Node: ", e[l].id), o.addNode(e[l - 1].length, e[l].id, e[l].descr, e[l].type);
|
|
break;
|
|
case 17:
|
|
o.getLogger().trace("Icon: ", e[l]), o.decorateNode({ icon: e[l] });
|
|
break;
|
|
case 18:
|
|
case 23:
|
|
o.decorateNode({ class: e[l] });
|
|
break;
|
|
case 19:
|
|
o.getLogger().trace("SPACELIST");
|
|
break;
|
|
case 20:
|
|
o.getLogger().trace("Node: ", e[l - 1].id), o.addNode(0, e[l - 1].id, e[l - 1].descr, e[l - 1].type, e[l]);
|
|
break;
|
|
case 21:
|
|
o.getLogger().trace("Node: ", e[l].id), o.addNode(0, e[l].id, e[l].descr, e[l].type);
|
|
break;
|
|
case 22:
|
|
o.decorateNode({ icon: e[l] });
|
|
break;
|
|
case 27:
|
|
o.getLogger().trace("node found ..", e[l - 2]), this.$ = { id: e[l - 1], descr: e[l - 1], type: o.getType(e[l - 2], e[l]) };
|
|
break;
|
|
case 28:
|
|
this.$ = { id: e[l], descr: e[l], type: 0 };
|
|
break;
|
|
case 29:
|
|
o.getLogger().trace("node found ..", e[l - 3]), this.$ = { id: e[l - 3], descr: e[l - 1], type: o.getType(e[l - 2], e[l]) };
|
|
break;
|
|
case 30:
|
|
this.$ = e[l - 1] + e[l];
|
|
break;
|
|
case 31:
|
|
this.$ = e[l];
|
|
break;
|
|
}
|
|
}, "anonymous"),
|
|
table: [{ 3: 1, 4: 2, 5: 3, 6: [1, 5], 8: g }, { 1: [3] }, { 1: [2, 1] }, { 4: 6, 6: [1, 7], 7: [1, 8], 8: g }, { 6: d, 7: [1, 10], 9: 9, 12: 11, 13: r, 14: 14, 16: p, 17: E, 18: 17, 19: 18, 20: f, 23: h }, t(L, [2, 3]), { 1: [2, 2] }, t(L, [2, 4]), t(L, [2, 5]), { 1: [2, 6], 6: d, 12: 21, 13: r, 14: 14, 16: p, 17: E, 18: 17, 19: 18, 20: f, 23: h }, { 6: d, 9: 22, 12: 11, 13: r, 14: 14, 16: p, 17: E, 18: 17, 19: 18, 20: f, 23: h }, { 6: C, 7: w, 10: 23, 11: N }, t(i, [2, 24], { 18: 17, 19: 18, 14: 27, 16: [1, 28], 17: [1, 29], 20: f, 23: h }), t(i, [2, 19]), t(i, [2, 21], { 15: 30, 24: H }), t(i, [2, 22]), t(i, [2, 23]), t(x, [2, 25]), t(x, [2, 26]), t(x, [2, 28], { 20: [1, 32] }), { 21: [1, 33] }, { 6: C, 7: w, 10: 34, 11: N }, { 1: [2, 7], 6: d, 12: 21, 13: r, 14: 14, 16: p, 17: E, 18: 17, 19: 18, 20: f, 23: h }, t(P, [2, 14], { 7: M, 11: U }), t(A, [2, 8]), t(A, [2, 9]), t(A, [2, 10]), t(i, [2, 16], { 15: 37, 24: H }), t(i, [2, 17]), t(i, [2, 18]), t(i, [2, 20], { 24: j }), t(x, [2, 31]), { 21: [1, 39] }, { 22: [1, 40] }, t(P, [2, 13], { 7: M, 11: U }), t(A, [2, 11]), t(A, [2, 12]), t(i, [2, 15], { 24: j }), t(x, [2, 30]), { 22: [1, 41] }, t(x, [2, 27]), t(x, [2, 29])],
|
|
defaultActions: { 2: [2, 1], 6: [2, 2] },
|
|
parseError: /* @__PURE__ */ c(function(s, n) {
|
|
if (n.recoverable)
|
|
this.trace(s);
|
|
else {
|
|
var a = new Error(s);
|
|
throw a.hash = n, a;
|
|
}
|
|
}, "parseError"),
|
|
parse: /* @__PURE__ */ c(function(s) {
|
|
var n = this, a = [0], o = [], u = [null], e = [], B = this.table, l = "", z = 0, ie = 0, ue = 2, re = 1, ge = e.slice.call(arguments, 1), b = Object.create(this.lexer), T = { yy: {} };
|
|
for (var J in this.yy)
|
|
Object.prototype.hasOwnProperty.call(this.yy, J) && (T.yy[J] = this.yy[J]);
|
|
b.setInput(s, T.yy), T.yy.lexer = b, T.yy.parser = this, typeof b.yylloc > "u" && (b.yylloc = {});
|
|
var q = b.yylloc;
|
|
e.push(q);
|
|
var de = b.options && b.options.ranges;
|
|
typeof T.yy.parseError == "function" ? this.parseError = T.yy.parseError : this.parseError = Object.getPrototypeOf(this).parseError;
|
|
function pe(S) {
|
|
a.length = a.length - 2 * S, u.length = u.length - S, e.length = e.length - S;
|
|
}
|
|
c(pe, "popStack");
|
|
function ae() {
|
|
var S;
|
|
return S = o.pop() || b.lex() || re, typeof S != "number" && (S instanceof Array && (o = S, S = o.pop()), S = n.symbols_[S] || S), S;
|
|
}
|
|
c(ae, "lex");
|
|
for (var k, R, v, Q, F = {}, X, I, oe, Y; ; ) {
|
|
if (R = a[a.length - 1], this.defaultActions[R] ? v = this.defaultActions[R] : ((k === null || typeof k > "u") && (k = ae()), v = B[R] && B[R][k]), typeof v > "u" || !v.length || !v[0]) {
|
|
var Z = "";
|
|
Y = [];
|
|
for (X in B[R])
|
|
this.terminals_[X] && X > ue && Y.push("'" + this.terminals_[X] + "'");
|
|
b.showPosition ? Z = "Parse error on line " + (z + 1) + `:
|
|
` + b.showPosition() + `
|
|
Expecting ` + Y.join(", ") + ", got '" + (this.terminals_[k] || k) + "'" : Z = "Parse error on line " + (z + 1) + ": Unexpected " + (k == re ? "end of input" : "'" + (this.terminals_[k] || k) + "'"), this.parseError(Z, {
|
|
text: b.match,
|
|
token: this.terminals_[k] || k,
|
|
line: b.yylineno,
|
|
loc: q,
|
|
expected: Y
|
|
});
|
|
}
|
|
if (v[0] instanceof Array && v.length > 1)
|
|
throw new Error("Parse Error: multiple actions possible at state: " + R + ", token: " + k);
|
|
switch (v[0]) {
|
|
case 1:
|
|
a.push(k), u.push(b.yytext), e.push(b.yylloc), a.push(v[1]), k = null, ie = b.yyleng, l = b.yytext, z = b.yylineno, q = b.yylloc;
|
|
break;
|
|
case 2:
|
|
if (I = this.productions_[v[1]][1], F.$ = u[u.length - I], F._$ = {
|
|
first_line: e[e.length - (I || 1)].first_line,
|
|
last_line: e[e.length - 1].last_line,
|
|
first_column: e[e.length - (I || 1)].first_column,
|
|
last_column: e[e.length - 1].last_column
|
|
}, de && (F._$.range = [
|
|
e[e.length - (I || 1)].range[0],
|
|
e[e.length - 1].range[1]
|
|
]), Q = this.performAction.apply(F, [
|
|
l,
|
|
ie,
|
|
z,
|
|
T.yy,
|
|
v[1],
|
|
u,
|
|
e
|
|
].concat(ge)), typeof Q < "u")
|
|
return Q;
|
|
I && (a = a.slice(0, -1 * I * 2), u = u.slice(0, -1 * I), e = e.slice(0, -1 * I)), a.push(this.productions_[v[1]][0]), u.push(F.$), e.push(F._$), oe = B[a[a.length - 2]][a[a.length - 1]], a.push(oe);
|
|
break;
|
|
case 3:
|
|
return !0;
|
|
}
|
|
}
|
|
return !0;
|
|
}, "parse")
|
|
}, m = /* @__PURE__ */ function() {
|
|
var _ = {
|
|
EOF: 1,
|
|
parseError: /* @__PURE__ */ c(function(n, a) {
|
|
if (this.yy.parser)
|
|
this.yy.parser.parseError(n, a);
|
|
else
|
|
throw new Error(n);
|
|
}, "parseError"),
|
|
// resets the lexer, sets new input
|
|
setInput: /* @__PURE__ */ c(function(s, n) {
|
|
return this.yy = n || this.yy || {}, this._input = s, 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__ */ c(function() {
|
|
var s = this._input[0];
|
|
this.yytext += s, this.yyleng++, this.offset++, this.match += s, this.matched += s;
|
|
var n = s.match(/(?:\r\n?|\n).*/g);
|
|
return n ? (this.yylineno++, this.yylloc.last_line++) : this.yylloc.last_column++, this.options.ranges && this.yylloc.range[1]++, this._input = this._input.slice(1), s;
|
|
}, "input"),
|
|
// unshifts one char (or a string) into the input
|
|
unput: /* @__PURE__ */ c(function(s) {
|
|
var n = s.length, a = s.split(/(?:\r\n?|\n)/g);
|
|
this._input = s + this._input, this.yytext = this.yytext.substr(0, this.yytext.length - n), this.offset -= n;
|
|
var o = 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 u = 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 === o.length ? this.yylloc.first_column : 0) + o[o.length - a.length].length - a[0].length : this.yylloc.first_column - n
|
|
}, this.options.ranges && (this.yylloc.range = [u[0], u[0] + this.yyleng - n]), this.yyleng = this.yytext.length, this;
|
|
}, "unput"),
|
|
// When called from action, caches matched text and appends it on next action
|
|
more: /* @__PURE__ */ c(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__ */ c(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__ */ c(function(s) {
|
|
this.unput(this.match.slice(s));
|
|
}, "less"),
|
|
// displays already matched input, i.e. for error messages
|
|
pastInput: /* @__PURE__ */ c(function() {
|
|
var s = this.matched.substr(0, this.matched.length - this.match.length);
|
|
return (s.length > 20 ? "..." : "") + s.substr(-20).replace(/\n/g, "");
|
|
}, "pastInput"),
|
|
// displays upcoming input, i.e. for error messages
|
|
upcomingInput: /* @__PURE__ */ c(function() {
|
|
var s = this.match;
|
|
return s.length < 20 && (s += this._input.substr(0, 20 - s.length)), (s.substr(0, 20) + (s.length > 20 ? "..." : "")).replace(/\n/g, "");
|
|
}, "upcomingInput"),
|
|
// displays the character position where the lexing error occurred, i.e. for error messages
|
|
showPosition: /* @__PURE__ */ c(function() {
|
|
var s = this.pastInput(), n = new Array(s.length + 1).join("-");
|
|
return s + this.upcomingInput() + `
|
|
` + n + "^";
|
|
}, "showPosition"),
|
|
// test the lexed token: return FALSE when not a match, otherwise return token
|
|
test_match: /* @__PURE__ */ c(function(s, n) {
|
|
var a, o, u;
|
|
if (this.options.backtrack_lexer && (u = {
|
|
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 && (u.yylloc.range = this.yylloc.range.slice(0))), o = s[0].match(/(?:\r\n?|\n).*/g), o && (this.yylineno += o.length), this.yylloc = {
|
|
first_line: this.yylloc.last_line,
|
|
last_line: this.yylineno + 1,
|
|
first_column: this.yylloc.last_column,
|
|
last_column: o ? o[o.length - 1].length - o[o.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + s[0].length
|
|
}, this.yytext += s[0], this.match += s[0], this.matches = s, 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(s[0].length), this.matched += s[0], a = this.performAction.call(this, this.yy, this, n, this.conditionStack[this.conditionStack.length - 1]), this.done && this._input && (this.done = !1), a)
|
|
return a;
|
|
if (this._backtrack) {
|
|
for (var e in u)
|
|
this[e] = u[e];
|
|
return !1;
|
|
}
|
|
return !1;
|
|
}, "test_match"),
|
|
// return next match in input
|
|
next: /* @__PURE__ */ c(function() {
|
|
if (this.done)
|
|
return this.EOF;
|
|
this._input || (this.done = !0);
|
|
var s, n, a, o;
|
|
this._more || (this.yytext = "", this.match = "");
|
|
for (var u = this._currentRules(), e = 0; e < u.length; e++)
|
|
if (a = this._input.match(this.rules[u[e]]), a && (!n || a[0].length > n[0].length)) {
|
|
if (n = a, o = e, this.options.backtrack_lexer) {
|
|
if (s = this.test_match(a, u[e]), s !== !1)
|
|
return s;
|
|
if (this._backtrack) {
|
|
n = !1;
|
|
continue;
|
|
} else
|
|
return !1;
|
|
} else if (!this.options.flex)
|
|
break;
|
|
}
|
|
return n ? (s = this.test_match(n, u[o]), s !== !1 ? s : !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__ */ c(function() {
|
|
var n = this.next();
|
|
return n || this.lex();
|
|
}, "lex"),
|
|
// activates a new lexer condition state (pushes the new lexer condition state onto the condition stack)
|
|
begin: /* @__PURE__ */ c(function(n) {
|
|
this.conditionStack.push(n);
|
|
}, "begin"),
|
|
// pop the previously active lexer condition state off the condition stack
|
|
popState: /* @__PURE__ */ c(function() {
|
|
var n = this.conditionStack.length - 1;
|
|
return n > 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__ */ c(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__ */ c(function(n) {
|
|
return n = this.conditionStack.length - 1 - Math.abs(n || 0), n >= 0 ? this.conditionStack[n] : "INITIAL";
|
|
}, "topState"),
|
|
// alias for begin(condition)
|
|
pushState: /* @__PURE__ */ c(function(n) {
|
|
this.begin(n);
|
|
}, "pushState"),
|
|
// return the number of states currently on the stack
|
|
stateStackSize: /* @__PURE__ */ c(function() {
|
|
return this.conditionStack.length;
|
|
}, "stateStackSize"),
|
|
options: { "case-insensitive": !0 },
|
|
performAction: /* @__PURE__ */ c(function(n, a, o, u) {
|
|
switch (o) {
|
|
case 0:
|
|
return this.pushState("shapeData"), a.yytext = "", 24;
|
|
case 1:
|
|
return this.pushState("shapeDataStr"), 24;
|
|
case 2:
|
|
return this.popState(), 24;
|
|
case 3:
|
|
const e = /\n\s*/g;
|
|
return a.yytext = a.yytext.replace(e, "<br/>"), 24;
|
|
case 4:
|
|
return 24;
|
|
case 5:
|
|
this.popState();
|
|
break;
|
|
case 6:
|
|
return n.getLogger().trace("Found comment", a.yytext), 6;
|
|
case 7:
|
|
return 8;
|
|
case 8:
|
|
this.begin("CLASS");
|
|
break;
|
|
case 9:
|
|
return this.popState(), 17;
|
|
case 10:
|
|
this.popState();
|
|
break;
|
|
case 11:
|
|
n.getLogger().trace("Begin icon"), this.begin("ICON");
|
|
break;
|
|
case 12:
|
|
return n.getLogger().trace("SPACELINE"), 6;
|
|
case 13:
|
|
return 7;
|
|
case 14:
|
|
return 16;
|
|
case 15:
|
|
n.getLogger().trace("end icon"), this.popState();
|
|
break;
|
|
case 16:
|
|
return n.getLogger().trace("Exploding node"), this.begin("NODE"), 20;
|
|
case 17:
|
|
return n.getLogger().trace("Cloud"), this.begin("NODE"), 20;
|
|
case 18:
|
|
return n.getLogger().trace("Explosion Bang"), this.begin("NODE"), 20;
|
|
case 19:
|
|
return n.getLogger().trace("Cloud Bang"), this.begin("NODE"), 20;
|
|
case 20:
|
|
return this.begin("NODE"), 20;
|
|
case 21:
|
|
return this.begin("NODE"), 20;
|
|
case 22:
|
|
return this.begin("NODE"), 20;
|
|
case 23:
|
|
return this.begin("NODE"), 20;
|
|
case 24:
|
|
return 13;
|
|
case 25:
|
|
return 23;
|
|
case 26:
|
|
return 11;
|
|
case 27:
|
|
this.begin("NSTR2");
|
|
break;
|
|
case 28:
|
|
return "NODE_DESCR";
|
|
case 29:
|
|
this.popState();
|
|
break;
|
|
case 30:
|
|
n.getLogger().trace("Starting NSTR"), this.begin("NSTR");
|
|
break;
|
|
case 31:
|
|
return n.getLogger().trace("description:", a.yytext), "NODE_DESCR";
|
|
case 32:
|
|
this.popState();
|
|
break;
|
|
case 33:
|
|
return this.popState(), n.getLogger().trace("node end ))"), "NODE_DEND";
|
|
case 34:
|
|
return this.popState(), n.getLogger().trace("node end )"), "NODE_DEND";
|
|
case 35:
|
|
return this.popState(), n.getLogger().trace("node end ...", a.yytext), "NODE_DEND";
|
|
case 36:
|
|
return this.popState(), n.getLogger().trace("node end (("), "NODE_DEND";
|
|
case 37:
|
|
return this.popState(), n.getLogger().trace("node end (-"), "NODE_DEND";
|
|
case 38:
|
|
return this.popState(), n.getLogger().trace("node end (-"), "NODE_DEND";
|
|
case 39:
|
|
return this.popState(), n.getLogger().trace("node end (("), "NODE_DEND";
|
|
case 40:
|
|
return this.popState(), n.getLogger().trace("node end (("), "NODE_DEND";
|
|
case 41:
|
|
return n.getLogger().trace("Long description:", a.yytext), 21;
|
|
case 42:
|
|
return n.getLogger().trace("Long description:", a.yytext), 21;
|
|
}
|
|
}, "anonymous"),
|
|
rules: [/^(?:@\{)/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^\"]+)/i, /^(?:[^}^"]+)/i, /^(?:\})/i, /^(?:\s*%%.*)/i, /^(?:kanban\b)/i, /^(?::::)/i, /^(?:.+)/i, /^(?:\n)/i, /^(?:::icon\()/i, /^(?:[\s]+[\n])/i, /^(?:[\n]+)/i, /^(?:[^\)]+)/i, /^(?:\))/i, /^(?:-\))/i, /^(?:\(-)/i, /^(?:\)\))/i, /^(?:\))/i, /^(?:\(\()/i, /^(?:\{\{)/i, /^(?:\()/i, /^(?:\[)/i, /^(?:[\s]+)/i, /^(?:[^\(\[\n\)\{\}@]+)/i, /^(?:$)/i, /^(?:["][`])/i, /^(?:[^`"]+)/i, /^(?:[`]["])/i, /^(?:["])/i, /^(?:[^"]+)/i, /^(?:["])/i, /^(?:[\)]\))/i, /^(?:[\)])/i, /^(?:[\]])/i, /^(?:\}\})/i, /^(?:\(-)/i, /^(?:-\))/i, /^(?:\(\()/i, /^(?:\()/i, /^(?:[^\)\]\(\}]+)/i, /^(?:.+(?!\(\())/i],
|
|
conditions: { shapeDataEndBracket: { rules: [], inclusive: !1 }, shapeDataStr: { rules: [2, 3], inclusive: !1 }, shapeData: { rules: [1, 4, 5], inclusive: !1 }, CLASS: { rules: [9, 10], inclusive: !1 }, ICON: { rules: [14, 15], inclusive: !1 }, NSTR2: { rules: [28, 29], inclusive: !1 }, NSTR: { rules: [31, 32], inclusive: !1 }, NODE: { rules: [27, 30, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42], inclusive: !1 }, INITIAL: { rules: [0, 6, 7, 8, 11, 12, 13, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26], inclusive: !0 } }
|
|
};
|
|
return _;
|
|
}();
|
|
V.lexer = m;
|
|
function O() {
|
|
this.yy = {};
|
|
}
|
|
return c(O, "Parser"), O.prototype = V, V.Parser = O, new O();
|
|
}();
|
|
$.parser = $;
|
|
var Ne = $, D = [], ne = [], ee = 0, se = {}, xe = /* @__PURE__ */ c(() => {
|
|
D = [], ne = [], ee = 0, se = {};
|
|
}, "clear"), ve = /* @__PURE__ */ c((t) => {
|
|
if (D.length === 0)
|
|
return null;
|
|
const g = D[0].level;
|
|
let d = null;
|
|
for (let r = D.length - 1; r >= 0; r--)
|
|
if (D[r].level === g && !d && (d = D[r]), D[r].level < g)
|
|
throw new Error('Items without section detected, found section ("' + D[r].label + '")');
|
|
return t === (d == null ? void 0 : d.level) ? null : d;
|
|
}, "getSection"), he = /* @__PURE__ */ c(function() {
|
|
return ne;
|
|
}, "getSections"), De = /* @__PURE__ */ c(function() {
|
|
const t = [], g = [], d = he(), r = W();
|
|
for (const p of d) {
|
|
const E = {
|
|
id: p.id,
|
|
label: G(p.label ?? "", r),
|
|
isGroup: !0,
|
|
ticket: p.ticket,
|
|
shape: "kanbanSection",
|
|
level: p.level,
|
|
look: r.look
|
|
};
|
|
g.push(E);
|
|
const f = D.filter((h) => h.parentId === p.id);
|
|
for (const h of f) {
|
|
const L = {
|
|
id: h.id,
|
|
parentId: p.id,
|
|
label: G(h.label ?? "", r),
|
|
isGroup: !1,
|
|
ticket: h == null ? void 0 : h.ticket,
|
|
priority: h == null ? void 0 : h.priority,
|
|
assigned: h == null ? void 0 : h.assigned,
|
|
icon: h == null ? void 0 : h.icon,
|
|
shape: "kanbanItem",
|
|
level: h.level,
|
|
rx: 5,
|
|
ry: 5,
|
|
cssStyles: ["text-align: left"]
|
|
};
|
|
g.push(L);
|
|
}
|
|
}
|
|
return { nodes: g, edges: t, other: {}, config: W() };
|
|
}, "getData"), Le = /* @__PURE__ */ c((t, g, d, r, p) => {
|
|
var C, w;
|
|
const E = W();
|
|
let f = ((C = E.mindmap) == null ? void 0 : C.padding) ?? K.mindmap.padding;
|
|
switch (r) {
|
|
case y.ROUNDED_RECT:
|
|
case y.RECT:
|
|
case y.HEXAGON:
|
|
f *= 2;
|
|
}
|
|
const h = {
|
|
id: G(g, E) || "kbn" + ee++,
|
|
level: t,
|
|
label: G(d, E),
|
|
width: ((w = E.mindmap) == null ? void 0 : w.maxNodeWidth) ?? K.mindmap.maxNodeWidth,
|
|
padding: f,
|
|
isGroup: !1
|
|
};
|
|
if (p !== void 0) {
|
|
let N;
|
|
p.includes(`
|
|
`) ? N = p + `
|
|
` : N = `{
|
|
` + p + `
|
|
}`;
|
|
const i = Ee(N, { schema: ke });
|
|
if (i.shape && (i.shape !== i.shape.toLowerCase() || i.shape.includes("_")))
|
|
throw new Error(`No such shape: ${i.shape}. Shape names should be lowercase.`);
|
|
i != null && i.shape && i.shape === "kanbanItem" && (h.shape = i == null ? void 0 : i.shape), i != null && i.label && (h.label = i == null ? void 0 : i.label), i != null && i.icon && (h.icon = i == null ? void 0 : i.icon.toString()), i != null && i.assigned && (h.assigned = i == null ? void 0 : i.assigned.toString()), i != null && i.ticket && (h.ticket = i == null ? void 0 : i.ticket.toString()), i != null && i.priority && (h.priority = i == null ? void 0 : i.priority);
|
|
}
|
|
const L = ve(t);
|
|
L ? h.parentId = L.id || "kbn" + ee++ : ne.push(h), D.push(h);
|
|
}, "addNode"), y = {
|
|
DEFAULT: 0,
|
|
NO_BORDER: 0,
|
|
ROUNDED_RECT: 1,
|
|
RECT: 2,
|
|
CIRCLE: 3,
|
|
CLOUD: 4,
|
|
BANG: 5,
|
|
HEXAGON: 6
|
|
}, Oe = /* @__PURE__ */ c((t, g) => {
|
|
switch (te.debug("In get type", t, g), t) {
|
|
case "[":
|
|
return y.RECT;
|
|
case "(":
|
|
return g === ")" ? y.ROUNDED_RECT : y.CLOUD;
|
|
case "((":
|
|
return y.CIRCLE;
|
|
case ")":
|
|
return y.CLOUD;
|
|
case "))":
|
|
return y.BANG;
|
|
case "{{":
|
|
return y.HEXAGON;
|
|
default:
|
|
return y.DEFAULT;
|
|
}
|
|
}, "getType"), Ie = /* @__PURE__ */ c((t, g) => {
|
|
se[t] = g;
|
|
}, "setElementForId"), Ce = /* @__PURE__ */ c((t) => {
|
|
if (!t)
|
|
return;
|
|
const g = W(), d = D[D.length - 1];
|
|
t.icon && (d.icon = G(t.icon, g)), t.class && (d.cssClasses = G(t.class, g));
|
|
}, "decorateNode"), we = /* @__PURE__ */ c((t) => {
|
|
switch (t) {
|
|
case y.DEFAULT:
|
|
return "no-border";
|
|
case y.RECT:
|
|
return "rect";
|
|
case y.ROUNDED_RECT:
|
|
return "rounded-rect";
|
|
case y.CIRCLE:
|
|
return "circle";
|
|
case y.CLOUD:
|
|
return "cloud";
|
|
case y.BANG:
|
|
return "bang";
|
|
case y.HEXAGON:
|
|
return "hexgon";
|
|
default:
|
|
return "no-border";
|
|
}
|
|
}, "type2Str"), Ae = /* @__PURE__ */ c(() => te, "getLogger"), Te = /* @__PURE__ */ c((t) => se[t], "getElementById"), Re = {
|
|
clear: xe,
|
|
addNode: Le,
|
|
getSections: he,
|
|
getData: De,
|
|
nodeType: y,
|
|
getType: Oe,
|
|
setElementForId: Ie,
|
|
decorateNode: Ce,
|
|
type2Str: we,
|
|
getLogger: Ae,
|
|
getElementById: Te
|
|
}, Pe = Re, Ve = /* @__PURE__ */ c(async (t, g, d, r) => {
|
|
var M, U, A, j, V;
|
|
te.debug(`Rendering kanban diagram
|
|
` + t);
|
|
const E = r.db.getData(), f = W();
|
|
f.htmlLabels = !1;
|
|
const h = fe(g), L = h.append("g");
|
|
L.attr("class", "sections");
|
|
const C = h.append("g");
|
|
C.attr("class", "items");
|
|
const w = E.nodes.filter(
|
|
// TODO: TypeScript 5.5 will infer this predicate automatically
|
|
(m) => m.isGroup
|
|
);
|
|
let N = 0;
|
|
const i = 10, H = [];
|
|
let x = 25;
|
|
for (const m of w) {
|
|
const O = ((M = f == null ? void 0 : f.kanban) == null ? void 0 : M.sectionWidth) || 200;
|
|
N = N + 1, m.x = O * N + (N - 1) * i / 2, m.width = O, m.y = 0, m.height = O * 3, m.rx = 5, m.ry = 5, m.cssClasses = m.cssClasses + " section-" + N;
|
|
const _ = await ye(L, m);
|
|
x = Math.max(x, (U = _ == null ? void 0 : _.labelBBox) == null ? void 0 : U.height), H.push(_);
|
|
}
|
|
let P = 0;
|
|
for (const m of w) {
|
|
const O = H[P];
|
|
P = P + 1;
|
|
const _ = ((A = f == null ? void 0 : f.kanban) == null ? void 0 : A.sectionWidth) || 200, s = -_ * 3 / 2 + x;
|
|
let n = s;
|
|
const a = E.nodes.filter((e) => e.parentId === m.id);
|
|
for (const e of a) {
|
|
if (e.isGroup)
|
|
throw new Error("Groups within groups are not allowed in Kanban diagrams");
|
|
e.x = m.x, e.width = _ - 1.5 * i;
|
|
const l = (await be(C, e, { config: f })).node().getBBox();
|
|
e.y = n + l.height / 2, await me(e), n = e.y + l.height / 2 + i / 2;
|
|
}
|
|
const o = O.cluster.select("rect"), u = Math.max(n - s + 3 * i, 50) + (x - 25);
|
|
o.attr("height", u);
|
|
}
|
|
_e(
|
|
void 0,
|
|
h,
|
|
((j = f.mindmap) == null ? void 0 : j.padding) ?? K.kanban.padding,
|
|
((V = f.mindmap) == null ? void 0 : V.useMaxWidth) ?? K.kanban.useMaxWidth
|
|
);
|
|
}, "draw"), Be = {
|
|
draw: Ve
|
|
}, Fe = /* @__PURE__ */ c((t) => {
|
|
let g = "";
|
|
for (let r = 0; r < t.THEME_COLOR_LIMIT; r++)
|
|
t["lineColor" + r] = t["lineColor" + r] || t["cScaleInv" + r], Se(t["lineColor" + r]) ? t["lineColor" + r] = le(t["lineColor" + r], 20) : t["lineColor" + r] = ce(t["lineColor" + r], 20);
|
|
const d = /* @__PURE__ */ c((r, p) => t.darkMode ? ce(r, p) : le(r, p), "adjuster");
|
|
for (let r = 0; r < t.THEME_COLOR_LIMIT; r++) {
|
|
const p = "" + (17 - 3 * r);
|
|
g += `
|
|
.section-${r - 1} rect, .section-${r - 1} path, .section-${r - 1} circle, .section-${r - 1} polygon, .section-${r - 1} path {
|
|
fill: ${d(t["cScale" + r], 10)};
|
|
stroke: ${d(t["cScale" + r], 10)};
|
|
|
|
}
|
|
.section-${r - 1} text {
|
|
fill: ${t["cScaleLabel" + r]};
|
|
}
|
|
.node-icon-${r - 1} {
|
|
font-size: 40px;
|
|
color: ${t["cScaleLabel" + r]};
|
|
}
|
|
.section-edge-${r - 1}{
|
|
stroke: ${t["cScale" + r]};
|
|
}
|
|
.edge-depth-${r - 1}{
|
|
stroke-width: ${p};
|
|
}
|
|
.section-${r - 1} line {
|
|
stroke: ${t["cScaleInv" + r]} ;
|
|
stroke-width: 3;
|
|
}
|
|
|
|
.disabled, .disabled circle, .disabled text {
|
|
fill: lightgray;
|
|
}
|
|
.disabled text {
|
|
fill: #efefef;
|
|
}
|
|
|
|
.node rect,
|
|
.node circle,
|
|
.node ellipse,
|
|
.node polygon,
|
|
.node path {
|
|
fill: ${t.background};
|
|
stroke: ${t.nodeBorder};
|
|
stroke-width: 1px;
|
|
}
|
|
|
|
.kanban-ticket-link {
|
|
fill: ${t.background};
|
|
stroke: ${t.nodeBorder};
|
|
text-decoration: underline;
|
|
}
|
|
`;
|
|
}
|
|
return g;
|
|
}, "genSections"), Ge = /* @__PURE__ */ c((t) => `
|
|
.edge {
|
|
stroke-width: 3;
|
|
}
|
|
${Fe(t)}
|
|
.section-root rect, .section-root path, .section-root circle, .section-root polygon {
|
|
fill: ${t.git0};
|
|
}
|
|
.section-root text {
|
|
fill: ${t.gitBranchLabel0};
|
|
}
|
|
.icon-container {
|
|
height:100%;
|
|
display: flex;
|
|
justify-content: center;
|
|
align-items: center;
|
|
}
|
|
.edge {
|
|
fill: none;
|
|
}
|
|
.cluster-label, .label {
|
|
color: ${t.textColor};
|
|
fill: ${t.textColor};
|
|
}
|
|
.kanban-label {
|
|
dy: 1em;
|
|
alignment-baseline: middle;
|
|
text-anchor: middle;
|
|
dominant-baseline: middle;
|
|
text-align: center;
|
|
}
|
|
`, "getStyles"), He = Ge, Ue = {
|
|
db: Pe,
|
|
renderer: Be,
|
|
parser: Ne,
|
|
styles: He
|
|
};
|
|
export {
|
|
Ue as diagram
|
|
};
|