2096 lines
102 KiB
JavaScript
2096 lines
102 KiB
JavaScript
|
import { m as be, q as we } from "./mermaidAPI-51c0c26b.js";
|
||
|
import { g as ct, l as K, b as Lt, e as Pt, c as _e, f as kt } from "./config-e567ef17.js";
|
||
|
import { g as ke, e as Le, d as Pe, s as te, b as Ie, a as Ne, f as ve } from "./commonDb-4dc3d465.js";
|
||
|
import { s as It, Z as ee, u as C } from "./utils-aa888deb.js";
|
||
|
import { c as Ae } from "./setupGraphViewbox-a4603a92.js";
|
||
|
import { s as Se } from "./selectAll-8155f162.js";
|
||
|
import "./errorRenderer-a3c4bedb.js";
|
||
|
var Bt = function() {
|
||
|
var t = function(rt, E, w, k) {
|
||
|
for (w = w || {}, k = rt.length; k--; w[rt[k]] = E)
|
||
|
;
|
||
|
return w;
|
||
|
}, e = [1, 2], s = [1, 3], n = [1, 5], i = [1, 7], a = [2, 5], o = [1, 15], l = [1, 17], u = [1, 19], h = [1, 21], T = [1, 22], y = [1, 23], p = [1, 29], x = [1, 30], b = [1, 31], L = [1, 32], v = [1, 33], M = [1, 34], I = [1, 35], B = [1, 36], V = [1, 37], z = [1, 38], G = [1, 39], Y = [1, 40], D = [1, 42], X = [1, 43], q = [1, 45], F = [1, 46], H = [1, 47], J = [1, 48], Z = [1, 49], m = [1, 50], P = [1, 53], _ = [1, 4, 5, 19, 21, 23, 26, 28, 34, 35, 36, 38, 40, 41, 42, 43, 44, 46, 48, 50, 51, 52, 53, 54, 56, 57, 62, 63, 64, 65, 73, 83], U = [4, 5, 21, 54, 56], N = [4, 5, 19, 21, 23, 26, 28, 34, 35, 36, 38, 40, 41, 42, 43, 44, 46, 48, 50, 54, 56, 57, 62, 63, 64, 65, 73, 83], Kt = [4, 5, 19, 21, 23, 26, 28, 34, 35, 36, 38, 40, 41, 42, 43, 44, 46, 48, 50, 53, 54, 56, 57, 62, 63, 64, 65, 73, 83], Gt = [4, 5, 19, 21, 23, 26, 28, 34, 35, 36, 38, 40, 41, 42, 43, 44, 46, 48, 50, 52, 54, 56, 57, 62, 63, 64, 65, 73, 83], Xt = [4, 5, 19, 21, 23, 26, 28, 34, 35, 36, 38, 40, 41, 42, 43, 44, 46, 48, 50, 51, 54, 56, 57, 62, 63, 64, 65, 73, 83], at = [71, 72, 73], et = [1, 125], Jt = [1, 4, 5, 7, 19, 21, 23, 26, 28, 34, 35, 36, 38, 40, 41, 42, 43, 44, 46, 48, 50, 51, 52, 53, 54, 56, 57, 62, 63, 64, 65, 73, 83], Mt = {
|
||
|
trace: function() {
|
||
|
},
|
||
|
yy: {},
|
||
|
symbols_: { error: 2, start: 3, SPACE: 4, NEWLINE: 5, directive: 6, SD: 7, document: 8, line: 9, statement: 10, box_section: 11, box_line: 12, participant_statement: 13, openDirective: 14, typeDirective: 15, closeDirective: 16, ":": 17, argDirective: 18, box: 19, restOfLine: 20, end: 21, signal: 22, autonumber: 23, NUM: 24, off: 25, activate: 26, actor: 27, deactivate: 28, note_statement: 29, links_statement: 30, link_statement: 31, properties_statement: 32, details_statement: 33, title: 34, legacy_title: 35, acc_title: 36, acc_title_value: 37, acc_descr: 38, acc_descr_value: 39, acc_descr_multiline_value: 40, loop: 41, rect: 42, opt: 43, alt: 44, else_sections: 45, par: 46, par_sections: 47, critical: 48, option_sections: 49, break: 50, option: 51, and: 52, else: 53, participant: 54, AS: 55, participant_actor: 56, note: 57, placement: 58, text2: 59, over: 60, actor_pair: 61, links: 62, link: 63, properties: 64, details: 65, spaceList: 66, ",": 67, left_of: 68, right_of: 69, signaltype: 70, "+": 71, "-": 72, ACTOR: 73, SOLID_OPEN_ARROW: 74, DOTTED_OPEN_ARROW: 75, SOLID_ARROW: 76, DOTTED_ARROW: 77, SOLID_CROSS: 78, DOTTED_CROSS: 79, SOLID_POINT: 80, DOTTED_POINT: 81, TXT: 82, open_directive: 83, type_directive: 84, arg_directive: 85, close_directive: 86, $accept: 0, $end: 1 },
|
||
|
terminals_: { 2: "error", 4: "SPACE", 5: "NEWLINE", 7: "SD", 17: ":", 19: "box", 20: "restOfLine", 21: "end", 23: "autonumber", 24: "NUM", 25: "off", 26: "activate", 28: "deactivate", 34: "title", 35: "legacy_title", 36: "acc_title", 37: "acc_title_value", 38: "acc_descr", 39: "acc_descr_value", 40: "acc_descr_multiline_value", 41: "loop", 42: "rect", 43: "opt", 44: "alt", 46: "par", 48: "critical", 50: "break", 51: "option", 52: "and", 53: "else", 54: "participant", 55: "AS", 56: "participant_actor", 57: "note", 60: "over", 62: "links", 63: "link", 64: "properties", 65: "details", 67: ",", 68: "left_of", 69: "right_of", 71: "+", 72: "-", 73: "ACTOR", 74: "SOLID_OPEN_ARROW", 75: "DOTTED_OPEN_ARROW", 76: "SOLID_ARROW", 77: "DOTTED_ARROW", 78: "SOLID_CROSS", 79: "DOTTED_CROSS", 80: "SOLID_POINT", 81: "DOTTED_POINT", 82: "TXT", 83: "open_directive", 84: "type_directive", 85: "arg_directive", 86: "close_directive" },
|
||
|
productions_: [0, [3, 2], [3, 2], [3, 2], [3, 2], [8, 0], [8, 2], [9, 2], [9, 1], [9, 1], [11, 0], [11, 2], [12, 2], [12, 1], [12, 1], [6, 4], [6, 6], [10, 1], [10, 4], [10, 2], [10, 4], [10, 3], [10, 3], [10, 2], [10, 3], [10, 3], [10, 2], [10, 2], [10, 2], [10, 2], [10, 2], [10, 1], [10, 1], [10, 2], [10, 2], [10, 1], [10, 4], [10, 4], [10, 4], [10, 4], [10, 4], [10, 4], [10, 4], [10, 1], [49, 1], [49, 4], [47, 1], [47, 4], [45, 1], [45, 4], [13, 5], [13, 3], [13, 5], [13, 3], [29, 4], [29, 4], [30, 3], [31, 3], [32, 3], [33, 3], [66, 2], [66, 1], [61, 3], [61, 1], [58, 1], [58, 1], [22, 5], [22, 5], [22, 4], [27, 1], [70, 1], [70, 1], [70, 1], [70, 1], [70, 1], [70, 1], [70, 1], [70, 1], [59, 1], [14, 1], [15, 1], [18, 1], [16, 1]],
|
||
|
performAction: function(E, w, k, g, A, c, Tt) {
|
||
|
var d = c.length - 1;
|
||
|
switch (A) {
|
||
|
case 4:
|
||
|
return g.apply(c[d]), c[d];
|
||
|
case 5:
|
||
|
case 10:
|
||
|
this.$ = [];
|
||
|
break;
|
||
|
case 6:
|
||
|
case 11:
|
||
|
c[d - 1].push(c[d]), this.$ = c[d - 1];
|
||
|
break;
|
||
|
case 7:
|
||
|
case 8:
|
||
|
case 12:
|
||
|
case 13:
|
||
|
this.$ = c[d];
|
||
|
break;
|
||
|
case 9:
|
||
|
case 14:
|
||
|
this.$ = [];
|
||
|
break;
|
||
|
case 18:
|
||
|
c[d - 1].unshift({ type: "boxStart", boxData: g.parseBoxData(c[d - 2]) }), c[d - 1].push({ type: "boxEnd", boxText: c[d - 2] }), this.$ = c[d - 1];
|
||
|
break;
|
||
|
case 20:
|
||
|
this.$ = { type: "sequenceIndex", sequenceIndex: Number(c[d - 2]), sequenceIndexStep: Number(c[d - 1]), sequenceVisible: !0, signalType: g.LINETYPE.AUTONUMBER };
|
||
|
break;
|
||
|
case 21:
|
||
|
this.$ = { type: "sequenceIndex", sequenceIndex: Number(c[d - 1]), sequenceIndexStep: 1, sequenceVisible: !0, signalType: g.LINETYPE.AUTONUMBER };
|
||
|
break;
|
||
|
case 22:
|
||
|
this.$ = { type: "sequenceIndex", sequenceVisible: !1, signalType: g.LINETYPE.AUTONUMBER };
|
||
|
break;
|
||
|
case 23:
|
||
|
this.$ = { type: "sequenceIndex", sequenceVisible: !0, signalType: g.LINETYPE.AUTONUMBER };
|
||
|
break;
|
||
|
case 24:
|
||
|
this.$ = { type: "activeStart", signalType: g.LINETYPE.ACTIVE_START, actor: c[d - 1] };
|
||
|
break;
|
||
|
case 25:
|
||
|
this.$ = { type: "activeEnd", signalType: g.LINETYPE.ACTIVE_END, actor: c[d - 1] };
|
||
|
break;
|
||
|
case 31:
|
||
|
g.setDiagramTitle(c[d].substring(6)), this.$ = c[d].substring(6);
|
||
|
break;
|
||
|
case 32:
|
||
|
g.setDiagramTitle(c[d].substring(7)), this.$ = c[d].substring(7);
|
||
|
break;
|
||
|
case 33:
|
||
|
this.$ = c[d].trim(), g.setAccTitle(this.$);
|
||
|
break;
|
||
|
case 34:
|
||
|
case 35:
|
||
|
this.$ = c[d].trim(), g.setAccDescription(this.$);
|
||
|
break;
|
||
|
case 36:
|
||
|
c[d - 1].unshift({ type: "loopStart", loopText: g.parseMessage(c[d - 2]), signalType: g.LINETYPE.LOOP_START }), c[d - 1].push({ type: "loopEnd", loopText: c[d - 2], signalType: g.LINETYPE.LOOP_END }), this.$ = c[d - 1];
|
||
|
break;
|
||
|
case 37:
|
||
|
c[d - 1].unshift({ type: "rectStart", color: g.parseMessage(c[d - 2]), signalType: g.LINETYPE.RECT_START }), c[d - 1].push({ type: "rectEnd", color: g.parseMessage(c[d - 2]), signalType: g.LINETYPE.RECT_END }), this.$ = c[d - 1];
|
||
|
break;
|
||
|
case 38:
|
||
|
c[d - 1].unshift({ type: "optStart", optText: g.parseMessage(c[d - 2]), signalType: g.LINETYPE.OPT_START }), c[d - 1].push({ type: "optEnd", optText: g.parseMessage(c[d - 2]), signalType: g.LINETYPE.OPT_END }), this.$ = c[d - 1];
|
||
|
break;
|
||
|
case 39:
|
||
|
c[d - 1].unshift({ type: "altStart", altText: g.parseMessage(c[d - 2]), signalType: g.LINETYPE.ALT_START }), c[d - 1].push({ type: "altEnd", signalType: g.LINETYPE.ALT_END }), this.$ = c[d - 1];
|
||
|
break;
|
||
|
case 40:
|
||
|
c[d - 1].unshift({ type: "parStart", parText: g.parseMessage(c[d - 2]), signalType: g.LINETYPE.PAR_START }), c[d - 1].push({ type: "parEnd", signalType: g.LINETYPE.PAR_END }), this.$ = c[d - 1];
|
||
|
break;
|
||
|
case 41:
|
||
|
c[d - 1].unshift({ type: "criticalStart", criticalText: g.parseMessage(c[d - 2]), signalType: g.LINETYPE.CRITICAL_START }), c[d - 1].push({ type: "criticalEnd", signalType: g.LINETYPE.CRITICAL_END }), this.$ = c[d - 1];
|
||
|
break;
|
||
|
case 42:
|
||
|
c[d - 1].unshift({ type: "breakStart", breakText: g.parseMessage(c[d - 2]), signalType: g.LINETYPE.BREAK_START }), c[d - 1].push({ type: "breakEnd", optText: g.parseMessage(c[d - 2]), signalType: g.LINETYPE.BREAK_END }), this.$ = c[d - 1];
|
||
|
break;
|
||
|
case 45:
|
||
|
this.$ = c[d - 3].concat([{ type: "option", optionText: g.parseMessage(c[d - 1]), signalType: g.LINETYPE.CRITICAL_OPTION }, c[d]]);
|
||
|
break;
|
||
|
case 47:
|
||
|
this.$ = c[d - 3].concat([{ type: "and", parText: g.parseMessage(c[d - 1]), signalType: g.LINETYPE.PAR_AND }, c[d]]);
|
||
|
break;
|
||
|
case 49:
|
||
|
this.$ = c[d - 3].concat([{ type: "else", altText: g.parseMessage(c[d - 1]), signalType: g.LINETYPE.ALT_ELSE }, c[d]]);
|
||
|
break;
|
||
|
case 50:
|
||
|
c[d - 3].type = "addParticipant", c[d - 3].description = g.parseMessage(c[d - 1]), this.$ = c[d - 3];
|
||
|
break;
|
||
|
case 51:
|
||
|
c[d - 1].type = "addParticipant", this.$ = c[d - 1];
|
||
|
break;
|
||
|
case 52:
|
||
|
c[d - 3].type = "addActor", c[d - 3].description = g.parseMessage(c[d - 1]), this.$ = c[d - 3];
|
||
|
break;
|
||
|
case 53:
|
||
|
c[d - 1].type = "addActor", this.$ = c[d - 1];
|
||
|
break;
|
||
|
case 54:
|
||
|
this.$ = [c[d - 1], { type: "addNote", placement: c[d - 2], actor: c[d - 1].actor, text: c[d] }];
|
||
|
break;
|
||
|
case 55:
|
||
|
c[d - 2] = [].concat(c[d - 1], c[d - 1]).slice(0, 2), c[d - 2][0] = c[d - 2][0].actor, c[d - 2][1] = c[d - 2][1].actor, this.$ = [c[d - 1], { type: "addNote", placement: g.PLACEMENT.OVER, actor: c[d - 2].slice(0, 2), text: c[d] }];
|
||
|
break;
|
||
|
case 56:
|
||
|
this.$ = [c[d - 1], { type: "addLinks", actor: c[d - 1].actor, text: c[d] }];
|
||
|
break;
|
||
|
case 57:
|
||
|
this.$ = [c[d - 1], { type: "addALink", actor: c[d - 1].actor, text: c[d] }];
|
||
|
break;
|
||
|
case 58:
|
||
|
this.$ = [c[d - 1], { type: "addProperties", actor: c[d - 1].actor, text: c[d] }];
|
||
|
break;
|
||
|
case 59:
|
||
|
this.$ = [c[d - 1], { type: "addDetails", actor: c[d - 1].actor, text: c[d] }];
|
||
|
break;
|
||
|
case 62:
|
||
|
this.$ = [c[d - 2], c[d]];
|
||
|
break;
|
||
|
case 63:
|
||
|
this.$ = c[d];
|
||
|
break;
|
||
|
case 64:
|
||
|
this.$ = g.PLACEMENT.LEFTOF;
|
||
|
break;
|
||
|
case 65:
|
||
|
this.$ = g.PLACEMENT.RIGHTOF;
|
||
|
break;
|
||
|
case 66:
|
||
|
this.$ = [
|
||
|
c[d - 4],
|
||
|
c[d - 1],
|
||
|
{ type: "addMessage", from: c[d - 4].actor, to: c[d - 1].actor, signalType: c[d - 3], msg: c[d] },
|
||
|
{ type: "activeStart", signalType: g.LINETYPE.ACTIVE_START, actor: c[d - 1] }
|
||
|
];
|
||
|
break;
|
||
|
case 67:
|
||
|
this.$ = [
|
||
|
c[d - 4],
|
||
|
c[d - 1],
|
||
|
{ type: "addMessage", from: c[d - 4].actor, to: c[d - 1].actor, signalType: c[d - 3], msg: c[d] },
|
||
|
{ type: "activeEnd", signalType: g.LINETYPE.ACTIVE_END, actor: c[d - 4] }
|
||
|
];
|
||
|
break;
|
||
|
case 68:
|
||
|
this.$ = [c[d - 3], c[d - 1], { type: "addMessage", from: c[d - 3].actor, to: c[d - 1].actor, signalType: c[d - 2], msg: c[d] }];
|
||
|
break;
|
||
|
case 69:
|
||
|
this.$ = { type: "addParticipant", actor: c[d] };
|
||
|
break;
|
||
|
case 70:
|
||
|
this.$ = g.LINETYPE.SOLID_OPEN;
|
||
|
break;
|
||
|
case 71:
|
||
|
this.$ = g.LINETYPE.DOTTED_OPEN;
|
||
|
break;
|
||
|
case 72:
|
||
|
this.$ = g.LINETYPE.SOLID;
|
||
|
break;
|
||
|
case 73:
|
||
|
this.$ = g.LINETYPE.DOTTED;
|
||
|
break;
|
||
|
case 74:
|
||
|
this.$ = g.LINETYPE.SOLID_CROSS;
|
||
|
break;
|
||
|
case 75:
|
||
|
this.$ = g.LINETYPE.DOTTED_CROSS;
|
||
|
break;
|
||
|
case 76:
|
||
|
this.$ = g.LINETYPE.SOLID_POINT;
|
||
|
break;
|
||
|
case 77:
|
||
|
this.$ = g.LINETYPE.DOTTED_POINT;
|
||
|
break;
|
||
|
case 78:
|
||
|
this.$ = g.parseMessage(c[d].trim().substring(1));
|
||
|
break;
|
||
|
case 79:
|
||
|
g.parseDirective("%%{", "open_directive");
|
||
|
break;
|
||
|
case 80:
|
||
|
g.parseDirective(c[d], "type_directive");
|
||
|
break;
|
||
|
case 81:
|
||
|
c[d] = c[d].trim().replace(/'/g, '"'), g.parseDirective(c[d], "arg_directive");
|
||
|
break;
|
||
|
case 82:
|
||
|
g.parseDirective("}%%", "close_directive", "sequence");
|
||
|
break;
|
||
|
}
|
||
|
},
|
||
|
table: [{ 3: 1, 4: e, 5: s, 6: 4, 7: n, 14: 6, 83: i }, { 1: [3] }, { 3: 8, 4: e, 5: s, 6: 4, 7: n, 14: 6, 83: i }, { 3: 9, 4: e, 5: s, 6: 4, 7: n, 14: 6, 83: i }, { 3: 10, 4: e, 5: s, 6: 4, 7: n, 14: 6, 83: i }, t([1, 4, 5, 19, 23, 26, 28, 34, 35, 36, 38, 40, 41, 42, 43, 44, 46, 48, 50, 54, 56, 57, 62, 63, 64, 65, 73, 83], a, { 8: 11 }), { 15: 12, 84: [1, 13] }, { 84: [2, 79] }, { 1: [2, 1] }, { 1: [2, 2] }, { 1: [2, 3] }, { 1: [2, 4], 4: o, 5: l, 6: 41, 9: 14, 10: 16, 13: 18, 14: 6, 19: u, 22: 20, 23: h, 26: T, 27: 44, 28: y, 29: 24, 30: 25, 31: 26, 32: 27, 33: 28, 34: p, 35: x, 36: b, 38: L, 40: v, 41: M, 42: I, 43: B, 44: V, 46: z, 48: G, 50: Y, 54: D, 56: X, 57: q, 62: F, 63: H, 64: J, 65: Z, 73: m, 83: i }, { 16: 51, 17: [1, 52], 86: P }, t([17, 86], [2, 80]), t(_, [2, 6]), { 6: 41, 10: 54, 13: 18, 14: 6, 19: u, 22: 20, 23: h, 26: T, 27: 44, 28: y, 29: 24, 30: 25, 31: 26, 32: 27, 33: 28, 34: p, 35: x, 36: b, 38: L, 40: v, 41: M, 42: I, 43: B, 44: V, 46: z, 48: G, 50: Y, 54: D, 56: X, 57: q, 62: F, 63: H, 64: J, 65: Z, 73: m, 83: i }, t(_, [2, 8]), t(_, [2, 9]), t(_, [2, 17]), { 20: [1, 55] }, { 5: [1, 56] }, { 5: [1, 59], 24: [1, 57], 25: [1, 58] }, { 27: 60, 73: m }, { 27: 61, 73: m }, { 5: [1, 62] }, { 5: [1, 63] }, { 5: [1, 64] }, { 5: [1, 65] }, { 5: [1, 66] }, t(_, [2, 31]), t(_, [2, 32]), { 37: [1, 67] }, { 39: [1, 68] }, t(_, [2, 35]), { 20: [1, 69] }, { 20: [1, 70] }, { 20: [1, 71] }, { 20: [1, 72] }, { 20: [1, 73] }, { 20: [1, 74] }, { 20: [1, 75] }, t(_, [2, 43]), { 27: 76, 73: m }, { 27: 77, 73: m }, { 70: 78, 74: [1, 79], 75: [1, 80], 76: [1, 81], 77: [1, 82], 78: [1, 83], 79: [1, 84], 80: [1, 85], 81: [1, 86] }, { 58: 87, 60: [1, 88], 68: [1, 89], 69: [1, 90] }, { 27: 91, 73: m }, { 27: 92, 73: m }, { 27: 93, 73: m }, { 27: 94, 73: m }, t([5, 55, 67, 74, 75, 76, 77, 78, 79, 80, 81, 82], [2, 69]), { 5: [1, 95] }, { 18: 96, 85: [1, 97] }, { 5: [2, 82] }, t(_, [2, 7]), t(U, [2, 10], { 11: 98 }), t(_, [2, 19]), { 5: [1, 100], 24: [1, 99] }, { 5: [1, 101] }, t(_, [2, 23]), { 5: [1, 102] }, { 5: [1, 103] }, t(_, [2, 26]), t(_, [2, 27]), t(_, [2, 28]), t(_, [2, 29]), t(_, [2, 30]), t(_, [2, 33]), t(_, [2, 34]), t(N, a, { 8: 104 }), t(N, a, { 8: 105 }), t(N, a, { 8: 106 }), t(Kt, a, { 45: 107, 8: 108 }), t(Gt, a, { 47: 109, 8: 110 }), t(Xt, a, { 49: 111, 8: 112 }), t(N, a, { 8: 113 }), { 5: [1, 115], 55: [1, 114] }, { 5: [1, 117], 55: [1, 116] }, { 27: 120, 71: [1, 118], 72: [1, 119], 73: m }, t(at, [2, 70]), t(at, [2, 71]), t(at, [2, 72]), t(at, [2, 73]), t(at, [2, 74]), t(at, [2, 75]), t(at, [2, 76]), t(at, [2, 77]), { 27: 121, 73: m }, { 27: 123, 61: 122, 73: m }, { 73: [2, 64] }, { 73: [2, 65] }, { 59: 124, 82: et }, { 59: 126, 82: et }, { 59: 127, 82: et }, { 59: 128, 82: et }, t(Jt, [2, 15]), { 16: 129, 86: P }, { 86: [2, 81] }, { 4: [1, 132], 5: [1, 134], 12: 131, 13: 133, 21: [1, 130], 54: D, 56: X }, { 5: [1, 135] }, t(_, [2, 21]), t(_, [2, 22]), t(_, [2, 24]), t(_, [2, 25]), { 4: o, 5: l, 6: 41, 9: 14, 10: 16, 13: 18, 14: 6, 19: u, 21: [1, 136], 22: 20, 23: h, 26: T, 27: 44, 28: y, 29: 24, 30: 25, 31: 26, 32: 27, 33: 28, 34: p, 35: x, 36: b, 38: L, 40: v, 41: M, 42: I, 43: B, 44: V, 46: z, 48: G, 50: Y, 54: D, 56: X, 57: q, 62: F, 63: H, 64: J, 65: Z, 73: m, 83: i }, { 4: o, 5: l, 6: 41, 9: 14, 10: 16, 13: 18, 14: 6, 19: u, 21: [1, 137], 22: 20, 23: h, 26: T, 27: 44, 28: y, 29: 24, 30: 25, 31: 26, 32: 27, 33: 28, 34: p, 35: x, 36: b, 38: L, 40: v, 41: M, 42: I, 43: B, 44: V, 46: z, 48: G, 50: Y, 54: D, 56: X, 57: q, 62: F, 63: H, 64: J, 65: Z, 73: m, 83: i }, { 4: o, 5: l, 6: 41, 9: 14, 10: 16, 13: 18, 14: 6, 19: u, 21: [1, 138], 22: 20, 23: h, 26: T, 27: 44, 28: y, 29: 24, 30: 25, 31: 26, 32: 27, 33: 28, 34: p, 35: x, 36: b, 38: L, 40: v, 41: M, 42: I, 43: B, 44: V, 46: z, 48: G, 50: Y, 54: D, 56: X, 57: q, 62: F, 63: H, 64: J, 65: Z, 73: m, 83: i }, { 21: [1, 139] }, { 4: o, 5: l, 6: 41, 9: 14, 10: 16, 13: 18, 14: 6, 19: u, 21: [2, 48], 22: 20, 23: h, 26: T, 27: 44, 28: y, 29: 24, 30: 25, 31: 26, 32: 27, 33: 28, 34: p, 35: x, 36: b, 38: L, 40: v, 41: M, 42: I, 43: B, 44: V, 46: z, 48: G, 50: Y
|
||
|
defaultActions: { 7: [2, 79], 8: [2, 1], 9: [2, 2], 10: [2, 3], 53: [2, 82], 89: [2, 64], 90: [2, 65], 97: [2, 81], 124: [2, 56], 125: [2, 78], 126: [2, 57], 127: [2, 58], 128: [2, 59], 150: [2, 68], 151: [2, 54], 152: [2, 55], 161: [2, 66], 162: [2, 67], 163: [2, 62], 164: [2, 49], 165: [2, 47], 166: [2, 45] },
|
||
|
parseError: function(E, w) {
|
||
|
if (w.recoverable)
|
||
|
this.trace(E);
|
||
|
else {
|
||
|
var k = new Error(E);
|
||
|
throw k.hash = w, k;
|
||
|
}
|
||
|
},
|
||
|
parse: function(E) {
|
||
|
var w = this, k = [0], g = [], A = [null], c = [], Tt = this.table, d = "", bt = 0, Zt = 0, Te = 2, Qt = 1, ye = c.slice.call(arguments, 1), O = Object.create(this.lexer), lt = { yy: {} };
|
||
|
for (var Dt in this.yy)
|
||
|
Object.prototype.hasOwnProperty.call(this.yy, Dt) && (lt.yy[Dt] = this.yy[Dt]);
|
||
|
O.setInput(E, lt.yy), lt.yy.lexer = O, lt.yy.parser = this, typeof O.yylloc > "u" && (O.yylloc = {});
|
||
|
var Vt = O.yylloc;
|
||
|
c.push(Vt);
|
||
|
var me = O.options && O.options.ranges;
|
||
|
typeof lt.yy.parseError == "function" ? this.parseError = lt.yy.parseError : this.parseError = Object.getPrototypeOf(this).parseError;
|
||
|
function Ee() {
|
||
|
var it;
|
||
|
return it = g.pop() || O.lex() || Qt, typeof it != "number" && (it instanceof Array && (g = it, it = g.pop()), it = w.symbols_[it] || it), it;
|
||
|
}
|
||
|
for (var W, ht, Q, Ct, pt = {}, wt, nt, jt, _t; ; ) {
|
||
|
if (ht = k[k.length - 1], this.defaultActions[ht] ? Q = this.defaultActions[ht] : ((W === null || typeof W > "u") && (W = Ee()), Q = Tt[ht] && Tt[ht][W]), typeof Q > "u" || !Q.length || !Q[0]) {
|
||
|
var Ot = "";
|
||
|
_t = [];
|
||
|
for (wt in Tt[ht])
|
||
|
this.terminals_[wt] && wt > Te && _t.push("'" + this.terminals_[wt] + "'");
|
||
|
O.showPosition ? Ot = "Parse error on line " + (bt + 1) + `:
|
||
|
` + O.showPosition() + `
|
||
|
Expecting ` + _t.join(", ") + ", got '" + (this.terminals_[W] || W) + "'" : Ot = "Parse error on line " + (bt + 1) + ": Unexpected " + (W == Qt ? "end of input" : "'" + (this.terminals_[W] || W) + "'"), this.parseError(Ot, {
|
||
|
text: O.match,
|
||
|
token: this.terminals_[W] || W,
|
||
|
line: O.yylineno,
|
||
|
loc: Vt,
|
||
|
expected: _t
|
||
|
});
|
||
|
}
|
||
|
if (Q[0] instanceof Array && Q.length > 1)
|
||
|
throw new Error("Parse Error: multiple actions possible at state: " + ht + ", token: " + W);
|
||
|
switch (Q[0]) {
|
||
|
case 1:
|
||
|
k.push(W), A.push(O.yytext), c.push(O.yylloc), k.push(Q[1]), W = null, Zt = O.yyleng, d = O.yytext, bt = O.yylineno, Vt = O.yylloc;
|
||
|
break;
|
||
|
case 2:
|
||
|
if (nt = this.productions_[Q[1]][1], pt.$ = A[A.length - nt], pt._$ = {
|
||
|
first_line: c[c.length - (nt || 1)].first_line,
|
||
|
last_line: c[c.length - 1].last_line,
|
||
|
first_column: c[c.length - (nt || 1)].first_column,
|
||
|
last_column: c[c.length - 1].last_column
|
||
|
}, me && (pt._$.range = [
|
||
|
c[c.length - (nt || 1)].range[0],
|
||
|
c[c.length - 1].range[1]
|
||
|
]), Ct = this.performAction.apply(pt, [
|
||
|
d,
|
||
|
Zt,
|
||
|
bt,
|
||
|
lt.yy,
|
||
|
Q[1],
|
||
|
A,
|
||
|
c
|
||
|
].concat(ye)), typeof Ct < "u")
|
||
|
return Ct;
|
||
|
nt && (k = k.slice(0, -1 * nt * 2), A = A.slice(0, -1 * nt), c = c.slice(0, -1 * nt)), k.push(this.productions_[Q[1]][0]), A.push(pt.$), c.push(pt._$), jt = Tt[k[k.length - 2]][k[k.length - 1]], k.push(jt);
|
||
|
break;
|
||
|
case 3:
|
||
|
return !0;
|
||
|
}
|
||
|
}
|
||
|
return !0;
|
||
|
}
|
||
|
}, ge = function() {
|
||
|
var rt = {
|
||
|
EOF: 1,
|
||
|
parseError: function(w, k) {
|
||
|
if (this.yy.parser)
|
||
|
this.yy.parser.parseError(w, k);
|
||
|
else
|
||
|
throw new Error(w);
|
||
|
},
|
||
|
// resets the lexer, sets new input
|
||
|
setInput: function(E, w) {
|
||
|
return this.yy = w || this.yy || {}, this._input = E, 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;
|
||
|
},
|
||
|
// consumes and returns one char from the input
|
||
|
input: function() {
|
||
|
var E = this._input[0];
|
||
|
this.yytext += E, this.yyleng++, this.offset++, this.match += E, this.matched += E;
|
||
|
var w = E.match(/(?:\r\n?|\n).*/g);
|
||
|
return w ? (this.yylineno++, this.yylloc.last_line++) : this.yylloc.last_column++, this.options.ranges && this.yylloc.range[1]++, this._input = this._input.slice(1), E;
|
||
|
},
|
||
|
// unshifts one char (or a string) into the input
|
||
|
unput: function(E) {
|
||
|
var w = E.length, k = E.split(/(?:\r\n?|\n)/g);
|
||
|
this._input = E + this._input, this.yytext = this.yytext.substr(0, this.yytext.length - w), this.offset -= w;
|
||
|
var g = 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), k.length - 1 && (this.yylineno -= k.length - 1);
|
||
|
var A = 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: k ? (k.length === g.length ? this.yylloc.first_column : 0) + g[g.length - k.length].length - k[0].length : this.yylloc.first_column - w
|
||
|
}, this.options.ranges && (this.yylloc.range = [A[0], A[0] + this.yyleng - w]), this.yyleng = this.yytext.length, this;
|
||
|
},
|
||
|
// When called from action, caches matched text and appends it on next action
|
||
|
more: function() {
|
||
|
return this._more = !0, this;
|
||
|
},
|
||
|
// 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: 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;
|
||
|
},
|
||
|
// retain first n characters of the match
|
||
|
less: function(E) {
|
||
|
this.unput(this.match.slice(E));
|
||
|
},
|
||
|
// displays already matched input, i.e. for error messages
|
||
|
pastInput: function() {
|
||
|
var E = this.matched.substr(0, this.matched.length - this.match.length);
|
||
|
return (E.length > 20 ? "..." : "") + E.substr(-20).replace(/\n/g, "");
|
||
|
},
|
||
|
// displays upcoming input, i.e. for error messages
|
||
|
upcomingInput: function() {
|
||
|
var E = this.match;
|
||
|
return E.length < 20 && (E += this._input.substr(0, 20 - E.length)), (E.substr(0, 20) + (E.length > 20 ? "..." : "")).replace(/\n/g, "");
|
||
|
},
|
||
|
// displays the character position where the lexing error occurred, i.e. for error messages
|
||
|
showPosition: function() {
|
||
|
var E = this.pastInput(), w = new Array(E.length + 1).join("-");
|
||
|
return E + this.upcomingInput() + `
|
||
|
` + w + "^";
|
||
|
},
|
||
|
// test the lexed token: return FALSE when not a match, otherwise return token
|
||
|
test_match: function(E, w) {
|
||
|
var k, g, A;
|
||
|
if (this.options.backtrack_lexer && (A = {
|
||
|
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 && (A.yylloc.range = this.yylloc.range.slice(0))), g = E[0].match(/(?:\r\n?|\n).*/g), g && (this.yylineno += g.length), this.yylloc = {
|
||
|
first_line: this.yylloc.last_line,
|
||
|
last_line: this.yylineno + 1,
|
||
|
first_column: this.yylloc.last_column,
|
||
|
last_column: g ? g[g.length - 1].length - g[g.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + E[0].length
|
||
|
}, this.yytext += E[0], this.match += E[0], this.matches = E, 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(E[0].length), this.matched += E[0], k = this.performAction.call(this, this.yy, this, w, this.conditionStack[this.conditionStack.length - 1]), this.done && this._input && (this.done = !1), k)
|
||
|
return k;
|
||
|
if (this._backtrack) {
|
||
|
for (var c in A)
|
||
|
this[c] = A[c];
|
||
|
return !1;
|
||
|
}
|
||
|
return !1;
|
||
|
},
|
||
|
// return next match in input
|
||
|
next: function() {
|
||
|
if (this.done)
|
||
|
return this.EOF;
|
||
|
this._input || (this.done = !0);
|
||
|
var E, w, k, g;
|
||
|
this._more || (this.yytext = "", this.match = "");
|
||
|
for (var A = this._currentRules(), c = 0; c < A.length; c++)
|
||
|
if (k = this._input.match(this.rules[A[c]]), k && (!w || k[0].length > w[0].length)) {
|
||
|
if (w = k, g = c, this.options.backtrack_lexer) {
|
||
|
if (E = this.test_match(k, A[c]), E !== !1)
|
||
|
return E;
|
||
|
if (this._backtrack) {
|
||
|
w = !1;
|
||
|
continue;
|
||
|
} else
|
||
|
return !1;
|
||
|
} else if (!this.options.flex)
|
||
|
break;
|
||
|
}
|
||
|
return w ? (E = this.test_match(w, A[g]), E !== !1 ? E : !1) : this._input === "" ? this.EOF : this.parseError("Lexical error on line " + (this.yylineno + 1) + `. Unrecognized text.
|
||
|
` + this.showPosition(), {
|
||
|
text: "",
|
||
|
token: null,
|
||
|
line: this.yylineno
|
||
|
});
|
||
|
},
|
||
|
// return next match that has a token
|
||
|
lex: function() {
|
||
|
var w = this.next();
|
||
|
return w || this.lex();
|
||
|
},
|
||
|
// activates a new lexer condition state (pushes the new lexer condition state onto the condition stack)
|
||
|
begin: function(w) {
|
||
|
this.conditionStack.push(w);
|
||
|
},
|
||
|
// pop the previously active lexer condition state off the condition stack
|
||
|
popState: function() {
|
||
|
var w = this.conditionStack.length - 1;
|
||
|
return w > 0 ? this.conditionStack.pop() : this.conditionStack[0];
|
||
|
},
|
||
|
// produce the lexer rule set which is active for the currently active lexer condition state
|
||
|
_currentRules: function() {
|
||
|
return this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1] ? this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules : this.conditions.INITIAL.rules;
|
||
|
},
|
||
|
// return the currently active lexer condition state; when an index argument is provided it produces the N-th previous condition state, if available
|
||
|
topState: function(w) {
|
||
|
return w = this.conditionStack.length - 1 - Math.abs(w || 0), w >= 0 ? this.conditionStack[w] : "INITIAL";
|
||
|
},
|
||
|
// alias for begin(condition)
|
||
|
pushState: function(w) {
|
||
|
this.begin(w);
|
||
|
},
|
||
|
// return the number of states currently on the stack
|
||
|
stateStackSize: function() {
|
||
|
return this.conditionStack.length;
|
||
|
},
|
||
|
options: { "case-insensitive": !0 },
|
||
|
performAction: function(w, k, g, A) {
|
||
|
switch (g) {
|
||
|
case 0:
|
||
|
return this.begin("open_directive"), 83;
|
||
|
case 1:
|
||
|
return this.begin("type_directive"), 84;
|
||
|
case 2:
|
||
|
return this.popState(), this.begin("arg_directive"), 17;
|
||
|
case 3:
|
||
|
return this.popState(), this.popState(), 86;
|
||
|
case 4:
|
||
|
return 85;
|
||
|
case 5:
|
||
|
return 5;
|
||
|
case 6:
|
||
|
break;
|
||
|
case 7:
|
||
|
break;
|
||
|
case 8:
|
||
|
break;
|
||
|
case 9:
|
||
|
break;
|
||
|
case 10:
|
||
|
break;
|
||
|
case 11:
|
||
|
return 24;
|
||
|
case 12:
|
||
|
return this.begin("LINE"), 19;
|
||
|
case 13:
|
||
|
return this.begin("ID"), 54;
|
||
|
case 14:
|
||
|
return this.begin("ID"), 56;
|
||
|
case 15:
|
||
|
return k.yytext = k.yytext.trim(), this.begin("ALIAS"), 73;
|
||
|
case 16:
|
||
|
return this.popState(), this.popState(), this.begin("LINE"), 55;
|
||
|
case 17:
|
||
|
return this.popState(), this.popState(), 5;
|
||
|
case 18:
|
||
|
return this.begin("LINE"), 41;
|
||
|
case 19:
|
||
|
return this.begin("LINE"), 42;
|
||
|
case 20:
|
||
|
return this.begin("LINE"), 43;
|
||
|
case 21:
|
||
|
return this.begin("LINE"), 44;
|
||
|
case 22:
|
||
|
return this.begin("LINE"), 53;
|
||
|
case 23:
|
||
|
return this.begin("LINE"), 46;
|
||
|
case 24:
|
||
|
return this.begin("LINE"), 52;
|
||
|
case 25:
|
||
|
return this.begin("LINE"), 48;
|
||
|
case 26:
|
||
|
return this.begin("LINE"), 51;
|
||
|
case 27:
|
||
|
return this.begin("LINE"), 50;
|
||
|
case 28:
|
||
|
return this.popState(), 20;
|
||
|
case 29:
|
||
|
return 21;
|
||
|
case 30:
|
||
|
return 68;
|
||
|
case 31:
|
||
|
return 69;
|
||
|
case 32:
|
||
|
return 62;
|
||
|
case 33:
|
||
|
return 63;
|
||
|
case 34:
|
||
|
return 64;
|
||
|
case 35:
|
||
|
return 65;
|
||
|
case 36:
|
||
|
return 60;
|
||
|
case 37:
|
||
|
return 57;
|
||
|
case 38:
|
||
|
return this.begin("ID"), 26;
|
||
|
case 39:
|
||
|
return this.begin("ID"), 28;
|
||
|
case 40:
|
||
|
return 34;
|
||
|
case 41:
|
||
|
return 35;
|
||
|
case 42:
|
||
|
return this.begin("acc_title"), 36;
|
||
|
case 43:
|
||
|
return this.popState(), "acc_title_value";
|
||
|
case 44:
|
||
|
return this.begin("acc_descr"), 38;
|
||
|
case 45:
|
||
|
return this.popState(), "acc_descr_value";
|
||
|
case 46:
|
||
|
this.begin("acc_descr_multiline");
|
||
|
break;
|
||
|
case 47:
|
||
|
this.popState();
|
||
|
break;
|
||
|
case 48:
|
||
|
return "acc_descr_multiline_value";
|
||
|
case 49:
|
||
|
return 7;
|
||
|
case 50:
|
||
|
return 23;
|
||
|
case 51:
|
||
|
return 25;
|
||
|
case 52:
|
||
|
return 67;
|
||
|
case 53:
|
||
|
return 5;
|
||
|
case 54:
|
||
|
return k.yytext = k.yytext.trim(), 73;
|
||
|
case 55:
|
||
|
return 76;
|
||
|
case 56:
|
||
|
return 77;
|
||
|
case 57:
|
||
|
return 74;
|
||
|
case 58:
|
||
|
return 75;
|
||
|
case 59:
|
||
|
return 78;
|
||
|
case 60:
|
||
|
return 79;
|
||
|
case 61:
|
||
|
return 80;
|
||
|
case 62:
|
||
|
return 81;
|
||
|
case 63:
|
||
|
return 82;
|
||
|
case 64:
|
||
|
return 71;
|
||
|
case 65:
|
||
|
return 72;
|
||
|
case 66:
|
||
|
return 5;
|
||
|
case 67:
|
||
|
return "INVALID";
|
||
|
}
|
||
|
},
|
||
|
rules: [/^(?:%%\{)/i, /^(?:((?:(?!\}%%)[^:.])*))/i, /^(?::)/i, /^(?:\}%%)/i, /^(?:((?:(?!\}%%).|\n)*))/i, /^(?:[\n]+)/i, /^(?:\s+)/i, /^(?:((?!\n)\s)+)/i, /^(?:#[^\n]*)/i, /^(?:%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[0-9]+(?=[ \n]+))/i, /^(?:box\b)/i, /^(?:participant\b)/i, /^(?:actor\b)/i, /^(?:[^\->:\n,;]+?([\-]*[^\->:\n,;]+?)*?(?=((?!\n)\s)+as(?!\n)\s|[#\n;]|$))/i, /^(?:as\b)/i, /^(?:(?:))/i, /^(?:loop\b)/i, /^(?:rect\b)/i, /^(?:opt\b)/i, /^(?:alt\b)/i, /^(?:else\b)/i, /^(?:par\b)/i, /^(?:and\b)/i, /^(?:critical\b)/i, /^(?:option\b)/i, /^(?:break\b)/i, /^(?:(?:[:]?(?:no)?wrap)?[^#\n;]*)/i, /^(?:end\b)/i, /^(?:left of\b)/i, /^(?:right of\b)/i, /^(?:links\b)/i, /^(?:link\b)/i, /^(?:properties\b)/i, /^(?:details\b)/i, /^(?:over\b)/i, /^(?:note\b)/i, /^(?:activate\b)/i, /^(?:deactivate\b)/i, /^(?:title\s[^#\n;]+)/i, /^(?:title:\s[^#\n;]+)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?:sequenceDiagram\b)/i, /^(?:autonumber\b)/i, /^(?:off\b)/i, /^(?:,)/i, /^(?:;)/i, /^(?:[^\+\->:\n,;]+((?!(-x|--x|-\)|--\)))[\-]*[^\+\->:\n,;]+)*)/i, /^(?:->>)/i, /^(?:-->>)/i, /^(?:->)/i, /^(?:-->)/i, /^(?:-[x])/i, /^(?:--[x])/i, /^(?:-[\)])/i, /^(?:--[\)])/i, /^(?::(?:(?:no)?wrap)?[^#\n;]+)/i, /^(?:\+)/i, /^(?:-)/i, /^(?:$)/i, /^(?:.)/i],
|
||
|
conditions: { acc_descr_multiline: { rules: [47, 48], inclusive: !1 }, acc_descr: { rules: [45], inclusive: !1 }, acc_title: { rules: [43], inclusive: !1 }, open_directive: { rules: [1, 8], inclusive: !1 }, type_directive: { rules: [2, 3, 8], inclusive: !1 }, arg_directive: { rules: [3, 4, 8], inclusive: !1 }, ID: { rules: [7, 8, 15], inclusive: !1 }, ALIAS: { rules: [7, 8, 16, 17], inclusive: !1 }, LINE: { rules: [7, 8, 28], inclusive: !1 }, INITIAL: { rules: [0, 5, 6, 8, 9, 10, 11, 12, 13, 14, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 44, 46, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67], inclusive: !0 } }
|
||
|
};
|
||
|
return rt;
|
||
|
}();
|
||
|
Mt.lexer = ge;
|
||
|
function Rt() {
|
||
|
this.yy = {};
|
||
|
}
|
||
|
return Rt.prototype = Mt, Mt.Parser = Rt, new Rt();
|
||
|
}();
|
||
|
Bt.parser = Bt;
|
||
|
const Me = Bt;
|
||
|
let yt, ot = {}, xt = [], j = [], Nt = !1, Yt, st;
|
||
|
const Re = function(t, e, s) {
|
||
|
be.parseDirective(this, t, e, s);
|
||
|
}, De = function(t) {
|
||
|
xt.push({
|
||
|
name: t.text,
|
||
|
wrap: t.wrap === void 0 && dt() || !!t.wrap,
|
||
|
fill: t.color,
|
||
|
actorKeys: []
|
||
|
}), st = xt.slice(-1)[0];
|
||
|
}, Ft = function(t, e, s, n) {
|
||
|
let i = st;
|
||
|
const a = ot[t];
|
||
|
if (a) {
|
||
|
if (st && a.box && st !== a.box)
|
||
|
throw new Error(
|
||
|
"A same participant should only be defined in one Box: " + a.name + " can't be in '" + a.box.name + "' and in '" + st.name + "' at the same time."
|
||
|
);
|
||
|
if (i = a.box ? a.box : st, a.box = i, a && e === a.name && s == null)
|
||
|
return;
|
||
|
}
|
||
|
(s == null || s.text == null) && (s = { text: e, wrap: null, type: n }), (n == null || s.text == null) && (s = { text: e, wrap: null, type: n }), ot[t] = {
|
||
|
box: i,
|
||
|
name: e,
|
||
|
description: s.text,
|
||
|
wrap: s.wrap === void 0 && dt() || !!s.wrap,
|
||
|
prevActor: yt,
|
||
|
links: {},
|
||
|
properties: {},
|
||
|
actorCnt: null,
|
||
|
rectData: null,
|
||
|
type: n || "participant"
|
||
|
}, yt && ot[yt] && (ot[yt].nextActor = t), st && st.actorKeys.push(t), yt = t;
|
||
|
}, Ve = (t) => {
|
||
|
let e, s = 0;
|
||
|
for (e = 0; e < j.length; e++)
|
||
|
j[e].type === mt.ACTIVE_START && j[e].from.actor === t && s++, j[e].type === mt.ACTIVE_END && j[e].from.actor === t && s--;
|
||
|
return s;
|
||
|
}, Ce = function(t, e, s, n) {
|
||
|
j.push({
|
||
|
from: t,
|
||
|
to: e,
|
||
|
message: s.text,
|
||
|
wrap: s.wrap === void 0 && dt() || !!s.wrap,
|
||
|
answer: n
|
||
|
});
|
||
|
}, R = function(t, e, s = { text: void 0, wrap: void 0 }, n) {
|
||
|
if (n === mt.ACTIVE_END && Ve(t.actor) < 1) {
|
||
|
let a = new Error("Trying to inactivate an inactive participant (" + t.actor + ")");
|
||
|
throw a.hash = {
|
||
|
text: "->>-",
|
||
|
token: "->>-",
|
||
|
line: "1",
|
||
|
loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 },
|
||
|
expected: ["'ACTIVE_PARTICIPANT'"]
|
||
|
}, a;
|
||
|
}
|
||
|
return j.push({
|
||
|
from: t,
|
||
|
to: e,
|
||
|
message: s.text,
|
||
|
wrap: s.wrap === void 0 && dt() || !!s.wrap,
|
||
|
type: n
|
||
|
}), !0;
|
||
|
}, Oe = function() {
|
||
|
return xt.length > 0;
|
||
|
}, Be = function() {
|
||
|
return xt.some((t) => t.name);
|
||
|
}, Ye = function() {
|
||
|
return j;
|
||
|
}, Fe = function() {
|
||
|
return xt;
|
||
|
}, We = function() {
|
||
|
return ot;
|
||
|
}, Et = function(t) {
|
||
|
return ot[t];
|
||
|
}, ze = function() {
|
||
|
return Object.keys(ot);
|
||
|
}, qe = function() {
|
||
|
Nt = !0;
|
||
|
}, He = function() {
|
||
|
Nt = !1;
|
||
|
}, Ue = () => Nt, Ke = function(t) {
|
||
|
Yt = t;
|
||
|
}, dt = () => Yt !== void 0 ? Yt : ct().sequence.wrap, Ge = function() {
|
||
|
ot = {}, xt = [], j = [], Nt = !1, ve();
|
||
|
}, Xe = function(t) {
|
||
|
const e = t.trim(), s = {
|
||
|
text: e.replace(/^:?(?:no)?wrap:/, "").trim(),
|
||
|
wrap: e.match(/^:?wrap:/) !== null ? !0 : e.match(/^:?nowrap:/) !== null ? !1 : void 0
|
||
|
};
|
||
|
return K.debug("parseMessage:", s), s;
|
||
|
}, Je = function(t) {
|
||
|
const e = t.match(/^((?:rgba?|hsla?)\s*\(.*\)|\w*)(.*)$/);
|
||
|
let s = e != null && e[1] ? e[1].trim() : "transparent", n = e != null && e[2] ? e[2].trim() : void 0;
|
||
|
if (window && window.CSS)
|
||
|
window.CSS.supports("color", s) || (s = "transparent", n = t.trim());
|
||
|
else {
|
||
|
const a = new Option().style;
|
||
|
a.color = s, a.color !== s && (s = "transparent", n = t.trim());
|
||
|
}
|
||
|
return {
|
||
|
color: s,
|
||
|
text: n !== void 0 ? Lt(n.replace(/^:?(?:no)?wrap:/, ""), ct()) : void 0,
|
||
|
wrap: n !== void 0 ? n.match(/^:?wrap:/) !== null ? !0 : n.match(/^:?nowrap:/) !== null ? !1 : void 0 : void 0
|
||
|
};
|
||
|
}, mt = {
|
||
|
SOLID: 0,
|
||
|
DOTTED: 1,
|
||
|
NOTE: 2,
|
||
|
SOLID_CROSS: 3,
|
||
|
DOTTED_CROSS: 4,
|
||
|
SOLID_OPEN: 5,
|
||
|
DOTTED_OPEN: 6,
|
||
|
LOOP_START: 10,
|
||
|
LOOP_END: 11,
|
||
|
ALT_START: 12,
|
||
|
ALT_ELSE: 13,
|
||
|
ALT_END: 14,
|
||
|
OPT_START: 15,
|
||
|
OPT_END: 16,
|
||
|
ACTIVE_START: 17,
|
||
|
ACTIVE_END: 18,
|
||
|
PAR_START: 19,
|
||
|
PAR_AND: 20,
|
||
|
PAR_END: 21,
|
||
|
RECT_START: 22,
|
||
|
RECT_END: 23,
|
||
|
SOLID_POINT: 24,
|
||
|
DOTTED_POINT: 25,
|
||
|
AUTONUMBER: 26,
|
||
|
CRITICAL_START: 27,
|
||
|
CRITICAL_OPTION: 28,
|
||
|
CRITICAL_END: 29,
|
||
|
BREAK_START: 30,
|
||
|
BREAK_END: 31
|
||
|
}, Ze = {
|
||
|
FILLED: 0,
|
||
|
OPEN: 1
|
||
|
}, Qe = {
|
||
|
LEFTOF: 0,
|
||
|
RIGHTOF: 1,
|
||
|
OVER: 2
|
||
|
}, ne = function(t, e, s) {
|
||
|
s.text, s.wrap === void 0 && dt() || s.wrap;
|
||
|
const n = [].concat(t, t);
|
||
|
j.push({
|
||
|
from: n[0],
|
||
|
to: n[1],
|
||
|
message: s.text,
|
||
|
wrap: s.wrap === void 0 && dt() || !!s.wrap,
|
||
|
type: mt.NOTE,
|
||
|
placement: e
|
||
|
});
|
||
|
}, ie = function(t, e) {
|
||
|
const s = Et(t);
|
||
|
try {
|
||
|
let n = Lt(e.text, ct());
|
||
|
n = n.replace(/&/g, "&"), n = n.replace(/=/g, "=");
|
||
|
const i = JSON.parse(n);
|
||
|
Ht(s, i);
|
||
|
} catch (n) {
|
||
|
K.error("error while parsing actor link text", n);
|
||
|
}
|
||
|
}, je = function(t, e) {
|
||
|
const s = Et(t);
|
||
|
try {
|
||
|
const o = {};
|
||
|
let l = Lt(e.text, ct());
|
||
|
var n = l.indexOf("@");
|
||
|
l = l.replace(/&/g, "&"), l = l.replace(/=/g, "=");
|
||
|
var i = l.slice(0, n - 1).trim(), a = l.slice(n + 1).trim();
|
||
|
o[i] = a, Ht(s, o);
|
||
|
} catch (o) {
|
||
|
K.error("error while parsing actor link text", o);
|
||
|
}
|
||
|
};
|
||
|
function Ht(t, e) {
|
||
|
if (t.links == null)
|
||
|
t.links = e;
|
||
|
else
|
||
|
for (let s in e)
|
||
|
t.links[s] = e[s];
|
||
|
}
|
||
|
const se = function(t, e) {
|
||
|
const s = Et(t);
|
||
|
try {
|
||
|
let n = Lt(e.text, ct());
|
||
|
const i = JSON.parse(n);
|
||
|
ae(s, i);
|
||
|
} catch (n) {
|
||
|
K.error("error while parsing actor properties text", n);
|
||
|
}
|
||
|
};
|
||
|
function ae(t, e) {
|
||
|
if (t.properties == null)
|
||
|
t.properties = e;
|
||
|
else
|
||
|
for (let s in e)
|
||
|
t.properties[s] = e[s];
|
||
|
}
|
||
|
function $e() {
|
||
|
st = void 0;
|
||
|
}
|
||
|
const re = function(t, e) {
|
||
|
const s = Et(t), n = document.getElementById(e.text);
|
||
|
try {
|
||
|
const i = n.innerHTML, a = JSON.parse(i);
|
||
|
a.properties && ae(s, a.properties), a.links && Ht(s, a.links);
|
||
|
} catch (i) {
|
||
|
K.error("error while parsing actor details text", i);
|
||
|
}
|
||
|
}, t0 = function(t, e) {
|
||
|
if (t !== void 0 && t.properties !== void 0)
|
||
|
return t.properties[e];
|
||
|
}, oe = function(t) {
|
||
|
if (Array.isArray(t))
|
||
|
t.forEach(function(e) {
|
||
|
oe(e);
|
||
|
});
|
||
|
else
|
||
|
switch (t.type) {
|
||
|
case "sequenceIndex":
|
||
|
j.push({
|
||
|
from: void 0,
|
||
|
to: void 0,
|
||
|
message: {
|
||
|
start: t.sequenceIndex,
|
||
|
step: t.sequenceIndexStep,
|
||
|
visible: t.sequenceVisible
|
||
|
},
|
||
|
wrap: !1,
|
||
|
type: t.signalType
|
||
|
});
|
||
|
break;
|
||
|
case "addParticipant":
|
||
|
Ft(t.actor, t.actor, t.description, "participant");
|
||
|
break;
|
||
|
case "addActor":
|
||
|
Ft(t.actor, t.actor, t.description, "actor");
|
||
|
break;
|
||
|
case "activeStart":
|
||
|
R(t.actor, void 0, void 0, t.signalType);
|
||
|
break;
|
||
|
case "activeEnd":
|
||
|
R(t.actor, void 0, void 0, t.signalType);
|
||
|
break;
|
||
|
case "addNote":
|
||
|
ne(t.actor, t.placement, t.text);
|
||
|
break;
|
||
|
case "addLinks":
|
||
|
ie(t.actor, t.text);
|
||
|
break;
|
||
|
case "addALink":
|
||
|
je(t.actor, t.text);
|
||
|
break;
|
||
|
case "addProperties":
|
||
|
se(t.actor, t.text);
|
||
|
break;
|
||
|
case "addDetails":
|
||
|
re(t.actor, t.text);
|
||
|
break;
|
||
|
case "addMessage":
|
||
|
R(t.from, t.to, t.msg, t.signalType);
|
||
|
break;
|
||
|
case "boxStart":
|
||
|
De(t.boxData);
|
||
|
break;
|
||
|
case "boxEnd":
|
||
|
$e();
|
||
|
break;
|
||
|
case "loopStart":
|
||
|
R(void 0, void 0, t.loopText, t.signalType);
|
||
|
break;
|
||
|
case "loopEnd":
|
||
|
R(void 0, void 0, void 0, t.signalType);
|
||
|
break;
|
||
|
case "rectStart":
|
||
|
R(void 0, void 0, t.color, t.signalType);
|
||
|
break;
|
||
|
case "rectEnd":
|
||
|
R(void 0, void 0, void 0, t.signalType);
|
||
|
break;
|
||
|
case "optStart":
|
||
|
R(void 0, void 0, t.optText, t.signalType);
|
||
|
break;
|
||
|
case "optEnd":
|
||
|
R(void 0, void 0, void 0, t.signalType);
|
||
|
break;
|
||
|
case "altStart":
|
||
|
R(void 0, void 0, t.altText, t.signalType);
|
||
|
break;
|
||
|
case "else":
|
||
|
R(void 0, void 0, t.altText, t.signalType);
|
||
|
break;
|
||
|
case "altEnd":
|
||
|
R(void 0, void 0, void 0, t.signalType);
|
||
|
break;
|
||
|
case "setAccTitle":
|
||
|
te(t.text);
|
||
|
break;
|
||
|
case "parStart":
|
||
|
R(void 0, void 0, t.parText, t.signalType);
|
||
|
break;
|
||
|
case "and":
|
||
|
R(void 0, void 0, t.parText, t.signalType);
|
||
|
break;
|
||
|
case "parEnd":
|
||
|
R(void 0, void 0, void 0, t.signalType);
|
||
|
break;
|
||
|
case "criticalStart":
|
||
|
R(void 0, void 0, t.criticalText, t.signalType);
|
||
|
break;
|
||
|
case "option":
|
||
|
R(void 0, void 0, t.optionText, t.signalType);
|
||
|
break;
|
||
|
case "criticalEnd":
|
||
|
R(void 0, void 0, void 0, t.signalType);
|
||
|
break;
|
||
|
case "breakStart":
|
||
|
R(void 0, void 0, t.breakText, t.signalType);
|
||
|
break;
|
||
|
case "breakEnd":
|
||
|
R(void 0, void 0, void 0, t.signalType);
|
||
|
break;
|
||
|
}
|
||
|
}, e0 = {
|
||
|
addActor: Ft,
|
||
|
addMessage: Ce,
|
||
|
addSignal: R,
|
||
|
addLinks: ie,
|
||
|
addDetails: re,
|
||
|
addProperties: se,
|
||
|
autoWrap: dt,
|
||
|
setWrap: Ke,
|
||
|
enableSequenceNumbers: qe,
|
||
|
disableSequenceNumbers: He,
|
||
|
showSequenceNumbers: Ue,
|
||
|
getMessages: Ye,
|
||
|
getActors: We,
|
||
|
getActor: Et,
|
||
|
getActorKeys: ze,
|
||
|
getActorProperty: t0,
|
||
|
getAccTitle: ke,
|
||
|
getBoxes: Fe,
|
||
|
getDiagramTitle: Le,
|
||
|
setDiagramTitle: Pe,
|
||
|
parseDirective: Re,
|
||
|
getConfig: () => ct().sequence,
|
||
|
clear: Ge,
|
||
|
parseMessage: Xe,
|
||
|
parseBoxData: Je,
|
||
|
LINETYPE: mt,
|
||
|
ARROWTYPE: Ze,
|
||
|
PLACEMENT: Qe,
|
||
|
addNote: ne,
|
||
|
setAccTitle: te,
|
||
|
apply: oe,
|
||
|
setAccDescription: Ie,
|
||
|
getAccDescription: Ne,
|
||
|
hasAtLeastOneBox: Oe,
|
||
|
hasAtLeastOneBoxWithTitle: Be
|
||
|
}, n0 = (t) => `.actor {
|
||
|
stroke: ${t.actorBorder};
|
||
|
fill: ${t.actorBkg};
|
||
|
}
|
||
|
|
||
|
text.actor > tspan {
|
||
|
fill: ${t.actorTextColor};
|
||
|
stroke: none;
|
||
|
}
|
||
|
|
||
|
.actor-line {
|
||
|
stroke: ${t.actorLineColor};
|
||
|
}
|
||
|
|
||
|
.messageLine0 {
|
||
|
stroke-width: 1.5;
|
||
|
stroke-dasharray: none;
|
||
|
stroke: ${t.signalColor};
|
||
|
}
|
||
|
|
||
|
.messageLine1 {
|
||
|
stroke-width: 1.5;
|
||
|
stroke-dasharray: 2, 2;
|
||
|
stroke: ${t.signalColor};
|
||
|
}
|
||
|
|
||
|
#arrowhead path {
|
||
|
fill: ${t.signalColor};
|
||
|
stroke: ${t.signalColor};
|
||
|
}
|
||
|
|
||
|
.sequenceNumber {
|
||
|
fill: ${t.sequenceNumberColor};
|
||
|
}
|
||
|
|
||
|
#sequencenumber {
|
||
|
fill: ${t.signalColor};
|
||
|
}
|
||
|
|
||
|
#crosshead path {
|
||
|
fill: ${t.signalColor};
|
||
|
stroke: ${t.signalColor};
|
||
|
}
|
||
|
|
||
|
.messageText {
|
||
|
fill: ${t.signalTextColor};
|
||
|
stroke: none;
|
||
|
}
|
||
|
|
||
|
.labelBox {
|
||
|
stroke: ${t.labelBoxBorderColor};
|
||
|
fill: ${t.labelBoxBkgColor};
|
||
|
}
|
||
|
|
||
|
.labelText, .labelText > tspan {
|
||
|
fill: ${t.labelTextColor};
|
||
|
stroke: none;
|
||
|
}
|
||
|
|
||
|
.loopText, .loopText > tspan {
|
||
|
fill: ${t.loopTextColor};
|
||
|
stroke: none;
|
||
|
}
|
||
|
|
||
|
.loopLine {
|
||
|
stroke-width: 2px;
|
||
|
stroke-dasharray: 2, 2;
|
||
|
stroke: ${t.labelBoxBorderColor};
|
||
|
fill: ${t.labelBoxBorderColor};
|
||
|
}
|
||
|
|
||
|
.note {
|
||
|
//stroke: #decc93;
|
||
|
stroke: ${t.noteBorderColor};
|
||
|
fill: ${t.noteBkgColor};
|
||
|
}
|
||
|
|
||
|
.noteText, .noteText > tspan {
|
||
|
fill: ${t.noteTextColor};
|
||
|
stroke: none;
|
||
|
}
|
||
|
|
||
|
.activation0 {
|
||
|
fill: ${t.activationBkgColor};
|
||
|
stroke: ${t.activationBorderColor};
|
||
|
}
|
||
|
|
||
|
.activation1 {
|
||
|
fill: ${t.activationBkgColor};
|
||
|
stroke: ${t.activationBorderColor};
|
||
|
}
|
||
|
|
||
|
.activation2 {
|
||
|
fill: ${t.activationBkgColor};
|
||
|
stroke: ${t.activationBorderColor};
|
||
|
}
|
||
|
|
||
|
.actorPopupMenu {
|
||
|
position: absolute;
|
||
|
}
|
||
|
|
||
|
.actorPopupMenuPanel {
|
||
|
position: absolute;
|
||
|
fill: ${t.actorBkg};
|
||
|
box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
|
||
|
filter: drop-shadow(3px 5px 2px rgb(0 0 0 / 0.4));
|
||
|
}
|
||
|
.actor-man line {
|
||
|
stroke: ${t.actorBorder};
|
||
|
fill: ${t.actorBkg};
|
||
|
}
|
||
|
.actor-man circle, line {
|
||
|
stroke: ${t.actorBorder};
|
||
|
fill: ${t.actorBkg};
|
||
|
stroke-width: 2px;
|
||
|
}
|
||
|
`, i0 = n0, vt = function(t, e) {
|
||
|
const s = t.append("rect");
|
||
|
return s.attr("x", e.x), s.attr("y", e.y), s.attr("fill", e.fill), s.attr("stroke", e.stroke), s.attr("width", e.width), s.attr("height", e.height), s.attr("rx", e.rx), s.attr("ry", e.ry), e.class !== void 0 && s.attr("class", e.class), s;
|
||
|
}, ce = (t, e) => {
|
||
|
we(() => {
|
||
|
const s = document.querySelectorAll(t);
|
||
|
s.length !== 0 && (s[0].addEventListener("mouseover", function() {
|
||
|
o0("actor" + e + "_popup");
|
||
|
}), s[0].addEventListener("mouseout", function() {
|
||
|
c0("actor" + e + "_popup");
|
||
|
}));
|
||
|
});
|
||
|
}, s0 = function(t, e, s, n, i) {
|
||
|
if (e.links === void 0 || e.links === null || Object.keys(e.links).length === 0)
|
||
|
return { height: 0, width: 0 };
|
||
|
const a = e.links, o = e.actorCnt, l = e.rectData;
|
||
|
var u = "none";
|
||
|
i && (u = "block !important");
|
||
|
const h = t.append("g");
|
||
|
h.attr("id", "actor" + o + "_popup"), h.attr("class", "actorPopupMenu"), h.attr("display", u), ce("#actor" + o + "_popup", o);
|
||
|
var T = "";
|
||
|
l.class !== void 0 && (T = " " + l.class);
|
||
|
let y = l.width > s ? l.width : s;
|
||
|
const p = h.append("rect");
|
||
|
if (p.attr("class", "actorPopupMenuPanel" + T), p.attr("x", l.x), p.attr("y", l.height), p.attr("fill", l.fill), p.attr("stroke", l.stroke), p.attr("width", y), p.attr("height", l.height), p.attr("rx", l.rx), p.attr("ry", l.ry), a != null) {
|
||
|
var x = 20;
|
||
|
for (let v in a) {
|
||
|
var b = h.append("a"), L = It(a[v]);
|
||
|
b.attr("xlink:href", L), b.attr("target", "_blank"), _0(n)(
|
||
|
v,
|
||
|
b,
|
||
|
l.x + 10,
|
||
|
l.height + x,
|
||
|
y,
|
||
|
20,
|
||
|
{ class: "actor" },
|
||
|
n
|
||
|
), x += 30;
|
||
|
}
|
||
|
}
|
||
|
return p.attr("height", x), { height: l.height + x, width: y };
|
||
|
}, le = function(t, e, s, n) {
|
||
|
const i = t.append("image");
|
||
|
i.attr("x", e), i.attr("y", s);
|
||
|
var a = It(n);
|
||
|
i.attr("xlink:href", a);
|
||
|
}, he = function(t, e, s, n) {
|
||
|
const i = t.append("use");
|
||
|
i.attr("x", e), i.attr("y", s);
|
||
|
var a = It(n);
|
||
|
i.attr("xlink:href", "#" + a);
|
||
|
}, a0 = function(t) {
|
||
|
return "var pu = document.getElementById('" + t + "'); if (pu != null) { pu.style.display = 'block'; }";
|
||
|
}, r0 = function(t) {
|
||
|
return "var pu = document.getElementById('" + t + "'); if (pu != null) { pu.style.display = 'none'; }";
|
||
|
}, o0 = function(t) {
|
||
|
var e = document.getElementById(t);
|
||
|
e != null && (e.style.display = "block");
|
||
|
}, c0 = function(t) {
|
||
|
var e = document.getElementById(t);
|
||
|
e != null && (e.style.display = "none");
|
||
|
}, gt = function(t, e) {
|
||
|
let s = 0, n = 0;
|
||
|
const i = e.text.split(Pt.lineBreakRegex), [a, o] = ee(e.fontSize);
|
||
|
let l = [], u = 0, h = () => e.y;
|
||
|
if (e.valign !== void 0 && e.textMargin !== void 0 && e.textMargin > 0)
|
||
|
switch (e.valign) {
|
||
|
case "top":
|
||
|
case "start":
|
||
|
h = () => Math.round(e.y + e.textMargin);
|
||
|
break;
|
||
|
case "middle":
|
||
|
case "center":
|
||
|
h = () => Math.round(e.y + (s + n + e.textMargin) / 2);
|
||
|
break;
|
||
|
case "bottom":
|
||
|
case "end":
|
||
|
h = () => Math.round(
|
||
|
e.y + (s + n + 2 * e.textMargin) - e.textMargin
|
||
|
);
|
||
|
break;
|
||
|
}
|
||
|
if (e.anchor !== void 0 && e.textMargin !== void 0 && e.width !== void 0)
|
||
|
switch (e.anchor) {
|
||
|
case "left":
|
||
|
case "start":
|
||
|
e.x = Math.round(e.x + e.textMargin), e.anchor = "start", e.dominantBaseline = "middle", e.alignmentBaseline = "middle";
|
||
|
break;
|
||
|
case "middle":
|
||
|
case "center":
|
||
|
e.x = Math.round(e.x + e.width / 2), e.anchor = "middle", e.dominantBaseline = "middle", e.alignmentBaseline = "middle";
|
||
|
break;
|
||
|
case "right":
|
||
|
case "end":
|
||
|
e.x = Math.round(e.x + e.width - e.textMargin), e.anchor = "end", e.dominantBaseline = "middle", e.alignmentBaseline = "middle";
|
||
|
break;
|
||
|
}
|
||
|
for (let [T, y] of i.entries()) {
|
||
|
e.textMargin !== void 0 && e.textMargin === 0 && a !== void 0 && (u = T * a);
|
||
|
const p = t.append("text");
|
||
|
if (p.attr("x", e.x), p.attr("y", h()), e.anchor !== void 0 && p.attr("text-anchor", e.anchor).attr("dominant-baseline", e.dominantBaseline).attr("alignment-baseline", e.alignmentBaseline), e.fontFamily !== void 0 && p.style("font-family", e.fontFamily), o !== void 0 && p.style("font-size", o), e.fontWeight !== void 0 && p.style("font-weight", e.fontWeight), e.fill !== void 0 && p.attr("fill", e.fill), e.class !== void 0 && p.attr("class", e.class), e.dy !== void 0 ? p.attr("dy", e.dy) : u !== 0 && p.attr("dy", u), e.tspan) {
|
||
|
const x = p.append("tspan");
|
||
|
x.attr("x", e.x), e.fill !== void 0 && x.attr("fill", e.fill), x.text(y);
|
||
|
} else
|
||
|
p.text(y);
|
||
|
e.valign !== void 0 && e.textMargin !== void 0 && e.textMargin > 0 && (n += (p._groups || p)[0][0].getBBox().height, s = n), l.push(p);
|
||
|
}
|
||
|
return l;
|
||
|
}, de = function(t, e) {
|
||
|
function s(i, a, o, l, u) {
|
||
|
return i + "," + a + " " + (i + o) + "," + a + " " + (i + o) + "," + (a + l - u) + " " + (i + o - u * 1.2) + "," + (a + l) + " " + i + "," + (a + l);
|
||
|
}
|
||
|
const n = t.append("polygon");
|
||
|
return n.attr("points", s(e.x, e.y, e.width, e.height, 7)), n.attr("class", "labelBox"), e.y = e.y + e.height / 2, gt(t, e), n;
|
||
|
};
|
||
|
let tt = -1;
|
||
|
const ue = (t, e) => {
|
||
|
t.selectAll && t.selectAll(".actor-line").attr("class", "200").attr("y2", e - 55);
|
||
|
}, l0 = function(t, e, s, n) {
|
||
|
const i = e.x + e.width / 2, a = e.y + 5, o = t.append("g");
|
||
|
var l = o;
|
||
|
n || (tt++, l.append("line").attr("id", "actor" + tt).attr("x1", i).attr("y1", a).attr("x2", i).attr("y2", 2e3).attr("class", "actor-line").attr("stroke-width", "0.5px").attr("stroke", "#999"), l = o.append("g"), e.actorCnt = tt, e.links != null && (l.attr("id", "root-" + tt), ce("#root-" + tt, tt)));
|
||
|
const u = At();
|
||
|
var h = "actor";
|
||
|
e.properties != null && e.properties.class ? h = e.properties.class : u.fill = "#eaeaea", u.x = e.x, u.y = e.y, u.width = e.width, u.height = e.height, u.class = h, u.rx = 3, u.ry = 3;
|
||
|
const T = vt(l, u);
|
||
|
if (e.rectData = u, e.properties != null && e.properties.icon) {
|
||
|
const p = e.properties.icon.trim();
|
||
|
p.charAt(0) === "@" ? he(l, u.x + u.width - 20, u.y + 10, p.substr(1)) : le(l, u.x + u.width - 20, u.y + 10, p);
|
||
|
}
|
||
|
Ut(s)(
|
||
|
e.description,
|
||
|
l,
|
||
|
u.x,
|
||
|
u.y,
|
||
|
u.width,
|
||
|
u.height,
|
||
|
{ class: "actor" },
|
||
|
s
|
||
|
);
|
||
|
let y = e.height;
|
||
|
if (T.node) {
|
||
|
const p = T.node().getBBox();
|
||
|
e.height = p.height, y = p.height;
|
||
|
}
|
||
|
return y;
|
||
|
}, h0 = function(t, e, s, n) {
|
||
|
const i = e.x + e.width / 2, a = e.y + 80;
|
||
|
n || (tt++, t.append("line").attr("id", "actor" + tt).attr("x1", i).attr("y1", a).attr("x2", i).attr("y2", 2e3).attr("class", "actor-line").attr("stroke-width", "0.5px").attr("stroke", "#999"));
|
||
|
const o = t.append("g");
|
||
|
o.attr("class", "actor-man");
|
||
|
const l = At();
|
||
|
l.x = e.x, l.y = e.y, l.fill = "#eaeaea", l.width = e.width, l.height = e.height, l.class = "actor", l.rx = 3, l.ry = 3, o.append("line").attr("id", "actor-man-torso" + tt).attr("x1", i).attr("y1", e.y + 25).attr("x2", i).attr("y2", e.y + 45), o.append("line").attr("id", "actor-man-arms" + tt).attr("x1", i - 18).attr("y1", e.y + 33).attr("x2", i + 18).attr("y2", e.y + 33), o.append("line").attr("x1", i - 18).attr("y1", e.y + 60).attr("x2", i).attr("y2", e.y + 45), o.append("line").attr("x1", i).attr("y1", e.y + 45).attr("x2", i + 16).attr("y2", e.y + 60);
|
||
|
const u = o.append("circle");
|
||
|
u.attr("cx", e.x + e.width / 2), u.attr("cy", e.y + 10), u.attr("r", 15), u.attr("width", e.width), u.attr("height", e.height);
|
||
|
const h = o.node().getBBox();
|
||
|
return e.height = h.height, Ut(s)(
|
||
|
e.description,
|
||
|
o,
|
||
|
l.x,
|
||
|
l.y + 35,
|
||
|
l.width,
|
||
|
l.height,
|
||
|
{ class: "actor" },
|
||
|
s
|
||
|
), e.height;
|
||
|
}, d0 = function(t, e, s, n) {
|
||
|
switch (e.type) {
|
||
|
case "actor":
|
||
|
return h0(t, e, s, n);
|
||
|
case "participant":
|
||
|
return l0(t, e, s, n);
|
||
|
}
|
||
|
}, u0 = function(t, e, s) {
|
||
|
const i = t.append("g");
|
||
|
pe(i, e), e.name && Ut(s)(
|
||
|
e.name,
|
||
|
i,
|
||
|
e.x,
|
||
|
e.y + (e.textMaxHeight || 0) / 2,
|
||
|
e.width,
|
||
|
0,
|
||
|
{ class: "text" },
|
||
|
s
|
||
|
), i.lower();
|
||
|
}, p0 = function(t) {
|
||
|
return t.append("g");
|
||
|
}, f0 = function(t, e, s, n, i) {
|
||
|
const a = At(), o = e.anchored;
|
||
|
a.x = e.startx, a.y = e.starty, a.class = "activation" + i % 3, a.width = e.stopx - e.startx, a.height = s - e.starty, vt(o, a);
|
||
|
}, x0 = function(t, e, s, n) {
|
||
|
const {
|
||
|
boxMargin: i,
|
||
|
boxTextMargin: a,
|
||
|
labelBoxHeight: o,
|
||
|
labelBoxWidth: l,
|
||
|
messageFontFamily: u,
|
||
|
messageFontSize: h,
|
||
|
messageFontWeight: T
|
||
|
} = n, y = t.append("g"), p = function(L, v, M, I) {
|
||
|
return y.append("line").attr("x1", L).attr("y1", v).attr("x2", M).attr("y2", I).attr("class", "loopLine");
|
||
|
};
|
||
|
p(e.startx, e.starty, e.stopx, e.starty), p(e.stopx, e.starty, e.stopx, e.stopy), p(e.startx, e.stopy, e.stopx, e.stopy), p(e.startx, e.starty, e.startx, e.stopy), e.sections !== void 0 && e.sections.forEach(function(L) {
|
||
|
p(e.startx, L.y, e.stopx, L.y).style(
|
||
|
"stroke-dasharray",
|
||
|
"3, 3"
|
||
|
);
|
||
|
});
|
||
|
let x = Wt();
|
||
|
x.text = s, x.x = e.startx, x.y = e.starty, x.fontFamily = u, x.fontSize = h, x.fontWeight = T, x.anchor = "middle", x.valign = "middle", x.tspan = !1, x.width = l || 50, x.height = o || 20, x.textMargin = a, x.class = "labelText", de(y, x), x = Wt(), x.text = e.title, x.x = e.startx + l / 2 + (e.stopx - e.startx) / 2, x.y = e.starty + i + a, x.anchor = "middle", x.valign = "middle", x.textMargin = a, x.class = "loopText", x.fontFamily = u, x.fontSize = h, x.fontWeight = T, x.wrap = !0;
|
||
|
let b = gt(y, x);
|
||
|
return e.sectionTitles !== void 0 && e.sectionTitles.forEach(function(L, v) {
|
||
|
if (L.message) {
|
||
|
x.text = L.message, x.x = e.startx + (e.stopx - e.startx) / 2, x.y = e.sections[v].y + i + a, x.class = "loopText", x.anchor = "middle", x.valign = "middle", x.tspan = !1, x.fontFamily = u, x.fontSize = h, x.fontWeight = T, x.wrap = e.wrap, b = gt(y, x);
|
||
|
let M = Math.round(
|
||
|
b.map((I) => (I._groups || I)[0][0].getBBox().height).reduce((I, B) => I + B)
|
||
|
);
|
||
|
e.sections[v].height += M - (i + a);
|
||
|
}
|
||
|
}), e.height = Math.round(e.stopy - e.starty), y;
|
||
|
}, pe = function(t, e) {
|
||
|
vt(t, {
|
||
|
x: e.startx,
|
||
|
y: e.starty,
|
||
|
width: e.stopx - e.startx,
|
||
|
height: e.stopy - e.starty,
|
||
|
fill: e.fill,
|
||
|
stroke: e.stroke,
|
||
|
class: "rect"
|
||
|
}).lower();
|
||
|
}, g0 = function(t) {
|
||
|
t.append("defs").append("symbol").attr("id", "database").attr("fill-rule", "evenodd").attr("clip-rule", "evenodd").append("path").attr("transform", "scale(.5)").attr(
|
||
|
"d",
|
||
|
"M12.258.001l.256.004.255.005.253.008.251.01.249.012.247.015.246.016.242.019.241.02.239.023.236.024.233.027.231.028.229.031.225.032.223.034.22.036.217.038.214.04.211.041.208.043.205.045.201.046.198.048.194.05.191.051.187.053.183.054.18.056.175.057.172.059.168.06.163.061.16.063.155.064.15.066.074.033.073.033.071.034.07.034.069.035.068.035.067.035.066.035.064.036.064.036.062.036.06.036.06.037.058.037.058.037.055.038.055.038.053.038.052.038.051.039.05.039.048.039.047.039.045.04.044.04.043.04.041.04.04.041.039.041.037.041.036.041.034.041.033.042.032.042.03.042.029.042.027.042.026.043.024.043.023.043.021.043.02.043.018.044.017.043.015.044.013.044.012.044.011.045.009.044.007.045.006.045.004.045.002.045.001.045v17l-.001.045-.002.045-.004.045-.006.045-.007.045-.009.044-.011.045-.012.044-.013.044-.015.044-.017.043-.018.044-.02.043-.021.043-.023.043-.024.043-.026.043-.027.042-.029.042-.03.042-.032.042-.033.042-.034.041-.036.041-.037.041-.039.041-.04.041-.041.04-.043.04-.044.04-.045.04-.047.039-.048.039-.05.039-.051.039-.052.038-.053.038-.055.038-.055.038-.058.037-.058.037-.06.037-.06.036-.062.036-.064.036-.064.036-.066.035-.067.035-.068.035-.069.035-.07.034-.071.034-.073.033-.074.033-.15.066-.155.064-.16.063-.163.061-.168.06-.172.059-.175.057-.18.056-.183.054-.187.053-.191.051-.194.05-.198.048-.201.046-.205.045-.208.043-.211.041-.214.04-.217.038-.22.036-.223.034-.225.032-.229.031-.231.028-.233.027-.236.024-.239.023-.241.02-.242.019-.246.016-.247.015-.249.012-.251.01-.253.008-.255.005-.256.004-.258.001-.258-.001-.256-.004-.255-.005-.253-.008-.251-.01-.249-.012-.247-.015-.245-.016-.243-.019-.241-.02-.238-.023-.236-.024-.234-.027-.231-.028-.228-.031-.226-.032-.223-.034-.22-.036-.217-.038-.214-.04-.211-.041-.208-.043-.204-.045-.201-.046-.198-.048-.195-.05-.19-.051-.187-.053-.184-.054-.179-.056-.176-.057-.172-.059-.167-.06-.164-.061-.159-.063-.155-.064-.151-.066-.074-.033-.072-.033-.072-.034-.07-.034-.069-.035-.068-.035-.067-.035-.066-.035-.064-.036-.063-.036-.062-.036-.061-.036-.06-.037-.058-.037-.057-.037-.056-.038-.055-.038-.053-.038-.052-.038-.051-.039-.049-.039-.049-.039-.046-.039-.046-.04-.044-.04-.043-.04-.041-.04-.04-.041-.039-.041-.037-.041-.036-.041-.034-.041-.033-.042-.032-.042-.03-.042-.029-.042-.027-.042-.026-.043-.024-.043-.023-.043-.021-.043-.02-.043-.018-.044-.017-.043-.015-.044-.013-.044-.012-.044-.011-.045-.009-.044-.007-.045-.006-.045-.004-.045-.002-.045-.001-.045v-17l.001-.045.002-.045.004-.045.006-.045.007-.045.009-.044.011-.045.012-.044.013-.044.015-.044.017-.043.018-.044.02-.043.021-.043.023-.043.024-.043.026-.043.027-.042.029-.042.03-.042.032-.042.033-.042.034-.041.036-.041.037-.041.039-.041.04-.041.041-.04.043-.04.044-.04.046-.04.046-.039.049-.039.049-.039.051-.039.052-.038.053-.038.055-.038.056-.038.057-.037.058-.037.06-.037.061-.036.062-.036.063-.036.064-.036.066-.035.067-.035.068-.035.069-.035.07-.034.072-.034.072-.033.074-.033.151-.066.155-.064.159-.063.164-.061.167-.06.172-.059.176-.057.179-.056.184-.054.187-.053.19-.051.195-.05.198-.048.201-.046.204-.045.208-.043.211-.041.214-.04.217-.038.22-.036.223-.034.226-.032.228-.031.231-.028.234-.027.236-.024.238-.023.241-.02.243-.019.245-.016.247-.015.249-.012.251-.01.253-.008.255-.005.256-.004.258-.001.258.001zm-9.258 20.499v.01l.001.021.003.021.004.022.005.021.006.022.007.022.009.023.01.022.011.023.012.023.013.023.015.023.016.024.017.023.018.024.019.024.021.024.022.025.023.024.024.025.052.049.056.05.061.051.066.051.07.051.075.051.079.052.084.052.088.052.092.052.097.052.102.051.105.052.11.052.114.051.119.051.123.051.127.05.131.05.135.05.139.048.144.049.147.047.152.047.155.047.16.045.163.045.167.043.171.043.176.041.178.041.183.039.187.039.19.037.194.035.197.035.202.033.204.031.209.03.212.029.216.027.219.025.222.024.226.021.23.02.233.018.236.016.24.015.243.012.246.01.249.008.253.005.256.004.259.001.26-.001.257-.004.254-.005.25-.008.247-.011.244-.012.241-.014.237-.016.233-.018.231-.021.226-.021.224-.024.22-.026.216-.027.212-.028.21-.031.205-.031.202-.034.198-.034.194-.036.191-.037.187-.039.183-.04.179-.04.175-.042.172-.043.168-.044.163-.045.16-.046.155-.046.152
|
||
|
);
|
||
|
}, T0 = function(t) {
|
||
|
t.append("defs").append("symbol").attr("id", "computer").attr("width", "24").attr("height", "24").append("path").attr("transform", "scale(.5)").attr(
|
||
|
"d",
|
||
|
"M2 2v13h20v-13h-20zm18 11h-16v-9h16v9zm-10.228 6l.466-1h3.524l.467 1h-4.457zm14.228 3h-24l2-6h2.104l-1.33 4h18.45l-1.297-4h2.073l2 6zm-5-10h-14v-7h14v7z"
|
||
|
);
|
||
|
}, y0 = function(t) {
|
||
|
t.append("defs").append("symbol").attr("id", "clock").attr("width", "24").attr("height", "24").append("path").attr("transform", "scale(.5)").attr(
|
||
|
"d",
|
||
|
"M12 2c5.514 0 10 4.486 10 10s-4.486 10-10 10-10-4.486-10-10 4.486-10 10-10zm0-2c-6.627 0-12 5.373-12 12s5.373 12 12 12 12-5.373 12-12-5.373-12-12-12zm5.848 12.459c.202.038.202.333.001.372-1.907.361-6.045 1.111-6.547 1.111-.719 0-1.301-.582-1.301-1.301 0-.512.77-5.447 1.125-7.445.034-.192.312-.181.343.014l.985 6.238 5.394 1.011z"
|
||
|
);
|
||
|
}, m0 = function(t) {
|
||
|
t.append("defs").append("marker").attr("id", "arrowhead").attr("refX", 9).attr("refY", 5).attr("markerUnits", "userSpaceOnUse").attr("markerWidth", 12).attr("markerHeight", 12).attr("orient", "auto").append("path").attr("d", "M 0 0 L 10 5 L 0 10 z");
|
||
|
}, E0 = function(t) {
|
||
|
t.append("defs").append("marker").attr("id", "filled-head").attr("refX", 18).attr("refY", 7).attr("markerWidth", 20).attr("markerHeight", 28).attr("orient", "auto").append("path").attr("d", "M 18,7 L9,13 L14,7 L9,1 Z");
|
||
|
}, b0 = function(t) {
|
||
|
t.append("defs").append("marker").attr("id", "sequencenumber").attr("refX", 15).attr("refY", 15).attr("markerWidth", 60).attr("markerHeight", 40).attr("orient", "auto").append("circle").attr("cx", 15).attr("cy", 15).attr("r", 6);
|
||
|
}, w0 = function(t) {
|
||
|
t.append("defs").append("marker").attr("id", "crosshead").attr("markerWidth", 15).attr("markerHeight", 8).attr("orient", "auto").attr("refX", 4).attr("refY", 5).append("path").attr("fill", "none").attr("stroke", "#000000").style("stroke-dasharray", "0, 0").attr("stroke-width", "1pt").attr("d", "M 1,2 L 6,7 M 6,2 L 1,7");
|
||
|
}, Wt = function() {
|
||
|
return {
|
||
|
x: 0,
|
||
|
y: 0,
|
||
|
fill: void 0,
|
||
|
anchor: void 0,
|
||
|
style: "#666",
|
||
|
width: void 0,
|
||
|
height: void 0,
|
||
|
textMargin: 0,
|
||
|
rx: 0,
|
||
|
ry: 0,
|
||
|
tspan: !0,
|
||
|
valign: void 0
|
||
|
};
|
||
|
}, At = function() {
|
||
|
return {
|
||
|
x: 0,
|
||
|
y: 0,
|
||
|
fill: "#EDF2AE",
|
||
|
stroke: "#666",
|
||
|
width: 100,
|
||
|
anchor: "start",
|
||
|
height: 100,
|
||
|
rx: 0,
|
||
|
ry: 0
|
||
|
};
|
||
|
}, Ut = function() {
|
||
|
function t(i, a, o, l, u, h, T) {
|
||
|
const y = a.append("text").attr("x", o + u / 2).attr("y", l + h / 2 + 5).style("text-anchor", "middle").text(i);
|
||
|
n(y, T);
|
||
|
}
|
||
|
function e(i, a, o, l, u, h, T, y) {
|
||
|
const { actorFontSize: p, actorFontFamily: x, actorFontWeight: b } = y, [L, v] = ee(p), M = i.split(Pt.lineBreakRegex);
|
||
|
for (let I = 0; I < M.length; I++) {
|
||
|
const B = I * L - L * (M.length - 1) / 2, V = a.append("text").attr("x", o + u / 2).attr("y", l).style("text-anchor", "middle").style("font-size", v).style("font-weight", b).style("font-family", x);
|
||
|
V.append("tspan").attr("x", o + u / 2).attr("dy", B).text(M[I]), V.attr("y", l + h / 2).attr("dominant-baseline", "central").attr("alignment-baseline", "central"), n(V, T);
|
||
|
}
|
||
|
}
|
||
|
function s(i, a, o, l, u, h, T, y) {
|
||
|
const p = a.append("switch"), b = p.append("foreignObject").attr("x", o).attr("y", l).attr("width", u).attr("height", h).append("xhtml:div").style("display", "table").style("height", "100%").style("width", "100%");
|
||
|
b.append("div").style("display", "table-cell").style("text-align", "center").style("vertical-align", "middle").text(i), e(i, p, o, l, u, h, T, y), n(b, T);
|
||
|
}
|
||
|
function n(i, a) {
|
||
|
for (const o in a)
|
||
|
a.hasOwnProperty(o) && i.attr(o, a[o]);
|
||
|
}
|
||
|
return function(i) {
|
||
|
return i.textPlacement === "fo" ? s : i.textPlacement === "old" ? t : e;
|
||
|
};
|
||
|
}(), _0 = function() {
|
||
|
function t(i, a, o, l, u, h, T) {
|
||
|
const y = a.append("text").attr("x", o).attr("y", l).style("text-anchor", "start").text(i);
|
||
|
n(y, T);
|
||
|
}
|
||
|
function e(i, a, o, l, u, h, T, y) {
|
||
|
const { actorFontSize: p, actorFontFamily: x, actorFontWeight: b } = y, L = i.split(Pt.lineBreakRegex);
|
||
|
for (let v = 0; v < L.length; v++) {
|
||
|
const M = v * p - p * (L.length - 1) / 2, I = a.append("text").attr("x", o).attr("y", l).style("text-anchor", "start").style("font-size", p).style("font-weight", b).style("font-family", x);
|
||
|
I.append("tspan").attr("x", o).attr("dy", M).text(L[v]), I.attr("y", l + h / 2).attr("dominant-baseline", "central").attr("alignment-baseline", "central"), n(I, T);
|
||
|
}
|
||
|
}
|
||
|
function s(i, a, o, l, u, h, T, y) {
|
||
|
const p = a.append("switch"), b = p.append("foreignObject").attr("x", o).attr("y", l).attr("width", u).attr("height", h).append("xhtml:div").style("display", "table").style("height", "100%").style("width", "100%");
|
||
|
b.append("div").style("display", "table-cell").style("text-align", "center").style("vertical-align", "middle").text(i), e(i, p, o, l, u, h, T, y), n(b, T);
|
||
|
}
|
||
|
function n(i, a) {
|
||
|
for (const o in a)
|
||
|
a.hasOwnProperty(o) && i.attr(o, a[o]);
|
||
|
}
|
||
|
return function(i) {
|
||
|
return i.textPlacement === "fo" ? s : i.textPlacement === "old" ? t : e;
|
||
|
};
|
||
|
}(), S = {
|
||
|
drawRect: vt,
|
||
|
drawText: gt,
|
||
|
drawLabel: de,
|
||
|
drawActor: d0,
|
||
|
drawBox: u0,
|
||
|
drawPopup: s0,
|
||
|
drawImage: le,
|
||
|
drawEmbeddedImage: he,
|
||
|
anchorElement: p0,
|
||
|
drawActivation: f0,
|
||
|
drawLoop: x0,
|
||
|
drawBackgroundRect: pe,
|
||
|
insertArrowHead: m0,
|
||
|
insertArrowFilledHead: E0,
|
||
|
insertSequenceNumber: b0,
|
||
|
insertArrowCrossHead: w0,
|
||
|
insertDatabaseIcon: g0,
|
||
|
insertComputerIcon: T0,
|
||
|
insertClockIcon: y0,
|
||
|
getTextObj: Wt,
|
||
|
getNoteRect: At,
|
||
|
popupMenu: a0,
|
||
|
popdownMenu: r0,
|
||
|
fixLifeLineHeights: ue,
|
||
|
sanitizeUrl: It
|
||
|
};
|
||
|
let r = {};
|
||
|
const f = {
|
||
|
data: {
|
||
|
startx: void 0,
|
||
|
stopx: void 0,
|
||
|
starty: void 0,
|
||
|
stopy: void 0
|
||
|
},
|
||
|
verticalPos: 0,
|
||
|
sequenceItems: [],
|
||
|
activations: [],
|
||
|
models: {
|
||
|
getHeight: function() {
|
||
|
return Math.max.apply(
|
||
|
null,
|
||
|
this.actors.length === 0 ? [0] : this.actors.map((t) => t.height || 0)
|
||
|
) + (this.loops.length === 0 ? 0 : this.loops.map((t) => t.height || 0).reduce((t, e) => t + e)) + (this.messages.length === 0 ? 0 : this.messages.map((t) => t.height || 0).reduce((t, e) => t + e)) + (this.notes.length === 0 ? 0 : this.notes.map((t) => t.height || 0).reduce((t, e) => t + e));
|
||
|
},
|
||
|
clear: function() {
|
||
|
this.actors = [], this.boxes = [], this.loops = [], this.messages = [], this.notes = [];
|
||
|
},
|
||
|
addBox: function(t) {
|
||
|
this.boxes.push(t);
|
||
|
},
|
||
|
addActor: function(t) {
|
||
|
this.actors.push(t);
|
||
|
},
|
||
|
addLoop: function(t) {
|
||
|
this.loops.push(t);
|
||
|
},
|
||
|
addMessage: function(t) {
|
||
|
this.messages.push(t);
|
||
|
},
|
||
|
addNote: function(t) {
|
||
|
this.notes.push(t);
|
||
|
},
|
||
|
lastActor: function() {
|
||
|
return this.actors[this.actors.length - 1];
|
||
|
},
|
||
|
lastLoop: function() {
|
||
|
return this.loops[this.loops.length - 1];
|
||
|
},
|
||
|
lastMessage: function() {
|
||
|
return this.messages[this.messages.length - 1];
|
||
|
},
|
||
|
lastNote: function() {
|
||
|
return this.notes[this.notes.length - 1];
|
||
|
},
|
||
|
actors: [],
|
||
|
boxes: [],
|
||
|
loops: [],
|
||
|
messages: [],
|
||
|
notes: []
|
||
|
},
|
||
|
init: function() {
|
||
|
this.sequenceItems = [], this.activations = [], this.models.clear(), this.data = {
|
||
|
startx: void 0,
|
||
|
stopx: void 0,
|
||
|
starty: void 0,
|
||
|
stopy: void 0
|
||
|
}, this.verticalPos = 0, xe(ct());
|
||
|
},
|
||
|
updateVal: function(t, e, s, n) {
|
||
|
t[e] === void 0 ? t[e] = s : t[e] = n(s, t[e]);
|
||
|
},
|
||
|
updateBounds: function(t, e, s, n) {
|
||
|
const i = this;
|
||
|
let a = 0;
|
||
|
function o(l) {
|
||
|
return function(h) {
|
||
|
a++;
|
||
|
const T = i.sequenceItems.length - a + 1;
|
||
|
i.updateVal(h, "starty", e - T * r.boxMargin, Math.min), i.updateVal(h, "stopy", n + T * r.boxMargin, Math.max), i.updateVal(f.data, "startx", t - T * r.boxMargin, Math.min), i.updateVal(f.data, "stopx", s + T * r.boxMargin, Math.max), l !== "activation" && (i.updateVal(h, "startx", t - T * r.boxMargin, Math.min), i.updateVal(h, "stopx", s + T * r.boxMargin, Math.max), i.updateVal(f.data, "starty", e - T * r.boxMargin, Math.min), i.updateVal(f.data, "stopy", n + T * r.boxMargin, Math.max));
|
||
|
};
|
||
|
}
|
||
|
this.sequenceItems.forEach(o()), this.activations.forEach(o("activation"));
|
||
|
},
|
||
|
insert: function(t, e, s, n) {
|
||
|
const i = Math.min(t, s), a = Math.max(t, s), o = Math.min(e, n), l = Math.max(e, n);
|
||
|
this.updateVal(f.data, "startx", i, Math.min), this.updateVal(f.data, "starty", o, Math.min), this.updateVal(f.data, "stopx", a, Math.max), this.updateVal(f.data, "stopy", l, Math.max), this.updateBounds(i, o, a, l);
|
||
|
},
|
||
|
newActivation: function(t, e, s) {
|
||
|
const n = s[t.from.actor], i = St(t.from.actor).length || 0, a = n.x + n.width / 2 + (i - 1) * r.activationWidth / 2;
|
||
|
this.activations.push({
|
||
|
startx: a,
|
||
|
starty: this.verticalPos + 2,
|
||
|
stopx: a + r.activationWidth,
|
||
|
stopy: void 0,
|
||
|
actor: t.from.actor,
|
||
|
anchored: S.anchorElement(e)
|
||
|
});
|
||
|
},
|
||
|
endActivation: function(t) {
|
||
|
const e = this.activations.map(function(s) {
|
||
|
return s.actor;
|
||
|
}).lastIndexOf(t.from.actor);
|
||
|
return this.activations.splice(e, 1)[0];
|
||
|
},
|
||
|
createLoop: function(t = { message: void 0, wrap: !1, width: void 0 }, e) {
|
||
|
return {
|
||
|
startx: void 0,
|
||
|
starty: this.verticalPos,
|
||
|
stopx: void 0,
|
||
|
stopy: void 0,
|
||
|
title: t.message,
|
||
|
wrap: t.wrap,
|
||
|
width: t.width,
|
||
|
height: 0,
|
||
|
fill: e
|
||
|
};
|
||
|
},
|
||
|
newLoop: function(t = { message: void 0, wrap: !1, width: void 0 }, e) {
|
||
|
this.sequenceItems.push(this.createLoop(t, e));
|
||
|
},
|
||
|
endLoop: function() {
|
||
|
return this.sequenceItems.pop();
|
||
|
},
|
||
|
addSectionToLoop: function(t) {
|
||
|
const e = this.sequenceItems.pop();
|
||
|
e.sections = e.sections || [], e.sectionTitles = e.sectionTitles || [], e.sections.push({ y: f.getVerticalPos(), height: 0 }), e.sectionTitles.push(t), this.sequenceItems.push(e);
|
||
|
},
|
||
|
bumpVerticalPos: function(t) {
|
||
|
this.verticalPos = this.verticalPos + t, this.data.stopy = this.verticalPos;
|
||
|
},
|
||
|
getVerticalPos: function() {
|
||
|
return this.verticalPos;
|
||
|
},
|
||
|
getBounds: function() {
|
||
|
return { bounds: this.data, models: this.models };
|
||
|
}
|
||
|
}, k0 = function(t, e) {
|
||
|
f.bumpVerticalPos(r.boxMargin), e.height = r.boxMargin, e.starty = f.getVerticalPos();
|
||
|
const s = S.getNoteRect();
|
||
|
s.x = e.startx, s.y = e.starty, s.width = e.width || r.width, s.class = "note";
|
||
|
const n = t.append("g"), i = S.drawRect(n, s), a = S.getTextObj();
|
||
|
a.x = e.startx, a.y = e.starty, a.width = s.width, a.dy = "1em", a.text = e.message, a.class = "noteText", a.fontFamily = r.noteFontFamily, a.fontSize = r.noteFontSize, a.fontWeight = r.noteFontWeight, a.anchor = r.noteAlign, a.textMargin = r.noteMargin, a.valign = "center";
|
||
|
const o = gt(n, a), l = Math.round(
|
||
|
o.map((u) => (u._groups || u)[0][0].getBBox().height).reduce((u, h) => u + h)
|
||
|
);
|
||
|
i.attr("height", l + 2 * r.noteMargin), e.height += l + 2 * r.noteMargin, f.bumpVerticalPos(l + 2 * r.noteMargin), e.stopy = e.starty + l + 2 * r.noteMargin, e.stopx = e.startx + s.width, f.insert(e.startx, e.starty, e.stopx, e.stopy), f.models.addNote(e);
|
||
|
}, ut = (t) => ({
|
||
|
fontFamily: t.messageFontFamily,
|
||
|
fontSize: t.messageFontSize,
|
||
|
fontWeight: t.messageFontWeight
|
||
|
}), ft = (t) => ({
|
||
|
fontFamily: t.noteFontFamily,
|
||
|
fontSize: t.noteFontSize,
|
||
|
fontWeight: t.noteFontWeight
|
||
|
}), zt = (t) => ({
|
||
|
fontFamily: t.actorFontFamily,
|
||
|
fontSize: t.actorFontSize,
|
||
|
fontWeight: t.actorFontWeight
|
||
|
});
|
||
|
function L0(t, e) {
|
||
|
f.bumpVerticalPos(10);
|
||
|
const { startx: s, stopx: n, message: i } = e, a = Pt.splitBreaks(i).length, o = C.calculateTextDimensions(i, ut(r)), l = o.height / a;
|
||
|
e.height += l, f.bumpVerticalPos(l);
|
||
|
let u, h = o.height - 10;
|
||
|
const T = o.width;
|
||
|
if (s === n) {
|
||
|
u = f.getVerticalPos() + h, r.rightAngles || (h += r.boxMargin, u = f.getVerticalPos() + h), h += 30;
|
||
|
const y = Math.max(T / 2, r.width / 2);
|
||
|
f.insert(
|
||
|
s - y,
|
||
|
f.getVerticalPos() - 10 + h,
|
||
|
n + y,
|
||
|
f.getVerticalPos() + 30 + h
|
||
|
);
|
||
|
} else
|
||
|
h += r.boxMargin, u = f.getVerticalPos() + h, f.insert(s, u - 10, n, u);
|
||
|
return f.bumpVerticalPos(h), e.height += h, e.stopy = e.starty + e.height, f.insert(e.fromBounds, e.starty, e.toBounds, e.stopy), u;
|
||
|
}
|
||
|
const P0 = function(t, e, s, n) {
|
||
|
const { startx: i, stopx: a, starty: o, message: l, type: u, sequenceIndex: h, sequenceVisible: T } = e, y = C.calculateTextDimensions(l, ut(r)), p = S.getTextObj();
|
||
|
p.x = i, p.y = o + 10, p.width = a - i, p.class = "messageText", p.dy = "1em", p.text = l, p.fontFamily = r.messageFontFamily, p.fontSize = r.messageFontSize, p.fontWeight = r.messageFontWeight, p.anchor = r.messageAlign, p.valign = "center", p.textMargin = r.wrapPadding, p.tspan = !1, gt(t, p);
|
||
|
const x = y.width;
|
||
|
let b;
|
||
|
i === a ? r.rightAngles ? b = t.append("path").attr(
|
||
|
"d",
|
||
|
`M ${i},${s} H ${i + Math.max(r.width / 2, x / 2)} V ${s + 25} H ${i}`
|
||
|
) : b = t.append("path").attr(
|
||
|
"d",
|
||
|
"M " + i + "," + s + " C " + (i + 60) + "," + (s - 10) + " " + (i + 60) + "," + (s + 30) + " " + i + "," + (s + 20)
|
||
|
) : (b = t.append("line"), b.attr("x1", i), b.attr("y1", s), b.attr("x2", a), b.attr("y2", s)), u === n.db.LINETYPE.DOTTED || u === n.db.LINETYPE.DOTTED_CROSS || u === n.db.LINETYPE.DOTTED_POINT || u === n.db.LINETYPE.DOTTED_OPEN ? (b.style("stroke-dasharray", "3, 3"), b.attr("class", "messageLine1")) : b.attr("class", "messageLine0");
|
||
|
let L = "";
|
||
|
r.arrowMarkerAbsolute && (L = window.location.protocol + "//" + window.location.host + window.location.pathname + window.location.search, L = L.replace(/\(/g, "\\("), L = L.replace(/\)/g, "\\)")), b.attr("stroke-width", 2), b.attr("stroke", "none"), b.style("fill", "none"), (u === n.db.LINETYPE.SOLID || u === n.db.LINETYPE.DOTTED) && b.attr("marker-end", "url(" + L + "#arrowhead)"), (u === n.db.LINETYPE.SOLID_POINT || u === n.db.LINETYPE.DOTTED_POINT) && b.attr("marker-end", "url(" + L + "#filled-head)"), (u === n.db.LINETYPE.SOLID_CROSS || u === n.db.LINETYPE.DOTTED_CROSS) && b.attr("marker-end", "url(" + L + "#crosshead)"), (T || r.showSequenceNumbers) && (b.attr("marker-start", "url(" + L + "#sequencenumber)"), t.append("text").attr("x", i).attr("y", s + 4).attr("font-family", "sans-serif").attr("font-size", "12px").attr("text-anchor", "middle").attr("class", "sequenceNumber").text(h));
|
||
|
}, qt = function(t, e, s, n, i, a, o) {
|
||
|
if (i.hideUnusedParticipants === !0) {
|
||
|
const y = /* @__PURE__ */ new Set();
|
||
|
a.forEach((p) => {
|
||
|
y.add(p.from), y.add(p.to);
|
||
|
}), s = s.filter((p) => y.has(p));
|
||
|
}
|
||
|
let l = 0, u = 0, h = 0, T;
|
||
|
for (const y of s) {
|
||
|
const p = e[y], x = p.box;
|
||
|
T && T != x && (o || f.models.addBox(T), u += r.boxMargin + T.margin), x && x != T && (o || (x.x = l + u, x.y = n), u += x.margin), p.width = p.width || r.width, p.height = Math.max(p.height || r.height, r.height), p.margin = p.margin || r.actorMargin, p.x = l + u, p.y = f.getVerticalPos();
|
||
|
const b = S.drawActor(t, p, r, o);
|
||
|
h = Math.max(h, b), f.insert(p.x, n, p.x + p.width, p.height), l += p.width + u, p.box && (p.box.width = l + x.margin - p.box.x), u = p.margin, T = p.box, f.models.addActor(p);
|
||
|
}
|
||
|
T && !o && f.models.addBox(T), f.bumpVerticalPos(h);
|
||
|
}, fe = function(t, e, s, n) {
|
||
|
let i = 0, a = 0;
|
||
|
for (const o of s) {
|
||
|
const l = e[o], u = v0(l), h = S.drawPopup(
|
||
|
t,
|
||
|
l,
|
||
|
u,
|
||
|
r,
|
||
|
r.forceMenus,
|
||
|
n
|
||
|
);
|
||
|
h.height > i && (i = h.height), h.width + l.x > a && (a = h.width + l.x);
|
||
|
}
|
||
|
return { maxHeight: i, maxWidth: a };
|
||
|
}, xe = function(t) {
|
||
|
_e(r, t), t.fontFamily && (r.actorFontFamily = r.noteFontFamily = r.messageFontFamily = t.fontFamily), t.fontSize && (r.actorFontSize = r.noteFontSize = r.messageFontSize = t.fontSize), t.fontWeight && (r.actorFontWeight = r.noteFontWeight = r.messageFontWeight = t.fontWeight);
|
||
|
}, St = function(t) {
|
||
|
return f.activations.filter(function(e) {
|
||
|
return e.actor === t;
|
||
|
});
|
||
|
}, $t = function(t, e) {
|
||
|
const s = e[t], n = St(t), i = n.reduce(function(o, l) {
|
||
|
return Math.min(o, l.startx);
|
||
|
}, s.x + s.width / 2), a = n.reduce(function(o, l) {
|
||
|
return Math.max(o, l.stopx);
|
||
|
}, s.x + s.width / 2);
|
||
|
return [i, a];
|
||
|
};
|
||
|
function $(t, e, s, n, i) {
|
||
|
f.bumpVerticalPos(s);
|
||
|
let a = n;
|
||
|
if (e.id && e.message && t[e.id]) {
|
||
|
const o = t[e.id].width, l = ut(r);
|
||
|
e.message = C.wrapLabel(`[${e.message}]`, o - 2 * r.wrapPadding, l), e.width = o, e.wrap = !0;
|
||
|
const u = C.calculateTextDimensions(e.message, l), h = Math.max(u.height, r.labelBoxHeight);
|
||
|
a = n + h, K.debug(`${h} - ${e.message}`);
|
||
|
}
|
||
|
i(e), f.bumpVerticalPos(a);
|
||
|
}
|
||
|
const I0 = function(t, e, s, n) {
|
||
|
const { securityLevel: i, sequence: a } = ct();
|
||
|
r = a, n.db.clear(), n.parser.parse(t);
|
||
|
let o;
|
||
|
i === "sandbox" && (o = kt("#i" + e));
|
||
|
const l = i === "sandbox" ? kt(o.nodes()[0].contentDocument.body) : kt("body"), u = i === "sandbox" ? o.nodes()[0].contentDocument : document;
|
||
|
f.init(), K.debug(n.db);
|
||
|
const h = i === "sandbox" ? l.select(`[id="${e}"]`) : kt(`[id="${e}"]`), T = n.db.getActors(), y = n.db.getBoxes(), p = n.db.getActorKeys(), x = n.db.getMessages(), b = n.db.getDiagramTitle(), L = n.db.hasAtLeastOneBox(), v = n.db.hasAtLeastOneBoxWithTitle(), M = N0(T, x, n);
|
||
|
r.height = A0(T, M, y), S.insertComputerIcon(h), S.insertDatabaseIcon(h), S.insertClockIcon(h), L && (f.bumpVerticalPos(r.boxMargin), v && f.bumpVerticalPos(y[0].textMaxHeight)), qt(h, T, p, 0, r, x, !1);
|
||
|
const I = R0(x, T, M, n);
|
||
|
S.insertArrowHead(h), S.insertArrowCrossHead(h), S.insertArrowFilledHead(h), S.insertSequenceNumber(h);
|
||
|
function B(m, P) {
|
||
|
const _ = f.endActivation(m);
|
||
|
_.starty + 18 > P && (_.starty = P - 6, P += 12), S.drawActivation(
|
||
|
h,
|
||
|
_,
|
||
|
P,
|
||
|
r,
|
||
|
St(m.from.actor).length
|
||
|
), f.insert(_.startx, P - 10, _.stopx, P);
|
||
|
}
|
||
|
let V = 1, z = 1;
|
||
|
const G = [];
|
||
|
x.forEach(function(m) {
|
||
|
let P, _, U;
|
||
|
switch (m.type) {
|
||
|
case n.db.LINETYPE.NOTE:
|
||
|
_ = m.noteModel, k0(h, _);
|
||
|
break;
|
||
|
case n.db.LINETYPE.ACTIVE_START:
|
||
|
f.newActivation(m, h, T);
|
||
|
break;
|
||
|
case n.db.LINETYPE.ACTIVE_END:
|
||
|
B(m, f.getVerticalPos());
|
||
|
break;
|
||
|
case n.db.LINETYPE.LOOP_START:
|
||
|
$(
|
||
|
I,
|
||
|
m,
|
||
|
r.boxMargin,
|
||
|
r.boxMargin + r.boxTextMargin,
|
||
|
(N) => f.newLoop(N)
|
||
|
);
|
||
|
break;
|
||
|
case n.db.LINETYPE.LOOP_END:
|
||
|
P = f.endLoop(), S.drawLoop(h, P, "loop", r), f.bumpVerticalPos(P.stopy - f.getVerticalPos()), f.models.addLoop(P);
|
||
|
break;
|
||
|
case n.db.LINETYPE.RECT_START:
|
||
|
$(
|
||
|
I,
|
||
|
m,
|
||
|
r.boxMargin,
|
||
|
r.boxMargin,
|
||
|
(N) => f.newLoop(void 0, N.message)
|
||
|
);
|
||
|
break;
|
||
|
case n.db.LINETYPE.RECT_END:
|
||
|
P = f.endLoop(), S.drawBackgroundRect(h, P), f.models.addLoop(P), f.bumpVerticalPos(P.stopy - f.getVerticalPos());
|
||
|
break;
|
||
|
case n.db.LINETYPE.OPT_START:
|
||
|
$(
|
||
|
I,
|
||
|
m,
|
||
|
r.boxMargin,
|
||
|
r.boxMargin + r.boxTextMargin,
|
||
|
(N) => f.newLoop(N)
|
||
|
);
|
||
|
break;
|
||
|
case n.db.LINETYPE.OPT_END:
|
||
|
P = f.endLoop(), S.drawLoop(h, P, "opt", r), f.bumpVerticalPos(P.stopy - f.getVerticalPos()), f.models.addLoop(P);
|
||
|
break;
|
||
|
case n.db.LINETYPE.ALT_START:
|
||
|
$(
|
||
|
I,
|
||
|
m,
|
||
|
r.boxMargin,
|
||
|
r.boxMargin + r.boxTextMargin,
|
||
|
(N) => f.newLoop(N)
|
||
|
);
|
||
|
break;
|
||
|
case n.db.LINETYPE.ALT_ELSE:
|
||
|
$(
|
||
|
I,
|
||
|
m,
|
||
|
r.boxMargin + r.boxTextMargin,
|
||
|
r.boxMargin,
|
||
|
(N) => f.addSectionToLoop(N)
|
||
|
);
|
||
|
break;
|
||
|
case n.db.LINETYPE.ALT_END:
|
||
|
P = f.endLoop(), S.drawLoop(h, P, "alt", r), f.bumpVerticalPos(P.stopy - f.getVerticalPos()), f.models.addLoop(P);
|
||
|
break;
|
||
|
case n.db.LINETYPE.PAR_START:
|
||
|
$(
|
||
|
I,
|
||
|
m,
|
||
|
r.boxMargin,
|
||
|
r.boxMargin + r.boxTextMargin,
|
||
|
(N) => f.newLoop(N)
|
||
|
);
|
||
|
break;
|
||
|
case n.db.LINETYPE.PAR_AND:
|
||
|
$(
|
||
|
I,
|
||
|
m,
|
||
|
r.boxMargin + r.boxTextMargin,
|
||
|
r.boxMargin,
|
||
|
(N) => f.addSectionToLoop(N)
|
||
|
);
|
||
|
break;
|
||
|
case n.db.LINETYPE.PAR_END:
|
||
|
P = f.endLoop(), S.drawLoop(h, P, "par", r), f.bumpVerticalPos(P.stopy - f.getVerticalPos()), f.models.addLoop(P);
|
||
|
break;
|
||
|
case n.db.LINETYPE.AUTONUMBER:
|
||
|
V = m.message.start || V, z = m.message.step || z, m.message.visible ? n.db.enableSequenceNumbers() : n.db.disableSequenceNumbers();
|
||
|
break;
|
||
|
case n.db.LINETYPE.CRITICAL_START:
|
||
|
$(
|
||
|
I,
|
||
|
m,
|
||
|
r.boxMargin,
|
||
|
r.boxMargin + r.boxTextMargin,
|
||
|
(N) => f.newLoop(N)
|
||
|
);
|
||
|
break;
|
||
|
case n.db.LINETYPE.CRITICAL_OPTION:
|
||
|
$(
|
||
|
I,
|
||
|
m,
|
||
|
r.boxMargin + r.boxTextMargin,
|
||
|
r.boxMargin,
|
||
|
(N) => f.addSectionToLoop(N)
|
||
|
);
|
||
|
break;
|
||
|
case n.db.LINETYPE.CRITICAL_END:
|
||
|
P = f.endLoop(), S.drawLoop(h, P, "critical", r), f.bumpVerticalPos(P.stopy - f.getVerticalPos()), f.models.addLoop(P);
|
||
|
break;
|
||
|
case n.db.LINETYPE.BREAK_START:
|
||
|
$(
|
||
|
I,
|
||
|
m,
|
||
|
r.boxMargin,
|
||
|
r.boxMargin + r.boxTextMargin,
|
||
|
(N) => f.newLoop(N)
|
||
|
);
|
||
|
break;
|
||
|
case n.db.LINETYPE.BREAK_END:
|
||
|
P = f.endLoop(), S.drawLoop(h, P, "break", r), f.bumpVerticalPos(P.stopy - f.getVerticalPos()), f.models.addLoop(P);
|
||
|
break;
|
||
|
default:
|
||
|
try {
|
||
|
U = m.msgModel, U.starty = f.getVerticalPos(), U.sequenceIndex = V, U.sequenceVisible = n.db.showSequenceNumbers();
|
||
|
const N = L0(h, U);
|
||
|
G.push({ messageModel: U, lineStartY: N }), f.models.addMessage(U);
|
||
|
} catch (N) {
|
||
|
K.error("error while drawing message", N);
|
||
|
}
|
||
|
}
|
||
|
[
|
||
|
n.db.LINETYPE.SOLID_OPEN,
|
||
|
n.db.LINETYPE.DOTTED_OPEN,
|
||
|
n.db.LINETYPE.SOLID,
|
||
|
n.db.LINETYPE.DOTTED,
|
||
|
n.db.LINETYPE.SOLID_CROSS,
|
||
|
n.db.LINETYPE.DOTTED_CROSS,
|
||
|
n.db.LINETYPE.SOLID_POINT,
|
||
|
n.db.LINETYPE.DOTTED_POINT
|
||
|
].includes(m.type) && (V = V + z);
|
||
|
}), G.forEach((m) => P0(h, m.messageModel, m.lineStartY, n)), r.mirrorActors && (f.bumpVerticalPos(r.boxMargin * 2), qt(h, T, p, f.getVerticalPos(), r, x, !0), f.bumpVerticalPos(r.boxMargin), ue(h, f.getVerticalPos())), f.models.boxes.forEach(function(m) {
|
||
|
m.height = f.getVerticalPos() - m.y, f.insert(m.x, m.y, m.x + m.width, m.height), m.startx = m.x, m.starty = m.y, m.stopx = m.startx + m.width, m.stopy = m.starty + m.height, m.stroke = "rgb(0,0,0, 0.5)", S.drawBox(h, m, r);
|
||
|
}), L && f.bumpVerticalPos(r.boxMargin);
|
||
|
const Y = fe(h, T, p, u), { bounds: D } = f.getBounds();
|
||
|
K.debug("For line height fix Querying: #" + e + " .actor-line"), Se("#" + e + " .actor-line").attr("y2", D.stopy);
|
||
|
let q = D.stopy - D.starty;
|
||
|
q < Y.maxHeight && (q = Y.maxHeight);
|
||
|
let F = q + 2 * r.diagramMarginY;
|
||
|
r.mirrorActors && (F = F - r.boxMargin + r.bottomMarginAdj);
|
||
|
let H = D.stopx - D.startx;
|
||
|
H < Y.maxWidth && (H = Y.maxWidth);
|
||
|
const J = H + 2 * r.diagramMarginX;
|
||
|
b && h.append("text").text(b).attr("x", (D.stopx - D.startx) / 2 - 2 * r.diagramMarginX).attr("y", -25), Ae(h, F, J, r.useMaxWidth);
|
||
|
const Z = b ? 40 : 0;
|
||
|
h.attr(
|
||
|
"viewBox",
|
||
|
D.startx - r.diagramMarginX + " -" + (r.diagramMarginY + Z) + " " + J + " " + (F + Z)
|
||
|
), K.debug("models:", f.models);
|
||
|
};
|
||
|
function N0(t, e, s) {
|
||
|
const n = {};
|
||
|
return e.forEach(function(i) {
|
||
|
if (t[i.to] && t[i.from]) {
|
||
|
const a = t[i.to];
|
||
|
if (i.placement === s.db.PLACEMENT.LEFTOF && !a.prevActor || i.placement === s.db.PLACEMENT.RIGHTOF && !a.nextActor)
|
||
|
return;
|
||
|
const o = i.placement !== void 0, l = !o, u = o ? ft(r) : ut(r), h = i.wrap ? C.wrapLabel(i.message, r.width - 2 * r.wrapPadding, u) : i.message, y = C.calculateTextDimensions(h, u).width + 2 * r.wrapPadding;
|
||
|
l && i.from === a.nextActor ? n[i.to] = Math.max(
|
||
|
n[i.to] || 0,
|
||
|
y
|
||
|
) : l && i.from === a.prevActor ? n[i.from] = Math.max(
|
||
|
n[i.from] || 0,
|
||
|
y
|
||
|
) : l && i.from === i.to ? (n[i.from] = Math.max(
|
||
|
n[i.from] || 0,
|
||
|
y / 2
|
||
|
), n[i.to] = Math.max(
|
||
|
n[i.to] || 0,
|
||
|
y / 2
|
||
|
)) : i.placement === s.db.PLACEMENT.RIGHTOF ? n[i.from] = Math.max(
|
||
|
n[i.from] || 0,
|
||
|
y
|
||
|
) : i.placement === s.db.PLACEMENT.LEFTOF ? n[a.prevActor] = Math.max(
|
||
|
n[a.prevActor] || 0,
|
||
|
y
|
||
|
) : i.placement === s.db.PLACEMENT.OVER && (a.prevActor && (n[a.prevActor] = Math.max(
|
||
|
n[a.prevActor] || 0,
|
||
|
y / 2
|
||
|
)), a.nextActor && (n[i.from] = Math.max(
|
||
|
n[i.from] || 0,
|
||
|
y / 2
|
||
|
)));
|
||
|
}
|
||
|
}), K.debug("maxMessageWidthPerActor:", n), n;
|
||
|
}
|
||
|
const v0 = function(t) {
|
||
|
let e = 0;
|
||
|
const s = zt(r);
|
||
|
for (const n in t.links) {
|
||
|
const a = C.calculateTextDimensions(n, s).width + 2 * r.wrapPadding + 2 * r.boxMargin;
|
||
|
e < a && (e = a);
|
||
|
}
|
||
|
return e;
|
||
|
};
|
||
|
function A0(t, e, s) {
|
||
|
let n = 0;
|
||
|
Object.keys(t).forEach((a) => {
|
||
|
const o = t[a];
|
||
|
o.wrap && (o.description = C.wrapLabel(
|
||
|
o.description,
|
||
|
r.width - 2 * r.wrapPadding,
|
||
|
zt(r)
|
||
|
));
|
||
|
const l = C.calculateTextDimensions(o.description, zt(r));
|
||
|
o.width = o.wrap ? r.width : Math.max(r.width, l.width + 2 * r.wrapPadding), o.height = o.wrap ? Math.max(l.height, r.height) : r.height, n = Math.max(n, o.height);
|
||
|
});
|
||
|
for (const a in e) {
|
||
|
const o = t[a];
|
||
|
if (!o)
|
||
|
continue;
|
||
|
const l = t[o.nextActor];
|
||
|
if (!l) {
|
||
|
const y = e[a] + r.actorMargin - o.width / 2;
|
||
|
o.margin = Math.max(y, r.actorMargin);
|
||
|
continue;
|
||
|
}
|
||
|
const h = e[a] + r.actorMargin - o.width / 2 - l.width / 2;
|
||
|
o.margin = Math.max(h, r.actorMargin);
|
||
|
}
|
||
|
let i = 0;
|
||
|
return s.forEach((a) => {
|
||
|
const o = ut(r);
|
||
|
let l = a.actorKeys.reduce((T, y) => T += t[y].width + (t[y].margin || 0), 0);
|
||
|
l -= 2 * r.boxTextMargin, a.wrap && (a.name = C.wrapLabel(a.name, l - 2 * r.wrapPadding, o));
|
||
|
const u = C.calculateTextDimensions(a.name, o);
|
||
|
i = Math.max(u.height, i);
|
||
|
const h = Math.max(l, u.width + 2 * r.wrapPadding);
|
||
|
if (a.margin = r.boxTextMargin, l < h) {
|
||
|
const T = (h - l) / 2;
|
||
|
a.margin += T;
|
||
|
}
|
||
|
}), s.forEach((a) => a.textMaxHeight = i), Math.max(n, r.height);
|
||
|
}
|
||
|
const S0 = function(t, e, s) {
|
||
|
const n = e[t.from].x, i = e[t.to].x, a = t.wrap && t.message;
|
||
|
let o = C.calculateTextDimensions(
|
||
|
a ? C.wrapLabel(t.message, r.width, ft(r)) : t.message,
|
||
|
ft(r)
|
||
|
);
|
||
|
const l = {
|
||
|
width: a ? r.width : Math.max(r.width, o.width + 2 * r.noteMargin),
|
||
|
height: 0,
|
||
|
startx: e[t.from].x,
|
||
|
stopx: 0,
|
||
|
starty: 0,
|
||
|
stopy: 0,
|
||
|
message: t.message
|
||
|
};
|
||
|
return t.placement === s.db.PLACEMENT.RIGHTOF ? (l.width = a ? Math.max(r.width, o.width) : Math.max(
|
||
|
e[t.from].width / 2 + e[t.to].width / 2,
|
||
|
o.width + 2 * r.noteMargin
|
||
|
), l.startx = n + (e[t.from].width + r.actorMargin) / 2) : t.placement === s.db.PLACEMENT.LEFTOF ? (l.width = Math.max(a ? r.width : e[t.from].width / 2 + e[t.to].width / 2, o.width + 2 * r.noteMargin), l.startx = n - l.width + (e[t.from].width - r.actorMargin) / 2) : t.to === t.from ? (o = C.calculateTextDimensions(
|
||
|
a ? C.wrapLabel(t.message, Math.max(r.width, e[t.from].width), ft(r)) : t.message,
|
||
|
ft(r)
|
||
|
), l.width = a ? Math.max(r.width, e[t.from].width) : Math.max(e[t.from].width, r.width, o.width + 2 * r.noteMargin), l.startx = n + (e[t.from].width - l.width) / 2) : (l.width = Math.abs(n + e[t.from].width / 2 - (i + e[t.to].width / 2)) + r.actorMargin, l.startx = n < i ? n + e[t.from].width / 2 - r.actorMargin / 2 : i + e[t.to].width / 2 - r.actorMargin / 2), a && (l.message = C.wrapLabel(
|
||
|
t.message,
|
||
|
l.width - 2 * r.wrapPadding,
|
||
|
ft(r)
|
||
|
)), K.debug(
|
||
|
`NM:[${l.startx},${l.stopx},${l.starty},${l.stopy}:${l.width},${l.height}=${t.message}]`
|
||
|
), l;
|
||
|
}, M0 = function(t, e, s) {
|
||
|
let n = !1;
|
||
|
if ([
|
||
|
s.db.LINETYPE.SOLID_OPEN,
|
||
|
s.db.LINETYPE.DOTTED_OPEN,
|
||
|
s.db.LINETYPE.SOLID,
|
||
|
s.db.LINETYPE.DOTTED,
|
||
|
s.db.LINETYPE.SOLID_CROSS,
|
||
|
s.db.LINETYPE.DOTTED_CROSS,
|
||
|
s.db.LINETYPE.SOLID_POINT,
|
||
|
s.db.LINETYPE.DOTTED_POINT
|
||
|
].includes(t.type) && (n = !0), !n)
|
||
|
return {};
|
||
|
const i = $t(t.from, e), a = $t(t.to, e), o = i[0] <= a[0] ? 1 : 0, l = i[0] < a[0] ? 0 : 1, u = [...i, ...a], h = Math.abs(a[l] - i[o]);
|
||
|
t.wrap && t.message && (t.message = C.wrapLabel(
|
||
|
t.message,
|
||
|
Math.max(h + 2 * r.wrapPadding, r.width),
|
||
|
ut(r)
|
||
|
));
|
||
|
const T = C.calculateTextDimensions(t.message, ut(r));
|
||
|
return {
|
||
|
width: Math.max(
|
||
|
t.wrap ? 0 : T.width + 2 * r.wrapPadding,
|
||
|
h + 2 * r.wrapPadding,
|
||
|
r.width
|
||
|
),
|
||
|
height: 0,
|
||
|
startx: i[o],
|
||
|
stopx: a[l],
|
||
|
starty: 0,
|
||
|
stopy: 0,
|
||
|
message: t.message,
|
||
|
type: t.type,
|
||
|
wrap: t.wrap,
|
||
|
fromBounds: Math.min.apply(null, u),
|
||
|
toBounds: Math.max.apply(null, u)
|
||
|
};
|
||
|
}, R0 = function(t, e, s, n) {
|
||
|
const i = {}, a = [];
|
||
|
let o, l, u;
|
||
|
return t.forEach(function(h) {
|
||
|
switch (h.id = C.random({ length: 10 }), h.type) {
|
||
|
case n.db.LINETYPE.LOOP_START:
|
||
|
case n.db.LINETYPE.ALT_START:
|
||
|
case n.db.LINETYPE.OPT_START:
|
||
|
case n.db.LINETYPE.PAR_START:
|
||
|
case n.db.LINETYPE.CRITICAL_START:
|
||
|
case n.db.LINETYPE.BREAK_START:
|
||
|
a.push({
|
||
|
id: h.id,
|
||
|
msg: h.message,
|
||
|
from: Number.MAX_SAFE_INTEGER,
|
||
|
to: Number.MIN_SAFE_INTEGER,
|
||
|
width: 0
|
||
|
});
|
||
|
break;
|
||
|
case n.db.LINETYPE.ALT_ELSE:
|
||
|
case n.db.LINETYPE.PAR_AND:
|
||
|
case n.db.LINETYPE.CRITICAL_OPTION:
|
||
|
h.message && (o = a.pop(), i[o.id] = o, i[h.id] = o, a.push(o));
|
||
|
break;
|
||
|
case n.db.LINETYPE.LOOP_END:
|
||
|
case n.db.LINETYPE.ALT_END:
|
||
|
case n.db.LINETYPE.OPT_END:
|
||
|
case n.db.LINETYPE.PAR_END:
|
||
|
case n.db.LINETYPE.CRITICAL_END:
|
||
|
case n.db.LINETYPE.BREAK_END:
|
||
|
o = a.pop(), i[o.id] = o;
|
||
|
break;
|
||
|
case n.db.LINETYPE.ACTIVE_START:
|
||
|
{
|
||
|
const y = e[h.from ? h.from.actor : h.to.actor], p = St(h.from ? h.from.actor : h.to.actor).length, x = y.x + y.width / 2 + (p - 1) * r.activationWidth / 2, b = {
|
||
|
startx: x,
|
||
|
stopx: x + r.activationWidth,
|
||
|
actor: h.from.actor,
|
||
|
enabled: !0
|
||
|
};
|
||
|
f.activations.push(b);
|
||
|
}
|
||
|
break;
|
||
|
case n.db.LINETYPE.ACTIVE_END:
|
||
|
{
|
||
|
const y = f.activations.map((p) => p.actor).lastIndexOf(h.from.actor);
|
||
|
delete f.activations.splice(y, 1)[0];
|
||
|
}
|
||
|
break;
|
||
|
}
|
||
|
h.placement !== void 0 ? (l = S0(h, e, n), h.noteModel = l, a.forEach((y) => {
|
||
|
o = y, o.from = Math.min(o.from, l.startx), o.to = Math.max(o.to, l.startx + l.width), o.width = Math.max(o.width, Math.abs(o.from - o.to)) - r.labelBoxWidth;
|
||
|
})) : (u = M0(h, e, n), h.msgModel = u, u.startx && u.stopx && a.length > 0 && a.forEach((y) => {
|
||
|
if (o = y, u.startx === u.stopx) {
|
||
|
const p = e[h.from], x = e[h.to];
|
||
|
o.from = Math.min(
|
||
|
p.x - u.width / 2,
|
||
|
p.x - p.width / 2,
|
||
|
o.from
|
||
|
), o.to = Math.max(x.x + u.width / 2, x.x + p.width / 2, o.to), o.width = Math.max(o.width, Math.abs(o.to - o.from)) - r.labelBoxWidth;
|
||
|
} else
|
||
|
o.from = Math.min(u.startx, o.from), o.to = Math.max(u.stopx, o.to), o.width = Math.max(o.width, u.width) - r.labelBoxWidth;
|
||
|
}));
|
||
|
}), f.activations = [], K.debug("Loop type widths:", i), i;
|
||
|
}, D0 = {
|
||
|
bounds: f,
|
||
|
drawActors: qt,
|
||
|
drawActorsPopup: fe,
|
||
|
setConf: xe,
|
||
|
draw: I0
|
||
|
}, z0 = {
|
||
|
parser: Me,
|
||
|
db: e0,
|
||
|
renderer: D0,
|
||
|
styles: i0
|
||
|
};
|
||
|
export {
|
||
|
z0 as diagram
|
||
|
};
|
||
|
//# sourceMappingURL=sequenceDiagram-c872c4ce.js.map
|